commit c04807e21f7ad2b89d62dda321405bdff231e818 Author: Kurt Kremitzki Date: Sun Jul 8 12:11:49 2018 -0500 Initial commit diff --git a/README b/README new file mode 100644 index 0000000..216a9eb --- /dev/null +++ b/README @@ -0,0 +1,38 @@ +this suite of tools can be used to retrieve a local copy +from the FreeCAD wiki and then use it to generate qhelp +and pdf files. The downloading of the entire wiki is now +a huge operation, prone to network errors, so it has been +cut into 2 parts, one to retrieve a list of files to +download and another to actually download the files. + +1) run "buildwikiindex.py" to build an index file containing + a list of all the files to download + +2) run "downloadwiki.py". If connection drops, run it again, + the already downloaded files will be skipped. + +3) run "buildqhelp.py" to generate freecad.qhc and freecad.qch + files + +4) run "buildpdf.py" to generate freecad.pdf (wkhtmltopdf must be installed) + +5) the qhelp files can be tested with "assistant -collectionFile freecad.qhc" + +6) If you have already downloaded the whole wiki, run "update.py" immediately + after, to create a list of revision IDs for each page. + +7) Once the initial revisions list has been created, the "update.py" script + can be ran anytime in the future, to check for pages that have changed + since the stored revision ID. The script is meant to run twice, one to get + a list of pages that have changed, and another one to download the changed + pages (and all their dependencies) again. + +8) To split the generated freecad.qch into parts that are smaller than 50Mb + (github limit): split -d --byte=49M localwiki/freecad.qch localwiki/freecad.qch.part + +9) To join the parts again (for testing): cat localwiki/freecad.qch.part* >> test.qch + Then check that test.qch has the same md5 number than localwiki/freecad.qch + +10) To test: assistant -collectionFile localwiki/freecad.qhc + + diff --git a/buildpdf.py b/buildpdf.py new file mode 100755 index 0000000..18e83f9 --- /dev/null +++ b/buildpdf.py @@ -0,0 +1,557 @@ +#!/usr/bin/env python + +#*************************************************************************** +#* * +#* Copyright (c) 2009 Yorik van Havre * +#* * +#* This program is free software; you can redistribute it and/or modify * +#* it under the terms of the GNU Lesser General Public License (LGPL) * +#* as published by the Free Software Foundation; either version 2 of * +#* the License, or (at your option) any later version. * +#* for detail see the LICENCE text file. * +#* * +#* This program is distributed in the hope that it will be useful, * +#* but WITHOUT ANY WARRANTY; without even the implied warranty of * +#* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * +#* GNU Library General Public License for more details. * +#* * +#* You should have received a copy of the GNU Library General Public * +#* License along with this program; if not, write to the Free Software * +#* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 * +#* USA * +#* * +#*************************************************************************** + +__title__="buildpdf" +__author__ = "Yorik van Havre " +__url__ = "http://www.freecadweb.org" + +""" +This script builds a pdf file from a local copy of the wiki +""" + +TOC="""Online_Help_Startpage +About_FreeCAD +Feature_list +Installing +Getting_started +Mouse_Model +Document_structure +Property_editor +Import_Export +Workbenches + +begin + +Part_Workbench +Part_Box +Part_Cone +Part_Cylinder +Part_Sphere +Part_Torus +Part_CreatePrimitives +Part_Plane +Part_Prism +Part_Wedge +Part_Helix +Part_Spiral +Part_Circle +Part_Ellipse +Part_Line +Part_Point +Part_RegularPolygon +Part_Booleans +# Part_Common +# Part_Cut +Part_Fuse +# Part_Shapebuilder +Part_Extrude +Part_Fillet +Part_Revolve +Part_SectionCross +Part_Chamfer +Part_Mirror +Part_RuledSurface +Part_Sweep +Part_Loft +Part_Offset +Part_Thickness +Part_RefineShape +Part_CheckGeometry + +begin + +PartDesign_Workbench +PartDesign_Pad +PartDesign_Pocket +PartDesign_Revolution +PartDesign_Groove + +Sketcher_Point +Sketcher_Line +Sketcher_Arc +Sketcher_Circle +Sketcher_Ellipse +Sketcher_Arc_of_Ellipse +Sketcher_Polyline +Sketcher_Rectangle +Sketcher_Triangle +Sketcher_Square +Sketcher_Pentagon +Sketcher_Hexagon +Sketcher_Heptagon +Sketcher_Octagon +Sketcher_Slot +Sketcher_Fillet +Sketcher_Trimming +# Sketcher_Arc3Point +# Sketcher_Circle3Point +# Sketcher_ConicSections +# Sketcher_Ellipse_by_3_Points + +Constraint_PointOnPoint +Constraint_Vertical +Constraint_Horizontal +Constraint_Parallel +Constraint_Perpendicular +Constraint_Tangent +Constraint_EqualLength +Constraint_Symmetric +Constraint_Lock +Constraint_HorizontalDistance +Constraint_VerticalDistance +Constraint_Length +Constraint_Radius +Constraint_InternalAngle +Constraint_SnellsLaw +Constraint_Internal_Alignment +# Constraint_PointOnObject + +Sketcher_MapSketch +Sketcher_Reorient +Sketcher_Validate +Sketcher_Show_Hide_Internal_Geometry +# Sketcher_MergeSketch +Sketcher_CloseShape +Sketcher_ConnectLines +# Sketcher_SelectConstraints +# Sketcher_SelectOrigin +# Sketcher_SelectVerticalAxis +# Sketcher_SelectHorizontalAxis +# Sketcher_SelectRedundantConstraints +# Sketcher_SelectConflictingConstraints +# Sketcher_SelectElementsAssociatedWithConstraints + +PartDesign_Fillet +PartDesign_Chamfer +PartDesign_Draft +PartDesign_Mirrored +PartDesign_LinearPattern +PartDesign_PolarPattern +PartDesign_Scaled +PartDesign_MultiTransform +PartDesign_WizardShaft +PartDesign_InvoluteGear + +Sketcher_Tutorial + +begin + +Draft_Workbench +Draft_Line +Draft_Wire +Draft_Circle +Draft_Arc +Draft_Ellipse +Draft_Polygon +Draft_Rectangle +Draft_Text +Draft_Dimension +Draft_BSpline +Draft_Point +Draft_ShapeString +Draft_Facebinder +Draft_BezCurve +Draft_Move +Draft_Rotate +Draft_Offset +Draft_Trimex +Draft_Upgrade +Draft_Downgrade +Draft_Scale +Draft_Edit +Draft_WireToBSpline +Draft_AddPoint +Draft_DelPoint +Draft_Shape2DView +Draft_Draft2Sketch +Draft_Array +Draft_Clone +Draft_SelectPlane +Draft_VisGroup + +begin + +Arch_Workbench +Arch_Wall +Arch_Structure +Arch_Rebar +Arch_Floor +Arch_Building +Arch_Site +Arch_Window +Arch_SectionPlane +Arch_Axis +Arch_Roof +Arch_Space +Arch_Stairs +Arch_Panel +Arch_Frame +Arch_Equipment +Arch_CutPlane +Arch_Add +Arch_Remove +Arch_Survey +Arch_tutorial + +begin + +Drawing_Workbench +Drawing_Landscape_A3 +Drawing_View +Drawing_Annotation +Drawing_Clip +Drawing_Openbrowser +Drawing_Symbol +Drawing_DraftView +Drawing_Save +Drawing_ProjectShape +# Drawing_Othoviews + +begin + +Raytracing_Workbench +# Raytracing_New +# Raytracing_Lux +# Raytracing_Part +# Raytracing_ResetCamera +# Raytracing_Export +# Raytracing_Render + +begin + +Robot_Workbench +# Robot_createRobot +# Robot_Simulate +# Robot_Export +# Robot_SetHomePos +# Robot_RestoreHomePos +# Robot_CreateTrajectory +# Robot_SetDefaultOrientation +# Robot_InsertWaypoint +# Robot_InsertWaypointPre +# Robot_Edge2Trac +# Robot_TrajectoryDressUp +# Robot_TrajectoryCompound + +begin + +OpenSCAD_Workbench +OpenSCAD_AddOpenSCADElement +# OpenSCAD_ColorCodeShape +# OpenSCAD_ReplaceObject +# OpenSCAD_RemoveSubtree +# OpenSCAD_RefineShapeFeature +# OpenSCAD_IncreaseTolerance +# OpenSCAD_Edgestofaces +# OpenSCAD_ExpandPlacements +# OpenSCAD_ExplodeGroup +# OpenSCAD_MeshBoolean +# OpenSCAD_Hull +# OpenSCAD_Minkowski + +begin + +Fem_Workbench +FEM_Analysis +# FEM_Solver +# FEM_Create +# FEM_Material +# FEM_Calculation +# FEM_DefineNodes +# FEM_FixedConstraint +# FEM_ForceConstraint +# FEM_BearingConstraint +# FEM_GearConstraint +# FEM_PulleyConstraint +# FEM_ShowResult + +begin + +Plot_Module +Plot_Save +Plot_Basic_tutorial +Plot_MultiAxes_tutorial +# Plot_Axes +# Plot_Series +# Plot_Grid +# Plot_Legend +# Plot_Labels +# Plot_Positions + +begin + +Mesh_Workbench + +end + +Interface_Customization +Preferences_Editor +Macros +Introduction_to_Python +Python_scripting_tutorial +Topological_data_scripting +Mesh_Scripting +Mesh_to_Part +Scenegraph +Pivy + +begin + +PySide +PySide_Beginner_Examples +PySide_Medium_Examples +PySide_Advanced_Examples + +end + +Scripted_objects +Embedding_FreeCAD +Embedding_FreeCADGui +Code_snippets""" + +import sys, os, re, tempfile, getopt, shutil, time +from urllib2 import urlopen, HTTPError + +# CONFIGURATION ################################################# + +INDEX = "Online_Help_Toc" # the start page from where to crawl the wiki +PDFCONVERTOR = 'wkhtmltopdf' # can be 'pisa', 'htmldoc', 'wkhtmltopdf' or 'firefox' +VERBOSE = True # set true to get output messages +INCLUDECOMMANDS = True # if true, the command pages of each workbench are included after each WB page +OVERWRITE = False # if true, pdf files are recreated even if already existing +FIREFOXPDFFOLDER = os.path.expanduser("~")+os.sep+"PDF" # if firefox is used, set this to where it places its pdf files by default +COVER = "http://www.freecadweb.org/wiki/images/7/79/Freecad-pdf-cover.svg" + +# END CONFIGURATION ############################################## + + +FOLDER = "./localwiki" + +fcount = dcount = 0 + +def crawl(): + "creates a pdf file from the localwiki folder" + + # tests ############################################### + + if PDFCONVERTOR == 'pisa': + try: + import ho.pisa as pisa + except: + "Error: Python-pisa not installed, exiting." + return 1 + elif PDFCONVERTOR == 'htmldoc': + if os.system('htmldoc --version'): + print "Error: Htmldoc not found, exiting." + return 1 + try: + from PyPDF2 import PdfFileReader,PdfFileWriter + except: + print "Error: Python-pypdf2 not installed, exiting." + + # run ######################################################## + + buildpdffiles() + joinpdf() + + if VERBOSE: print "All done!" + return 0 + + +def buildpdffiles(): + "scans a folder for html files and converts them all to pdf" + templist = os.listdir(FOLDER) + if PDFCONVERTOR == 'wkhtmltopdf': + makeStyleSheet() + global fileslist + fileslist = [] + for i in templist: + if i[-5:] == '.html': + fileslist.append(i) + print "converting ",len(fileslist)," pages" + i = 1 + for f in fileslist: + print i," : ",f + if PDFCONVERTOR == 'pisa': + createpdf_pisa(f[:-5]) + elif PDFCONVERTOR == 'wkhtmltopdf': + createpdf_wkhtmltopdf(f[:-5]) + elif PDFCONVERTOR == 'firefox': + createpdf_firefox(f[:-5]) + else: + createpdf_htmldoc(f[:-5]) + i += 1 + + +def fetch_resources(uri, rel): + """ + Callback to allow pisa/reportlab to retrieve Images,Stylesheets, etc. + 'uri' is the href attribute from the html link element. + 'rel' gives a relative path, but it's not used here. + + Note from Yorik: Not working!! + """ + path = os.path.join(FOLDER,uri.replace("./", "")) + return path + +def createpdf_pisa(pagename): + "creates a pdf file from a saved page using pisa (python module)" + import ho.pisa as pisa + if (not exists(pagename+".pdf",image=True)) or OVERWRTIE: + infile = open(FOLDER + os.sep + pagename+'.html','ro') + outfile = open(FOLDER + os.sep + pagename+'.pdf','wb') + if VERBOSE: print "Converting " + pagename + " to pdf..." + pdf = pisa.CreatePDF(infile,outfile,FOLDER,link_callback=fetch_resources) + outfile.close() + if pdf.err: + return pdf.err + return 0 + + +def createpdf_firefox(pagename): + "creates a pdf file from a saved page using firefox (needs command line printing extension)" + # the default printer will be used, so make sure it is set to pdf + # command line printing extension http://forums.mozillazine.org/viewtopic.php?f=38&t=2729795 + if (not exists(pagename+".pdf",image=True)) or OVERWRITE: + infile = FOLDER + os.sep + pagename+'.html' + outfile = FOLDER + os.sep + pagename+'.pdf' + return os.system('firefox -print ' + infile) + time.sleep(6) + if os.path.exists(FIREFOXPDFFOLDER + os.sep + pagename + ".pdf"): + shutil.move(FIREFOXPDFFOLDER+os.sep+pagename+".pdf",outfile) + else: + print "-----------------------------------------> Couldn't find print output!" + + +def createpdf_htmldoc(pagename): + "creates a pdf file from a saved page using htmldoc (external app, but supports images)" + if (not exists(pagename+".pdf",image=True)) or OVERWRITE: + infile = FOLDER + os.sep + pagename+'.html' + outfile = FOLDER + os.sep + pagename+'.pdf' + return os.system('htmldoc --webpage --textfont sans --browserwidth 840 -f '+outfile+' '+infile) + + +def createpdf_wkhtmltopdf(pagename): + "creates a pdf file from a saved page using htmldoc (external app, but supports images)" + if (not exists(pagename+".pdf",image=True)) or OVERWRITE: + infile = FOLDER + os.sep + pagename+'.html' + outfile = FOLDER + os.sep + pagename+'.pdf' + cmd = 'wkhtmltopdf -L 5mm --user-style-sheet '+FOLDER+os.sep+'wkhtmltopdf.css '+infile+' '+outfile + print cmd + #return os.system(cmd) + else: + print "skipping" + + +def joinpdf(): + "creates one pdf file from several others, following order from the cover" + from PyPDF2 import PdfFileReader,PdfFileWriter + if VERBOSE: print "Building table of contents..." + + result = PdfFileWriter() + createCover() + inputfile = PdfFileReader(open(FOLDER+os.sep+'Cover.pdf','rb')) + result.addPage(inputfile.getPage(0)) + count = 1 + + tocfile = TOC.split("\n") + parent = False + for page in tocfile: + page = page.strip() + if page: + if page[0] == "#": + continue + if page == "begin": + parent = True + continue + if page == "end": + parent = False + continue + if VERBOSE: print 'Appending',page, "at position",count + title = page.replace("_"," ") + pdffile = page + ".pdf" + if exists(pdffile,True): + inputfile = PdfFileReader(open(FOLDER + os.sep + pdffile,'rb')) + numpages = inputfile.getNumPages() + for i in range(numpages): + result.addPage(inputfile.getPage(i)) + if parent == True: + parent = result.addBookmark(title,count) + elif parent == False: + result.addBookmark(title,count) + else: + result.addBookmark(title,count,parent) + count += numpages + else: + print "page",pdffile,"not found, aborting." + sys.exit() + + if VERBOSE: print "Writing..." + outputfile = open(FOLDER+os.sep+"freecad.pdf",'wb') + result.write(outputfile) + outputfile.close() + if VERBOSE: + print ' ' + print 'Successfully created '+FOLDER+os.sep+'freecad.pdf' + + +def local(page,image=False): + "returns a local path for a given page/image" + if image: + return FOLDER + os.sep + page + else: + return FOLDER + os.sep + page + '.html' + + +def exists(page,image=False): + "checks if given page/image already exists" + path = local(page,image) + if os.path.exists(path): return True + return False + + +def makeStyleSheet(): + "Creates a stylesheet for wkhtmltopdf" + outputfile = open(FOLDER+os.sep+"wkhtmltopdf.css",'wb') + outputfile.write(""" +.printfooter { + display:none !important; +} +""") + outputfile.close() + + +def createCover(): + "downloads and creates a cover page" + if VERBOSE: print "fetching " + COVER + data = (urlopen(COVER).read()) + path = FOLDER + os.sep + "Cover.svg" + fil = open(path,'wb') + fil.write(data) + fil.close() + os.system('inkscape --export-pdf='+FOLDER+os.sep+'Cover.pdf'+' '+FOLDER+os.sep+'Cover.svg') + + +if __name__ == "__main__": + crawl() diff --git a/buildqhelp.py b/buildqhelp.py new file mode 100755 index 0000000..350f543 --- /dev/null +++ b/buildqhelp.py @@ -0,0 +1,237 @@ +#!/usr/bin/env python + +#*************************************************************************** +#* * +#* Copyright (c) 2009 Yorik van Havre * +#* * +#* This program is free software; you can redistribute it and/or modify * +#* it under the terms of the GNU Lesser General Public License (LGPL) * +#* as published by the Free Software Foundation; either version 2 of * +#* the License, or (at your option) any later version. * +#* for detail see the LICENCE text file. * +#* * +#* This program is distributed in the hope that it will be useful, * +#* but WITHOUT ANY WARRANTY; without even the implied warranty of * +#* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * +#* GNU Library General Public License for more details. * +#* * +#* You should have received a copy of the GNU Library General Public * +#* License along with this program; if not, write to the Free Software * +#* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 * +#* USA * +#* * +#*************************************************************************** + +__title__="wiki2qhelp" +__author__ = "Yorik van Havre " +__url__ = "http://www.freecadweb.org" + +""" +This script builds qhrlp files from a local copy of the wiki +""" + +import sys, os, re, tempfile, getopt, shutil +from urllib2 import urlopen, HTTPError + +# CONFIGURATION ################################################# + +FOLDER = "./localwiki" +INDEX = "Online_Help_Toc" # the start page from where to crawl the wiki +VERBOSE = True # to display what's going on. Otherwise, runs totally silent. +QHELPCOMPILER = 'qhelpgenerator' +QCOLLECTIOMGENERATOR = 'qcollectiongenerator' +RELEASE = '0.17' + +# END CONFIGURATION ############################################## + +fcount = dcount = 0 + +def crawl(): + "downloads an entire wiki site" + + # tests ############################################### + + if os.system(QHELPCOMPILER +' -v'): + print "Error: QAssistant not fully installed, exiting." + return 1 + if os.system(QCOLLECTIOMGENERATOR +' -v'): + print "Error: QAssistant not fully installed, exiting." + return 1 + + # run ######################################################## + + qhp = buildtoc() + qhcp = createCollProjectFile() + shutil.copy("freecad-icon-64.png","localwiki/freecad-icon-64.png") + if generate(qhcp) or compile(qhp): + print "Error at compiling" + return 1 + if VERBOSE: print "All done!" + i=raw_input("Copy the files to their correct location in the source tree? y/n (default=no) ") + if i.upper() in ["Y","YES"]: + shutil.copy("localwiki/freecad.qch","../../Doc/freecad.qch") + shutil.copy("localwiki/freecad.qhc","../../Doc/freecad.qhc") + else: + print 'Files are in localwiki. Test with "assistant -collectionFile localwiki/freecad.qhc"' + return 0 + +def compile(qhpfile): + "compiles the whole html doc with qassistant" + qchfile = FOLDER + os.sep + "freecad.qch" + if not os.system(QHELPCOMPILER + ' '+qhpfile+' -o '+qchfile): + if VERBOSE: print "Successfully created",qchfile + return 0 + +def generate(qhcpfile): + "generates qassistant-specific settings like icon, title, ..." + txt=""" +
FreeCAD """+RELEASE+""" help files
+http://www.freecadweb.org
+ """ + about=open(FOLDER + os.sep + "about.txt","w") + about.write(txt) + about.close() + qhcfile = FOLDER + os.sep + "freecad.qhc" + if not os.system(QCOLLECTIOMGENERATOR+' '+qhcpfile+' -o '+qhcfile): + if VERBOSE: print "Successfully created ",qhcfile + return 0 + +def createCollProjectFile(): + qprojectfile = ''' + + + FreeCAD User Manual + freecad-icon-64.png + freecad/freecad + qthelp://org.freecad.usermanual/doc/Online_Help_Startpage.html + + About FreeCAD + + + about.txt + + freecad-icon-64.png + + true + true + true + + + + + freecad.qhp + freecad.qch + + + + freecad.qch + + + +''' + if VERBOSE: print "Building project file..." + qfilename = FOLDER + os.sep + "freecad.qhcp" + f = open(qfilename,'w') + f.write(qprojectfile) + f.close() + if VERBOSE: print "Done writing qhcp file",qfilename + return qfilename + +def buildtoc(): + ''' + gets the table of contents page and parses its + contents into a clean lists structure + ''' + + qhelpfile = ''' + + org.freecad.usermanual + doc + + + + + + + + + + + + +''' + + def getname(line): + line = re.compile('
  • ').sub('',line) + line = re.compile('
  • ').sub('',line) + title = line.strip() + link = '' + if "]*>(.*?)',line)[0].strip() + link = re.findall('href="(.*?)"',line)[0].strip() + if not link: link = 'default.html' + return title,link + + if VERBOSE: print "Building table of contents..." + f = open(FOLDER+os.sep+INDEX+'.html') + html = '' + for line in f: html += line + f.close() + html = html.replace("\n"," ") + html = html.replace("> <","><") + html = re.findall("",html)[0] + items = re.findall(']*>.*?|',html) + inserttoc = '
    \n' + insertkeywords = '' + for item in items: + if not ("
      " in item): + if ("
    " in item): + inserttoc += '
    \n' + else: + link = '' + title,link=getname(item) + if link: + link='" ref="'+link + insertkeywords += ('\n') + inserttoc += ('
    \n') + else: + subitems = item.split("
      ") + for i in range(len(subitems)): + link = '' + title,link=getname(subitems[i]) + if link: + link='" ref="'+link + insertkeywords += ('\n') + trail = '' + if i == len(subitems)-1: trail = '' + inserttoc += ('
      '+trail+'\n') + inserttoc += '
      \n' + + insertfiles = "\n" + for fil in os.listdir(FOLDER): + insertfiles += (""+fil+"\n") + insertfiles += "\n" + + qhelpfile = re.compile('').sub(insertkeywords,qhelpfile) + qhelpfile = re.compile('').sub(inserttoc,qhelpfile) + qhelpfile = re.compile('').sub(insertfiles,qhelpfile) + qfilename = FOLDER + os.sep + "freecad.qhp" + f = open(qfilename,'wb') + f.write(qhelpfile) + f.close() + if VERBOSE: print "Done writing qhp file",qfilename + return qfilename + +if __name__ == "__main__": + crawl() + diff --git a/buildwikiindex.py b/buildwikiindex.py new file mode 100755 index 0000000..933b63d --- /dev/null +++ b/buildwikiindex.py @@ -0,0 +1,200 @@ +#!/usr/bin/env python + +#*************************************************************************** +#* * +#* Copyright (c) 2009 Yorik van Havre * +#* * +#* This program is free software; you can redistribute it and/or modify * +#* it under the terms of the GNU Lesser General Public License (LGPL) * +#* as published by the Free Software Foundation; either version 2 of * +#* the License, or (at your option) any later version. * +#* for detail see the LICENCE text file. * +#* * +#* This program is distributed in the hope that it will be useful, * +#* but WITHOUT ANY WARRANTY; without even the implied warranty of * +#* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * +#* GNU Library General Public License for more details. * +#* * +#* You should have received a copy of the GNU Library General Public * +#* License along with this program; if not, write to the Free Software * +#* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 * +#* USA * +#* * +#*************************************************************************** + +__title__="buildwikiindex.py" +__author__ = "Yorik van Havre " +__url__ = "http://www.freecadweb.org" + +""" +This script parses the contents of a wiki site and saves a file containing +names of pages and images to be downloaded. +""" + +import sys, os, re, tempfile, getopt +from urllib2 import urlopen, HTTPError + +# CONFIGURATION ################################################# + +URL = "https://www.freecadweb.org/wiki" #default URL if no URL is passed +INDEX = "Online_Help_Toc" # the start page from where to crawl the wiki +NORETRIEVE = ['Manual','Developer_hub','Power_users_hub','Users_hub','Source_documentation', 'User_hub','Main_Page','About_this_site','Interesting_links','Syndication_feeds','FreeCAD:General_disclaimer','FreeCAD:About','FreeCAD:Privacy_policy','WikiPages'] # pages that won't be fetched (kept online) +GETTRANSLATIONS = False # Set true if you want to get the translations too. +MAXFAIL = 3 # max number of retries if download fails +VERBOSE = True # to display what's going on. Otherwise, runs totally silent. +WRITETHROUGH = True # if true, fetched files are constantly written to disk, in case of failure. + +# END CONFIGURATION ############################################## + +wikiindex = "/index.php?title=" + +def crawl(pagename=[]): + "downloads an entire wiki site" + todolist = [] + processed = [] + count = 1 + if pagename: + if not isinstance(pagename,list): + pagename = [pagename] + todolist = pagename + else: + if os.path.exists("wikifiles.txt"): + f = open("wikifiles.txt","r") + if VERBOSE: print "Reading existing list..." + for l in f.readlines(): + if l.strip() != "": + if VERBOSE: print "Adding ",l + processed.append(l.strip()) + f.close() + if os.path.exists("todolist.txt"): + f = open("todolist.txt","r") + if VERBOSE: print "Reading existing todo list..." + for l in f.readlines(): + if l.strip() != "": + todolist.append(l.strip()) + f.close() + else: + indexpages,imgs = get(INDEX) + todolist.extend(indexpages) + while todolist: + targetpage = todolist.pop() + if (not targetpage in NORETRIEVE): + if VERBOSE: print count, ": Scanning ", targetpage + pages,images = get(targetpage) + count += 1 + processed.append(targetpage) + processed.extend(images) + if VERBOSE: print "got",len(pages),"links" + for p in pages: + if (not (p in todolist)) and (not (p in processed)): + todolist.append(p) + if WRITETHROUGH: + writeList(processed) + writeList(todolist,"todolist.txt") + if VERBOSE: print "Fetched ", count, " pages" + if not WRITETHROUGH: + writeList(processed) + if pagename: + return processed + return 0 + +def get(page): + "downloads a single page, returns the other pages it links to" + html = fetchpage(page) + html = cleanhtml(html) + pages = getlinks(html) + images = getimagelinks(html) + return pages,images + +def cleanhtml(html): + "cleans given html code from dirty script stuff" + html = html.replace('\n','Wlinebreak') # removing linebreaks for regex processing + html = re.compile('(.*)]+column-content+[^>]+>').sub('',html) # stripping before content + html = re.compile(']+column-one+[^>]+>.*').sub('',html) # stripping after content + html = re.compile('').sub('',html) # removing comment tags + html = re.compile(']*>.*?').sub('',html) # removing script tags + html = re.compile('').sub('',html) # removing IE tags + html = re.compile('
      ]*>.*?
      ').sub('',html) # removing nav div + html = re.compile('

      ]*>.*?

      ').sub('',html) # removing print subtitle + html = re.compile('Retrieved from').sub('Online version:',html) # changing online title + html = re.compile(' + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/API_documentation.html b/localwiki/API_documentation.html new file mode 100644 index 0000000..8126d93 --- /dev/null +++ b/localwiki/API_documentation.html @@ -0,0 +1,45 @@ +API documentation

      API documentation

      (Redirected from API documentation)
      + +

      This category gathers article that list objects and methods available to the python programmer. +

      +
      This section contains obsolete data, and is in the process of being transferred to autogenerated API documentation on http://www.freecadweb.org/api
      + + + +
      + +
      +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/About_FreeCAD.html b/localwiki/About_FreeCAD.html new file mode 100644 index 0000000..330cf03 --- /dev/null +++ b/localwiki/About_FreeCAD.html @@ -0,0 +1,30 @@ +About FreeCAD

      About FreeCAD

      + +
      Freecad default.jpg
      +

      FreeCAD is a general purpose parametric 3D CAD modeler. The development is completely Open Source (LGPL License). FreeCAD is aimed directly at mechanical engineering and product design but also fits in a wider range of uses around engineering, such as architecture or other engineering specialties. +

      FreeCAD features tools similar to Catia, SolidWorks or Solid Edge, and therefore also falls into the category of MCAD, PLM, CAx and CAE. It is a feature based parametric modeler with a modular software architecture which makes it easy to provide additional functionality without modifying the core system. +

      As with many modern 3D CAD modelers it has many 2D components in order to sketch 2D shapes or extract design details from the 3D model to create 2D production drawings, but direct 2D drawing (like AutoCAD LT) is not the focus, neither are animation or organic shapes (like Maya, 3ds Max, Blender or Cinema 4D), although, thanks to its wide adaptability, FreeCAD might become useful in a much broader area than its current focus. +

      FreeCAD makes heavy use of all the great open-source libraries that exist out there in the field of Scientific Computing. Among them are OpenCascade, a powerful CAD kernel, Coin3D, an incarnation of Open Inventor, Qt, the world-famous UI framework, and Python, one of the best scripting languages available. FreeCAD itself can also be used as a library by other programs. +

      FreeCAD is also fully multi-platform, and currently runs flawlessly on Windows and Linux/Unix and Mac OSX systems, with the exact same look and functionality on all platforms. +

      For more information about FreeCAD's capabilities, take a look at the Feature list, the latest release notes or the Getting started articles, or see more screenshots. +

      +

      About the FreeCAD project

      +

      The FreeCAD project was started as far as 2001, as described in its history page. +

      FreeCAD is maintained and developed by a community of enthusiastic developers and users (see the contributors page). They work on FreeCAD voluntarily, in their free time. They cannot guarantee that FreeCAD contains or will contain everything you might wish, but they will usually do their best! The community gathers on the FreeCAD forum, where most of the ideas and decisions are discussed. Feel free to join us there! +

      + +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Accessories-calculator.svg b/localwiki/Accessories-calculator.svg new file mode 100644 index 0000000..88cf76a --- /dev/null +++ b/localwiki/Accessories-calculator.svg @@ -0,0 +1,636 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + Calculator + + + Jakub Steiner + + + + + + + + + + + calc + calculator + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Accessories-text-editor.svg b/localwiki/Accessories-text-editor.svg new file mode 100644 index 0000000..aa7188e --- /dev/null +++ b/localwiki/Accessories-text-editor.svg @@ -0,0 +1,552 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + Jakub Steiner + + + http://jimmac.musichall.cz + + Text Editor + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Add_FEM_Constraint_Tutorial.html b/localwiki/Add_FEM_Constraint_Tutorial.html new file mode 100644 index 0000000..8888f98 --- /dev/null +++ b/localwiki/Add_FEM_Constraint_Tutorial.html @@ -0,0 +1,308 @@ +Add FEM Constraint Tutorial

      Add FEM Constraint Tutorial

      + +
      + + + + + + + + + + + + + + + + + + + + + + + + + + + +
      +

      Base ExampleCommandModel.png Tutorial

      +
      Topic +
      +
      Level +
      +
      Time to complete +
      +
      Author +
      M42kus +
      FreeCAD version +
      +
      Example File(s) +
      +

      + +
      +


      +

      In this tutorial we are going to add the flow velocity constraint to FreeCAD and implement support for elmer solver. Please make sure you have read and understood Extend FEM Module before reading this tutorial. +

      This tutorial only covers how to implement constraints in python. In contrast to solver and equations constraints follow the classic FEM module structure. That is, all modules of a constraint have there place in eather the PyObjects or PyGui package. +

      +

      Summary

      +
      1. Create document object: The docuemnt object that resides inside the analysis and though which the constraint can be parametrized and attached to boundaries.
      2. +
      3. Create GUI command: Add a command to the FEM workbench that adds a flow constriant to the active analysis.
      4. +
      5. Create a task panel: The task panel is nessecary to allow the user to set the boundaries at which he wants to set the velocity constraint. It also makes entering the paramters a little more user friendly.
      6. +
      7. Extend elmers writer: Add support for the new constraint to elmer by extinging its sif file exporter.
      +

      Create Document Object

      +

      In this step we are going to modify the following files: +

      +
      • src/Mod/Fem/CMakeLists.txt
      • +
      • src/Mod/Fem/App/CMakeLists.txt
      • +
      • src/Mod/Fem/ObjectsFem.py
      +

      and add the following files: +

      +
      • src/Mod/Fem/PyObjects/_FemConstraintFlowVelocity.py
      • +
      • src/Mod/Fem/PyGui/_ViewProviderFemConstraintFlowVelocity.py
      +

      A document proxy and a view proxy are required for the new constraint. Those reside in separate modules. The document proxy in PyObjects and the view proxy in PyGui. Just copy the modules from an existing constraint e.g. +

      +
      • PyObjects/_FemConstraintSelfWeight.py
      • +
      • PyGui/_ViewProviderFemConstraintSelfWeight.py
      +

      Adjust the Type variable and the properties to your needs. The document proxy of the flow constraint looks like the following: +

      +
      class Proxy(FemConstraint.Proxy):
      +    Type = "Fem::ConstraintFlowVelocity"
      +    def __init__(self, obj):
      +        super(Proxy, self).__init__(obj)
      +        obj.addProperty(
      +            "App::PropertyFloat", "VelocityX",
      +            "Parameter", "Body heat flux")
      +        obj.addProperty(
      +            "App::PropertyBool", "VelocityXEnabled",
      +            "Parameter", "Body heat flux")
      +        obj.addProperty(
      +            "App::PropertyFloat", "VelocityY",
      +            "Parameter", "Body heat flux")
      +        obj.addProperty(
      +            "App::PropertyBool", "VelocityYEnabled",
      +            "Parameter", "Body heat flux")
      +        obj.addProperty(
      +            "App::PropertyFloat", "VelocityZ",
      +            "Parameter", "Body heat flux")
      +        obj.addProperty(
      +            "App::PropertyBool", "VelocityZEnabled",
      +            "Parameter", "Body heat flux")
      +        obj.addProperty(
      +            "App::PropertyBool", "NormalToBoundary",
      +            "Parameter", "Body heat flux")
      +

      The module containing the view proxy might look a little more complicated. But for now just adjust the icon path. We are going to come back to this file in later steps of the tutorial. +

      +
      class ViewProxy(FemConstraint.ViewProxy):
      +    def getIcon(self):
      +        return ":/icons/fem-constraint-flow-velocity.svg"
      +

      Add the two new modules to the build system like descripted in Extend FEM Module. Locate the correct list be searching for constraint modules. +

      As all objects of the FEM workbench the velocity constraint must be registerd in ObjectsFem.py. The following method adds a velocity constraint to the active document. This method will be used by the GUI command to add the constraint. It must be inserted somewhere in ObjectsFem.py. +

      +
      def makeConstraintFlowVelocity(name="FlowVelocity"):
      +    obj = FreeCAD.ActiveDocument.addObject("Fem::ConstraintPython", name)
      +    import PyObjects._FemConstraintFlowVelocity
      +    PyObjects._FemConstraintFlowVelocity.Proxy(obj)
      +    if FreeCAD.GuiUp:
      +        import PyGui._ViewProviderFemConstraintFlowVelocity
      +        PyGui._ViewProviderFemConstraintFlowVelocity.ViewProxy(obj.ViewObject)
      +    return obj
      +

      Create GUI command

      +

      In this step we are going to modify the following files: +

      +
      • src/Mod/Fem/CMakeLists.txt
      • +
      • src/Mod/Fem/App/CMakeLists.txt
      • +
      • src/Mod/Fem/Gui/Workbench.cpp
      +

      and add the following new file: +

      +
      • src/Mod/Fem/PyGui/_CommandFemConstraintFlowVelocity.py
      +

      The command allows the user to actually add the constraint to the active analysis. Just copy a command from an existing constraint. Commands reside in the PyGui package. Adjust the resources attribute and the make method called in Activated to your needs. Also use a different command id in the addCommand call on the bottom of the module. The following class is the command class of the velocity constraint. +

      +
      class Command(FemCommands.FemCommands):
      +
      +    def __init__(self):
      +        super(Command, self).__init__()
      +        self.resources = {
      +            'Pixmap': 'fem-constraint-flow-velocity',
      +            'MenuText': QtCore.QT_TRANSLATE_NOOP(
      +                "FEM_ConstraintFlowVelocity",
      +                "Constraint Velocity"),
      +            'ToolTip': QtCore.QT_TRANSLATE_NOOP(
      +                "FEM_ConstraintFlowVelocity",
      +                "Creates a FEM constraint body heat flux")}
      +        self.is_active = 'with_analysis'
      +
      +    def Activated(self):
      +        App.ActiveDocument.openTransaction(
      +            "Create FemConstraintFlowVelocity")
      +        Gui.addModule("ObjectsFem")
      +        Gui.doCommand(
      +            "FemGui.getActiveAnalysis().Member += "
      +            "[ObjectsFem.makeConstraintFlowVelocity()]")
      +
      +Gui.addCommand('FEM_AddConstraintFlowVelocity', Command())
      +

      Add the new command file to the build system as decripted in Extend FEM Module. Locate the correct list be searching for existing command modules. +

      Put the command into Gui/Workbench.cpp to add it to the toolbar and menu. Search for an existing constraint of the same category as the new one (e.g. Flow) copy-paste it and adjust the command id. This should be done two times. Once for the menu and again for the toolbar. +

      +

      Create a Task Panel

      +

      In this step we are going to modify the following file: +

      +
      • src/Mod/Fem/PyGui/_ViewProviderFemConstraintFlowVelocity.py
      +

      In FreeCAD constraint objects benefit greatly from task panels. Task panels can make use of more powerful input widgets which expose the unit of entered values directely to the user. The velocity constraint even requires the use of a task panel since a task panel is the only way of specifieing the face(s) on which the constraint shall be applied. +

      The location of the module in which task panels are implemented is not strictely defined. For the velocity constraint we are just going to put the task panel in the same module we put the view proxy. The task panel is quite complicated. It makes use of the FemSolectionWidgets.BoundarySelector(). Thats a qt widget which allows the user to select the boundaries on which the constraint shall be applied. In addition to this widget it generates another one by loading a ui file specifically created for the velocity constraint. Via this widget the velocity vector can be specified. +

      Most of the time is should be sufficient to just copy this class, use a suitable ui file (instead of TaskPanelFemFlowVelocity.ui) and adjust _initParamWidget() as well as _applyWidgetChanges(). If the new constraint requires bodies as references instead of boundaries just replace the BoundarySelector object with the SolidSelector. +

      +
      class _TaskPanel(object):
      +
      +    def __init__(self, obj):
      +        self._obj = obj
      +        self._refWidget = FemSelectionWidgets.BoundarySelector()
      +        # self._refWidget = FemSelectionWidgets.SolidSelector()
      +        self._refWidget.setReferences(obj.References)
      +        self._paramWidget = Gui.PySideUic.loadUi(
      +            App.getHomePath() + "Mod/Fem/PyGui/TaskPanelFemFlowVelocity.ui")
      +        self._initParamWidget()
      +        self.form = [self._refWidget, self._paramWidget]
      +        analysis = FemMisc.findAnalysisOfMember(obj)
      +        self._mesh = FemMisc.getSingleMember(analysis, "Fem::FemMeshObject")
      +        self._part = self._mesh.Part if self._mesh is not None else None
      +        self._partVisible = None
      +        self._meshVisible = None
      +
      +    def open(self):
      +        if self._mesh is not None and self._part is not None:
      +            self._meshVisible = self._mesh.ViewObject.isVisible()
      +            self._partVisible = self._part.ViewObject.isVisible()
      +            self._mesh.ViewObject.hide()
      +            self._part.ViewObject.show()
      +
      +    def reject(self):
      +        self._restoreVisibility()
      +        return True
      +
      +    def accept(self):
      +        if self._obj.References != self._refWidget.references():
      +            self._obj.References = self._refWidget.references()
      +        self._applyWidgetChanges()
      +        self._obj.Document.recompute()
      +        self._restoreVisibility()
      +        return True
      +
      +    def _restoreVisibility(self):
      +        if self._mesh is not None and self._part is not None:
      +            if self._meshVisible:
      +                self._mesh.ViewObject.show()
      +            else:
      +                self._mesh.ViewObject.hide()
      +            if self._partVisible:
      +                self._part.ViewObject.show()
      +            else:
      +                self._part.ViewObject.hide()
      +
      +    def _initParamWidget(self):
      +        unit = "m/s"
      +        self._paramWidget.velocityXTxt.setText(
      +            str(self._obj.VelocityX) + unit)
      +        self._paramWidget.velocityYTxt.setText(
      +            str(self._obj.VelocityY) + unit)
      +        self._paramWidget.velocityZTxt.setText(
      +            str(self._obj.VelocityZ) + unit)
      +        self._paramWidget.velocityXBox.setChecked(
      +            not self._obj.VelocityXEnabled)
      +        self._paramWidget.velocityYBox.setChecked(
      +            not self._obj.VelocityYEnabled)
      +        self._paramWidget.velocityZBox.setChecked(
      +            not self._obj.VelocityZEnabled)
      +        self._paramWidget.normalBox.setChecked(
      +            self._obj.NormalToBoundary)
      +
      +    def _applyWidgetChanges(self):
      +        unit = "m/s"
      +        self._obj.VelocityXEnabled = \
      +            not self._paramWidget.velocityXBox.isChecked()
      +        if self._obj.VelocityXEnabled:
      +            quantity = Units.Quantity(self._paramWidget.velocityXTxt.text())
      +            self._obj.VelocityX = float(quantity.getValueAs(unit))
      +        self._obj.VelocityYEnabled = \
      +            not self._paramWidget.velocityYBox.isChecked()
      +        if self._obj.VelocityYEnabled:
      +            quantity = Units.Quantity(self._paramWidget.velocityYTxt.text())
      +            self._obj.VelocityY = float(quantity.getValueAs(unit))
      +        self._obj.VelocityZEnabled = \
      +            not self._paramWidget.velocityZBox.isChecked()
      +        if self._obj.VelocityZEnabled:
      +            quantity = Units.Quantity(self._paramWidget.velocityZTxt.text())
      +            self._obj.VelocityZ = float(quantity.getValueAs(unit))
      +        self._obj.NormalToBoundary = self._paramWidget.normalBox.isChecked()
      +

      The view proxy must be extended to support the task panel we just implemented. The following extended view proxy opens the task panel when the user makes a double click on the constraint object in the tree view. +

      +
      class ViewProxy(FemConstraint.ViewProxy):
      +
      +    def getIcon(self):
      +        return ":/icons/fem-constraint-flow-velocity.svg"
      +
      +    def setEdit(self, vobj, mode=0):
      +        task = _TaskPanel(vobj.Object)
      +        Gui.Control.showDialog(task)
      +
      +    def unsetEdit(self, vobj, mode=0):
      +        Gui.Control.closeDialog()
      +
      +    def doubleClicked(self, vobj):
      +        if Gui.Control.activeDialog():
      +            Gui.Control.closeDialog()
      +        Gui.ActiveDocument.setEdit(vobj.Object.Name)
      +        return True
      +

      Extend Elmers Writer

      +

      In this step we are going to modify the following file: +

      +
      • src/Mod/Fem/FemSolver/Elmer/Writer.py
      +

      The writer module contains methods for all equation types. Depending on the type of the constriant, boundary condition, initial condition or body force one has to modifiy different methods. For our flow velocity we have to adjust _handleFlowBndConditions(...). +

      +
      def _handleFlowBndConditions(self):
      +    for obj in self._getMember("Fem::ConstraintFlowVelocity"):
      +        if obj.References:
      +            for name in obj.References[0][1]:
      +                if obj.VelocityXEnabled:
      +                    velocity = getFromUi(obj.VelocityX, "m/s", "L/T")
      +                    self._boundary(name, "Velocity 1", velocity)
      +                if obj.VelocityYEnabled:
      +                    velocity = getFromUi(obj.VelocityY, "m/s", "L/T")
      +                    self._boundary(name, "Velocity 2", velocity)
      +                if obj.VelocityZEnabled:
      +                    velocity = getFromUi(obj.VelocityZ, "m/s", "L/T")
      +                    self._boundary(name, "Velocity 3", velocity)
      +                if obj.NormalToBoundary:
      +                    self._boundary(name, "Normal-Tangential Velocity", True)
      +            self._handled(obj)
      +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Add_FEM_Equation_Tutorial.html b/localwiki/Add_FEM_Equation_Tutorial.html new file mode 100644 index 0000000..90f1e1c --- /dev/null +++ b/localwiki/Add_FEM_Equation_Tutorial.html @@ -0,0 +1,188 @@ +Add FEM Equation Tutorial

      Add FEM Equation Tutorial

      + +
      + + + + + + + + + + + + + + + + + + + + + + + + + + + +
      +

      Base ExampleCommandModel.png Tutorial

      +
      Topic +
      +
      Level +
      +
      Time to complete +
      +
      Author +
      M42kus +
      FreeCAD version +
      +
      Example File(s) +
      +

      + +
      +


      +

      In this tutorial we are going to add the flow equation to FreeCAD and implement support for elmer solver. Please make sure you have read and understood Extend FEM Module before reading this tutorial. +

      The task can be split into four parts. The first step is to make the FEM workbench aware of a new type of equation. This step must only be done if the equation doesn't exist in FreeCAD jet (as opposed to a equation that is already in FreeCAD but not supported by the target solver). The secound step is to add a concrete document object representing the elmer specific equation. The third step is to add support for the new equation to the solver object of elmer. After that the analysis export of elmer must be extended to support the new equation type. +

      +

      New Equation Type

      +

      In this step we are going to modify the following files: +

      +
      • src/Mod/Fem/FemSolver/EquationBase.py
      • +
      • src/Mod/Fem/PyGui/_CommandFemEquation.py
      • +
      • src/Mod/Fem/Workbench.cpp
      • +
      • src/Mod/Fem/Gui/Resources/Fem.qrc
      +

      The equation type is shared among all equation objects of the different solver. Each type has a string specifier (e.g. "Heat") and a dedicated command that adds the equation to the selected solver. This allows for a simpler GUI where we have only one button for the heat equation which is used for all supported solver. +

      First add the new equation to the EquationBase module. Each equation requires two classes. A document proxy and a view proxy. Just copy-paste them from an existing equation type and adjust the icon path inside getIcon(self) of the view proxy. +

      +
      class FlowProxy(BaseProxy):
      +    pass
      +
      +class FlowViewProxy(BaseViewProxy):
      +    def getIcon(self):
      +        return ":/icons/fem-equation-flow.svg"
      +

      Those two classes will later be used as base classes for the elmer specific equation classes. In addition to those base classes we have to create a new command class that adds a flow equation to the selected solver object. Additionally, the new .svg has to be registered with <file>icons/fem-equation-flow.svg</file> in Fem.qrc. +

      The command should be added to the _CommandFemEquation module. Just copy an existing command and adjust the icon, menu text and tool-tip in GetResources(self) and the specifier in getSpecifier(self). We will need the specifier again later in the tutorial. Don't forget to register the command at the bottom of the module file by using the addCommand(...) method. +

      +
      class Flow(_Base):
      +
      +    def getSpecifier(self):
      +        return "Flow"
      +
      +    def GetResources(self):
      +        return {
      +            'Pixmap': 'fem-equation-flow',
      +            'MenuText': "Flow Equation",
      +            'ToolTip': "Add flow equation to selected solver."
      +        }
      +
      +Gui.addCommand('FEM_AddEquationFlow', Flow())
      +

      Our newly created command still needs to be made accessable via the GUI of the FEM workbench. To add it to the toolbar search for the following code snippet in Workbench.cpp and add the new command to the rest of the equation commands. +

      +
       Gui::ToolBarItem* solve = new Gui::ToolBarItem(root);
      + solve->setCommand("Solve");
      + *solve << "FEM_SolverCalculix"
      +       << "FEM_AddSolverElmer"
      +       << "Separator"
      +       << "FEM_AddEquationHeat"
      +       << "FEM_AddEquationElasticity"
      + +      << "FEM_AddEquationFlow"
      +       << "Separator"
      +       << "FEM_SolverControl"
      +       << "FEM_SolverRun";
      +

      We are also going to add the flow equation command to the solve menu of the FEM workbench. To do this insert our equation into the following code snippet in Workbench.cpp. +

      +
       Gui::MenuItem* solve = new Gui::MenuItem;
      + root->insertItem(item, solve);
      + solve->setCommand("&Solve");
      + *solve << "FEM_SolverCalculix"
      +        << "FEM_SolverZ88"
      +        << "FEM_AddSolverElmer"
      +        << "Separator"
      +        << "FEM_AddEquationHeat"
      +        << "FEM_AddEquationElasticity"
      + +       << "FEM_AddEquationFlow"
      +        << "Separator"
      +        << "FEM_SolverControl"
      +        << "FEM_SolverRun";
      +

      Elmers Equation Object

      +

      In this step we are going to modify the following files: +

      +
      • src/Mod/Fem/CMakeLists.txt
      • +
      • src/Mod/Fem/App/CMakeLists.txt
      +

      and add the following new file: +

      +
      • src/Mod/Fem/FemSolver/Elmer/Equations/Flow.py
      +

      Lets start with the module that implements the document object. In can be copied from an existing equation. If the new equation only supports keywords for linear systems copy the FemSolver/Elmer/Equations/Elasticity.py module. If it supports non-linear keywords too copy FemSolver/Elmer/Equations/Heat.py. The flow equation in elmer is a potentially non-linear equation. This means that we are going to base our work on Heat.py. +

      After copying Heat.py to Flow.py adjust - the name argument of the create module function, - the Type attribute of the Proxy class, - the base classes of the Proxy and the ViewProxy classes, - and the properties added via the obj.addProperty(..) function to those needed by the equation. +

      +
      def create(doc, name="Flow"):
      +    return FemMisc.createObject(
      +        doc, name, Proxy, ViewProxy)
      +
      +class Proxy(Nonlinear.Proxy, FemEquation.FlowProxy):
      +    Type = "Fem::FemEquationElmerFlow"
      +    def __init__(self, obj):
      +        super(Proxy, self).__init__(obj)
      +        obj.Priority = 10
      +
      +class ViewProxy(Nonlinear.ViewProxy, FemEquation.FlowViewProxy):
      +    pass
      +

      At the moment of writing this tutorial elmers flow equation doesn't have any special properties. See elmers elasticity equation for an example with properties. +

      Last but not least register the new module file (Flow.py) in both CMakeLists.txt files the way descripted in Extend FEM Module. The suitable lists can be easily found by searching for existing equation modules files of elmer. +

      +

      Extend Solver Object

      +

      In this step we are going to modify the following file: +

      +
      • src/Mod/Fem/FemSolver/Elmer/Object.py
      +

      Right now we made FreeCAD aware that there is a new type of equation and even added a command that adds this equation to the selected solver object. We also implemented a concrete equation object for elmer. Whats left to do now it to make the connection beween elmer and the flow equation. This must be done directely in elmers solver object. +

      Register the module in which we just implemented our new equation object (Flow.py) with the equation specifier from step 1 ("Flow") in the Proxy._EQUATIONS list in Elmer/Object.py. +

      +
      _EQUATIONS = {
      +    "Heat": Equations.Heat,
      +    "Elasticity": Equations.Elasticity,
      ++    "Flow": Equations.Flow,
      +}
      +

      Extend Analysis Export

      +

      In this step we are going to modify the following file: +

      +
      • src/Mod/Fem/FemSolver/Elmer/Writer.py
      +

      This is the most demaning part of implementing a new equation. This file contains a Writer class which exports the analysis into elmers sif format. +

      For every supported equation there are a series of methods handling the export of the respective equation. Just copy all of them from an existing equation and adjust them to your needs. Our Flow equation uses the following methods: +

      +
      • _handleFlow
      • +
      • _getFlowSolver
      • +
      • _handleFlowConstants
      • +
      • _handleFlowBndConditions
      • +
      • _handleFlowInitial
      • +
      • _handleFlowBodyForces
      • +
      • _handleFlowMaterial
      • +
      • _handleFlowEquation
      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/AddonManager.html b/localwiki/AddonManager.html new file mode 100644 index 0000000..df81027 --- /dev/null +++ b/localwiki/AddonManager.html @@ -0,0 +1,75 @@ +AddonManager

      AddonManager

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Addon manager

      +
      Menu location +
      Tools → Addon manager +
      Workbenches +
      N/A +
      Default shortcut +
      None +
      See also +
      Macros +

      + +
      +


      +

      The Addon manager is a tool to install and manage add-on workbenches and macros provided by the FreeCAD community. The complete list of workbenches is available on the add-ons repository. +

      available in version 0.17 +


      +Addon manager.png +

      +

      How to use

      +
      • Open the Tools → Addon manager menu.
      • +
      • To install a workbench or a macro: scroll through the list and select the add-on. The description of the add-on will be displayed below the list, as well as the link to the add-on page. Then press the Install / update button. +
        For macros, click on the Macros tab.
      • +
      • To remove a workbench or a macro: scroll through the list, select the add-on then press the Remove button.
      • +
      • To update a workbench or a macro: scroll through the list, select the add-on then press the Install / update button.
      • +
      • To check for updates: press the Std Refresh.png button. (Note: the icon may look different depending on your operating system.) Available updates will be reported below the list. Pressing the update button again will update all updates at once.
      +

      Limitations

      +
      • The add-ons are not part of the official FreeCAD package and are not supported by the FreeCAD team. You should read the information provided on each of the add-on pages before installing any of them, to make sure you know what you are installing.
      +
      • Bug reports and feature requests should be made directly on each add-on page.
      +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/AddonManager.svg b/localwiki/AddonManager.svg new file mode 100644 index 0000000..2c7537f --- /dev/null +++ b/localwiki/AddonManager.svg @@ -0,0 +1,378 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Addon_manager.png b/localwiki/Addon_manager.png new file mode 100644 index 0000000..421614c Binary files /dev/null and b/localwiki/Addon_manager.png differ diff --git a/localwiki/Aeroplane.html b/localwiki/Aeroplane.html new file mode 100644 index 0000000..cc9bda9 --- /dev/null +++ b/localwiki/Aeroplane.html @@ -0,0 +1,138 @@ +Aeroplane

      Aeroplane

      + +
      + + + + + + + + + + + + + + + + + + + + + + + + + + + +
      +

      Base ExampleCommandModel.png Tutorial

      +
      Topic +
      Part Workbench +
      Level +
      Beginner +
      Time to complete +
      10 minutes +
      Author +
      +
      FreeCAD version +
      +
      Example File(s) +
      +

      + +
      +


      +


      +

      +

      First Steps

      +

      We will be working in the Part Workbench - select it from menus via View->Workbench->Part or from the Workbench selector. +

      +
      • Create a new empty document.
      • +
      • Switch to Axonometric View.
      • +
      • Toggle axis cross ON (via View Menu).
      • +
      • Ensure you have the Combo View showing (via View->Views).
      +
      • Create a cylinder by clicking on the Part Cylinder.png Cylinder button.
      • +
      • Select it by clicking on Cylinder in the Project viewer.
      • +
      • Click on the Data tab at the bottom of the Project viewer.
      +

      Change the Height to 20mm. Leave the Radius at 2mm. +

      Click on Placement (note the little [+]) and a button with three dots will appear. Click on it. (You can also select: Menu->Edit->Placement.) The Tasks viewer appears. +

      HTCaeroplane01.png +

      If you are unfamiliar with the XYZ axes then have a play with the numbers in the Translation box. When finished playing click on the Reset button. +

      +

      Second Steps

      +
      HTCaeroplane02.png
      +

      We are now going to rotate the cylinder so that it is lying along the X axis. To do this it needs to be rotated around the Y axis. The Rotation box should say 'Rotation axis with angle' so change the Axis to Y and increment the Angle until it reaches 90. Click on OK. +

      I like to play with rotating the view at this point (and often!) so by all means do so. You should find the 'seam' of the cylinder on the underside. +


      +

      +
      HTCaeroplane03.png
      +

      We are now going to add and modify a box so click on the Part Box.png Box button. Select it by clicking on Box in the Project viewer. +Change the Height to 1mm, the Length to 5mm and the Width to 20mm. +

      Click on Placement and the three dots to get the Tasks viewer. Using the Translation box enter Y: -10 and Z: -1. Click on OK +

      We are now going to merge these two shapes together with a Boolean Operation. Click on the Part Booleans.png Booleans button and the Tasks viewer will display the Boolean Operation selector. +

      Make sure Union is selected, and that the Cylinder and the Box are each ticked once in the two shape lists. Click on Apply. Click on Close. You now have a single object called Fusion. +


      +

      Let's add one more box to finish off our model. Create a Box, Select it and change its Height to 5mm, Length to 3mm and Width to 1mm. Change its Placement by Y: -0.5. +

      We now need to join our Fusion to Box001 so we'll do it the quick way. Click on Fusion in the Project viewer and CTRL-click on Box001. This selects both parts together. Now click on the Part Fuse.png Union button to get Fusion001. +

      You should now have a simple aeroplane model. Right-click on Fusion001 and Rename it 'Aeroplane'. +

      +
      HTCaeroplane04.png
      +

      I think the wings need to be moved forward a bit but if I select Aeroplane and try changing its Placement X Translation the whole thing moves. I only want to move the wings so cancel the Placement. +

      Expand Aeroplane (click on the [+] beside it) and expand Fusion. +

      Click on Box and get its Placement into Tasks. Notice it already has Y: -10 and Z: -1 in the Translation. Change the X translation to 3 and click on Apply. That's better. Click OK. +


      +

      +

      Rotations

      +

      Click on Aeroplane and get its Placement into Tasks (Other explanation on Placement). In the Rotation section change where it says 'Rotation axis with angle' to 'Euler angles' because they're a lot easier to work with. +

      +
      Tache Placement Lacet fr Mini.gif
      Yaw is the rotation about the Z axis, that is to say a rotation from left to right. (The yaw angle is the Psi ψ). +
      +
      Tache Placement Tangage fr Mini.gif
      Pitch is rotation about the Y axis, that is to say nose-up and nose-down. (The Pitch angle is the Phi φ). +
      +
      Tache Placement Roulis fr Mini.gif
      Roll is rotation about the X axis, that is to say wing up and down. (The Roll angle is the Thêta θ). +


      +

      +
      +


      +However, even here there are some important things to remember: +

      +
      • Positive Rotations are clockwise when viewed from the Origin outwards along a positive axis. Or to put it another way: Positive Rotations are anticlockwise when viewed from a positive axis towards the Origin.
      +
      • Although the three labels are Yaw, Pitch and Roll that's not really what they are. Yaw, Pitch and Roll are references to the body coordinates of an object in 3D space. The labels should be Heading, Elevation and Bank or even Azimuth, Inclination and Bank because thay actually refer to the space coordinates of the 3D system. These are the Tait-Bryan angles. If you want more information then try Euler Angles.
      +
      • With the Aeroplane in its present position simple rules apply. Yaw is rotation around the Z axis, ie left and right. Pitch is rotation around the Y axis, ie nose up and down. Roll is rotation around the X axis, ie wings up and down. That's fine to start with but it's not going to be true later!
      +

      Have a play with the three YPR numbers. You only need to change things by a few degrees to get the idea. Reset when you finished. +

      Now we're going to see why the Yaw-Pitch-Roll labels are not really suitable. Change the Roll number to 90°. Yaw should move the nose of the aeroplane up and down and Pitch should move it side to side as viewed from outside the aeroplane which is where we are. Do they? No they don't! Pitch changes the yaw and Yaw changes the pitch. OK, Reset. +

      So, a better way of thinking about rotations is that Yaw changes your Longitude, Pitch changes your Latitude and Roll changes the direction (NSEW) that you're facing. Or you could check out Axes conventions for other descriptions. +

      Right, back to work. Change Yaw to 45° and Pitch to -30°. Click on OK to show that the operation has been completed. Now get back the Placement Task and look at the Rotation box. It has reverted to 'Rotation axis with angle' and has some wierd numbers Axis and Angle boxes. Mine had Axis: (0.219493,-0.529904,0.819161) and Angle: 53.65°. The three numbers in brackets are the XYZ components of a unit vector in the 3D space. It is the axis about which our original Aeroplane was rotated to get our final Aeroplane. The angle is how much it was rotated. Clever, huh, but not very friendly! It was Euler who showed that you could combine a series of XYZ rotations into one rotation about one axis. +

      Here's some more suggestions for playing with the Aeroplane: +

      +
      • Change the Z Location (and Apply) then change the YPR numbers and see what the effect is. Then try changing the X and Y Locations and rotating.
      • +
      • Change the X Centre (and Apply) then change the YPR numbers and see what the effect is. Then try changing the Y and Z Centres and rotating.
      +

      I hope this little tutorial has helped you to get a feel for rotations. +


      +

      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Aliasmanager_screenshot.png b/localwiki/Aliasmanager_screenshot.png new file mode 100644 index 0000000..be845ba Binary files /dev/null and b/localwiki/Aliasmanager_screenshot.png differ diff --git a/localwiki/Aligner-ico.png b/localwiki/Aligner-ico.png new file mode 100644 index 0000000..389aa06 Binary files /dev/null and b/localwiki/Aligner-ico.png differ diff --git a/localwiki/AngleSample.png b/localwiki/AngleSample.png new file mode 100644 index 0000000..1851cf5 Binary files /dev/null and b/localwiki/AngleSample.png differ diff --git a/localwiki/Angularity.svg b/localwiki/Angularity.svg new file mode 100644 index 0000000..54233a5 --- /dev/null +++ b/localwiki/Angularity.svg @@ -0,0 +1,112 @@ + + + + + Angularity + + + + + + image/svg+xml + + Angularity + + + bavariaSHAPE + + + + + bavariaSHAPE + + + + + bavariaSHAPE + + + 15.10.2016 + Geometric dimensioning and tolerancing symbols +All symbols in this repository are licensed under CC-BY 3.0 + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/AppImage-logo.png b/localwiki/AppImage-logo.png new file mode 100644 index 0000000..7d48e2f Binary files /dev/null and b/localwiki/AppImage-logo.png differ diff --git a/localwiki/Application-exit.svg b/localwiki/Application-exit.svg new file mode 100644 index 0000000..0e10988 --- /dev/null +++ b/localwiki/Application-exit.svg @@ -0,0 +1,456 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + Jakub Steiner + + + http://jimmac.musichall.cz + + System Log Out + + + log out + logout + exit + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Applications-accessories.svg b/localwiki/Applications-accessories.svg new file mode 100644 index 0000000..9f3e78a --- /dev/null +++ b/localwiki/Applications-accessories.svg @@ -0,0 +1,520 @@ + +image/svg+xmlGo Homejakub Steinerhttp://jimmac.musichall.czhomereturngodefaultuserdirectory + + \ No newline at end of file diff --git a/localwiki/Applications-python.svg b/localwiki/Applications-python.svg new file mode 100644 index 0000000..d782f8d --- /dev/null +++ b/localwiki/Applications-python.svg @@ -0,0 +1,142 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + + + + + + diff --git a/localwiki/ApplyingForceToFace.PNG b/localwiki/ApplyingForceToFace.PNG new file mode 100644 index 0000000..f0f8efc Binary files /dev/null and b/localwiki/ApplyingForceToFace.PNG differ diff --git a/localwiki/Appveyor.svg b/localwiki/Appveyor.svg new file mode 100644 index 0000000..32f9118 --- /dev/null +++ b/localwiki/Appveyor.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/localwiki/ArchDesign.png b/localwiki/ArchDesign.png new file mode 100644 index 0000000..5ae3457 Binary files /dev/null and b/localwiki/ArchDesign.png differ diff --git a/localwiki/ArchExample.png b/localwiki/ArchExample.png new file mode 100644 index 0000000..ce6e233 Binary files /dev/null and b/localwiki/ArchExample.png differ diff --git a/localwiki/ArchWorkbench.svg b/localwiki/ArchWorkbench.svg new file mode 100644 index 0000000..c55eaba --- /dev/null +++ b/localwiki/ArchWorkbench.svg @@ -0,0 +1,666 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [triplus] + + + ArchWorkbench + 2016-02-26 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Arch/Resources/icons/ArchWorkbench.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Arch_3DS.html b/localwiki/Arch_3DS.html new file mode 100644 index 0000000..e15bb27 --- /dev/null +++ b/localwiki/Arch_3DS.html @@ -0,0 +1,20 @@ +Arch 3DS

      Arch 3DS

      + +

      The Arch Workbench supports importing 3DS files. The 3DS format is ancient but still widely used on the internet. It can contain mesh data and material information. At the moment, it will import mesh objects contained in the file as FreeCAD mesh objects, and has no support for materials yet. +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Arch_3Views.html b/localwiki/Arch_3Views.html new file mode 100644 index 0000000..cbc8da4 --- /dev/null +++ b/localwiki/Arch_3Views.html @@ -0,0 +1,71 @@ +Arch 3Views

      Arch 3Views

      + +
      +

      This documentation is not finished. Please help and contribute documentation. +

      See Draft ShapeString for good documented Command. Gui Command gives an overview over commands. And see List of Commands for other commands. +

      Go to Help FreeCAD to contribute. +

      +
      + + + + + + + + + + + + + + + + + + + + +
      +

      Arch 3Views.png Arch 3Views

      +
      Menu location +
      Arch → Utilities → 3 Views from mesh +
      Workbenches +
      Arch +
      Default shortcut +
      +
      See also +
      +

      + +
      +


      +

      +

      Description

      +

      This command is currently not in use. It will serve to generate flat, shape-based views from a Mesh based object, to be used by the Arch Equipment tool. +

      +

      How to use

      +
      1. Select a Mesh object
      2. +
      3. Select menu Arch → Utilities → Arch 3Views.png 3Views
      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Arch_3Views.svg b/localwiki/Arch_3Views.svg new file mode 100644 index 0000000..d3a88fd --- /dev/null +++ b/localwiki/Arch_3Views.svg @@ -0,0 +1,64 @@ + + + + + + + + + + + + + image/svg+xml + + + + + [Yorik van Havre] + + + Arch_3Views + 2014-08-29 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Arch/Resources/icons/Arch_3Views.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Arch_A_Landscape.svg b/localwiki/Arch_A_Landscape.svg new file mode 100644 index 0000000..239d69d --- /dev/null +++ b/localwiki/Arch_A_Landscape.svg @@ -0,0 +1,1475 @@ + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + AUTHOR NAME + CREATION DATE + SUPERVISOR NAME + CHECK DATE + ARCH A + SCALE + WEIGHT + NUMBER + SHEET + TITLE + SUBTITLE + COMPANY NAME + COPYRIGHT + _________ + _________ + _________ + _________ + _________ + _________ + _________ + _________ + _________ + + + + diff --git a/localwiki/Arch_A_Portrait.svg b/localwiki/Arch_A_Portrait.svg new file mode 100644 index 0000000..fb93c28 --- /dev/null +++ b/localwiki/Arch_A_Portrait.svg @@ -0,0 +1,1518 @@ + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + AUTHOR NAME + CREATION DATE + SUPERVISOR NAME + CHECK DATE + ARCH A + SCALE + WEIGHT + NUMBER + SHEET + TITLE + SUBTITLE + COMPANY NAME + COPYRIGHT + _________ + _________ + _________ + _________ + _________ + _________ + _________ + _________ + _________ + + + + diff --git a/localwiki/Arch_Add.html b/localwiki/Arch_Add.html new file mode 100644 index 0000000..5eb13cb --- /dev/null +++ b/localwiki/Arch_Add.html @@ -0,0 +1,85 @@ +Arch Add

      Arch Add

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Arch Add.png Arch Add

      +
      Menu location +
      Arch → Add +
      Workbenches +
      Arch +
      Default shortcut +
      None +
      See also +
      Arch Remove +

      + +
      +


      +

      +

      Description

      +

      The Add tool allows you to do 4 kinds of operations: +

      + +

      Arch Add example.jpg +

      In the above image, a box is being added to a wall. +

      +

      How to use

      +
      1. Select the object(s) to be added, then the "host" object (the host object must be the last one you selected)
      2. +
      3. Press the Arch Add.png Add button
      +

      Scripting

      +

      The Add tool can by used in macros and from the python console by using the following function: +

      +
      addComponents (objectsList,hostObject) 
      +
      • Adds the given object or the objects from the given list as components to the given host Object. Use this for example to add windows to a wall, or to add walls to a floor.
      • +
      • Returns nothing.
      +

      Example: +

      +
      import FreeCAD, Arch, Draft, Part
      +line = Draft.makeWire([FreeCAD.Vector(0,0,0),FreeCAD.Vector(2,2,0)])
      +wall = Arch.makeWall(line)
      +box = Part.makeBox(1,1,1)
      +Arch.addComponents(box,wall) 
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Arch_Add.svg b/localwiki/Arch_Add.svg new file mode 100644 index 0000000..18db382 --- /dev/null +++ b/localwiki/Arch_Add.svg @@ -0,0 +1,71 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [wmayer] + + + Arch_Add + 2011-10-10 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Arch/Resources/icons/Arch_Add.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + diff --git a/localwiki/Arch_Axis.html b/localwiki/Arch_Axis.html new file mode 100644 index 0000000..c2e4b30 --- /dev/null +++ b/localwiki/Arch_Axis.html @@ -0,0 +1,92 @@ +Arch Axis

      Arch Axis

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Arch Axis.png Arch Axis

      +
      Menu location +
      Arch → Axis +
      Workbenches +
      Arch +
      Default shortcut +
      A X +
      See also +
      Axis System +

      + +
      +


      +

      +

      Description

      +

      The Axis tool allows you to places a series of axes in the current document. The distance and the angle between axes is customizable, as well as the numbering style. The axes serve mainly as references to snap objects onto, but can also be used together with Axes Systems, and can also be referenced by other Arch objects to create parametric arrays, for example of beams or columns. +

      Arch Axis example.jpg +

      The image above shows two different axis objects positioned perpendicularly to each other +

      +

      How to use

      +
      1. Press the Arch Axis.png Arch Axis button, or press A then X keys
      2. +
      3. Move/rotate the axes system to the desired position
      4. +
      5. Enter edit mode by double-clicking the axes system in the tree view to adjust its settings like number of axes, distances and angles between axes.
      +

      Options

      +
      • Each axis in the series has its own distance and angle in relation to the previous axis. This allows to do very complex systems such as non-orthogonal systems, polar systems or any kind of non-uniform system
      • +
      • Double-clicking the axis in the tree view allows to edit the distances, angles and labels of each axis
      • +
      • Axes length, size of the bubbles and numbering styles are customizable directly via the axes system's properties
      • +
      • Each axis can also display a label, also editable via the task panel dialog
      +

      Properties

      +
      • DATALength: The length of the axes
      • +
      • VIEWBubble Size: The size of the axis bubbles
      • +
      • VIEWNumeration style: How the axes are numbered: 1,2,3, A,B,C, etc...
      • +
      • VIEWBubble Position: Where the bubble is placed on the axis: At start point, endpoint, both or none.
      • +
      • VIEWFont Name: A font to draw the bubble number and/or labels
      • +
      • VIEWFont Size: The size of the label text only (bubble text is controlled by the bubble size)
      • +
      • VIEWShow Labels: Turns the display of the label texts on/off
      +

      Scripting

      +

      The Axis tool can by used in macros and from the python console by using the following function: +

      +
      makeAxis ([number],[interval]) 
      +
      makes an axes series based on the given number of axes and interval distance
      +

      Example: +

      +
      import Arch
      +Arch.makeAxis(5,2) 
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Arch_Axis.svg b/localwiki/Arch_Axis.svg new file mode 100644 index 0000000..d5b14c8 --- /dev/null +++ b/localwiki/Arch_Axis.svg @@ -0,0 +1,335 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [yorikvanhavre] + + + Arch_Axis + 2011-12-12 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Arch/Resources/icons/Arch_Axis.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Arch_AxisSystem.html b/localwiki/Arch_AxisSystem.html new file mode 100644 index 0000000..298abc0 --- /dev/null +++ b/localwiki/Arch_AxisSystem.html @@ -0,0 +1,84 @@ +Arch AxisSystem

      Arch AxisSystem

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Arch AxisSystem.png Arch AxisSystem

      +
      Menu location +
      Arch → Axis System +
      Workbenches +
      Arch +
      Default shortcut +
      None +
      See also +
      Arch Axis +

      + +
      +


      +

      +

      Description

      +

      The Axis System tool allows you to combine 2 or 3 Arch Axis objects. The main function of this tool is to calculate intersection points between the different axes included in this system. Arch objects can then use this system to duplicate their shape on the different intersection points. +

      Arch AxisSystem example.jpg +

      The above image shows three Arch Axis objects combined into one Axis System. A column object then uses this system as its Axis property, to have its shape duplicated at each intersection point. +

      +

      How to use

      +
      1. Optionally, select the Arch Axis objects you wish to include in this system
      2. +
      3. Press the Arch AxisSystem.png Arch AxisSystem button
      4. +
      5. Right-click the newly created axes system object in the tree view to add/edit the Arch Axis objects included in this system
      6. +
      7. Select any existing Arch Axis and press Add or Delete buttons to add or remove it to/from this system
      8. +
      9. Set the Axis property of any Arch object to point to this system, to have its shape duplicated to the intersection points of this system
      +

      Options

      +
      • A same Arch Axis object can be part of more than one system
      • +
      • Any shape-based object can also be used as the Axis property of Arch objects. In this case, the object shape will be duplicated along the vertices of the Axis object
      +

      Scripting

      +

      The Axis System tool can by used in macros and from the python console by using the following function: +

      +
      makeAxisSystem ([axes]) 
      +

      Makes an Axis System based on the given list of Arch Axis +

      Example: +

      +
      import Arch
      +a = Arch.makeAxis(5,2)
      +Arch.makeAxisSystem([a]) 
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Arch_Axis_System.svg b/localwiki/Arch_Axis_System.svg new file mode 100644 index 0000000..c3ba571 --- /dev/null +++ b/localwiki/Arch_Axis_System.svg @@ -0,0 +1,426 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [yorikvanhavre] + + + Arch_Axis + 2011-12-12 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Arch/Resources/icons/Arch_Axis.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Arch_Axis_System_Tree.svg b/localwiki/Arch_Axis_System_Tree.svg new file mode 100644 index 0000000..b7b08c8 --- /dev/null +++ b/localwiki/Arch_Axis_System_Tree.svg @@ -0,0 +1,421 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [yorikvanhavre] + + + Arch_Axis_Tree + 2011-12-12 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Arch/Resources/icons/Arch_Axis_Tree.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Arch_Axis_Tree.svg b/localwiki/Arch_Axis_Tree.svg new file mode 100644 index 0000000..2afcf10 --- /dev/null +++ b/localwiki/Arch_Axis_Tree.svg @@ -0,0 +1,335 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [yorikvanhavre] + + + Arch_Axis_Tree + 2011-12-12 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Arch/Resources/icons/Arch_Axis_Tree.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Arch_B_Landscape.svg b/localwiki/Arch_B_Landscape.svg new file mode 100644 index 0000000..770660e --- /dev/null +++ b/localwiki/Arch_B_Landscape.svg @@ -0,0 +1,1476 @@ + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + AUTHOR NAME + CREATION DATE + SUPERVISOR NAME + CHECK DATE + ARCH B + SCALE + WEIGHT + NUMBER + SHEET + TITLE + SUBTITLE + COMPANY NAME + COPYRIGHT + _________ + _________ + _________ + _________ + _________ + _________ + _________ + _________ + _________ + + + + diff --git a/localwiki/Arch_B_Portrait.svg b/localwiki/Arch_B_Portrait.svg new file mode 100644 index 0000000..ff855e8 --- /dev/null +++ b/localwiki/Arch_B_Portrait.svg @@ -0,0 +1,1518 @@ + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + AUTHOR NAME + CREATION DATE + SUPERVISOR NAME + CHECK DATE + ARCH B + SCALE + WEIGHT + NUMBER + SHEET + TITLE + SUBTITLE + COMPANY NAME + COPYRIGHT + _________ + _________ + _________ + _________ + _________ + _________ + _________ + _________ + _________ + + + + diff --git a/localwiki/Arch_BimServer.html b/localwiki/Arch_BimServer.html new file mode 100644 index 0000000..8dc189d --- /dev/null +++ b/localwiki/Arch_BimServer.html @@ -0,0 +1,93 @@ +Arch BimServer

      Arch BimServer

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Arch BimServer.png Arch BimServer‏‎‏‎

      +
      Menu location +
      Arch → Utilities → BIM server +
      Workbenches +
      Arch +
      Default shortcut +
      ‏‎ +
      See also +
      +

      + +
      +


      +

      Note: Starting from FreeCAD v0.17, this tool has been removed from the Arch Workbench and is now part of the external Webtools Workbench that you can install via menu Tools -> Addons Manager +

      +

      Description

      +

      This command allows you to interact with a BIMServer instance, open files stored on the Bim server, and save new revisions of those files. BIMServer is a free, open-source server system made to work with IFC files. In its current state, it allows to manage projects with multiple IFC files, and manage revisions. Its highly extensible database system and plugin architecture also allows to design advanced querying/validating tools and intelligent merging workflows. +

      In order to use this command, the following conditions must be met: +

      +
      • The json and requests Python modules must be installed on your system
      • +
      • You need to have access to a BimServer instance (read the BIMServer documentation to install a BIMServer locally), and have credentials (login and password) for that server. At the time of writing, the stable version of BIMServer is 1.4, but we recommend you to install one of the available beta 1.5.X versions, which installs a lot of plugins automatically (in version 1.4 you have to install plugins manually).
      • +
      • All the file transfers with the BIMServer are done with IFC files. Therefore, you need to know how to work with IFC files.
      +

      How to use

      +
      1. Make sure the above requirements are met, and you have access to a running BIMServer instance
      2. +
      3. Select menu Arch -> Utilities -> Arch BimServer.png BIM Server
      4. +
      5. Press the Connect button and fill in your credential details
      6. +
      7. Once the connection to the BIMServer has been made, choose a project to work with from the Project drop-down box
      +

      Options

      +
      Arch Bimserver panel.jpg
      +
      • If this is the first time you are connecting to a BIMServer from FreeCAD, press the Connect button, and fill in the server URL, your login (which is always an email address) and your password in the dialog box that will pop up. If you wish to log in automatically the next time you will use the BimServer command, check the save credentials option (your login and password are not saved by FreeCAD, only a session cookie).
      • +
      • Once FreeCAD has successfully connected to a BIMServer instance, the Connect button will turn to Connected. Click the button again to disconnect. This will also erase the stored session cookie, so you will need to enter your credentials again next time.
      • +
      • In order to delete the session cookie manually and reset everything, you can simply delete the BIMServer URL stored in Edit -> Preferences -> Arch -> BimServer.
      • +
      • The Open in browser button will open the web interface of the BIMServer either in FreeCAD's internal web browser, or, if you marked that option in Edit -> Preferences -> Arch -> BimServer, in an external web browser. This allows for example to create new projects, or analyze the contents stored on the BIMServer.
      +

      Downloading revisions

      +
      • The Project drop-down box will show the available projects stored on the BIMServer. Choose one to see the available revisions for that project.
      • +
      • Select one revision and click Open to download and open the IFC file corresponding to that revision in FreeCAD.
      • +
      • When pressing the Open button, a dialog box will open to allow you to save the downloaded IFC file at a location of your choice before opening it. If you press Cancel, the file will be saved under a temporary name in the system's temporary directory instead.
      +

      Uploading revisions

      +
      • If you wish to upload a new revision, make sure the right project has been selected in the Project drop-down box
      • +
      • Choose the Root object you wish to upload. It must be either an Arch Site or an Arch Building. Only objects belonging to that root object will be uploaded.
      • +
      • Write a Comment, that will be the description (name) of the revision.
      • +
      • Press the Upload button. A dialog box will open to allow you to save the produced IFC file at a location of your choice before uploading it. If you press Cancel, the file will be saved under a temporary name in the system's temporary directory instead.
      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Arch_Bimserver.svg b/localwiki/Arch_Bimserver.svg new file mode 100644 index 0000000..33f916c --- /dev/null +++ b/localwiki/Arch_Bimserver.svg @@ -0,0 +1,454 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + Jakub Steiner + + + http://jimmac.musichall.cz + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Arch_Bimserver_panel.jpg b/localwiki/Arch_Bimserver_panel.jpg new file mode 100644 index 0000000..9d3d772 Binary files /dev/null and b/localwiki/Arch_Bimserver_panel.jpg differ diff --git a/localwiki/Arch_Building.html b/localwiki/Arch_Building.html new file mode 100644 index 0000000..a652b10 --- /dev/null +++ b/localwiki/Arch_Building.html @@ -0,0 +1,78 @@ +Arch Building

      Arch Building

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Arch Building.png Arch Building

      +
      Menu location +
      Arch → Building +
      Workbenches +
      Arch +
      Default shortcut +
      B U +
      See also +
      Arch Floor, Arch Site +

      + +
      +


      +

      +

      Description

      +

      The Arch Building is a special type of FreeCAD group object particularly suited for representing a whole building unit. They are mostly used to organize your model, by containing floor objects. +

      +

      How to use

      +
      1. Optionally, select one or more objects to be included in your new building
      2. +
      3. Press the Arch Building.png Arch Building button, or press the B then U keys
      +

      Options

      +
      • After creating a building, you can add more objects to it by drag and dropping them in the Tree View or by using the Arch Add.png Arch Add tool
      • +
      • You can remove objects from a building by drag and dropping them out of it the Tree View or by using the Arch Remove.png Arch Remove tool
      +

      Scripting

      +

      The Building tool can by used in macros and from the python console by using the following function: +

      +
      makeBuilding ([objectslist]) 
      +

      creates a building including the objects from the given list. +

      Example: +

      +
      import Arch
      +Arch.makeBuilding() 
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Arch_Building.svg b/localwiki/Arch_Building.svg new file mode 100644 index 0000000..f549fd7 --- /dev/null +++ b/localwiki/Arch_Building.svg @@ -0,0 +1,125 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [wmayer] + + + Arch_Building + 2011-10-10 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Arch/Resources/icons/Arch_Building.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + diff --git a/localwiki/Arch_Building_Tree.svg b/localwiki/Arch_Building_Tree.svg new file mode 100644 index 0000000..c6903c7 --- /dev/null +++ b/localwiki/Arch_Building_Tree.svg @@ -0,0 +1,125 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [yorikvanhavre] + + + Arch_Building_Tree + 2011-12-06 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Arch/Resources/icons/Arch_Building_Tree.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + diff --git a/localwiki/Arch_C_Landscape.svg b/localwiki/Arch_C_Landscape.svg new file mode 100644 index 0000000..9aba960 --- /dev/null +++ b/localwiki/Arch_C_Landscape.svg @@ -0,0 +1,1475 @@ + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + AUTHOR NAME + CREATION DATE + SUPERVISOR NAME + CHECK DATE + ARCH C + SCALE + WEIGHT + NUMBER + SHEET + TITLE + SUBTITLE + COMPANY NAME + COPYRIGHT + _________ + _________ + _________ + _________ + _________ + _________ + _________ + _________ + _________ + + + + diff --git a/localwiki/Arch_C_Portrait.svg b/localwiki/Arch_C_Portrait.svg new file mode 100644 index 0000000..0238c44 --- /dev/null +++ b/localwiki/Arch_C_Portrait.svg @@ -0,0 +1,1519 @@ + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + AUTHOR NAME + CREATION DATE + SUPERVISOR NAME + CHECK DATE + ARCH C + SCALE + WEIGHT + NUMBER + SHEET + TITLE + SUBTITLE + COMPANY NAME + COPYRIGHT + _________ + _________ + _________ + _________ + _________ + _________ + _________ + _________ + _________ + + + + diff --git a/localwiki/Arch_Cell.html b/localwiki/Arch_Cell.html new file mode 100644 index 0000000..1aa78d6 --- /dev/null +++ b/localwiki/Arch_Cell.html @@ -0,0 +1,28 @@ +Arch Cell

      Arch Cell

      + +

      NOTE: Starting with version 0.13 this command is deleted. Instead, use the command Draft_AddToGroup group. +

      +

      Description

      +

      The Cell tools allows to group several architectural components into a "group". The similar geometries are joined (walls with walls, structure elements with structure elements, etc) +

      Arch Cell example.jpg +

      In the above example, the 3 walls at the left are joined into a cell, displayed at the right +

      +

      Usage

      +
      • Select base objects to be grouped
      • +
      • Press the Arch Cell.png Arch Cell button
      • +
      • Individual components can then be added or removed to/from the cell with the Arch Add and Arch Remove tools.
      + + + + +
      + +
      +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Arch_Cell.svg b/localwiki/Arch_Cell.svg new file mode 100644 index 0000000..0780591 --- /dev/null +++ b/localwiki/Arch_Cell.svg @@ -0,0 +1,130 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [wmayer] + + + Arch_Cell + 2011-10-10 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Arch/Resources/icons/Arch_Cell.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Arch_Cell_Tree.svg b/localwiki/Arch_Cell_Tree.svg new file mode 100644 index 0000000..da7b6f7 --- /dev/null +++ b/localwiki/Arch_Cell_Tree.svg @@ -0,0 +1,130 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [yorikvanhavre] + + + Arch_Cell_Tree + 2011-12-06 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Arch/Resources/icons/Arch_Cell_Tree.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Arch_Cell_example.jpg b/localwiki/Arch_Cell_example.jpg new file mode 100644 index 0000000..e7a9432 Binary files /dev/null and b/localwiki/Arch_Cell_example.jpg differ diff --git a/localwiki/Arch_Check.html b/localwiki/Arch_Check.html new file mode 100644 index 0000000..81143ac --- /dev/null +++ b/localwiki/Arch_Check.html @@ -0,0 +1,71 @@ +Arch Check

      Arch Check

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Arch Check.png Arch Check

      +
      Menu location +
      Arch → Utilities → Check +
      Workbenches +
      Arch +
      Default shortcut +
      None +
      See also +
      Arch CloseHoles +

      + +
      +


      +

      +

      Description

      +

      This tool checks the current document or the selected objects for non-solid Part or Arch objects, that might give problems, since most operations of the Arch module require solid objects. +

      +

      How to use

      +
      1. Press the Arch Check.png Check entry in Arch → Utilities menu
      +

      Scripting

      +

      This tool can by used in macros and from the python console by using the following function: +

      +
      check (objectslist,includehidden=False) 
      +

      checks if the given objects contain only solids +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Arch_Check.svg b/localwiki/Arch_Check.svg new file mode 100644 index 0000000..9ab7b88 --- /dev/null +++ b/localwiki/Arch_Check.svg @@ -0,0 +1,75 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [Yorik van Havre] + + + Arch_Check + 2012-07-22 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Arch/Resources/icons/Arch_Check.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + diff --git a/localwiki/Arch_CloneComponent.html b/localwiki/Arch_CloneComponent.html new file mode 100644 index 0000000..51bf867 --- /dev/null +++ b/localwiki/Arch_CloneComponent.html @@ -0,0 +1,62 @@ +Arch CloneComponent

      Arch CloneComponent

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Arch cloneComponent.png Arch cloneComponent‏‎‏‎

      +
      Menu location +
      Arch → Utilities → Clone Component +
      Workbenches +
      Arch +
      Default shortcut +
      C,C‏‎ +
      See also +
      +

      + +
      +


      +

      +

      Description

      +

      This tool produces Arch Components that are clones of selected Arch objects. Unlike the Draft Clone tool, which will produce a clone of the same type as the selected object, this tool produces a generic Arch Component object, that can therefore assume any role, not necessarily the role of the cloned object. +

      The clone component will simply have its CloneOf property set to the selected object. +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Arch_CloseHoles.html b/localwiki/Arch_CloseHoles.html new file mode 100644 index 0000000..8ef5eec --- /dev/null +++ b/localwiki/Arch_CloseHoles.html @@ -0,0 +1,72 @@ +Arch CloseHoles

      Arch CloseHoles

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Arch CloseHoles.png Arch CloseHoles

      +
      Menu location +
      Arch → Utilities → Close Holes +
      Workbenches +
      Arch +
      Default shortcut +
      None +
      See also +
      Arch Check +

      + +
      +


      +

      +

      Description

      +

      This tool identifies holes (circular sequence of open edges) in a Shape object and attempts to close it by adding it a new face made from that edges sequence. You must still verify yourself that the result is a solid, though. +

      +

      How to use

      +
      1. Select a Shape object
      2. +
      3. Press the Arch CloseHoles.png Close Holes entry in Arch -> Utilities menu
      +

      Scripting

      +

      This tool can by used in macros and from the python console by using the following function: +

      +
      closeHole (shape) 
      +

      closes a hole in an open shape +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Arch_CloseHoles.svg b/localwiki/Arch_CloseHoles.svg new file mode 100644 index 0000000..4c46f27 --- /dev/null +++ b/localwiki/Arch_CloseHoles.svg @@ -0,0 +1,67 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [Yorik van Havre] + + + Arch_CloseHoles + 2012-07-22 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Arch/Resources/icons/Arch_CloseHoles.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + diff --git a/localwiki/Arch_Component.html b/localwiki/Arch_Component.html new file mode 100644 index 0000000..08f3c7c --- /dev/null +++ b/localwiki/Arch_Component.html @@ -0,0 +1,81 @@ +Arch Component

      Arch Component

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Arch Component.png Arch Component‏‎‏‎

      +
      Menu location +
      Arch → Utilities → Component +
      Workbenches +
      Arch +
      Default shortcut +
      C,M‏‎ +
      See also +
      +

      + +
      +


      +

      +

      Description

      +

      Creates a non-parametric Arch component from any Part-based object. This gives the Part-based object the same attributes and properties as other Arch objects, and allows to specify how it should be exported to IFC by setting its Role property. +

      +

      How to use

      +
      1. Select a Part-based object
      2. +
      3. Select menu Arch → Utilities → Arch Component.png Component
      +

      Common Arch component properties

      +

      The Arch component object is also a base shared by all other Arch objects (Wall, Structure, etc). Therefore some of its properties and behaviours are common to all Arch objects (excepted tools that don't produce solid objects, like Section Plane or Axis): +

      +
      • Base shape: Arch Components are always based on a Shape-based base object. Some types of Arch objects will just use the Base shape as is, others (for example Wall) will do some additional operations on it, such as an extrusion. Fro some types, having a base object is not mandatory (Structure)
      +
      • Additions: Arch Components have an addition property, that can hold reference to any number of other Shape-based objects. The shape of these additions will be united with the base shape of the component, to produce the final shape.
      +
      • Subtractions: Arch Components have an subtraction property, that can hold reference to any number of other Shape-based objects. The shape of these objects will be subtracted from the base shape of the component, to produce the final shape.
      +
      • The Placement of the Arch Component is applied after the additions and subtractions are done, so these are performed against the base object at its base location. Then the result is moved to the location of the Placement
      +
      • Objects can be added or removed to/from a Component's Additions and Subtractions lists by selecting both the object and the component, and using the Arch Add or Arch Remove commands, or from the task panel by double-clicking the Component in the Tree view. The task panel also allows to check which object is currently part of these lists.
      +
      • Role: Each Arch Component, besides the function defined by its type (wall, window, etc), also has a Role property, that can define further which kind of function it performs. For example, an Structure can have a beam o column role. Generic Arch Components (as produced by this command) can have any role available in the whole Arch workbench. The role is what is used to define the type of IFC object to export to when exporting to IFC.
      +
      • Clone Of: Any Arch Component can be a clone of another Arch Component of the same type (A Wall can only be a clone of another Wall, etc.). The only exception is the generic Arch Component (as produced by this command), that can be clone of any other type (Wall, structure, window, etc). This allows to use a generic Arch Component to override the type of another one.
      +
      • Description: All Arch Components have a Description field, that can contain any text. This is used when exporting to IFC.
      +
      • Tag: The Tag property is another text field, which can be used to give an additional custom identity to objects.
      +
      • Material: All Arch Components have a Material slot, that can contain either a Material or a MultiMaterial (not all Arch object type support the use of MutiMaterials). The DiffuseColor and Transparency properties of the attached material will define the Shape color and transparency of the Arch component. The material will be imported and exported to IFC, OBJ and DAE.
      +
      • Move with Host: When a component is embedded inside another (for example a window inside a wall), setting this property to True will make the object move and rotate together when its host object is moved or rotated using Draft Move or Draft Rotate.
      +
      • Hi Res: Arch Components can use the shape of another object as a higher-resolution version of themselves. For this, both the Hi Res property and the Hi Res display mode must be set. This allows, for example, to make a simple wall, and then model every brick that composes the wall,for example with Part Box. Then, use a compond of those bricks as a high-resolution version of the wall. The shape of the wall is not modified by adding a Hi-Res object. Only its representation in the 3D view will change by adopting the representation of the high-resolution version instead of its own.
      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Arch_Component.svg b/localwiki/Arch_Component.svg new file mode 100644 index 0000000..5e260dd --- /dev/null +++ b/localwiki/Arch_Component.svg @@ -0,0 +1,71 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [Yorik van Havre] + + + Arch_Component + 2015-04-08 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Arch/Resources/icons/Arch_Component.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + diff --git a/localwiki/Arch_Component_Clone.svg b/localwiki/Arch_Component_Clone.svg new file mode 100644 index 0000000..7ed31ef --- /dev/null +++ b/localwiki/Arch_Component_Clone.svg @@ -0,0 +1,626 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [Yorik van Havre] + + + Arch_Component + 2015-04-08 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Arch/Resources/icons/Arch_Component.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Arch_Concept.html b/localwiki/Arch_Concept.html new file mode 100644 index 0000000..e7f5ab8 --- /dev/null +++ b/localwiki/Arch_Concept.html @@ -0,0 +1,169 @@ +Arch Concept

      Arch Concept

      + +

      This page is an attempt to collect ideas about parametric design in the field of architecture for building the Arch Module. Since it is a bit different than the mech engineering field, I want to define concepts a bit better before thinking about how to start implementing it... Feel free to add your ideas! +

      + + +

      Similar software

      + +

      File formats

      + +

      General concepts

      +
      • FreeCAD is perfect for the task. Designing with parametric objects will greatly reduce the only real problem I see in FreeCAD, which is dealing with thousands of objects. Everything needed is there already, like custom object types, custom properties, etc. The main difficulty, designing a general model for dealing with interaction between objects, is now potentially over, since FreeCAD introduced a dependency graph especially for that purpose.
      +
      • BIM (building information modeling) is a concept invented by a couple of building parametric design software vendors, principally autodesk. It means that you don't project a building by drawing anymore, but by inserting information (parameters). The software would then produce a drawing automatically. This is totally bullshit highly questionable in my opinion and only a propaganda concept. Even in most advanced BIM software around (Revit, Archicad and Microstation GC), you can't abstract the act of drawing unless you want to kill any creativity. The goal here is not to be the most automatic, but to keep flexible.
      +
      • Mech engineering parametric design is usually based on changes history and constraint solving. Those two concept have much less importance in building design, since you rarely want to crawl back in the steps you did (they are usually very simple), and keeping constraints like horizontality, angle, or distance, even if they are useful, is not as important as in mech design.
      +
      • Arch parametric design is based on archetypes: wall, door/window, roof, slab, beam, are the basic ones. Outside them, what you'll mostly have are derivatives of those
      +
      • It makes heavy use of assembly: for example several windows are grouped together to form a curtain wall
      +
      • Relationship is the key. Elements are rarely very complex or require much modeling work, but they must often be transformed by the juxtaposition or inclusion of other elements. For example a wall is nothing else than a simple extrusion, but it must connect to other walls, or take a hole when a window is inserted into it. How to build that relationship model and how/where to store it is the big problem.
      +
      • A problem of about all parametric building modeling software is that they rely heavily on those archetype objects. Creating new, not-in-the-library parts, is extremely hard (Archicad) or much easier (Revit) but always a bit of a problem, and there is always a big communication problem between "parametric" parts and "non-parametric" parts. Basically you only gain the full power of the software if you use parts that are made for the job. For example transforming a simple solid into a wall is extremely problematic.
      + +
      • Speed of object calculation is not a very big issue IMHO. Modifying an object shouldn't affect many other objects, and it is usually made in a phase of adjustments, so it's not so important to have lightning-speed updates. One important thing, though, is to always save the final shape of objects, so opening saved models should not require calculations. Before saving, everything should always be recomputed.
      +
      • A state-of-the-art section tool is very important. Floor plans, Elevations, Sections, Ceiling Plans - all are similar BIM tools, as they are axonometric/orthographic "cut planes" through the BIM model.
      +
      • There is the problem of annotation. Where to draw dimensions? on the model? Directly on the svg sheet? Not very practical... This point must be investigated further. Dimensions will belong to a layer that can be turned on/off on the plots. Also, since plots are made to a specific scale, dimensions will be scaled to match the selected scale or a custom one, chosen by user.
      +
      • A "parametric building" should be understood as a mix of relationship-capable objects (archetype-based) and other, non-archetype based. Transforming one object from one category to another should be feasible, and all should behave the same way under sectioning (and dimensioning).
      +
      • A system for creating new components and assemblies, graphically if possible. Assemblies would work as "sub-models" that can be inserted/imported/linked to any BIM model. That way, a sub-model can be updated/changed and that will reflect automatically into the BIM model (if the sub-model is "linked", if it is "imported", then user can select to "update" the model to reflect the latest version of the sub-model, otherwise that will remain as last imported).
      +
      • An edit mode, so one can modify the original shape that generated the part.
      +

      About archetypes

      +
      • All archetypes should always behave like object-oriented programming objects: You can make a new class based on another class.
      • +
      • All archetypes should be able to interact with common object. For this, probably common objects would need custom properties.
      • +
      • Walls should be defined by a simple wire (that would be extruded horizontally, then vertically), a planar shape (that would simply be added a thickness) or a solid (that would be done nothing). The result would always be a solid. Its parameters would therefore vary, depending of your data at the time of creation.
      • +
      • Walls should connect to crossing/touching walls
      • +
      • Walls could be made of different layers (materials). Same materials would connect together.
      • +
      • Walls don't really need a drawing tool. You make them easily by converting something else. But in that case, the draft module could gain a "double-line" tool.
      • +
      • Doors/Windows are quite simple objects, their parameter almost only concerns their internal look. But they must have a "box" that creates holes in other objects.
      • +
      • Beams and Slabs are simple too, but depending on their materials they must be able to connect to other slabs, beams and walls. Beams and slabs could also be joined into one single "structural" element. There are pillars too. All of them could be defined the same way as walls, by a wire, a shape or a solid. They could even be based on the same basis as walls...
      • +
      • Roofs are a special type of object, not very interesting in their own actually, but useful because it's painful to calculate a roof manually. Basically you need to create a shape based on a contour and inclination. Should be easy to do and to extend later to other roof types.
      • +
      • Assemblies need to be defined further. They are basically made of other parts, that could be anything, shapes, windows, etc... and custom properties, such as array repetition, deformation (follow a shape?), etc.
      • +
      • Site Builder - a special set of tools must handle site creation and update. This toolbox needs to be compatible with other major Open Source terrain/site modelers and GIS applications (like GRASS). SiteBuilder will allow for creation of a site based on topo curves, and easy manipulation/update of the site. That will allow easy creation of: sidewalks, curbs and curb cuts, roads, landscaping, parking lots with all required sewer/runoff systems, etc. The database generated will allow for estimating cut and fill as well as other info required to do the site work. SiteBuilder will be useful also to generate the excavation required for a project.
      +

      Archetypes (object types)

      +

      Wall

      +

      Wall is a vertical building component that follows a path on a defined level (i.e. first floor, third floor, etc.) or is extruded horizontally from a vertical surface. Walls are made of several layers (materials, each one with specific thickness and thermal properties), and allow for openings (resulted from subtractions) or appendices (unions). When two different walls intersect, user can select the option to connect the two walls (with similar structure). All parameters of a wall are available for future structural and thermal calculations, as well to generate reports (bill of materials). So for a wall, face areas, volumes, material quantities, etc. are directly inserted in the bill of materials and cost estimate. +

      As mentioned, walls in BIM are defined by a line/polyline/etc. that represents the "center-line" of the wall. This line can be aligned with the exterior face of the wall, interior face of the wall, or the center or the wall, or if user chose to, it can be custom defined. Walls have several parameters that define them: +

      +
      - level in which wall is placed( i.e. first floor, basement, fifth floor, etc.)
      +
      - width
      +
      - height
      +
      - composition
      +

      The level in which walls are placed, require a previous insertion of that "level" by user. Once a level is inserted in the BIM model, that creates automatically a horizontal section, that in turn will generate a "sheet", i.e. once I insert level called "First Floor" at height 0.00 that will automatically section all the visible elements at that height (plus and minus up and down so doors/windows/openings will be visible in that floor plan). Levels and elevations are similar in concept, as basically both are "section planes" located to a certain position/rotation in the 3D space. +

      Walls allow for insertions of libraries like: doors, windows, curtain walls, and other custom made objects that require an opening in that wall. If just an opening is required, that can be inserted as well. +

      +

      Door/Window (Insert element)

      +

      Doors and windows are really the same thing, a totally object which can have a lot of parameters to define its shape, and an invisible volume that is used to cut openings through receiving walls. They are typically inserted into a wall, but not always. since they can differ much, they should be easy to design. +

      +

      Roof

      +

      Roof is simply a handy way to calculate roof slope intersections +

      +

      Slab

      +

      Slab is horizontal, made from extruding vertically a closed wire or face, should connect by material to other structural members, and can have a number of appendices (union) or holes (subtraction), and layers (materials). The horizontal areas and volume must be calculated +

      +

      Beam/Pillar (Structural element)

      +

      A closed wire or face extruded in any direction, can have a number of appendices (union) or holes (subtraction). +

      +

      Assembly

      +

      A group of windows that can be shaped as a whole +

      +

      Generic mechanisms

      +
      • Dependency: windows must know which wall they are inserted, walls must know which window they contain, etc... See part booleans
      • +
      • Joints: walls must know which other wall connect to them and correctly connect their materials together. Moving a wall must therefore recalculate the neighbours. Establish a chart of possible joint types
      • +
      • Edge categories: some edges must not be drawn when they are between 2 objects of same material. Mark edges for choosing later how to render them.
      • +
      • Auto-grouping: Objects of a certain type go automatically into specific groups
      • +
      • "Window designer": An easy way to design parametric windows, based on profiles
      +

      Energy Analysis

      +
      • Building needs to perform appropriate to the program that serves as well to the particular geographical location. For example a single project can be built in Miami, Florida (US) or Frankfurt (Germany) or Sydney (Australia). However, it will perform with large differences. What is appropriate for one location, might be inappropriate for another location. Designs we generate with FCBIM should be "tested" and see how they performs in terms of energy consumption. At this moment there are few tools available out there that allows energy performance of buildings. Major Freeware/Open Source players are: EnergyPlus, OpenStudio (an GUI interface for EnergyPlus) and ESP-r.
      +

      Daylight Simulation

      +
      • Harvesting daylight is one of the basic approaches in sustainable design. Many modern designs turn their back to natural light and result in undesirable solutions for human beings. In US a large percentage of buildings create the so-called Sick Building Syndrome, that lead to health issues for people that live and work in these. Using daylight alleviate part of this problem. FCBIM should incorporate tools that allows daylight simulations, maybe Radiance or LuxRender or Yaf(a)ray.
      +

      HVAC & Natural Ventilation

      +
      • Tools to insert draw and calculate HVAC and allow to calculate for use of natural ventilation. Maybe OpenFOAM should be a candidate in this area, that will complement FCBIM.
      +

      Capturing Building Knowledge

      +

      The effort to create a module that will make it possible for FreeCAD to provide a contemporary building information modeling (BIM) environment is underway. The effort is geared towards bringing its capabilities to compare to those of more mature architectural modeling systems such as Revit. We recognize the limitations in available implementations of BIM one of which is the ignorance of building knowledge. For this reason we are also pursuing a parallel goal of developing capabilities that will enable FreeCAD capture such knowledge typically created mostly in the early design stage but also in the later detail design stage. In the following sections, we document capabilities that are not so common in available tools but which we believe are more appropriate and efficient in capturing building knowledge and information from concept to demolition. The following sections provide specifications and guidelines regarding the "what" part of this effort. We shall fill in the "how" as our effort progresses. Needless to say, things will change or be amended as our understanding and implementation comes together. +

      +

      Procedure Descriptions to Identify Objects

      +

      The building design session begins on the site where the designer establishes the north-direction and introduces appropriate setbacks according to the building code applicable in the design locale. By doing this the maximum footprint for the new building is established. +

      +

      Object 1: Building Site

      +

      There is only one building site in a project. This object should be created as soon as the decision to design a house is made by the designer. It should exist as a form of container (because it secludes a space. More on this later) with sides, a top and a bottom. The sides can then be interactively defines in terms of length and angle. It should also be possible to add or remove sides as needed. Although the bottom is created flat, it can also be redefined with contours to provide appropriate slope. The bottom is the only part of the site that should be visible. +

      +

      Object 2: North-Direction

      +

      The north direction is an object that establishes the angle in the direction of true north. It is a part of the site and makes it possible for the site to determine the prevailing winds, the movement of the sun, etc. +

      +

      Object 3: SetBack

      +

      These are distances from the boundaries of the site which are required by code. They are part of the site but require certain parameters to be provided in order to determine which boundaries and what distances. For example the setback from the boundary next to the street may be different from the setback from a boundary next to a neighboring site. This information can be provided interactively but with the north-direction established, it is possible for the designer to enter this information during the collection of the requirements for the design. The setback, like the site, is a type of container object. +

      +

      Object 4: Building Level

      +

      At this point the maximum footprint for the building has been established. This footprint represents the first building level. The building level is an object that makes it possible to integrate the different building systems. Examples of building systems are architectural, structural, electrical, etc. The building level, like the building site, is a form of container. There can be one or more levels which are typically stacked on top of each other starting from the bottom. The first level is established after designating the setback for all site boundaries. Additional levels can be created but only the elevation of the bottom is modified as the boundaries of the level are invisible. +

      +

      Object 5: Building Space

      +

      The space is defined to satisfy the main function of the building such as a space for sleeping, eating, relaxing, working, etc. Spaces are created and grouped inside levels. There are different types of spaces which provide the appropriate functions in different building types. For example in a residential building type there are 4 main types including sleeping, living, service and traffic. +

      +

      Object 6: Space Object

      +

      This represents everything else that can be located in a space. Each object will have certain fundamental knowledge of its requirements. For example to describe an area for sitting, an object with at least a seat area, a leg room and maximum height requirements will be necessary. +

      +

      Object 7: Building Container

      +

      Most of the objects described so far are types of containers. Containers have an interior area that are secluded by boundaries. There are Bottom, Top and Side boundaries. Two containers can share a side boundary. When this sharing occurs a special Share-Side object replaces the individual sides from each of the participating containers. It establishes a link between the two containers and makes it possible for them to communicate. For example when there is a shared side between a sleeping and a service space such as a bathroom and a bedroom, that side will expect some form of treatment for noise dampening to avoid flooding the sleeping area with too much noise. Each boundary in a container has a Form. A form is a container-type object that can have the necessary descriptions or Property of materials typical in building envelops. +

      +

      Object Diagram

      +

      The following diagram illustrates the relationship between all objects described so far. +

      +
      Objects for capturing building knowledge
      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Arch_CutPlane.html b/localwiki/Arch_CutPlane.html new file mode 100644 index 0000000..2182080 --- /dev/null +++ b/localwiki/Arch_CutPlane.html @@ -0,0 +1,79 @@ +Arch CutPlane

      Arch CutPlane

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Arch CutPlane.png Arch CutPlane

      +
      Menu location +
      Arch → Cut Plane +
      Workbenches +
      Arch +
      Default shortcut +
      None +
      See also +
      Arch Remove +

      + +
      +


      +

      +

      Description

      +

      The Cut Plane tool allows you to cut an Arch object according to a plan: +

      +
      • You can cut an Arch object with the selected face, normal or opposite of the face plan.
      • +
      • This add a substraction component CutVolume to the Arch object
      +

      Arch CutPlane example.jpg +

      In the above image, two Arch Structure are cut with respective plane. +

      +

      How to use

      +
      1. Select the object to be cut, then the face (the face must be the last one you selected, and must be selected in the 3D-View)
      2. +
      3. Press the Arch CutPlane.svg Cut Plane button
      4. +
      5. Choose if the object is cut behind the normale face or front of the normal face
      6. +
      7. Click the Ok button
      +

      Scripting

      +

      The CutPlane tool can by used in macros and from the python console by using the following function: +

      +
      cutComponentwithPlane (archObject,face,faceSide) 
      +
      • archObject is the object to cut
      • +
      • face is the face of an object that come the plan from
      • +
      • faceSide is the side of the face to cut. 0 = Behind, 1 = Front
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Arch_CutPlane.svg b/localwiki/Arch_CutPlane.svg new file mode 100644 index 0000000..eca21b6 --- /dev/null +++ b/localwiki/Arch_CutPlane.svg @@ -0,0 +1,137 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + + [wood galaxy] + + + Arch_CutPlane + 2014-11-11 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Arch/Resources/icons/Arch_CutPlane.svg + + + FreeCAD LGPL2+ + + + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Arch_CutPlane_example.jpg b/localwiki/Arch_CutPlane_example.jpg new file mode 100644 index 0000000..0051fcc Binary files /dev/null and b/localwiki/Arch_CutPlane_example.jpg differ diff --git a/localwiki/Arch_DAE.html b/localwiki/Arch_DAE.html new file mode 100644 index 0000000..0a727ea --- /dev/null +++ b/localwiki/Arch_DAE.html @@ -0,0 +1,23 @@ +Arch DAE

      Arch DAE

      + +

      The Collada (DAE) format is a standard file format for exchange of Mesh data. The Arch Module can import meshes from .dae files, and export Arch and other Shape-based objects to the .dae format. +

      Note that imported objects will be Mesh objects, and will need to be turned into Shapes or Arch objects for optimal use. The Arch Module has several tools to help you in performing that operation. +

      The Collada import functionality in the Arch module depends on pycollada. If it is not installed on your system, Collada import/export will be disabled. +

      +

      Links

      + +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Arch_D_Landscape.svg b/localwiki/Arch_D_Landscape.svg new file mode 100644 index 0000000..4cdd89f --- /dev/null +++ b/localwiki/Arch_D_Landscape.svg @@ -0,0 +1,1475 @@ + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + AUTHOR NAME + CREATION DATE + SUPERVISOR NAME + CHECK DATE + ARCH D + SCALE + WEIGHT + NUMBER + SHEET + TITLE + SUBTITLE + COMPANY NAME + COPYRIGHT + _________ + _________ + _________ + _________ + _________ + _________ + _________ + _________ + _________ + + + + diff --git a/localwiki/Arch_D_Portrait.svg b/localwiki/Arch_D_Portrait.svg new file mode 100644 index 0000000..5b19661 --- /dev/null +++ b/localwiki/Arch_D_Portrait.svg @@ -0,0 +1,1519 @@ + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + AUTHOR NAME + CREATION DATE + SUPERVISOR NAME + CHECK DATE + ARCH D + SCALE + WEIGHT + NUMBER + SHEET + TITLE + SUBTITLE + COMPANY NAME + COPYRIGHT + _________ + _________ + _________ + _________ + _________ + _________ + _________ + _________ + _________ + + + + diff --git a/localwiki/Arch_E1_Landscape.svg b/localwiki/Arch_E1_Landscape.svg new file mode 100644 index 0000000..6d2261b --- /dev/null +++ b/localwiki/Arch_E1_Landscape.svg @@ -0,0 +1,1475 @@ + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + AUTHOR NAME + CREATION DATE + SUPERVISOR NAME + CHECK DATE + Arch E1 + SCALE + WEIGHT + NUMBER + SHEET + TITLE + SUBTITLE + COMPANY NAME + COPYRIGHT + _________ + _________ + _________ + _________ + _________ + _________ + _________ + _________ + _________ + + + + diff --git a/localwiki/Arch_E1_Portrait.svg b/localwiki/Arch_E1_Portrait.svg new file mode 100644 index 0000000..1d123e9 --- /dev/null +++ b/localwiki/Arch_E1_Portrait.svg @@ -0,0 +1,1519 @@ + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + AUTHOR NAME + CREATION DATE + SUPERVISOR NAME + CHECK DATE + Arch E1 + SCALE + WEIGHT + NUMBER + SHEET + TITLE + SUBTITLE + COMPANY NAME + COPYRIGHT + _________ + _________ + _________ + _________ + _________ + _________ + _________ + _________ + _________ + + + + diff --git a/localwiki/Arch_E2_Landscape.svg b/localwiki/Arch_E2_Landscape.svg new file mode 100644 index 0000000..4986e45 --- /dev/null +++ b/localwiki/Arch_E2_Landscape.svg @@ -0,0 +1,1475 @@ + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + AUTHOR NAME + CREATION DATE + SUPERVISOR NAME + CHECK DATE + Arch E2 + SCALE + WEIGHT + NUMBER + SHEET + TITLE + SUBTITLE + COMPANY NAME + COPYRIGHT + _________ + _________ + _________ + _________ + _________ + _________ + _________ + _________ + _________ + + + + diff --git a/localwiki/Arch_E2_Portrait.svg b/localwiki/Arch_E2_Portrait.svg new file mode 100644 index 0000000..1aa1491 --- /dev/null +++ b/localwiki/Arch_E2_Portrait.svg @@ -0,0 +1,1609 @@ + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + AUTHOR NAME + CREATION DATE + SUPERVISOR NAME + CHECK DATE + Arch E2 + SCALE + WEIGHT + NUMBER + SHEET + TITLE + SUBTITLE + COMPANY NAME + COPYRIGHT + _________ + _________ + _________ + _________ + _________ + _________ + _________ + _________ + _________ + + + + diff --git a/localwiki/Arch_E3_Landscape.svg b/localwiki/Arch_E3_Landscape.svg new file mode 100644 index 0000000..23d3b48 --- /dev/null +++ b/localwiki/Arch_E3_Landscape.svg @@ -0,0 +1,1475 @@ + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + AUTHOR NAME + CREATION DATE + SUPERVISOR NAME + CHECK DATE + Arch E3 + SCALE + WEIGHT + NUMBER + SHEET + TITLE + SUBTITLE + COMPANY NAME + COPYRIGHT + _________ + _________ + _________ + _________ + _________ + _________ + _________ + _________ + _________ + + + + diff --git a/localwiki/Arch_E3_Portrait.svg b/localwiki/Arch_E3_Portrait.svg new file mode 100644 index 0000000..6b8d946 --- /dev/null +++ b/localwiki/Arch_E3_Portrait.svg @@ -0,0 +1,1519 @@ + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + AUTHOR NAME + CREATION DATE + SUPERVISOR NAME + CHECK DATE + Arch E3 + SCALE + WEIGHT + NUMBER + SHEET + TITLE + SUBTITLE + COMPANY NAME + COPYRIGHT + _________ + _________ + _________ + _________ + _________ + _________ + _________ + _________ + _________ + + + + diff --git a/localwiki/Arch_E_Landscape.svg b/localwiki/Arch_E_Landscape.svg new file mode 100644 index 0000000..f6770cd --- /dev/null +++ b/localwiki/Arch_E_Landscape.svg @@ -0,0 +1,1392 @@ + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + AUTHOR NAME + CREATION DATE + SUPERVISOR NAME + CHECK DATE + Arch E + SCALE + WEIGHT + NUMBER + SHEET + TITLE + SUBTITLE + COMPANY NAME + COPYRIGHT + _________ + _________ + _________ + _________ + _________ + _________ + _________ + _________ + _________ + + + + diff --git a/localwiki/Arch_E_Portrait.svg b/localwiki/Arch_E_Portrait.svg new file mode 100644 index 0000000..b7e2436 --- /dev/null +++ b/localwiki/Arch_E_Portrait.svg @@ -0,0 +1,1519 @@ + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + AUTHOR NAME + CREATION DATE + SUPERVISOR NAME + CHECK DATE + Arch E + SCALE + WEIGHT + NUMBER + SHEET + TITLE + SUBTITLE + COMPANY NAME + COPYRIGHT + _________ + _________ + _________ + _________ + _________ + _________ + _________ + _________ + _________ + + + + diff --git a/localwiki/Arch_Equipment.html b/localwiki/Arch_Equipment.html new file mode 100644 index 0000000..ff76c35 --- /dev/null +++ b/localwiki/Arch_Equipment.html @@ -0,0 +1,90 @@ +Arch Equipment

      Arch Equipment

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Arch Equipment.png Arch Equipment

      +
      Menu location +
      Arch → Equipment +
      Workbenches +
      Arch +
      Default shortcut +
      E Q +
      See also +
      3 views from mesh +

      + +
      +


      +

      +

      Description

      +

      The Equipment tool offers you a simple and convenient way to insert non-structural, standalone elements such as pieces of furniture, hidro-sanitary equipments or electrical appliances to your projects. Equipments are based on Part shapes, which allow them to benefit from the solidity and possibilities of BRep geometry, and generate nice views when rendered to plan and section views. +

      Arch equipment example.jpg +

      As of version 0.17, equipment objects also have a HiRes property where a Mesh object can be attached. Equipment objects can then be made to display that mesh in the 3D view instead of their shape, which allows to use any high-resolution mesh objects such as detailed pieces of furniture commonly found on websites. +

      Arch equipment mesh.jpg +

      When using the Arch OBJ exporter, all equipments that are in Mesh display mode will be exported as their mesh instead of their shape. +

      +

      How to use

      +
      1. Select a Part shape, and optionally a Mesh object
      2. +
      3. Press the Arch Equipment.png Arch Equipment button, or press E then Q keys
      +

      Options

      +
      • Equipments share the common properties and behaviours of all Arch Components
      +

      Properties

      +
      • DATAModel: A description of the model of this equipment.
      • +
      • DATAUrl: An URL of the product page where more information about this equipment can be found.
      • +
      • DATAMesh: A Mesh representation to use for this equipment. When set, the Mesh display mode becomes available.
      +

      Scripting

      +

      The Equipment tool can by used in macros and from the python console by using the following function: +

      +
      makeEquipment ( baseObject ) 
      +
      • Creates an equipment object from a base object (Mesh or Part)
      • +
      • Returns the new equipment object, or None if the operation failed.
      +

      Example: +

      +
      import Part, Arch
      +box = Part.makeBox(2,2,2)
      +base = FreeCAD.ActiveDocument.addObject("Part::Feature","Box")
      +base.Shape = box
      +Arch.makeEquipment(base) 
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Arch_Equipment.svg b/localwiki/Arch_Equipment.svg new file mode 100644 index 0000000..0fdddef --- /dev/null +++ b/localwiki/Arch_Equipment.svg @@ -0,0 +1,896 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Arch_Equipment_Clone.svg b/localwiki/Arch_Equipment_Clone.svg new file mode 100644 index 0000000..33fdb11 --- /dev/null +++ b/localwiki/Arch_Equipment_Clone.svg @@ -0,0 +1,1132 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [Yorik van Havre] + + + Arch_Equipment_Clone + 2016-09-07 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Arch/Resources/icons/Arch_Equipment_Clone.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Arch_Equipment_Tree.svg b/localwiki/Arch_Equipment_Tree.svg new file mode 100644 index 0000000..bf710c6 --- /dev/null +++ b/localwiki/Arch_Equipment_Tree.svg @@ -0,0 +1,232 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [Yorik van Havre] + + + Arch_Equipment_Tree + 2014-08-29 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Arch/Resources/icons/Arch_Equipment_Tree.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Arch_Fixture.svg b/localwiki/Arch_Fixture.svg new file mode 100644 index 0000000..2014eef --- /dev/null +++ b/localwiki/Arch_Fixture.svg @@ -0,0 +1,111 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [Yorik van Havre] + + + Arch_Fixture + 2013-07-07 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Arch/Resources/icons/Arch_ + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Arch_Floor.html b/localwiki/Arch_Floor.html new file mode 100644 index 0000000..f42ba5c --- /dev/null +++ b/localwiki/Arch_Floor.html @@ -0,0 +1,81 @@ +Arch Floor

      Arch Floor

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Arch Floor.png Arch Floor

      +
      Menu location +
      Arch → Floor +
      Workbenches +
      Arch +
      Default shortcut +
      F L +
      See also +
      Arch Building, Arch Site +

      + +
      +


      +

      +

      Description

      +

      The Arch Floor is a special type of FreeCAD group object that has a couple of additional properties particularly suited for building floors. Particularly, they have a height property, that its children objects (walls and structures) can use to set their own height automatically. They are mostly used to organize your model. +

      +

      How to use

      +
      1. Optionally, select one or more objects to be included in your new floor
      2. +
      3. Press the Arch Floor.png Arch Floor button or press the F then L keys
      +

      Options

      +
      • After creating a floor, you can add more objects to it by drag and dropping them in the Tree View or by using the Arch Add.png Arch Add tool
      • +
      • You can remove objects from a floor by drag and dropping them out of it the Tree View or by using the Arch Remove.png Arch Remove tool
      +

      Properties

      +
      • DATAHeight: The height of the floor, to be used by its child objects
      +

      Scripting

      +

      The Floor tool can by used in macros and from the python console by using the following function: +

      +
      makeFloor ([objectslist]) 
      +

      creates a floor including the objects from the given list. +

      Example: +

      +
      import Arch
      +Arch.makeFloor() 
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Arch_Floor.svg b/localwiki/Arch_Floor.svg new file mode 100644 index 0000000..2094ecf --- /dev/null +++ b/localwiki/Arch_Floor.svg @@ -0,0 +1,120 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [wmayer] + + + Arch_Floor + 2011-10-10 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Arch/Resources/icons/Arch_ + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + diff --git a/localwiki/Arch_Floor_Tree.svg b/localwiki/Arch_Floor_Tree.svg new file mode 100644 index 0000000..05e2013 --- /dev/null +++ b/localwiki/Arch_Floor_Tree.svg @@ -0,0 +1,116 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [yorikvanhavre] + + + Arch_Floor_Tree + 2011-12-06 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Arch/Resources/icons/Arch_ + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + diff --git a/localwiki/Arch_Frame.html b/localwiki/Arch_Frame.html new file mode 100644 index 0000000..e9af41f --- /dev/null +++ b/localwiki/Arch_Frame.html @@ -0,0 +1,92 @@ +Arch Frame

      Arch Frame

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Arch Frame.png Arch Frame

      +
      Menu location +
      Arch → Frame +
      Workbenches +
      Arch +
      Default shortcut +
      F R +
      See also +
      None +

      + +
      +


      +

      +

      Description

      +

      The Frame tool is used to build all kinds of frame objects based on a profile and a layout. The profile is extruded along the edges of the layout, which can be any 2D object such as a sketch, or a draft object. It is especially useful to create railings, or frame walls. Frame objects can then easily be turned into wall or structure objects. +

      Arch Frame example.jpg +

      In the above image, a line has been turned into an array, and a frame object has been made using the array as layout, and a circle as profile. +

      +

      How to use

      +
      1. Create a layout object and a profile object, for example with the Draft Workbench or the Sketcher Workbench
      2. +
      3. Select the layout object first, then, with CTRL pressed, select the profile object
      4. +
      5. Press the Arch Frame.png Arch Frame button, or press F then R keys
      +

      Options

      +
      • Frames share the common properties and behaviours of all Arch Components
      • +
      • The frame object can be placed at a certain distance from the layout object, by setting its Offset property
      • +
      • The profile will be copied at the base of each edge of the layout object, then extruded along it. You can control how the profile is placed at the base of each edge with the Align and Rotation properties.
      +

      Properties

      +
      • DATABase: The layout this frame is based on.
      • +
      • DATAProfile: The profile this frame is based on.
      • +
      • DATAAlign: Specifies if the profile must be rotated to have its normal axis aligned with each edge.
      • +
      • DATAOffset: An optional distance between the layout object and the frame object.
      • +
      • DATARotation: The rotation of the profile around its extrusion axis.
      +

      Scripting

      +

      The Frame tool can by used in macros and from the python console by using the following function: +

      +
      makeFrame ( layout,profile ) 
      +
      • Creates a frame object from a base sketch (or any other object containing wires) and a profile object (an extrudable 2D object containing faces or closed wires)
      • +
      • Returns the new frame object, or None if the operation failed.
      +

      Example: +

      +
      import Draft, Arch
      +layout = Draft.makeLine(FreeCAD.Vector(0,0,0),FreeCAD.Vector(2,0,0))
      +profile = Draft.makeCircle(.2)
      +Arch.makeFrame(layout,profile) 
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Arch_Frame.svg b/localwiki/Arch_Frame.svg new file mode 100644 index 0000000..07cdf70 --- /dev/null +++ b/localwiki/Arch_Frame.svg @@ -0,0 +1,289 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [Yorik van Havre] + + + Arch_Frame + 2013-12-22 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Arch/Resources/icons/Arch_ + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Arch_Frame_Tree.svg b/localwiki/Arch_Frame_Tree.svg new file mode 100644 index 0000000..4a7ea5c --- /dev/null +++ b/localwiki/Arch_Frame_Tree.svg @@ -0,0 +1,319 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [Yorik van Havre] + + + Arch_Frame_Tree + 2013-12-22 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Arch/Resources/icons/Arch_ + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Arch_Git.html b/localwiki/Arch_Git.html new file mode 100644 index 0000000..3863342 --- /dev/null +++ b/localwiki/Arch_Git.html @@ -0,0 +1,144 @@ +Arch Git

      Arch Git

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Arch Git.png Arch Git‏‎

      +
      Menu location +
      Arch → Utilities → Git +
      Workbenches +
      Arch +
      Default shortcut +
      ‏‎ +
      See also +
      +

      + +
      +


      +

      Note: Starting from FreeCAD v0.17, this tool has been removed from the Arch Workbench and is now part of the external Webtools Workbench that you can install via menu Tools -> Addons Manager +

      +

      Description

      +

      This command allows to manage the current document with GIT. GIT is a powerful file version control system, which can manage different versions of files and keep track of the changes. +

      Git is a complex tool, consider learning the basics of it before using this tool, to avoid wrong operations that can cause data loss. An abundant literature about GIT is available and easy to find on the internet. +

      Current limitations: +

      +
      • The tool cannot create new repositories yet. You must have an existing local repository already created (FreeCAD will check if the current document file is inside a Git repository)
      • +
      • The tool cannot change or create branches. You must do that manually with standard Git tools.
      +

      Note: To be able to use this command, the gitpython package must be installed on your system. On most linux distributions, gitpython is available from the standard software repositories as gitpython or python-git. +

      +

      How to use

      +
      1. Save the current active document
      2. +
      3. Make sure the saved file is inside an existing git repository
      4. +
      5. Select menu Arch -> Utilities -> Arch CommitGit.png Git
      +

      Options

      +
      Arch Git panel.jpg
      +
      • Make sure the Report Window is open since Git messages will be printed there.
      • +
      • The Git tool will only open if the current file is saved inside a Git repository. It can be in a subdirectory.
      • +
      • The Log button will pop up a dialog showing the most recent log entries.
      • +
      • The Refresh button will re-scan the repository for changed files.
      • +
      • The Diff button will show the differences between the current version of a selected file and the previous version stored in the repository.
      • +
      • The Select all button will select all files to be committed.
      • +
      • The Commit button will commit the selected files. Be sure to write a commit message that describes the changes you are committing.
      • +
      • The Pull button will download any new changes to the repository from the selected remote. If the file currently opened in FreeCAD is being modified by a pull, a warning message will inform you so you can either save the file again or save it elsewhere.
      • +
      • The Push button will upload your latest commit(s) to the selected remote.
      +

      Enabling human-readable diff for FCStd files

      +

      FreeCAD's Fcstd file format is a zip-based binary format, for which Git cannot produce proper diffs. This means that you cannot see what has changed between one version and another, and also that each new version stored in the Git repository is a full copy of the file. +

      Although the second problem currently has no solution, the first one can be solved with a little tool available from the FreeCAD source code, called fcinfo. Git can be told to use the fcinfo utility to print a human-friendly report of a FCStd file, and, when asked to produce a diff between two FCStd files, will produce a diff between the two fcinfo reports instead. Please note that this is only visual feedback, a full copy of the file will still be stored internally. +

      Example of a diff produced with fcinfo: +

      +
      diff --git a/testhouse.FcStd b/testhouse.FcStd
      +index 08077b6..985b1d8 100644
      +--- a/testhouse.FcStd
      ++++ b/testhouse.FcStd
      +@@ -1,26 +1,25 @@
      +-Document: /tmp/43un09_testhouse.FcStd (442K)
      +-   SHA1: 67c1985a45d93cba57d5bf44490897aba460100d
      ++Document: /tmp/zfXoDd_testhouse.FcStd (370K)
      ++   SHA1: db1cb5fca18af7bfdca849028f40550df4d845cb
      +    Comment : This is a test house to showcase FreeCAD's BIM worflow and IFC export capabilities
      +    Company : uncreated.net
      +    CreatedBy : Yorik van Havre
      +    CreationDate : Fri May  9 12:05:54 2014 
      +    FileVersion : 1
      +    Id : 
      +-   Label : testhouse
      +-   LastModifiedBy : Yorik van Havre
      +-   LastModifiedDate : 2016-06-28T17:05:57-03:00
      ++   Label : testhouse2
      ++   LastModifiedBy : Yorik van Havre
      ++   LastModifiedDate : Sat Sep 13 20:46:36 2014
      ++
      +    License : CC-BY 3.0
      +    LicenseURL : http://creativecommons.org/licenses/by/3.0/
      +-   ProgramVersion : 0.17R7800 (Git)
      +-   TipName : 
      ++   ProgramVersion : 0.15R3989 (Git)
      +    Uid : 67e62d8a-6674-4358-92fe-615443be887a
      +-   Objects: (231)
      ++   Objects: (221)
      +        Annotation : Drawing::FeatureViewAnnotation
      +        Annotation001 : Drawing::FeatureViewAnnotation
      +        Annotation002 : Drawing::FeatureViewAnnotation
      +        Annotation003 : Drawing::FeatureViewAnnotation
      +-       Annotation004 : Drawing::FeatureViewAnnotation
      +-       Annotation005 : Drawing::FeatureViewAnnotation
      +        Array : Part::FeaturePython (9K)
      +        Box : Part::Box (2K)
      +        Building : App::DocumentObjectGroupPython
      +@@ -110,7 +109,7 @@ Document: /tmp/43un09_testhouse.FcStd (442K)
      +        Floor : App::DocumentObjectGroupPython
      +        Floor001 : App::DocumentObjectGroupPython
      +        Floor002 : App::DocumentObjectGroupPython
      +-       Frame : Part::FeaturePython (89K) 
      +

      Each FreeCAD file contains a SHA1 checksum number, which will change each time the file is saved, even if no contents was changed. So fcinfo will always print something, no matter of the contents changes. +

      To enable the use of fcinfo (Linux and Mac only - TODO: add Windows instructions) +

      +
      1. Save the fcinfo file somewhere in your system path
      2. +
      3. Make it executalbe
      4. +
      5. Create a .gitattributes file in your Git repository
      6. +
      7. Add the following line in it:
      +
      *.FCStd diff=fcinfo
      +
      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Arch_Git_panel.jpg b/localwiki/Arch_Git_panel.jpg new file mode 100644 index 0000000..dc1a4c9 Binary files /dev/null and b/localwiki/Arch_Git_panel.jpg differ diff --git a/localwiki/Arch_Grid.html b/localwiki/Arch_Grid.html new file mode 100644 index 0000000..17cb9d5 --- /dev/null +++ b/localwiki/Arch_Grid.html @@ -0,0 +1,94 @@ +Arch Grid

      Arch Grid

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Arch Grid.png Arch Grid

      +
      Menu location +
      Arch → Axis tools → Grid +
      Workbenches +
      Arch +
      Default shortcut +
      None +
      See also +
      Axis +

      + +
      +


      +

      +

      Description

      +

      The Grid tool allows you to place a grid-like object in the document. This object is meant to serve as a base to build Arch objects that need a regular but complex frame, such as windows, curtain walls, column grids, railings, etc. The Grid object is editable like a spreadsheet, where you can add or remove columns and rows, define their size, and merge cells. +

      The Grid is a 2D object, and can therefore be used anywhere a 2D shape such as a Draft or Sketch is needed, but it can also behave as a Arch AxisSystem, and be used to propagate the placement of other Arch objects. +

      Arch Grid example.jpg +

      The image above shows a grid of columns, a railing system and a window, each based on a Grid object. +

      +

      How to use

      +
      1. Press the Arch Grid.png Arch Grid button
      2. +
      3. Set the Width and Height of the grid in the properties
      4. +
      5. Enter edit mode by double-clicking the grid object in the tree view
      6. +
      7. Add rows and columns
      8. +
      9. Set the desired width and height of rows and columns by double-clicking the row or column headers
      +

      Options

      +
      • A column width or row height of 0 means its size will be adapted automatically to fit the total width/height of the grid
      • +
      • Cells can be merged and unmerged by selecting them and clicking the appropriate button
      • +
      • When used as the Axis property of other Arch objects, the grid will drive the positioning of these objects. The Points Output property defines how the other objects are placed on the grid: At vertices, edge midpoints or face centers
      • +
      • By setting the Auto Height or Auto Width properties to a non-zero value, the total number of rows/columns and their individual heights/widths is ignored. Instead, the maximum number of columns or rows of the given auto width/height get automatically created
      +

      Properties

      +
      • DATARows: The number of rows
      • +
      • DATAColumns: The number of columns
      • +
      • DATARow Size: The sizes for rows
      • +
      • DATAColumn Size: The sizes of columns
      • +
      • DATAPoints Output: The type of 3D points produced by this grid object
      • +
      • DATAWidth: The total width of this grid
      • +
      • DATAHeight: The total height of this grid
      • +
      • DATAAuto Width: Creates automatic column divisions (set to 0 to disable)
      • +
      • DATAAuto Height: Creates automatic row divisions (set to 0 to disable)
      • +
      • DATAReorient: When in edge midpoint mode, if this grid must reorient its children along edge normals or not
      • +
      • DATAHidden Faces: The indices of faces to hide
      +

      Scripting

      +

      The Grid tool can by used in macros and from the python console by using the following function: +

      +
      makeGrid() 
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Arch_Grid.svg b/localwiki/Arch_Grid.svg new file mode 100644 index 0000000..f613440 --- /dev/null +++ b/localwiki/Arch_Grid.svg @@ -0,0 +1,410 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [yorikvanhavre] + + + Arch_Axis + 2011-12-12 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Arch/Resources/icons/Arch_Axis.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Arch_IFC.html b/localwiki/Arch_IFC.html new file mode 100644 index 0000000..517ca53 --- /dev/null +++ b/localwiki/Arch_IFC.html @@ -0,0 +1,35 @@ +Arch IFC

      Arch IFC

      + +

      The Arch Workbench features an Industry Foundation Classes (IFC) importer. The IFC format is a more and more widely spread format to interchange data between BIM applications, used in architecture and engineering. +

      The importer is still a work in progress, and depends on an external piece of open-source software, called IfcOpenShell, which is not bundled with FreeCAD and must be installed on your system. If IfcOpenShell is correctly installed, it will be detected by FreeCAD and used to import IFC files. It is still possible to force the use of the old python IFC importer, which doesn't depend on IfcOpenShell, by enabling the related option in the Arch preferences settings. But this importer has been discontinued and will only be able to import a small subset of IFC objects. +

      The use of IfcOpenShell is highly recommended, since it is much faster and more powerful than the internal parser. IfcOpenShell supports all IFC2x3 and IFC4 entities that carry geometry information, not all of them can be converted to Arch objects, those that can't will be imported as simple Part shapes. +

      +

      Importing

      +

      All IfcProduct-based entities from IFC2x3 or IFC4 files will be imported into the FreeCAD document. The IFC preferences settings allow you to set how the IFC objects are imported: as full parametric Arch objects, as non-parametric Arch objects, as non-parametric Part shapes, or as one Part shape per floor. Each of these types looses some information over the previous one, but is lighter on resources, which allows to open bigger files. A last type allows to discard entirely the importing of Arch objects, which is useful for structural analytic models. +

      If parametric Arch objects are used, for all IFC types that have an equivalent in the Arch Module, the corresponding type is used. For the others, a generic Part shape is created. All Arch objects, parametric and non-parametric, will carry the full set of IfcProperties attached to each object. +

      IfcAnnotation objects are also imported, as well as linear and curve-based IfcStructuralItem-based entities. +

      Enabling the show debug messages in the IFC preferences settings will print a report indicating if any object from the IFC file failed to import. +

      +

      Exporting

      +

      Exporting to IFC files will export all the selected objects and their descendants. To export a whole building or a whole floor, it is only needed to select the building or floor object. Arch objects will be exported with the type set in their "Role" property. Their IfcProperties are exported as well, and if these objects have an IFC UID from a previous import, the same UID will be kept at export. Objects that are not Arch objects are exported as IfcBuildingElementPRoxy. +

      IFC files are exported as IFC2x3 or IFC4 depending on your version of IfcOpenShell, which can be compiled with any of the IFC schemas. +

      If the shape of exported objects is based on an extrusion or a boolean operation, the operation and components will be correctly exported to IFC. If not, the object's shape is exported as IfcFacetedBrep. If the shape contains curves, these will be faceted. +

      +

      Links

      +

      Tutorial Import/Export IFC - compiling IfcOpenShell +

      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Arch_IfcExplorer.html b/localwiki/Arch_IfcExplorer.html new file mode 100644 index 0000000..b16330a --- /dev/null +++ b/localwiki/Arch_IfcExplorer.html @@ -0,0 +1,63 @@ +Arch IfcExplorer

      Arch IfcExplorer

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Arch IfcExplorer.png Arch IfcExplorer

      +
      Menu location +
      Arch → Utilities → Ifc Explorer +
      Workbenches +
      Arch +
      Default shortcut +
      None +
      See also +
      Arch IFC +

      + +
      +


      +

      +

      Description

      +

      The IFC explorer is a simple utility to explore the contents of an IFC file. IFC files are text files, and are therefore readable in a text editor, but the information is condensed and hard to browse. This utility presents you the exact same content, but displayed in an easier way. +

      Arch IfcExplorer example.jpg +

      The purpose of this explorer is simply to allow you to check what is really written in an IFC file, in case you want to verify if the contents were correctly imported or exported to / from an IFC-aware application such as FreeCAD. +


      +

      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Arch_JSON.html b/localwiki/Arch_JSON.html new file mode 100644 index 0000000..49226bf --- /dev/null +++ b/localwiki/Arch_JSON.html @@ -0,0 +1,38 @@ +Arch JSON

      Arch JSON

      + +

      The main purpose of this export format is to make it easier to process FreeCAD model data from programming languages. The JSON format is as follows: +

      +
       {
      +   "version": "0.0.1",
      +   "description": "Mesh data exported from FreeCAD",
      +   "objects": [
      +     {
      +       "name": "<object name>",
      +       "description": "<object description>",
      +       "color": "<object color>",
      +       "wires": [[[<float>, <float>, <float>], . . .], . . .],
      +       "vertices": [[<float>, <float>, <float>], . . .],
      +       "normals": [[<float>, <float>, <float>], . . .],
      +       "facets": [[<int>, <int>, <int>], . . .]
      +     }, . . .
      +   ]
      + }
      +
      +

      Note that facets form triangles and their integer values reference points in the vertices array. Facet normals are found at the corresponding position in the normals array. description, color and wires are all optional. This format could easily be expanded to include additional model data. +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Arch_MakeIfcSpreadsheet.html b/localwiki/Arch_MakeIfcSpreadsheet.html new file mode 100644 index 0000000..2c0caf1 --- /dev/null +++ b/localwiki/Arch_MakeIfcSpreadsheet.html @@ -0,0 +1,62 @@ +Arch MakeIfcSpreadsheet

      Arch MakeIfcSpreadsheet

      + +
      +

      This documentation is not finished. Please help and contribute documentation. +

      See Draft ShapeString for good documented Command. Gui Command gives an overview over commands. And see List of Commands for other commands. +

      Go to Help FreeCAD to contribute. +

      +
      + + + + + + + + + + + + + + + + + + + + +
      +

      Official icon not found Arch_MakeIfcSpreadsheet

      +
      Menu location +
      Arch → Utilities → Create schedule... +
      Workbenches +
      Arch +
      Default shortcut +
      +
      See also +
      None +

      + +
      +


      +

      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Arch_Material.svg b/localwiki/Arch_Material.svg new file mode 100644 index 0000000..a2937db --- /dev/null +++ b/localwiki/Arch_Material.svg @@ -0,0 +1,128 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [Yorik van Havre] + + + Arch_Material + 2015-04-15 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Arch/Resources/icons/Arch_Material.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + diff --git a/localwiki/Arch_Material_Group.svg b/localwiki/Arch_Material_Group.svg new file mode 100644 index 0000000..4a6bb9b --- /dev/null +++ b/localwiki/Arch_Material_Group.svg @@ -0,0 +1,185 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [Yorik van Havre] + + + Arch_Material_Group + 2015-04-19 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Arch/Resources/icons/Arch_Material_Group.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Arch_Material_Multi.svg b/localwiki/Arch_Material_Multi.svg new file mode 100644 index 0000000..d368454 --- /dev/null +++ b/localwiki/Arch_Material_Multi.svg @@ -0,0 +1,857 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [Yorik van Havre] + + + Arch_Material_Group + 2015-04-19 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Arch/Resources/icons/Arch_Material_Group.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Arch_MergeWalls.html b/localwiki/Arch_MergeWalls.html new file mode 100644 index 0000000..bfbb322 --- /dev/null +++ b/localwiki/Arch_MergeWalls.html @@ -0,0 +1,67 @@ +Arch MergeWalls

      Arch MergeWalls

      + +
      +

      This documentation is not finished. Please help and contribute documentation. +

      See Draft ShapeString for good documented Command. Gui Command gives an overview over commands. And see List of Commands for other commands. +

      Go to Help FreeCAD to contribute. +

      +
      + + + + + + + + + + + + + + + + + + + + +
      +

      Arch MergeWalls.png Arch MergeWalls

      +
      Menu location +
      Arch → Utilities → Merge Walls +
      Workbenches +
      Arch +
      Default shortcut +
      +
      See also +
      +

      + +
      +


      +

      +

      Description

      +

      How to use

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Arch_MergeWalls.svg b/localwiki/Arch_MergeWalls.svg new file mode 100644 index 0000000..a4e6447 --- /dev/null +++ b/localwiki/Arch_MergeWalls.svg @@ -0,0 +1,116 @@ + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [Yorik van Havre] + + + Arch_MergeWalls + 2013-03-24 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Arch/Resources/icons/Arch_MergeWalls.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Arch_MeshToShape.html b/localwiki/Arch_MeshToShape.html new file mode 100644 index 0000000..39e3597 --- /dev/null +++ b/localwiki/Arch_MeshToShape.html @@ -0,0 +1,73 @@ +Arch MeshToShape

      Arch MeshToShape

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Arch MeshToShape.png Arch MeshToShape

      +
      Menu location +
      Arch → Utilities → Mesh to Shape +
      Workbenches +
      Arch +
      Default shortcut +
      None +
      See also +
      Arch RemoveShape +

      + +
      +


      +

      +

      Description

      +

      This tool converts a selected Mesh object into a Shape object. Note that this tool is optimized for objects with flat faces (no curves). The corresponding tool from the Part Workbench might be more suited for objects that contain curved surfaces. +

      +

      How to use

      +
      1. Select a mesh object
      2. +
      3. Press the Arch MeshToShape.png Mesh to Shape entry in Arch → Utilities menu
      +

      Scripting

      +

      This tool can by used in macros and from the python console by using the following function: +

      +
      meshToShape (object,[mark]) 
      +

      turns a mesh into a shape, joining coplanar facets. +

      If mark is True (default), non-solid objects will be marked in red +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Arch_MeshToShape.svg b/localwiki/Arch_MeshToShape.svg new file mode 100644 index 0000000..a6f2ed5 --- /dev/null +++ b/localwiki/Arch_MeshToShape.svg @@ -0,0 +1,121 @@ + + + + Mesh_Mesh_from_Shape + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + Mesh_Mesh_from_Shape + + Solid cube with arrow pointing towards a tesselated cube mesh + + + [agryson] Alexander Gryson, [agryson] Alexander Gryson + + + + + cube + mesh + solid + convert + + + http://www.freecadweb.org/wiki/index.php?title=Artwork + FreeCAD/src/Mod/Mesh/Gui/Resources/icons/Mesh_Mesh_from_Shape.svg + + + FreeCAD LGPL2+ + + + + + FreeCAD + + + Sat Dec 14 00:58:58 2013 +1100 + + + [jmaustpc] + + + https://www.gnu.org/copyleft/lesser.html + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Arch_Module.html b/localwiki/Arch_Module.html new file mode 100644 index 0000000..7925222 --- /dev/null +++ b/localwiki/Arch_Module.html @@ -0,0 +1,123 @@ +Arch Module

      Arch Module

      + +

      The Arch workbench provides modern BIM workflow to FreeCAD, with support for features like IFC support, fully parametric architectural entities such as walls, structural elements or windows, and rich 2D document production. The Arch workbench also feature all the tools from the Draft Workbench. +

      Note: The BIM functionality of FreeCAD is now progressively split into this Arch Workbench, which holds all the base BIM tools, and the BIM Workbench addon, that you can install via menu Tools->Addon Manager, that adds a new interface layer on top of the Arch tools, with the aim to make BIM workflow in FreeCAD more intuitive and user-friendly. +

      Screenshot arch window.jpg +

      + + +

      Tools

      +

      These are tools for creating architectural objects. +

      +
      • Arch Wall.png Wall: Creates a wall from scratch or using a selected object as a base
      • +
      • Arch Structure.png Structural element: Creates a structural element from scratch or using a selected object as a base
      +
      • Rebar tools +
        • Arch Rebar Straight.png Straight Rebar: Creates a Straight reinforcement bar in a selected structural element
        • +
        • Arch Rebar UShape.png UShape Rebar: Creates a UShape reinforcement bar in a selected structural element
        • +
        • Arch Rebar LShape.png LShape Rebar: Creates a LShape reinforcement bar in a selected structural element
        • +
        • Arch Rebar BentShape.png Bent Shape Rebar: Creates a Bent Shape reinforcement bar in a selected structural element
        • +
        • Arch Rebar Stirrup.png Stirrup Rebar: Creates a Stirrup reinforcement bar in a selected structural element
        • +
        • Arch Rebar Helical.png Helical Rebar: Creates a Helical reinforcement bar in a selected structural element
        • +
        • Arch Rebar.png Rebar: Creates a custom reinforcement bar in a selected structural element using a sketch
      +
      • Arch Floor.png Floor: Creates a floor including selected objects
      • +
      • Arch Building.png Building: Creates a building including selected objects
      • +
      • Arch Site.png Site: Creates a site including selected objects
      • +
      • Arch Window.png Window: Creates a window using a selected object as a base
      • +
      • Arch SectionPlane.png Section Plane: Adds a section plane object to the document
      +
      • Axis tools +
        • Arch Axis.png Axis: Adds a 1-direction array of axes to the document
        • +
        • Arch AxisSystem.png Axes system: Adds an axes system composed of several axes to the document
        • +
        • Arch Grid.png Grid: Adds a grid-like object to the document
      +
      • Arch Roof.png Roof: Creates a sloped roof from a selected face
      • +
      • Arch Space.png Space: Creates a space object in the document
      • +
      • Arch Stairs.png Stairs: Creates a stairs object in the document
      + + + +


      +

      +
      • Arch Frame.png Frame: Creates a frame object from a selected layout
      • +
      • Arch Equipment.png Equipment: Creates an equipment or furniture object
      + + + +


      +

      + +
      • Arch Schedule.png Schedule: Creates different types of schedules
      +

      Modification tools

      +

      These are tools for modifying architectural objects. +

      + +

      Utilities

      +

      These are additional tools to help you in specific tasks. +

      + +

      Preferences

      + +

      File formats

      +
      • IFC : Industry foundation Classes
      • +
      • DAE : Collada mesh format
      • +
      • OBJ : Obj mesh format (export only)
      • +
      • JSON : JavaScript Object Notation format (export only)
      • +
      • 3DS : 3DS format (import only)
      +

      API

      +

      The Arch module can be used in python scripts and macros using the Arch Python API functions. +

      +

      Tutorials

      + + +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Arch_MultiMaterial.html b/localwiki/Arch_MultiMaterial.html new file mode 100644 index 0000000..0f77741 --- /dev/null +++ b/localwiki/Arch_MultiMaterial.html @@ -0,0 +1,85 @@ +Arch MultiMaterial

      Arch MultiMaterial

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Arch MultiMaterial.png Arch MultiMaterial

      +
      Menu location +
      Arch → Multi-Material +
      Workbenches +
      Arch +
      Default shortcut +
      None +
      See also +
      None +

      + +
      +


      +

      +

      Description

      +

      The Multi-Material tool defines a list of materials with, for each material, a name and a thickness value. This multi-materials list can then be added to an Arch object instead of a single Arch Material . +

      Arch multimaterial example.png +

      Not all Arch objects can currently make use of multi-materials, and the use they do of it differs. Currently: +

      +
      • Walls with a MultiMaterial will use the material definitions and thicknesses to create a multi-layer wall
      • +
      • Windows with a MultiMaterial will attribute materials with a given name defined inside the MultiMaterial to window components with a same name or type (see below). Material thickness is not considered.
      • +
      • Panels with a MultiMaterial will use the material definitions and thicknesses to create a multi-layer panel
      +

      How to use

      +
      1. Create first a series of Arch Materials that you will need in your Multi-Material
      2. +
      3. Optionally, select an Arch object you wish to attribute the new Multi-Material to
      4. +
      5. Press the Arch MultiMaterial.png Multi-Material button
      6. +
      7. Set the desired material layers
      +

      Options

      +

      Arch multimaterial panel.png +

      Upon creating or editing a multi-material by double-clicking it in the tree, the following options are available: +

      +
      • Duplicate another existing Multi-Material from the same document. This only copies the values over, and doesn't link the two multi-materials in any way.
      • +
      • The Name field will also set the material object's Label
      • +
      • The Composition list is the list of the different material layers that compose this multi-material. Each layer has a name, a material and a thickness value.
      • +
      • Click Add to add a new layer, Up to move a selected layer up, Down to move a selected layer down, or Del to delete a selected layer.
      • +
      • Double-click the name of a layer to edit it, the material will offer you a drop-down list of available Arch Materials in the same document, and thickness can be set to any value in any unit
      • +
      • Name and Material fields are mandatory. Thickness can be left blank (it will then adopt a value of 0).
      • +
      • When a multi-material contains layers with a thickness of zero, that thickness is considered variable. Arch objects that use the multi-material, such as Walls and Panels, will treat that accordingly, and give that layer the remaining space available given their own width or thickness.
      • +
      • If you name the different components of a multi-material "Frame", "Solid panel", "Glass panel" or "Louvre", and apply that material to a window, the given materials will be applied to the corresponding window components.
      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Arch_Nest.html b/localwiki/Arch_Nest.html new file mode 100644 index 0000000..7dc6d9c --- /dev/null +++ b/localwiki/Arch_Nest.html @@ -0,0 +1,84 @@ +Arch Nest

      Arch Nest

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Arch Nest.png Arch Nest

      +
      Menu location +
      Arch → Panel tools → Nest +
      Workbenches +
      Arch +
      Default shortcut +
      None +
      See also +
      None +

      + +
      +


      +

      +

      Description

      +

      The Nest tool allows to select a flat shape to be a container, and a series of other flat shapes to be organized inside the space defined by the container shape. This is typically needed for CNC operations, where you want to cut a series of pieces out of a base panel, and need to organize those pieces in the best possible compact way so they occupy less space on the panel. +

      The algorithm behind the Nest tool is in constant evolution, and is currently not fully optimized. In the future the performance of this tool should become much better. +

      Arch Nest example.jpg +

      The image above shows a series of shapes before and after the nesting operation +

      +

      How to use

      +

      Arch Nest panel.jpg +

      +
      1. Press the Arch Nest.png Arch Nest button
      2. +
      3. Select an object to be the container. This object must be flat, and, at the moment, rectangular
      4. +
      5. Click the "Pick container" button to use that object as the container
      6. +
      7. Select a series of other flat objects that you wish to place inside the container. These objects must all be flat and in the same plane as the container.
      8. +
      9. Adjust desired options below
      10. +
      11. Start the calculation process
      12. +
      13. At the end of the calculation, click the Preview button to create a temporary preview of the result.
      14. +
      15. If you wish to apply the result (move and rotate the actual shapes into place), click OK.
      +

      Notes

      +
      • All objects must have a face
      • +
      • At the moment the tool will only work with flat objects that all have the same orientation.
      • +
      • At the moment, the container must be rectangular.
      • +
      • At the moment, margin / spacing between the pieces is not implemented yet
      • +
      • The calculation can take a lot of time with many objects. That will be optimized in the future
      +


      +

      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Arch_Nest.svg b/localwiki/Arch_Nest.svg new file mode 100644 index 0000000..927c49e --- /dev/null +++ b/localwiki/Arch_Nest.svg @@ -0,0 +1,680 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [Yorik van Havre] + + + Arch_Panel_Sheet + 2016-12-17 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Arch/Resources/icons/Arch_Panel_Sheet.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + diff --git a/localwiki/Arch_OBJ.html b/localwiki/Arch_OBJ.html new file mode 100644 index 0000000..41f8478 --- /dev/null +++ b/localwiki/Arch_OBJ.html @@ -0,0 +1,22 @@ +Arch OBJ

      Arch OBJ

      + +

      Additionally to the standard FreeCAD OBJ exporter, the Arch Module features an alternative exporter that exports coplanar faces as whole OBJ faces, instead of triangulating Shape-based objects, like the standard exporter does. +

      +

      Tutorials

      + +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Arch_Panel.html b/localwiki/Arch_Panel.html new file mode 100644 index 0000000..57974e2 --- /dev/null +++ b/localwiki/Arch_Panel.html @@ -0,0 +1,107 @@ +Arch Panel

      Arch Panel

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Arch Panel.png Arch Panel

      +
      Menu location +
      Arch → Panel Tools → Panel +
      Workbenches +
      Arch +
      Default shortcut +
      P,A +
      See also +
      Arch Panel Cut, Arch Panel Sheet +

      + +
      +


      +

      +

      Description

      +

      This tool allows you to build all kinds of panel-like elements, typically for panel constructions like the WikiHouse project, but also for all kinds of objects that are based on a flat profile. +

      Arch Panel example.jpg +

      The above image shows a series of panel objects, simply made from imported 2D contours from a DXF file. They can then be rotated and assembled to create structures. +

      Since version 0.17, the Arch Panel can also be used to create corrugated or trapezoidal profiles: +

      Arch panel wave.jpg +


      +

      +

      How to use

      +
      1. Select a 2D shape (draft object, face or sketch) - optional
      2. +
      3. Press the Arch Panel.png Arch Panel button, or press P then A keys
      4. +
      5. Adjust the desired properties
      +

      Options

      +
      • Panels share the common properties and behaviours of all Arch Components
      • +
      • The thickness of a panel can be adjusted after creation
      • +
      • Press ESC or the Cancel button to abort the current command.
      • +
      • Double-clicking on the panel in the tree view after it is created allows you to enter edit mode and access and modify its additions and subtractions
      • +
      • It is possible to automatically make panels composed of more than one sheet of a material, by raising its Sheets property.
      • +
      • Panels can make use of Multi-Materials. When using a multi-material, the panel will become multi-layer, using the thicknesses specified by the multi-material. Any layer with a thickness of zero will have its thickness defined automatically by the remaining space defined by the Panel's own Thickness value, after subtracting the other layers.
      +

      Properties

      +
      • DATALength: The length of the panel
      • +
      • DATAWidth: The width of the panel
      • +
      • DATAThickness: The thickness of the panel
      • +
      • DATAArea: The area of the panel (automatic)
      • +
      • DATASheets: The number of sheets of material the panel is made of
      • +
      • DATAWave Length: The length of the wave for corrugated panels
      • +
      • DATAWave Height: The height of the wave for corrugated panels
      • +
      • DATAWave Type: The type of the wave for corrugated panels, curved, trapezoidal or spiked
      • +
      • DATAWave Direction: The orientation of the waves for corrugated panels
      • +
      • DATABottom Wave: If the bottom wave of the panel is flat or not
      +

      Scripting

      +

      The Panel tool can by used in macros and from the python console by using the following function: +

      +
      makePanel ([obj],[length],[width],[thickness],[name]) 
      +

      Example: +

      +
      import Arch,Draft
      +base = Draft.makeRectangle(500,200)
      +Arch.makePanel(base,thickness=36) 
      +

      Tutorials

      + +

      Limitations

      +
      • There is currently no automatic system to produce 2D cutting sheets from panel objects, but such feature is in the plans and will be added in the future.
      • +
      • This tool is not available in FreeCAD versions prior to 0.15
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Arch_Panel.svg b/localwiki/Arch_Panel.svg new file mode 100644 index 0000000..a816858 --- /dev/null +++ b/localwiki/Arch_Panel.svg @@ -0,0 +1,68 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [Yorik van Havre] + + + Arch_Panel + 2014-04-07 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Arch/Resources/icons/Arch_Panel.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + diff --git a/localwiki/Arch_Panel_Clone.svg b/localwiki/Arch_Panel_Clone.svg new file mode 100644 index 0000000..74fb563 --- /dev/null +++ b/localwiki/Arch_Panel_Clone.svg @@ -0,0 +1,572 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [Yorik van Havre] + + + Arch_Panel_Clone + 2016-12-03 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Arch/Resources/icons/Arch_Panel_Clone.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Arch_Panel_Cut.html b/localwiki/Arch_Panel_Cut.html new file mode 100644 index 0000000..11db5cd --- /dev/null +++ b/localwiki/Arch_Panel_Cut.html @@ -0,0 +1,98 @@ +Arch Panel Cut

      Arch Panel Cut

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Arch Panel Cut.png Arch Panel Cut

      +
      Menu location +
      Arch → Panel Tools → Panel Cut +
      Workbenches +
      Arch +
      Default shortcut +
      P,C +
      See also +
      Arch Panel +

      + +
      +


      +

      +

      Description

      +

      This tool creates, in the 3D document, a flat, 2D view of an Arch Panel, to be included in an Arch Panel Sheet or directly exported to DXF. +

      Arch Wikihouse 02.jpg +

      +

      How to use

      +
      1. Select one or more Arch Panel objects
      2. +
      3. Press the Arch Panel Cut.png Arch Panel Cut button, or press P then C keys
      4. +
      5. Adjust the desired properties
      +

      Options

      +
      • If the panel is not flat (corrugated, for example), the relief won't appear in the Panel cut. This tool is useful mainly for flat panels
      • +
      • The panel cut can display a tag. This tag can be a custom line of text or can automatically show the Tag, Label or Description of its linked Panel.
      • +
      • To be useful for CNC machining, the tag should be written using a sticky font, where letters are simple polylines that are easy for the machine to follow. Upon creation, the Panel Cut object will automatically use the font specified in Edit → Preferences → Draft → Texts and Dimensions → ShapeString Font
      • +
      • Double-clicking on the panel cut in the tree view after it is created allows you to enter edit mode and modify the position of the tag
      • +
      • When you need to layout different Panel Cuts together, Panel Cuts can display a margin, that is useful to make sure a certain space is always present between a cut and another
      +

      Properties

      +
      • DATASource: The Arch Panel object shown by this Cut
      • +
      • DATATag Text: The text to display. Can be %tag%, %label% or %description% to display the panel tag or label
      • +
      • DATATag Size: The size of the tag text
      • +
      • DATATag Position: The position of the tag text. Keep (0,0,0) for automatic center position
      • +
      • DATATag Rotation: The rotation of the tag text
      • +
      • DATAFont File: The font of the tag text
      • +
      • VIEWMargin: A margin that can be displayed outside the panel cut shape
      • +
      • VIEWShow Margin: Turns the display of the margin on/off
      • +
      • DATAMake Face: If True, the panel is a Part Face, otherwise a Part Wire
      +

      Scripting

      +

      The Panel tool can by used in macros and from the python console by using the following function: +

      +
      makePanelCut (object) 
      +

      Example: +

      +
      import Arch,Draft
      +base = Draft.makeRectangle(500,200)
      +panel = Arch.makePanel(base,thickness=36)
      +Arch.makePanelCut(panel) 
      +

      Tutorials

      + +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Arch_Panel_Cut.svg b/localwiki/Arch_Panel_Cut.svg new file mode 100644 index 0000000..8978429 --- /dev/null +++ b/localwiki/Arch_Panel_Cut.svg @@ -0,0 +1,70 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [Yorik van Havre] + + + Arch_Panel_Cut + 2016-12-17 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Arch/Resources/icons/Arch_Panel_Cut.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + diff --git a/localwiki/Arch_Panel_Sheet.html b/localwiki/Arch_Panel_Sheet.html new file mode 100644 index 0000000..6f4c05f --- /dev/null +++ b/localwiki/Arch_Panel_Sheet.html @@ -0,0 +1,105 @@ +Arch Panel Sheet

      Arch Panel Sheet

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Arch Panel Sheet.png Arch Panel Sheet

      +
      Menu location +
      Arch → Panel tools → Panel Sheet +
      Workbenches +
      Arch +
      Default shortcut +
      P,S +
      See also +
      Arch Panel +

      + +
      +


      +

      +

      Description

      +

      This tool allows to build a 2D sheet, including any number of Arch Panel Cut objects, or any other 2D object such as those made by the Draft Workbench and Sketcher Workbench. The Panel Sheet is typically made to layout cuts to be made by a CNC machine. These sheets can then be exported to a DXF file. +

      Arch Wikihouse 03.jpg +

      Arch Wikihouse 04.jpg +

      The above image shows how Panel Sheets appear when exported to DXF. +

      +

      How to use

      +
      1. Optionally, select one or more Arch Panel Cut objects or any other 2D object that lies on the XY plane
      2. +
      3. Press the Arch Panel Sheet.png Arch Panel Sheet button, or press P then S keys
      4. +
      5. Adjust the desired properties
      +

      Options

      +
      • After the panel sheet is created, with or without child objects, Any other child object can be added/removed to/from the panel sheet by double-clicking it in the tree view and adding or removing objects from its Group folder
      • +
      • Double-clicking on the panel in the tree view also allows you to move the objects contained in this sheet, or move its tag
      • +
      • It is possible to automatically make panels composed of more than one sheet of a material, by raising its Sheets property
      • +
      • Panel Sheets can display a margin, that is useful to make sure a certain space is always present between inner objects and the border of the sheet
      • +
      • When Panel sheets are exported to DXF, the outlines, inner holes, tags of their inner children are placed on different layers, as shown on the above image
      +

      Properties

      +
      • DATAHeight: The height of the sheet
      • +
      • DATAWidth: The width of the sheet
      • +
      • DATAFill Ratio: The percentage of the sheet area that is filled by cuts (automatic)
      • +
      • DATATag Text: The text to display
      • +
      • DATATag Size: The size of the tag text
      • +
      • DATATag Position: The position of the tag text. Keep (0,0,0) for automatic center position
      • +
      • DATATag Rotation: The rotation of the tag text
      • +
      • DATAFont File: The font of the tag text
      • +
      • DATAMake Face: If True, the panel is a Part Face, otherwise a Part Wire
      • +
      • DATAGrain Direction: This allows you to inform the main direction of the panel fiber (clockwise direction, 0° means up)
      • +
      • VIEWMargin: A margin that can be displayed inside the panel border
      • +
      • VIEWShow Margin: Turns the display of the margin on/off
      • +
      • VIEWShow Grain: Shows a fiber texture (Make Face must be set to True)
      +

      Scripting

      +

      The Panel sheet tool can by used in macros and from the python console by using the following function: +

      +
      makePanelSheet ([objectslist]) 
      +

      Example: +

      +
      import Arch,Draft
      +base = Draft.makeRectangle(500,200)
      +panel = Arch.makePanel(base,thickness=36)
      +cut = Arch.makePanelCut(panel)
      +sheet = Arch.makePanelSheet([cut]) 
      +

      Tutorials

      + +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Arch_Panel_Sheet.svg b/localwiki/Arch_Panel_Sheet.svg new file mode 100644 index 0000000..bd12afb --- /dev/null +++ b/localwiki/Arch_Panel_Sheet.svg @@ -0,0 +1,128 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [Yorik van Havre] + + + Arch_Panel_Sheet + 2016-12-17 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Arch/Resources/icons/Arch_Panel_Sheet.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + diff --git a/localwiki/Arch_Panel_Tree.svg b/localwiki/Arch_Panel_Tree.svg new file mode 100644 index 0000000..906398d --- /dev/null +++ b/localwiki/Arch_Panel_Tree.svg @@ -0,0 +1,68 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [Yorik van Havre] + + + Arch_Panel_Tree + 2014-04-07 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Arch/Resources/icons/Arch_Panel_Tree.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + diff --git a/localwiki/Arch_Pipe.html b/localwiki/Arch_Pipe.html new file mode 100644 index 0000000..2fc63ce --- /dev/null +++ b/localwiki/Arch_Pipe.html @@ -0,0 +1,108 @@ +Arch Pipe

      Arch Pipe

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Arch Pipe.png Arch Pipe

      +
      Menu location +
      Arch → Pipe Tools → Pipe +
      Workbenches +
      Arch +
      Default shortcut +
      P I +
      See also +
      Arch PipeConnector +

      + +
      +


      +

      +

      Description

      +

      available in version 0.17 +

      This tool allows to create pipes from scratch, or from selected objects. The selected objects must be Part-based (Draft, Sketch, etc..) and contain one and only one open Wire. +

      +

      How to use

      +
      1. Optionally, select a linear Part shape such as a Draft Line, a Draft Wire or an open Sketch
      2. +
      3. Press the Arch Pipe.png Arch Pipe button, or press P then I keys
      +

      Options

      + +

      Properties

      +
      • DATALength: Sets the length of this pipe, when it is not based on a wire
      • +
      • DATADiameter: The diameter of this pipe, when it is not based on a profile
      • +
      • DATABase: The base wire of this pipe, if any
      • +
      • DATAProfile: The base profile of this pipe. If not given, the pipe is cylindrical.
      +

      Typical workflow

      +
      • Start by placing sanitary/hydraulic appliance items (below is an imported step file). You turn these objects into Arch Equipments by selecting them, and pressing the Arch Equipment button.
      +

      Arch pipe example 01.jpg +

      +
      • Arch Equipments now have a new SnapPoints property, which is a list of 3D vectors. This allows you to add custom snap points, to which you can snap when the new Draft Special snap button is turned on. Currently that property is only available to python, though. In the case above I added a new snap point at the exit of the wc appliance. The vectors inside SnapPoints appear on the model as white dots:
      +
      FreeCAD.ActiveDocument.Equipment.SnapPoints=[FreeCAD.Vector(0,0,100)]
      +
      +

      Arch pipe example 02.jpg +

      +
      • With the new "Snap Special" Draft Snap, you can now snap to these custom points:
      +

      Arch pipe example 03.jpg +

      +
      • Now we can draw our piping using Draft Lines, Draft Wires, or Sketches. The best way, though, is using only Draft Lines:
      +

      Arch pipe example 04.jpg +

      +
      • There is now a new Draft Slope tool that allows to change the slope of Draft lines, to, for example, 5% (0.05). So we can quickly give our waste lines a correct slope. Only z coordinates are change by this tool, so we only need to snap them back to each other, the top projection will stay unchanged.
      +

      Arch pipe example 05.jpg +

      +
      • We now only have to select all our lines, and press the Arch Pipe button. Arch Pipe works with any Part-based object that contains one and only one open wire.
      +

      Arch pipe example 06.jpg +

      +
      • We can now create connections by selecting 2 or 3 coincident tubes, and press the Arch PipeConnector button. If 3 pipes are selected, two of them must be aligned in order to create a tee element:
      +

      Arch pipe example 07.jpg +

      +
      • Changing the connectors radius doesn't change the length of the underlying base line, only the resulting tube (by changing their OffsetStart or OffsetEnd property). So you can still draw your line layout with only straight lines, without the need to care about curves and radius.
      +

      It is also possible to create Arch Pipes without a base line, in this case use its "Length" property to define the length. +

      +

      Scripting

      +

      The Pipe tool can by used in macros and from the python console by using the following function: +

      +
      import Arch
      +Arch.makePipe ( [objectsList,diameter] ) 
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Arch_Pipe.svg b/localwiki/Arch_Pipe.svg new file mode 100644 index 0000000..74df010 --- /dev/null +++ b/localwiki/Arch_Pipe.svg @@ -0,0 +1,96 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [Yorik van Havre] + + + Arch_Pipe + 2016-08-24 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Arch/Resources/icons/Arch_Pipe.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + diff --git a/localwiki/Arch_PipeConnector.html b/localwiki/Arch_PipeConnector.html new file mode 100644 index 0000000..1b89558 --- /dev/null +++ b/localwiki/Arch_PipeConnector.html @@ -0,0 +1,78 @@ +Arch PipeConnector

      Arch PipeConnector

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Arch PipeConnector.png Arch PipeConnector

      +
      Menu location +
      Arch → Pipe Tools → Pipe Connector +
      Workbenches +
      Arch +
      Default shortcut +
      P C +
      See also +
      Arch Pipe +

      + +
      +


      +

      +

      Description

      +

      available in version 0.17 +

      This tool allows to create corner or tee connection between two or three selected Arch Pipes. +

      +

      How to use

      +
      1. Select 2 or 3 Arch Pipes. If you are selecting 3 pipes, two of them must be exactly aligned.
      2. +
      3. Press the Arch PipeConnector.png Arch PipeConnector button, or press P then C keys
      +

      Properties

      +
      • DATARadius: The curvature radius of this connector
      +

      Typical workflow

      +

      See Arch Pipe#Typical_workflow +

      +

      Scripting

      +

      The Pipe Connector tool can by used in macros and from the python console by using the following function: +

      +
      import Arch
      +Arch.makePipeConnector ( objectsList ) 
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Arch_PipeConnector.svg b/localwiki/Arch_PipeConnector.svg new file mode 100644 index 0000000..1fa4b23 --- /dev/null +++ b/localwiki/Arch_PipeConnector.svg @@ -0,0 +1,106 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [Yorik van Havre] + + + Arch_PipeConnector + 2016-08-24 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Arch/Resources/icons/Arch_PipeConnector.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + diff --git a/localwiki/Arch_Pipe_Tree.svg b/localwiki/Arch_Pipe_Tree.svg new file mode 100644 index 0000000..af7045b --- /dev/null +++ b/localwiki/Arch_Pipe_Tree.svg @@ -0,0 +1,96 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [Yorik van Havre] + + + Arch_Pipe_Tree + 2016-08-24 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Arch/Resources/icons/Arch_Pipe_Tree.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + diff --git a/localwiki/Arch_Preferences.html b/localwiki/Arch_Preferences.html new file mode 100644 index 0000000..8da2ef4 --- /dev/null +++ b/localwiki/Arch_Preferences.html @@ -0,0 +1,25 @@ +Arch Preferences

      Arch Preferences

      + +

      General settings

      +

      Preference Arch Tab 01.png +

      +
      +

      Defaults

      +

      Preference Arch Tab 02.png +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Arch_Rebar.html b/localwiki/Arch_Rebar.html new file mode 100644 index 0000000..f62ef49 --- /dev/null +++ b/localwiki/Arch_Rebar.html @@ -0,0 +1,110 @@ +Arch Rebar

      Arch Rebar

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Arch Rebar.png Arch Rebar

      +
      Menu location +
      Arch → Rebar +
      Workbenches +
      Arch +
      Default shortcut +
      R B +
      See also +
      Arch Structure +

      + +
      +


      +

      +

      Description

      +

      The Rebar tool allows you to place reinforcing bars inside Arch Structure objects. Rebar objects are based on 2D profiles such as sketches or draft objects, that must be drawn on a face of a structure object. You can then adjust the configuration of the rebars, such as the number and diameter of the bars, or the offset distance between the two ends of the structural element. +

      Arch Rebar example.jpg +

      The above image shows a structural object, where two sketches are drawn, defining two bar diagrams. These two sketches are then turned into rebar objects. +

      +

      Extension available

      +

      The Rebar tool has been greatly enhanced during the Google Summer of Code 2017 edition. The result of that work is a series of new presets and wizards for the most common rebar types. They are packaged under an independent module called Reinforcement, that you can install via menu Tools -> Addons Manager. Once the Reinforcement addon is installed, on next run, FreeCAD will detect it and add a series of new tools under the Rebar button in the Arch toolbar and menu. The different tools from the Reinforcement Addon are described on the Arch Workbench page. +

      +

      How to use

      +
      1. Create a structure element
      2. +
      3. Switch to the Sketcher Workbench
      4. +
      5. Select one face of the structural element
      6. +
      7. Press the Sketcher NewSketch.png New Sketch button to start a new sketch on the selected face
      8. +
      9. Draw the diagram of your bar
      10. +
      11. Press the Sketcher LeaveSketch.png Leave Sketch button to finish
      12. +
      13. Switch back to the Arch Workbench
      14. +
      15. Select the sketch you just drew
      16. +
      17. Press the Arch Rebar.png Arch Rebar button, or press R then B keys
      18. +
      19. Adjust the desired properties (your rebar might not appear immediately, if some of the properties create an impossible situation, such as the bar diameter being 0, or the offset distances being bigger than the length of the structural element)
      +

      Options

      +
      • Rebars share the common properties and behaviours of all Arch Components
      • +
      • The rounding value is expressed in times the diameter. If your bar has a diameter of 5mm, a rounding value of 3 will create rounding at angles with a radius of 15mm.
      • +
      • Default values for new rebars can be set in the Arch preferences settings.
      • +
      • If a direction vector is not specified, the direction and distance along which the bars will spread is calculated automatically from the host structural object, by taking the normal direction of the base sketch, and taking its intersection with the structural object. If you specify a direction vector, the length of that vector will also be taken into account.
      • +
      • The spacing value is calculated from the current amount of bars, and represents the distance between the axes of each bar. You must therefore subtract the bar diameter to obtain the size of the free space between bars.
      +

      Properties

      +
      • DATAAmount: The amount of bars.
      • +
      • DATADiameter: The diameter of the bars.
      • +
      • DATADirection: The direction (and length) along which the bars must spread. If the value is (0,0,0), the direction is calculated automatically from the host structural object.
      • +
      • DATAOffset Start: The offset distance between the border of the structural object and the first bar.
      • +
      • DATAOffset End: The offset distance between the border of the structural object and the last bar.
      • +
      • DATARounding: A rounding value to be applied to the corners of the bars, expressed in times the diameter.
      • +
      • DATASpacing: The distance between the axes of each bar.
      +

      Scripting

      +

      The Rebar tool can by used in macros and from the python console by using the following function: +

      +
      makeRebar (structure,sketch,[diameter],[amount],[offset]) 
      +
      • Adds a Reinforcing Bar object to the given structural object, using the given sketch as profile.
      • +
      • If no diameter, amount or offset value is given, the default values from the Arch preferences settings are applied.
      • +
      • Returns the new Rebar object.
      +

      Example: +

      +
      import FreeCAD, Arch, Sketcher, PArt
      +struct = Arch.makeStructure(1,1,3)
      +sketch = FreeCAD.ActiveDocument.addObject('Sketcher::SketchObject','Sketch')
      +sketch.Support = (struct,["Face6"])
      +sketch.addGeometry(Part.Line(App.Vector(-0.4,0.4,0),App.Vector(0.4,0.4,0)))
      +Arch.makeRebar(structure,sketch) 
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Arch_Rebar.svg b/localwiki/Arch_Rebar.svg new file mode 100644 index 0000000..fed850e --- /dev/null +++ b/localwiki/Arch_Rebar.svg @@ -0,0 +1,169 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [Yorik van Havre] + + + Arch_Rebar + 2013-10-07 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Arch/Resources/icons/Arch_Rebar.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Arch_Rebar_BentShape.html b/localwiki/Arch_Rebar_BentShape.html new file mode 100644 index 0000000..44fa8f0 --- /dev/null +++ b/localwiki/Arch_Rebar_BentShape.html @@ -0,0 +1,121 @@ +Arch Rebar BentShape

      Arch Rebar BentShape

      + +
      + + + + + + + + + + + + + + + + + + + + + + + +
      +

      Arch Rebar BentShape.png Arch Rebar BentShape

      +
      Menu location +
      Arch → Rebar tools +
      Workbenches +
      Arch +
      Default shortcut +
      None +
      See also +
      Stirrup +
        +
      This command is part of the Reinforcement AddOn, that you can install via menu Tools → Addons Manager +

      + +
      +


      +

      +

      Description

      +

      The Arch Rebar BentShape.png Bent Shape Rebar tool allows user to create a bent shape reinforcing bar in the structural element. +

      BentShapeRebar.png +

      +

      How to use

      +
      1. Create a structure element
      2. +
      3. Select any face of the structure
      4. +
      5. Then select Arch Rebar BentShape.png Bent Shape Rebar from the rebar tools
      6. +
      7. A task panel will pop-out on the left side of the screen as shown below BentShapeDialog.png
      8. +
      9. Select the desired orientation
      10. +
      11. Give the inputs like front cover, left cover, right cover, bottom cover, top cover, anchor length, bent angle, rounding and diameter of the rebar
      12. +
      13. Select the mode of distribution either amount or spacing
      14. +
      15. If spacing is selected, a user can also opt for custom spacing
      16. +
      17. Pick selected face is used to verify or change the face for rebar distribution
      18. +
      19. Click OK or Apply to generate the rebars
      20. +
      21. Click Cancel to exit the task panel
      +

      Properties

      +
      • DATAOrientation: It decides the orientation of the rebar (like a bottom, top, right and left).
      • +
      • DATAFront Cover: The distance between rebar and selected face.
      • +
      • DATALeft Cover: The distance between the left end of the rebar to the left face of the structure.
      • +
      • DATARight Cover: The distance between the right end of the rebar to right face of the structure.
      • +
      • DATABottom Cover: The distance between rebar from the bottom face of the structure.
      • +
      • DATATop Cover: The distance between rebar from the top face of the structure.
      • +
      • DATAAnchor Length: It is the arm's length of bent shape rebar.
      • +
      • DATABent Angle: It decides angle in bent shape rebar.
      • +
      • DATAAmount: The amount of rebars.
      • +
      • DATASpacing: The distance between the axes of each bar.
      +

      Scripting

      +

      The Arch Rebar BentShape.png Bent Shape Rebar tool can by used in macros and from the python console by using the following function: +

      +
      makeBentShapeRebar(FrontCover, BottomCover, LeftCover, RightCover, Diameter, TopCover, BentLength, BentAngle, Rounding, AmountSpacingCheck, AmountSpacingValue, Orientation, Structure, Facename) 
      +
      • The Bent Shape Rebar have four different orientations: +
        • Bottom
        • +
        • Top
        • +
        • Left
        • +
        • Right
      • +
      • Adds a Bent Shape reinforcing bar object to the given structural object.
      • +
      • If no Structure and Facename is given, it will take user selected face as input.
      • +
      • Here CoverAlong argument is having type tuple.
      • +
      • Returns the new Rebar object.
      +

      Example: +Creating Bent Shape rebar. +

      +
      import Arch, BentShapeRebar
      +structure = Arch.makeStructure(length=1000.0, width=1000.0, height=100.0)
      +structure.ViewObject.Transparency = 80
      +FreeCAD.ActiveDocument.recompute()
      +rebar = BentShapeRebar.makeBentShapeRebar(20, 20, 20, 20, 8, 20, 100, 135, 2, True, 10, "Bottom", structure, "Face1") 
      +

      Changing properties of Bent Shape rebar. +

      +
      import BentShapeRebar
      +BentShapeRebar.editBentShapeRebar(rebar, 50, 50, 50, 50, 12, 20, 100, 135, 2, True, 10, "Top") 
      +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Arch_Rebar_Helical.html b/localwiki/Arch_Rebar_Helical.html new file mode 100644 index 0000000..7b389d5 --- /dev/null +++ b/localwiki/Arch_Rebar_Helical.html @@ -0,0 +1,117 @@ +Arch Rebar Helical

      Arch Rebar Helical

      + +
      + + + + + + + + + + + + + + + + + + + + + + + +
      +

      Arch Rebar Helical.png Arch Rebar Helical

      +
      Menu location +
      Arch → Rebar tools +
      Workbenches +
      Arch +
      Default shortcut +
      None +
      See also +
      Arch Rebar +
        +
      This command is part of the Reinforcement AddOn, that you can install via menu Tools → Addons Manager +

      + +
      +


      +

      +

      Description

      +

      The Arch Rebar Helical.png Helical Rebar tool allows user to create a helical reinforcing bar in the structural element. +

      HelicalRebar.png +

      +

      How to use

      +
      1. Create a structure element
      2. +
      3. Select any face of the structure
      4. +
      5. Then select Arch Rebar Helical.png Helical Rebar from the rebar tools
      6. +
      7. A task panel will pop-out on the left side of the screen as shown below HelicalRebarDialog.png
      8. +
      9. Select the desired orientation
      10. +
      11. Give the inputs like front cover, right side cover, left side cover, bottom cover and diameter of the rebar
      12. +
      13. Select the mode of distribution either amount or spacing
      14. +
      15. If spacing is selected, a user can also opt for custom spacing
      16. +
      17. Pick selected face is used to verify or change the face for rebar distribution
      18. +
      19. Click OK or Apply to generate the rebars
      20. +
      21. Click Cancel to exit the task panel
      +

      Properties

      +
      • DATASide Cover: The distance between rebar to the curved face.
      • +
      • DATATop Cover: The distance between rebar from the top face of the structure.
      • +
      • DATABottom Cover: The distance between rebar from the bottom face of the structure.
      • +
      • DATAPitch: The pitch of a helix is the height of one complete helix turn, measured parallel to the axis of the helix.
      • +
      • DATADiameter: Diameter of the rebar.
      +

      Scripting

      +

      The Arch Rebar Helical.png Helical Rebar tool can by used in macros and from the python console by using the following function: +

      +
      makeHelicalRebar(SideCover, BottomCover, Diameter, TopCover, Pitch, Structure, Facename) 
      +
      • Adds a Straight reinforcing bar object to the given structural object.
      • +
      • If no Structure and Facename is given, it will take user selected face as input.
      • +
      • Here CoverAlong argument is having type tuple.
      • +
      • Returns the new Rebar object.
      +

      Example: +

      Creating Helical rebar. +

      +
      import Arch, Draft, HelicalRebar
      +# Creating circle
      +pl=FreeCAD.Placement()
      +pl.Rotation.Q=(0.0,-0.0,-0.0,1.0)
      +pl.Base=FreeCAD.Vector(-1.0,-1.0,0.0)
      +circle = Draft.makeCircle(radius=130.107647738,placement=pl,face=True,support=None)
      +Draft.autogroup(circle)
      +# Creating Structure element from circle
      +structure = Arch.makeStructure(circle)
      +structure.ViewObject.Transparency = 80
      +FreeCAD.ActiveDocument.recompute()
      +# Creating Helical rebar
      +rebar = HelicalRebar.makeHelicalRebar(20, 50, 8, 50, 50, structure, "Face2") 
      +

      Changing properties of Helical rebar. +

      +
      import HelicalRebar
      +HelicalRebar.editHelicalRebar(rebar, 20, 100, 12, 100, 100) 
      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Arch_Rebar_LShape.html b/localwiki/Arch_Rebar_LShape.html new file mode 100644 index 0000000..29c2aeb --- /dev/null +++ b/localwiki/Arch_Rebar_LShape.html @@ -0,0 +1,118 @@ +Arch Rebar LShape

      Arch Rebar LShape

      + +
      + + + + + + + + + + + + + + + + + + + + + + + +
      +

      Arch Rebar LShape.png Arch Rebar LShape

      +
      Menu location +
      Arch → Rebar tools +
      Workbenches +
      Arch +
      Default shortcut +
      None +
      See also +
      Bent Shape Rebar +
        +
      This command is part of the Reinforcement AddOn, that you can install via menu Tools → Addons Manager +

      + +
      +


      +

      +

      Description

      +

      The Arch Rebar LShape.png LShape Rebar tool allows user to create LShape reinforcing bar in the structural element. +

      LShapeRebarNew.png +

      +

      How to use

      +
      1. Create a structure element
      2. +
      3. Select any face of the structure
      4. +
      5. Then select Arch Rebar LShape.png LShape Rebar from the rebar tools
      6. +
      7. A task panel will pop-out on the left side of the screen as shown below LShapeDialog.png
      8. +
      9. Select the desired orientation
      10. +
      11. Give the inputs like front cover, left side cover, right side cover, bottom cover, top cover, rounding and diameter of the rebar
      12. +
      13. Select the mode of distribution either amount or spacing
      14. +
      15. If spacing is selected, a user can also opt for custom spacing
      16. +
      17. Pick selected face is used to verify or change the face for rebar distribution
      18. +
      19. Click OK or Apply to generate the rebars
      20. +
      21. Click Cancel to exit the task panel
      +

      Properties

      +
      • DATAOrientation: It decides the orientation of the rebar (like a bottom, top, right and left).
      • +
      • DATAFront Cover: The distance between rebar and selected face.
      • +
      • DATARight Cover: The distance between the right end of the rebar to right face of the structure.
      • +
      • DATALeft Cover: The distance between the left end of the rebar to the left face of the structure.
      • +
      • DATABottom Cover: The distance between rebar from the bottom face of the structure.
      • +
      • DATATop Cover: The distance between rebar from the top face of the structure.
      • +
      • DATARounding: A rounding value to be applied to the corners of the bars, expressed in times the diameter.
      • +
      • DATAAmount: The amount of rebars.
      • +
      • DATASpacing: The distance between the axes of each bar.
      +

      Scripting

      +

      The Arch Rebar LShape.png LShape Rebar tool can by used in macros and from the python console by using the following function: +

      +
      makeLShapeRebar(FrontCover, BottomCover, LeftCover, RightCover, Diameter, TopCover, Rounding, AmountSpacingCheck, AmountSpacingValue, orientation, Structure, Facename) 
      +
      • The LShape Rebar have four different orientations: +
        • Bottom Right
        • +
        • Bottom Left
        • +
        • Top Right
        • +
        • Top Left
      • +
      • Adds a LShape reinforcing bar object to the given structural object.
      • +
      • If no Structure and Facename is given, it will take user selected face as input.
      • +
      • Here CoverAlong argument is having type tuple.
      • +
      • Returns the new Rebar object.
      +

      Example: +Creating LShape rebar. +

      +
      import Arch, LShapeRebar
      +structure = Arch.makeStructure(length=1000.0, width=1000.0, height=400.0)
      +structure.ViewObject.Transparency = 80
      +FreeCAD.ActiveDocument.recompute()
      +rebar = LShapeRebar.makeLShapeRebar(20, 20, 20, 20, 8, 20, 2, True, 10, "Bottom Left", structure, "Face1") 
      +

      Changing properties of LShape rebar. +

      +
      import LShapeRebar
      +LShapeRebar.editLShapeRebar(50, 50, 20, 20, 8, 20, 2, True, 5, "Top Left") 
      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Arch_Rebar_Stirrup.html b/localwiki/Arch_Rebar_Stirrup.html new file mode 100644 index 0000000..445065a --- /dev/null +++ b/localwiki/Arch_Rebar_Stirrup.html @@ -0,0 +1,113 @@ +Arch Rebar Stirrup

      Arch Rebar Stirrup

      + +
      + + + + + + + + + + + + + + + + + + + + + + + +
      +

      Arch Rebar Stirrup.png Arch Rebar Stirrup

      +
      Menu location +
      Arch → Rebar tools +
      Workbenches +
      Arch +
      Default shortcut +
      None +
      See also +
      Helical Rebar +
        +
      This command is part of the Reinforcement AddOn, that you can install via menu Tools → Addons Manager +

      + +
      +


      +

      +

      Description

      +

      The Arch Rebar Stirrup.png Stirrup Rebar tool allows user to create a stirrup reinforcing bar in the structural element. +

      Stirrup.png +

      +

      How to use

      +
      1. Create a structure element
      2. +
      3. Select any face of the structure
      4. +
      5. Then select Arch Rebar Stirrup.png Stirrup Rebar from the rebar tools
      6. +
      7. A task panel will pop-out on the left side of the screen as shown below StirrupDialog.png
      8. +
      9. Select the desired orientation
      10. +
      11. Give the inputs like left cover, right cover, top cover, bottom, front cover, bent angle, bent factor, rounding and diameter of the rebar
      12. +
      13. Select the mode of distribution either amount or spacing
      14. +
      15. If spacing is selected, a user can also opt for custom spacing
      16. +
      17. Pick selected face is used to verify or change the face for rebar distribution
      18. +
      19. Click OK or Apply to generate the rebars
      20. +
      21. Click Cancel to exit the task panel
      +

      Properties

      +
      • DATAFront Cover: The distance between rebar and selected face.
      • +
      • DATARight Cover: The distance between the right end of the rebar to right face of the structure.
      • +
      • DATALeft Cover: The distance between the left end of the rebar to the left face of the structure.
      • +
      • DATABottom Cover: The distance between rebar from the bottom face of the structure.
      • +
      • DATATop Cover: The distance between rebar from the top face of the structure.
      • +
      • DATABent Angle: Bent angle defines the angle at the ends of a stirrup.
      • +
      • DATABent Factor: Bent Factor defines length of stirrup end.
      • +
      • DATAAmount: The amount of rebars.
      • +
      • DATASpacing: The distance between the axes of each bar.
      +

      Scripting

      +

      The Arch Rebar Stirrup.png Stirrup Rebar tool can by used in macros and from the python console by using the following function: +

      +
      makeStirrup(LeftCover, RightCover, TopCover, BottomCover, FrontCover, BentAngle, BentFactor, Diameter, Rounding, AmountSpacingCheck, AmountSpacingValue, Structure, Facename) 
      +
      • Adds a Stirrup reinforcing bar object to the given structural object.
      • +
      • If no Structure and Facename is given, it will take user selected face as input.
      • +
      • Here CoverAlong argument is having type tuple.
      • +
      • Returns the new Rebar object.
      +

      Example: +Creating Stirrup rebar. +

      +
      import Arch, Stirrup
      +structure = Arch.makeStructure(length=1000.0, width=400.0, height=400.0)
      +structure.ViewObject.Transparency = 80
      +FreeCAD.ActiveDocument.recompute()
      +rebar = Stirrup.makeStirrup(20,  20, 20, 20, 20, 135, 4, 8, 2, True, 10, structure, "Face6") 
      +

      Changing properties of Stirrup rebar. +

      +
      import Stirrup
      +Stirrup.editStirrup(rebar, 20, 20, 20, 20, 50, 90, 4, 8, 2, True, 6, structure, "Face6") 
      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Arch_Rebar_Straight.html b/localwiki/Arch_Rebar_Straight.html new file mode 100644 index 0000000..5c073d9 --- /dev/null +++ b/localwiki/Arch_Rebar_Straight.html @@ -0,0 +1,130 @@ +Arch Rebar Straight

      Arch Rebar Straight

      + +
      + + + + + + + + + + + + + + + + + + + + + + + +
      +

      Arch Rebar Straight.png Arch Rebar Straight

      +
      Menu location +
      Arch → Rebar tools +
      Workbenches +
      Arch +
      Default shortcut +
      None +
      See also +
      UShape Rebar +
        +
      This command is part of the Reinforcement AddOn, that you can install via menu Tools → Addons Manager +

      + +
      +


      +

      +

      Description

      +

      The Arch Rebar Straight.png Straight Rebar tool allows user to create a straight reinforcing bar in the structural element. +

      StraightRebar.png +

      +

      How to use

      +
      1. Create a structure element
      2. +
      3. Select any face of the structure
      4. +
      5. Then select Arch Rebar Straight.png Straight Rebar from the rebar tools
      6. +
      7. A task panel will pop-out on the left side of the screen as shown below StraightRebarDialog.png
      8. +
      9. Select the desired orientation
      10. +
      11. Give the inputs like front cover, right side cover, left side cover, bottom cover and diameter of the rebar
      12. +
      13. Select the mode of distribution either amount or spacing
      14. +
      15. If spacing is selected, a user can also opt for custom spacing
      16. +
      17. Pick selected face is used to verify or change the face for rebar distribution
      18. +
      19. Click OK or Apply to generate the rebars
      20. +
      21. Click Cancel to exit the task panel
      +

      Properties

      +
      • DATAOrientation: It decides the orientation of the rebar (like a bottom, top, right and left).
      • +
      • DATAFront Cover: The distance between rebar and selected face.
      • +
      • DATARight Cover: The distance between the right end of the rebar to right face of the structure.
      • +
      • DATALeft Cover: The distance between the left end of the rebar to the left face of the structure.
      • +
      • DATACover along: These property facilities the user to specify either top or bottom cover.
      • +
      • DATABottom Cover: The distance between rebar from the bottom face of the structure.
      • +
      • DATATop Cover: The distance between rebar from the top face of the structure.
      • +
      • DATAAmount: The amount of rebars.
      • +
      • DATASpacing: The distance between the axes of each bar.
      +

      Scripting

      +

      The Arch Rebar Straight.png Straight Rebar tool can by used in macros and from the python console by using the following function: +

      1. When orientation of straight rebar is horizontal: +

      +
      makeStraightRebar(FrontCover, CoverAlong, RightCover, LeftCover, Diameter, AmountSpacingCheck, AmountSpacingValue, Orientation = "Horizontal", Structure, Facename) 
      +

      Note: +

      +
      • Type of CoverAlong argument is a tuple. Syntax: (<Along>, <Value>). Here we have horizontal orientation so we can pass Top Side and Bottom Side to <Along> arguments.
      +

      For eg. ("Top Side", 20) and ("Bottom Side", 20) +

      2. When orientation of straight rebar is vertical: +

      +
      makeStraightRebar(FrontCover, CoverAlong, TopCover, BottomCover, Diameter, AmountSpacingCheck, AmountSpacingValue, Orientation = "Horizontal", Structure, Facename) 
      +

      Note: +

      +
      • Type of CoverAlong argument is a tuple. Syntax: (<Along>, <Value>). Here we have vertical orientation so we can pass Left Side and Right Side to <Along> arguments.
      +

      For eg. ("Left Side", 20) and ("Right Side", 20) +


      +

      +
      +


      +

      +
      • Adds a Straight reinforcing bar object to the given structural object.
      • +
      • If no Structure and Facename is given, it will take user selected face as input.
      • +
      • Here CoverAlong argument is having type tuple.
      • +
      • Returns the new Rebar object.
      +

      Example: +Creating Straight rebar. +

      +
      import Arch, StraightRebar
      +structure = Arch.makeStructure(length=1000.0, width=1000.0, height=400.0)
      +structure.ViewObject.Transparency = 80
      +FreeCAD.ActiveDocument.recompute()
      +rebar = StraightRebar.makeStraightRebar(20, ("Bottom Side", 20), 20, 20, 8, True, 10, "Horizontal", structure, "Face1") 
      +

      Changing properties of Straight rebar. +

      +
      import StraightRebar
      +StraightRebar.editStraightRebar(rebar, 25, ("Top Side", 20), 20, 20, 8, True, 10, "Horizontal") 
      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Arch_Rebar_Tree.svg b/localwiki/Arch_Rebar_Tree.svg new file mode 100644 index 0000000..77ad45c --- /dev/null +++ b/localwiki/Arch_Rebar_Tree.svg @@ -0,0 +1,169 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [Yorik van Havre] + + + Arch_Rebar_Tree + 2013-10-07 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Arch/Resources/icons/Arch_Rebar_Tree.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Arch_Rebar_UShape.html b/localwiki/Arch_Rebar_UShape.html new file mode 100644 index 0000000..d42f8bd --- /dev/null +++ b/localwiki/Arch_Rebar_UShape.html @@ -0,0 +1,117 @@ +Arch Rebar UShape

      Arch Rebar UShape

      + +
      + + + + + + + + + + + + + + + + + + + + + + + +
      +

      Arch Rebar UShape.png Arch Rebar UShape

      +
      Menu location +
      Arch → Rebar tools +
      Workbenches +
      Arch +
      Default shortcut +
      None +
      See also +
      LShape Rebar +
        +
      This command is part of the Reinforcement AddOn, that you can install via menu Tools → Addons Manager +

      + +
      +


      +

      +

      Description

      +

      The UShapeRebar.png UShape Rebar tool allows user to create a UShape reinforcing bar in the structural element. +

      Footing UShapeRebar.png +

      +

      How to use

      +
      1. Create a structure element
      2. +
      3. Select any face of the structure
      4. +
      5. Then select UShapeRebar.png UShape Rebar from the rebar tools
      6. +
      7. A task panel will pop-out on the left side of the screen as shown below UShapeDialog.png
      8. +
      9. Select the desired orientation
      10. +
      11. Give the inputs like front cover, right side cover, left side cover, bottom cover, top cover, rounding factor and diameter of the rebar
      12. +
      13. Select the mode of distribution either amount or spacing
      14. +
      15. If spacing is selected, a user can also opt for custom spacing
      16. +
      17. Pick selected face is used to verify or change the face for rebar distribution
      18. +
      19. Click OK or Apply to generate the rebars
      20. +
      21. Click Cancel to exit the task panel
      +

      Properties

      +
      • DATAOrientation: It decides the orientation of the rebar (like a bottom, top, right and left).
      • +
      • DATAFront Cover: The distance between rebar and selected face.
      • +
      • DATARight Cover: The distance between the right end of the rebar to right face of the structure.
      • +
      • DATALeft Cover: The distance between the left end of the rebar to the left face of the structure.
      • +
      • DATABottom Cover: The distance between rebar from the bottom face of the structure.
      • +
      • DATATop Cover: The distance between rebar from the top face of the structure.
      • +
      • DATARounding: A rounding value to be applied to the corners of the bars, expressed in times the diameter.
      • +
      • DATAAmount: The amount of rebars.
      • +
      • DATASpacing: The distance between the axes of each bar.
      +

      Scripting

      +

      The UShapeRebar.png UShape Rebar tool can by used in macros and from the python console by using the following function: +

      +
      makeUShapeRebar(FrontCover, BottomCover, RightCover, LeftCover, Diameter, Topcover, Rounding, AmountSpacingCheck, AmountSpacingValue, Orientation, Structure, Facename) 
      +
      • The UShape Rebar have four different orientations: +
        • Bottom
        • +
        • Top
        • +
        • Right
        • +
        • Left
      • +
      • Adds a UShape reinforcing bar object to the given structural object.
      • +
      • If no Structure and Facename is given, it will take user selected face as input.
      • +
      • Returns the new Rebar object.
      +

      Example: +Creating UShape rebar. +

      +
      import Arch, UShapeRebar
      +structure = Arch.makeStructure(length=1000.0, width=1000.0, height=400.0)
      +structure.ViewObject.Transparency = 80
      +FreeCAD.ActiveDocument.recompute()
      +rebar = UShapeRebar.makeUShapeRebar(20, 20, 20, 20, 8, 20, 4, True, 10, "Bottom", structure, "Face1") 
      +

      Changing properties of UShape rebar. +

      +
      import UShapeRebar
      +UShapeRebar.editUShapeRebar(rebar, 25, 25, 25, 25, 16, 25, 2, True, 15, "Top") 
      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Arch_Remove.html b/localwiki/Arch_Remove.html new file mode 100644 index 0000000..6100ad3 --- /dev/null +++ b/localwiki/Arch_Remove.html @@ -0,0 +1,85 @@ +Arch Remove

      Arch Remove

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Arch Remove.png Arch Remove

      +
      Menu location +
      Arch → Remove +
      Workbenches +
      Arch +
      Default shortcut +
      None +
      See also +
      Arch Add +

      + +
      +


      +

      +

      Description

      +

      The Remove tools allows you to do 2 kinds of operations: +

      +
      • Remove a subcomponent from an Arch object, for example remove a box that has been added to a wall, like in the Arch Add example
      • +
      • Subtract a shape-based object from an Arch component such as a wall or structure
      +

      Arch Remove example.jpg +

      In the above image, a box is being subtracted from a wall +

      +

      How to use

      +
      1. Select a subcomponent inside an Arch object, or:
      2. +
      3. Select object(s) to be subtracted, then the Arch component from which they must be subtracted (the arch component must be the last thing you selected)
      4. +
      5. Press the Arch Remove.png Remove button
      +

      Scripting

      +

      The Remove tool can by used in macros and from the python console by using the following function: +

      +
      removeComponents (objectsList,[hostObject])
      +
      +
      • removes the given component or the components from the given list from their parents. If a host object is specified, this function will try adding the components as holes to the host object instead.
      +

      Example: +

      +
      import FreeCAD, Arch, Draft, Part
      +line = Draft.makeWire([FreeCAD.Vector(0,0,0),FreeCAD.Vector(2,2,0)])
      +wall = Arch.makeWall(line)
      +box = Part.makeBox(1,1,1)
      +Arch.addComponents(box,wall)
      +Arch.removeComponents(box) 
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Arch_Remove.svg b/localwiki/Arch_Remove.svg new file mode 100644 index 0000000..bd5f2c8 --- /dev/null +++ b/localwiki/Arch_Remove.svg @@ -0,0 +1,71 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [wmayer] + + + Arch_Remove + 2011-10-10 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Arch/Resources/icons/Arch_Remove.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + diff --git a/localwiki/Arch_RemoveShape.html b/localwiki/Arch_RemoveShape.html new file mode 100644 index 0000000..0cec8fe --- /dev/null +++ b/localwiki/Arch_RemoveShape.html @@ -0,0 +1,72 @@ +Arch RemoveShape

      Arch RemoveShape

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Arch RemoveShape.png Arch RemoveShape

      +
      Menu location +
      Arch → Utilities → Remove Shape +
      Workbenches +
      Arch +
      Default shortcut +
      None +
      See also +
      Arch MeshToShape +

      + +
      +


      +

      +

      Description

      +

      This tool attempts at removing the inner cubic shape of an Arch Wall or Arch Structure, and adjusting its properties, making it totally parametric. This tool will only work if the underlying shape is cubic (exactly 6 faces, all corners have only right angles). +

      +

      How to use

      +
      1. Select an Arch Wall or Arch Structure
      2. +
      3. Press the Arch RemoveShape.png Remove Shape entry in Arch -> Utilities menu
      +

      Scripting

      +

      This tool can by used in macros and from the python console by using the following function: +

      +
      removeShape (object) 
      +

      takes an arch object (wall or structure) built on a cubic shape, and removes the inner shape, keeping its length, width and height as parameters. +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Arch_RemoveShape.svg b/localwiki/Arch_RemoveShape.svg new file mode 100644 index 0000000..0dd0b76 --- /dev/null +++ b/localwiki/Arch_RemoveShape.svg @@ -0,0 +1,85 @@ + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [wmayer] + + + Arch_RemoveShape + 2011-10-10 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Arch/Resources/icons/Arch_RemoveShape.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Arch_Roof.html b/localwiki/Arch_Roof.html new file mode 100644 index 0000000..292480f --- /dev/null +++ b/localwiki/Arch_Roof.html @@ -0,0 +1,100 @@ +Arch Roof

      Arch Roof

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Arch Roof.png Arch Roof

      +
      Menu location +
      Arch → Roof +
      Workbenches +
      Arch +
      Default shortcut +
      R F +
      See also +
      None +

      + +
      +


      +

      +

      Description

      +

      The Roof tool allows you to create a sloped roof from a selected wire. The created roof object is parametric, keeping its relationship with the base object. Please note that this tool is still in development, and might fail with very complex shapes. The principle is that each edge is seen allotting a profile of roof (slope, width, overhang, thickness…). +

      RoofExample.png +

      +

      How to use

      +
      1. Create a wire with following the conterclockwise direction and select it. +
        • CounterclockwiseWire.png
      2. +
      3. Press the Arch Roof.png Arch Roof button, or press R then F keys
      4. +
      5. The default roof object could have a strange shape, it's because the tool have not all the needed informations.
      6. +
      7. After creating the default roof, double click on the object in the tree view to access and edit all the properties. Angle must be between 0 and 90. +
        • RoofTable.png
      8. +
      9. Each line correspond to a roof pane. So you can set properties you want for each roof pane.
      10. +
      11. To help you, you can set Angle or Run to 0 and defined a Relative Id, this make automatic calculs to find the data relative to the relative Id.
      12. +
      13. It work like this : +
        1. If Angle = 0 and Run = 0 then profile is identical to the relative profile.
        2. +
        3. If Angle = 0 then angle is calculated so that the height is the same one as the relative profile.
        4. +
        5. If Run = 0 then Run is calculated so that the height is the same one as the relative profile.
      14. +
      15. At the end, set an angle to 90° to make a gable. +
        • RoofProfil.png
      16. +
      17. Also you can check this video : https://www.youtube.com/watch?v=4Urwru71dVk
      +

      Options

      + +

      Properties

      +
      • DATAAngles: List of the slope angle of the roof pane (an angle for each edge in the wire).
      • +
      • DATARuns: List of the width of the roof pane (a run for each edge in the wire).
      • +
      • DATAIdRel: List of relation Id The slope angle of the roof
      • +
      • DATAThickness: List of thickness of the roof pane. (a thickness for each edge in the wire).
      • +
      • DATAOverhang: List of the overhang of the roof pane (an overhang for each edge in the wire).
      • +
      • DATAFace: The face index of the base object to be used #Not really used
      +

      Scripting

      +

      The Roof tool can by used in macros and from the python console by using the following function: +

      +
      makeRoof (baseobj,[facenr],[angles],[runs],[idrel],[thickness],[overhang],[name]) 
      +
      Makes a roof based on a closed wire. You can provide a list of angles, run, idrel, thickness, overhang for each edges in the wire to define the roof shape. The default for angle is 45 and the list is automatically complete to match with number of edges in the wire.
      +

      Example: +

      +
      import Arch, Draft
      +rect = Draft.makeRectangle(30,40)
      +Arch.makeRoof(rect,angles=[30.,]) 
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Arch_Roof.svg b/localwiki/Arch_Roof.svg new file mode 100644 index 0000000..0f1e146 --- /dev/null +++ b/localwiki/Arch_Roof.svg @@ -0,0 +1,106 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [Yorik van Havre] + + + Arch_Roof + 2012-05-13 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Arch/Resources/icons/Arch_Roof.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + diff --git a/localwiki/Arch_Roof_Tree.svg b/localwiki/Arch_Roof_Tree.svg new file mode 100644 index 0000000..393ba98 --- /dev/null +++ b/localwiki/Arch_Roof_Tree.svg @@ -0,0 +1,106 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [Yorik van Havre] + + + Arch_Roof_Tree + 2012-05-13 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Arch/Resources/icons/Arch_Roof_Tree.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + diff --git a/localwiki/Arch_Schedule.html b/localwiki/Arch_Schedule.html new file mode 100644 index 0000000..3f27396 --- /dev/null +++ b/localwiki/Arch_Schedule.html @@ -0,0 +1,103 @@ +Arch Schedule

      Arch Schedule

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Arch Schedule.png Arch Schedule

      +
      Menu location +
      Arch → Create schedule... +
      Workbenches +
      Arch +
      Default shortcut +
      +
      See also +
      None +

      + +
      +


      +


      +

      +

      Description

      +

      The Schedule tool allows you to create and automatically populate a spreadsheet with contents gathered from the model. +

      Note: This tool has been rewritten in FreeCAD 0.17 and differs in previous versions. +

      +

      How to use

      +
      1. Open or create a FreeCAD document which contains some objects
      2. +
      3. Press the Arch Schedule.png Schedule button
      4. +
      5. Adjust the desired options
      6. +
      7. Press OK
      +

      Workflow

      +

      First you need to have a model. For example, here is a document with a couple of objects. I did Arch stuff here, but it doesn't need to be Arch, it can be anything. +

      Arch schedule example01.jpg +

      Then you press the Arch Schedule button. You get a task panel like this. It is pretty wide, so you'll need to widen the task panel to be comfortable. +

      Arch schedule example02.jpg +

      Then you can fill line by line. Each line is a "query" and will render one line in the spreadsheet. Press the Add button to add a new line, and double-click each cell from that line to fill in the values. The Del button will delete the line which contains a currently selected cell, and Clear will delete all the lines. Possible values to put in columns are: +

      +
      • Description: A description for this query. The Description column will be the first column of the resulting spreadsheet. The description is mandatory to have a query performed. If you leave the description cell empty, the whole line will be skipped and left blank in the spreadsheet. This allows you to add "separator" lines.
      • +
      • Value: This is the real query that you want to perform on all the objects selected by this query. It can be two kinds of things: either the word count (or Count or COUNT, it's case-insensitive), which will simply count objects, or retrieve ans sum a property, for example object.Shape.Volume or object.Length or even object.Label. The name you use before the first dot (object) can be anything, you could also write x.Shape.Volume. The rule is: what comes after the first dot will be retrieved from each object selected by this query, if possible (object that don't have the required property will be skipped), and the result will be added together. For example, if you use object.Shape.Volume, you will get the sum of all volumes of all objects selected by this query.
      • +
      • Unit: An optional unit to express the results in. It's up to you to give a unit that matches the query you are doing, for example, if you are retrieving volumes, you should use a volume unit, such as m^3. If you use a wrong unit, for ex. cm, you'll get wrong results.
      • +
      • Objects: You can leave this empty, then all the objects of the document will be considered by this query, or give a semicolon (;)-separated list of object names (not labels). If any of the objects in this list is a group, its children will be selected as well. So the easiest way to use this feature is to group your objects meaningfully in the document, and just give a group name here. You can also use the Selection button to add objects currently selected in the document.
      • +
      • Filter: Here you can add a semicolon(;)-separated list of filters. Each filter is written in the form: filter:value, where filter can be (it's case-insensitive too): Name, Label, Type, or Role (see full list below). For example: name:door;type:window will filter the objects we got from the step above, and retain only those whose name contains "door" AND the type (returned by Draft.getType) is "wall". Everything is case-insensitive. Filters that begins with ! are inverted. For example, !name:wall will retain only objects that DON'T have "wall" in their name. "Role" is a property that all Arch objects have.
      +

      The Import button allows you to build this list in another spreadsheet application, and import that as a csv file here. +

      So we can build a list of queries like this: +

      Arch schedule example03.jpg +

      After that, press OK and a new Schedule object is added to the document, which contains a result spreadsheet: +

      Arch schedule example04.jpg +

      By double-clicking the Schedule object, you get back to the task panel and change the values. By double-clicking the spreadsheet itself, you get the results in 3 columns: description, value, unit (if applicable): +

      Arch schedule example05.jpg +

      The spreadsheet can then be exported to csv normally, from the Spreadsheet workbench. +

      +

      Filters

      +

      Currently available filters: +

      +
      • name:something: Will retain only objects that have "something" in their name (case-insensitive)
      • +
      • !name:something: Will retain only objects that don't have "something" in their name
      • +
      • label:something: Will retain only objects that have "something" in their label (case-insensitive)
      • +
      • !label:something: Will retain only objects that don't have "something" in their label
      • +
      • type:something: Will retain only objects where the Draft.getType() function returns "something"
      • +
      • !type:something: Will retain only objects where the Draft.getType() function does not return "something"
      • +
      • role:something: Will retain only objects that have a Role property set to "something"
      • +
      • !role:something: Will retain only objects that don't have a Role property, or where the Role property is not set to "something"
      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Arch_Schedule.svg b/localwiki/Arch_Schedule.svg new file mode 100644 index 0000000..25328ac --- /dev/null +++ b/localwiki/Arch_Schedule.svg @@ -0,0 +1,68 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [Yorik van Havre] + + + Arch_Schedule + 2015-04-26 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Arch/Resources/icons/Arch_Schedule.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + diff --git a/localwiki/Arch_SectionPlane.html b/localwiki/Arch_SectionPlane.html new file mode 100644 index 0000000..d0f1f1f --- /dev/null +++ b/localwiki/Arch_SectionPlane.html @@ -0,0 +1,101 @@ +Arch SectionPlane

      Arch SectionPlane

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Arch SectionPlane.png Arch SectionPlane

      +
      Menu location +
      Arch → Section Plane +
      Workbenches +
      Arch +
      Default shortcut +
      S P +
      See also +
      None +

      + +
      +


      +

      +

      Description

      +

      This tool places in the current Document a section plane gizmo, which defines a section or view plane. The gizmo take his placement according to the current Draft Working Plane and can be relocated and reoriented by moving and rotating it, until it describes the 2D view you want to obtain. The Section plane object will only consider a certain set of objects. Objects that are selected when you create a Section Plane will be added to that set automatically. Other objects can later be added or removed from a SectionPlane object with the Arch Add and Arch Remove tools, or by double-clicking the Section Plane in the tree view. +

      The Section Plane alone won't create any view of its objects set. For that, you must either create a Drawing DraftView to create a view on a Drawing page, a Draft Shape2DView to create a view in the 3D document itself, or a TechDraw ArchView to create a view in a TechDraw page. +

      Arch SectionPlane example.jpg +

      +

      How to use

      +
      1. Optionally, set the Draft Working Plane to reflect the plane where you want to place the Section Plane
      2. +
      3. Select objects you want to be included in your section view
      4. +
      5. Press the Arch SectionPlane.png SectionPlane button or press S then P keys
      6. +
      7. Move/rotate the Section Plane into correct position if needed
      8. +
      9. Select the Section Plane if not selected already
      10. +
      11. Use either Drawing DraftView, Draft Shape2DView or TechDraw ArchView to create a view
      +

      Options

      +
      • The Section plane object will only consider a certain set of objects, not all the objects of the document. Objects can be added or removed from a SectionPlane object by using the Arch Add and Arch Remove tools, or by double-clicking the Section Plane in the tree view, selecting objects either in the list of in the 3D scene, and pressing the add or remove buttons.
      +
      • With a section plane object selected, use the Draft Shape2DView tool to create a shape object representing the section view in the document
      +

      Arch Section example2.jpg +

      + +

      Arch Section example3.jpg +

      +
      • The Section Plane can also be used to show the entire 3D view cut by an infinite plane. This is only visual, and won't affect the geometry of the objects being cut.
      +

      Arch SectionPlane CutView.jpg +

      +

      Properties

      +
      • DATAOnly Solids: If this is True, non-solid objects in the set will be disregarded
      • +
      • VIEWDisplay Length: The length of the section plane gizmo in the 3D view. Doesn't affect the resulting view
      • +
      • VIEWDisplay Height: The height of the section plane gizmo in the 3D view. Doesn't affect the resulting view
      • +
      • VIEWArrow Size: The size of the arrows of the section plane gizmo in the 3D view. Doesn't affect the resulting view
      • +
      • VIEWCut View: If this is true, the whole 3D view will be cut at the location of this section plane (experimental).
      +

      Scripting

      +

      The Section Plane tool can by used in macros and from the python console by using the following function: +

      +
      makeSectionPlane ([objectslist]) 
      +
      Creates a Section plane objects including the given objects.
      +

      Example: +

      +
      import FreeCAD, Draft, Arch
      +trace = Draft.makeLine(FreeCAD.Vector (0, 0, 0),FreeCAD.Vector (2, 2, 0))
      +wall = Arch.makeWall(trace,width=0.1,height=1,align="Center")
      +Arch.makeSectionPlane([wall]) 
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Arch_SectionPlane.svg b/localwiki/Arch_SectionPlane.svg new file mode 100644 index 0000000..47bc65f --- /dev/null +++ b/localwiki/Arch_SectionPlane.svg @@ -0,0 +1,67 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [wmayer] + + + Arch_SectionPlane + 2011-10-10 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Arch/Resources/icons/Arch_SectionPlane.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + diff --git a/localwiki/Arch_SectionPlane_Tree.svg b/localwiki/Arch_SectionPlane_Tree.svg new file mode 100644 index 0000000..9bf5b3e --- /dev/null +++ b/localwiki/Arch_SectionPlane_Tree.svg @@ -0,0 +1,56 @@ + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [yorikvanhavre] + + + Arch_SectionPlane_Tree + 2011-12-06 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Arch/Resources/icons/Arch_SectionPlane_Tree.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + diff --git a/localwiki/Arch_SelectNonManifold.svg b/localwiki/Arch_SelectNonManifold.svg new file mode 100644 index 0000000..13fdb94 --- /dev/null +++ b/localwiki/Arch_SelectNonManifold.svg @@ -0,0 +1,77 @@ + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [Yorik van Havre] + + + Arch_SelectNonManifold + 2012-07-22 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Arch/Resources/icons/Arch_SelectNonManifold.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Arch_SelectNonSolidMeshes.html b/localwiki/Arch_SelectNonSolidMeshes.html new file mode 100644 index 0000000..3235a4c --- /dev/null +++ b/localwiki/Arch_SelectNonSolidMeshes.html @@ -0,0 +1,65 @@ +Arch SelectNonSolidMeshes

      Arch SelectNonSolidMeshes

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Arch SelectNonSolidMeshes.png Arch SelectNonSolidMeshes

      +
      Menu location +
      Arch → Utilities → Select non solid +
      Workbenches +
      Arch +
      Default shortcut +
      None +
      See also +
      Arch MeshToShape +

      + +
      +


      +

      +

      Description

      +

      This tool identifies and selects the non-solid (non-manifold) meshes in a selected group of selected Mesh objects. +

      +

      How to use

      +
      1. Select a mesh object
      2. +
      3. Press the Arch SelectNonSolidMeshes.png Select non solid entry in Arch → Utilities menu
      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Arch_SetMaterial.html b/localwiki/Arch_SetMaterial.html new file mode 100644 index 0000000..95d8e2d --- /dev/null +++ b/localwiki/Arch_SetMaterial.html @@ -0,0 +1,82 @@ +Arch SetMaterial

      Arch SetMaterial

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Arch SetMaterial.png Arch SetMaterial

      +
      Menu location +
      Arch → Set material... +
      Workbenches +
      Arch +
      Default shortcut +
      M,T +
      See also +
      None +

      + +
      +


      +

      +

      Description

      +

      The Material tools allows to add materials to the active document, and attribute a material to an Arch object. Materials can all the properties of a certain material, and control the color of the object to which it is attached. Materials are stored into a Materials folder in the active document. +

      Arch materials 01.jpg +

      +

      How to use

      +
      1. Optionally, select one or more objects to which you wish to attribute a new material
      2. +
      3. Press the Arch SetMaterial.png Set Material button
      4. +
      5. Load a preset material, or create a new one by filling the fields.
      6. +
      7. Press OK
      +

      Options

      +
      • Upon creating a new material, a task panel allows you to set different options:
      +

      Arch materials 02.jpg +

      +
      • Choose preset: Choose one of the preset materials, to be used as is, or to be adapted by modifying the fields below
      • +
      • Name: Choose a name for the material
      • +
      • Edit button: This opens the current material in FreeCAD's Material editor, which allows you to edit many additional properties and add your own custom ones
      • +
      • Description: A more detailed description of the material
      • +
      • Color: A display color for the material, which will be applied to all objects that use that material
      • +
      • Code: A name and reference number of a specification system such as Masterformat or Omniclass.
      • +
      • Code browser button: Not implemented yet - will allow to open the reference in a web browser
      • +
      • URL: An URL where more informaiton about the material can be found
      • +
      • URL button:Opens the URL in a web browser
      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Arch_Site.html b/localwiki/Arch_Site.html new file mode 100644 index 0000000..d474ad3 --- /dev/null +++ b/localwiki/Arch_Site.html @@ -0,0 +1,122 @@ +Arch Site

      Arch Site

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Arch Site.png Arch Site

      +
      Menu location +
      Arch → Site +
      Workbenches +
      Arch +
      Default shortcut +
      S I +
      See also +
      Arch Floor, Arch Building +

      + +
      +


      +

      +

      Description

      +

      The Arch Site is a special object that combines properties of a standard FreeCAD group object and Arch objects. It is particularly suited for representing a whole project site, or terrain. In IFC-based architectural work, it is mostly used to organize your model, by containing building objects. The site is also used to manage and display a physical terrain, and can computes volumes of earth to be added or removed. +

      +

      How to use

      +
      1. Optionally, select one or more objects to be included in your new site
      2. +
      3. Press the Arch Site.png Arch Site button, or press the S then I keys
      +

      Options

      +
      • After creating a site, you can add more objects to it by drag and dropping them in the Tree View or by using the Arch Add.png Arch Add tool. This only determines which object is part of the given site, and has no effect on the terrain itself.
      • +
      • You can remove objects from a site by drag and dropping them out of it the Tree View or by using the Arch Remove.png Arch Remove tool
      • +
      • You can add a terrain object by editing the Site's Terrain property. The terrain must be an open shell or surface.
      • +
      • You can add volumes to be added or subtracted from the base terrain, by double-clicking the Site, and adding objects to its Subtractions or Additions groups. The objects must be solids.
      • +
      • The Extrusion Vector property can be used to solve some problems that can appear when working with subtractions and additions. In order to perform those additions/subtractions, the terrain surface is extruded into a solid, which is then appropriately unioned/subtracted. Depending on the terrain topology, this extrusion might fail with the default extrusion vector. You might therefore be able to remedy the problem by changing this to a different value.
      +

      Properties

      +
      • DATATerrain: The base terrain of this site
      • +
      • DATAAddress: The street and housenumber of this site
      • +
      • DATAPostal Code: The postal or zip code of this site
      • +
      • DATACity: The city of this site
      • +
      • DATACountry: The country of this site
      • +
      • DATALatitude: The latitude of this site
      • +
      • DATALongitude: The longitude of this site
      • +
      • DATAUrl: An url that shows this site in a mapping website
      • +
      • DATAProjected Area: The area of the projection of this object onto the XY plane
      • +
      • DATAPerimeter: The perimeter length of this terrain
      • +
      • DATAAddition Volume: The volume of earth to be added to this terrain
      • +
      • DATASubtraction Volume: The volume of earth to be removed from this terrain
      • +
      • DATAExtrusion Vector: An extrusion vector to use when performing boolean operations
      • +
      • DATARemove Splitter: Remove splitters from the resulting shape
      • +
      • DATANorth Deviation: The angle between the true North and the north direction in this document
      • +
      • VIEWSolar Diagram: Shows or hides the solar diagram
      • +
      • VIEWSolar Diagram Color: The color of the solar diagram
      • +
      • VIEWSolar Diagram Position: The position of the solar diagram
      • +
      • VIEWSolar Diagram Scale: The scale of the solar diagram
      +

      Typical workflow

      +

      Start by creating an object that represents your terrain. It must be an open surface, not a solid. For example, it is easy to import mesh data, that can be turned into a Part Shape from menu Part -> Create Shape from Mesh.... Then, create a Site object, and set its Terrain property to the Part we just created: +

      Arch site example 01.jpg +

      Create some volumes (they must be solids) that represent the areas that you wish to be excavated or filled. Double-click the Site object in the Tree View, and add these volumes to the Additions or Subtractions groups. Click OK. +

      Arch site example 02.jpg +

      The site geometry will be recomputed and the areas, perimeter, and volumes properties recalculated. +

      Arch site example 03.jpg +

      +

      Solar diagram

      +

      If pysolar is installed on your system, Arch Sites can display a solar diagram. For this, Longitude, Latitude and NorthDeviation properties must be correctly set, and SolarDiagram view property turned on. available in version 0.17 +


      +Freecad-solar-diagram.jpg +

      +

      Scripting

      +

      The Site tool can by used in macros and from the python console by using the following function: +

      +
      makeSite ([objectslist]) 
      +

      creates a site including the objects from the given list. +

      Example: +

      +
      import Arch
      +Arch.makeSite() 
      +

      A solar diagram can also be created with: +

      +
      import Arch,FreeCADGui
      +node = Arch.makeSolarDiagram(-46.38,-23.33) # longitude, latitude, [scale]
      +FreeCADGui.ActiveDocument.ActiveView.getSceneGraph().addChild(node) 
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Arch_Site.svg b/localwiki/Arch_Site.svg new file mode 100644 index 0000000..38a3ebb --- /dev/null +++ b/localwiki/Arch_Site.svg @@ -0,0 +1,71 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [wmayer] + + + Arch_Site + 2011-10-10 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Arch/Resources/icons/Arch_Site.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + diff --git a/localwiki/Arch_Site_Tree.svg b/localwiki/Arch_Site_Tree.svg new file mode 100644 index 0000000..1545a06 --- /dev/null +++ b/localwiki/Arch_Site_Tree.svg @@ -0,0 +1,71 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [yorikvanhavre] + + + Arch_Site_Tree + 2011-12-06 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Arch/Resources/icons/Arch_Site_Tree.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + diff --git a/localwiki/Arch_Space.html b/localwiki/Arch_Space.html new file mode 100644 index 0000000..bf01a8b --- /dev/null +++ b/localwiki/Arch_Space.html @@ -0,0 +1,99 @@ +Arch Space

      Arch Space

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Arch Space.png Arch Space

      +
      Menu location +
      Arch → Space +
      Workbenches +
      Arch +
      Default shortcut +
      S P +
      See also +
      None +

      + +
      +


      +

      +

      Description

      +

      The Space tool allows you to define an empty volume, either by basing it on a solid shape, or by defining its boundaries, or a mix of both. If it is based solely on boundaries, the volume is calculated by starting from the bounding box of all the given boundaries, and subtracting the spaces behind each boundary. The space object always defines a solid volume. The floor area of a space object, calculated by intersecting a horizontal plane at the center of mass of the space volume, can also be displayed, by setting the display mode of the space object to "detailed". +

      Arch Space example.jpg +

      In the above image, a space object is created from an existing solid object, then two wall faces are added as boundaries, and the display mode is set to "detailed" to show the floor area. +

      +

      How to use

      +
      1. Select an existing solid object, or faces on boundary objects
      2. +
      3. Press the Arch Space.png Arch Space button, or press S, P keys
      +

      Properties

      +
      • DATABase: The base object, if any (must be a solid)
      • +
      • DATABoundaries: A list of optional boundary elements
      +

      Scripting

      +

      The space tool can be used in python scripts and macros by using the following function: +

      +
      makeSpace(objects) 
      +
      • Creates a space object from the given objects.
      • +
      • Objects can be one document object, in which case it becomes the base shape of the space object, or a list of selection objects as returned by FreeCADGui.Selection.getSelectionEx(), or a list of tuples (object, subobjectname).
      • +
      • Returns the newly created space object.
      +

      Example: +

      +
      import FreeCAD, Arch, Part
      +b = Part.makeBox(2,2,2)
      +FreeCAD.ActiveDocument.addObject("Part::Feature","Box").Shape=b
      +sp = makeSpace([FreeCAD.ActiveDocument.Box]) 
      +

      After a space object is created, selected faces can be added to it with the following function: +

      +
      import FreeCADGui
      +Arch.addSpaceBoundaries(sp, FreeCADGui.Selection.getSelectionEx()) 
      +

      Boundaries can also be removed with: +

      +
      Arch.removeSpaceBoundaries(sp, FreeCADGui.Selection.getSelectionEx()) 
      +

      Limitations

      +
      • Not available below FreeCAD version 0.14
      • +
      • The boundaries properties is currently not editable via GUI
      • +
      • See the forum announcement
      +
      +


      +

      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Arch_Space.svg b/localwiki/Arch_Space.svg new file mode 100644 index 0000000..a4c1f4b --- /dev/null +++ b/localwiki/Arch_Space.svg @@ -0,0 +1,114 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [Yorik van Havre] + + + Arch_Space + 2013-07-16 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Arch/Resources/icons/Arch_Space.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Arch_Space_Tree.svg b/localwiki/Arch_Space_Tree.svg new file mode 100644 index 0000000..83fe9c3 --- /dev/null +++ b/localwiki/Arch_Space_Tree.svg @@ -0,0 +1,112 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [Yorik van Havre] + + + Arch_Space_Tree + 2013-07-16 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Arch/Resources/icons/Arch_Space_Tree.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Arch_SplitMesh.html b/localwiki/Arch_SplitMesh.html new file mode 100644 index 0000000..25da377 --- /dev/null +++ b/localwiki/Arch_SplitMesh.html @@ -0,0 +1,73 @@ +Arch SplitMesh

      Arch SplitMesh

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Arch SplitMesh.png Arch SplitMesh

      +
      Menu location +
      Arch → Utilities → Split Mesh +
      Workbenches +
      Arch +
      Default shortcut +
      None +
      See also +
      Arch SelectNonSolidMeshes +

      + +
      +


      +

      +

      Description

      +

      This tool splits a selected Mesh object into its separate components +

      +

      How to use

      +
      1. Select a mesh object
      2. +
      3. Press the Arch SplitMesh.png Split Mesh entry in Arch -> Utilities menu
      +

      Scripting

      +

      The Split Mesh tool can by used in macros and from the python console by using the following function: +

      +
      splitMesh (object,[mark]) 
      +

      splits the given mesh object into separated components. +

      If mark is False, nothing else is done. If True (default), non-manifold components will be painted in red. +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Arch_SplitMesh.svg b/localwiki/Arch_SplitMesh.svg new file mode 100644 index 0000000..b2b6952 --- /dev/null +++ b/localwiki/Arch_SplitMesh.svg @@ -0,0 +1,64 @@ + + + + + + + + + + + + + image/svg+xml + + + + + [wmayer] + + + Arch_SplitMesh + 2011-10-10 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Arch/Resources/icons/Arch_SplitMesh.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Arch_Stairs.html b/localwiki/Arch_Stairs.html new file mode 100644 index 0000000..9268337 --- /dev/null +++ b/localwiki/Arch_Stairs.html @@ -0,0 +1,114 @@ +Arch Stairs

      Arch Stairs

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Arch Stairs.png Arch Stairs

      +
      Menu location +
      Arch → Stairs +
      Workbenches +
      Arch +
      Default shortcut +
      S R +
      See also +
      None +

      + +
      +


      +

      +

      Description

      +

      The stairs tool allows you to build automatically several types of stairs. At the moment, only straight stairs (with or without a central landing) are supported. Stairs can be built from scratch, or from a straight line, in which case the stairs follow the line. If the line is not horizontal but has a vertical inclination, the stairs will also follow its slope. +

      See the Stairs entry in wikipedia for a definition of the different terms used to describe parts of stairs. +

      Arch Stairs example.jpg +

      On the above image, two stairs were created, one with a massive structure and a landing, and another one with a single stringer. +

      +

      Options

      + +

      How to use

      +
      1. Press the Arch Stairs.png Arch Stairs button, or press S, R keys
      2. +
      3. Adjust the desired properties. Some parts of the stairs, such as the structure, might not appear immediately, if any of the properties makes it impossible, such as a structure thickness of 0.
      +

      Properties

      +

      Base +

      +
      • DATAAlign: The alignment of these stairs on their baseline, if applicable.
      • +
      • DATABase: The baseline of these stairs, if any.
      • +
      • DATAHeight: The total height of these stairs, if not based on a baseline, or the baseline is horizontal.
      • +
      • DATALength: The total length of these stairs if no baseline is defined.
      • +
      • DATAWidth: The width of these stairs.
      +

      Steps +

      +
      • DATANosing: The size of the nosing.
      • +
      • DATANumber of Steps: The numbers of steps (risers) in these stairs.
      • +
      • DATARiser Height: The height of the risers.
      • +
      • DATATread Depth: The depth of the treads.
      • +
      • DATATread Thickness: The thickness of the treads.
      +

      Structure +

      +
      • DATALandings: The type of landings.
      • +
      • DATAStringer Offset: The offset between the border of the stairs and the structure.
      • +
      • DATAStringer Width: The width of the stringers.
      • +
      • DATAStructure: The type of structure of these stairs.
      • +
      • DATAStructure Thickness: The thickness of the structure.
      • +
      • DATAWinders: The type of winders.
      +

      Scripting

      +

      Stairs can be created from python scripts and macros by using the following function: +

      +
      makeStairs([base], [length], [width], [height], [steps]) 
      +
      • Creates a stairs object with the given attributes.
      • +
      • Returns the new stairs object.
      +

      Example: +

      +
      import Arch
      +makeStairs(length=5, width=1.2, height=3, steps=14) 
      +

      Limitations

      +
      • Not available before FreeCAD version 0.14
      • +
      • Only straight stairs are available at the moment
      • +
      • See the forum entry for circle stairs.
      • +
      • See the forum announcement.
      +
      +


      +

      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Arch_Stairs.svg b/localwiki/Arch_Stairs.svg new file mode 100644 index 0000000..add894a --- /dev/null +++ b/localwiki/Arch_Stairs.svg @@ -0,0 +1,138 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [Yorik van Havre] + + + Arch_Stairs + 2013-07-25 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Arch/Resources/icons/Arch_Stairs.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Arch_Stairs_Tree.svg b/localwiki/Arch_Stairs_Tree.svg new file mode 100644 index 0000000..62007ac --- /dev/null +++ b/localwiki/Arch_Stairs_Tree.svg @@ -0,0 +1,138 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [Yorik van Havre] + + + Arch_Stairs_Tree + 2013-07-25 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Arch/Resources/icons/Arch_Stairs_Tree.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Arch_StructuralSystem.svg b/localwiki/Arch_StructuralSystem.svg new file mode 100644 index 0000000..740715a --- /dev/null +++ b/localwiki/Arch_StructuralSystem.svg @@ -0,0 +1,112 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [Yorik van Havre] + + + Arch_StructuralSystem + 2014-03-28 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Arch/Resources/icons/Arch_StructuralSystem.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Arch_StructuralSystem_Tree.svg b/localwiki/Arch_StructuralSystem_Tree.svg new file mode 100644 index 0000000..4932ff1 --- /dev/null +++ b/localwiki/Arch_StructuralSystem_Tree.svg @@ -0,0 +1,112 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [Yorik van Havre] + + + Arch_StructuralSystem_Tree + 2014-03-28 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Arch/Resources/icons/Arch_StructuralSystem_Tree.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Arch_Structure.html b/localwiki/Arch_Structure.html new file mode 100644 index 0000000..4558f17 --- /dev/null +++ b/localwiki/Arch_Structure.html @@ -0,0 +1,115 @@ +Arch Structure

      Arch Structure

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Arch Structure.png Arch Structure

      +
      Menu location +
      Arch → Structure +
      Workbenches +
      Arch +
      Default shortcut +
      S T +
      See also +
      Arch Wall +

      + +
      +


      +

      +

      Description

      +

      This tool allows you to build structural elements such as columns or beams, by specifying their width, length and height, or by basing them on a 2D profile. +

      Arch Structure example.jpg +

      The above image shows a column based on a 2D base profile, a column and a beam based on no profile (defined by their height, length and width dimensions) and a metallic profile based on a 2D contour (face, wire or sketch). Additionally, a certain number of presets available during object creation, allow you to quickly build a structural element from a predefined standard profile. +

      +

      How to use

      +
      1. Select a 2D shape (draft object, face or sketch) (optional)
      2. +
      3. Press the Arch Structure.png Arch Structure button, or press S then T keys
      4. +
      5. Adjust the desired properties
      +

      Options

      +
      • Structural elements share the common properties and behaviours of all Arch Components
      • +
      • If no object is selected, a default 3-dimension block is created
      • +
      • The height, width and length of a structure can be adjusted after creation
      • +
      • Press ESC or the Cancel button to abort the current command.
      • +
      • Double-clicking on the structure in the tree view after it is created allows you to enter edit mode and access and modify its additions and subtractions
      • +
      • In edit mode, it is also possible to add axes systems to the structural element. When adding one axes system, the structural element will be copied once on each axis of the system. When adding two axes systems, the structural element will be copied once on each intersection of the two systems.
      +

      Properties

      +
      • DATALength: The length of the structure (only used if not based on a profile)
      • +
      • DATAWidth: The width of the structure (only used if not based on a profile)
      • +
      • DATAHeight: The height of the structure (or the extrusion length when based on a profile). If no height is given, and the structure is inside a floor object with its height defined, the structure will automatically take the value of the floor height.
      • +
      • DATANodes Offset: An optional offset between the centerline and the nodes line
      • +
      • VIEWNodes Type: The type of structural nodes of this object, linear or area.
      • +
      • VIEWShow Nodes: Shows or hides the structural nodes.
      +

      Presets

      +

      The Structure tool also features a series of presets that allow to quickly build standard metallic profiles or precast concrete elements. +

      Arch presets example.jpg +

      The presets are obtained by choosing a Category from the structure options panel. Available categories are Precast concrete or any of the industry-standard metallic profiles such as HEA, HEB or INP. For each of these categories, a number of presets are available. Once a preset is chosen, its individual parameters such as Length, Width or Height can be adjusted. However, for metallic profiles, the profile size is set by the preset and cannot be changed. +

      The Switch L/H button can be used to switch Length and Height values, and therefore building a horizontal beam rather than a vertical column. +

      Arch precast example.jpg +

      +

      Structural nodes

      +

      Structural objects also have the ability to display structural nodes. Structural nodes are a sequence of 3D points stored in a "Nodes" property. By switching the "Show Nodes" view property on/off, one can see the structural nodes of a structural element: +

      Arch structural nodes.jpg +

      +
      • Nodes are calculated and updated automatically, as long as you don't modify them manually. If you did, they won't be updated if the shape of the structural object changes, unless you use the "Reset nodes" tool below.
      • +
      • Arch structures can have not only linear nodes, but also planar nodes. For this, 1- There must be at least 3 vectors in the "Nodes" property of the object, 2- the "NodesType" property of their ViewObject must be set to "Area".
      • +
      • When the nodes calculation is automatic (that is, if you never touched them manually), when setting the Role property of a structure to "Slab", it will automatically become a planar node (there will be more than 3 vectors and the NodesType will be set to "Area").
      • +
      • When editing a structure object (double-click), a couple of node tools are available in the task view: +
        • Reset the nodes to automatic calculation, in case you modified them manually
        • +
        • Edit the nodes graphically, works the same way as Draft Edit
        • +
        • Extend the nodes of the edited object until it touches the node of another object
        • +
        • Make the node of this object and another one coincident
        • +
        • Toggle the display of all nodes of all structural objects of the document on/off
      +

      Scripting

      +

      The Structure tool can by used in macros and from the python console by using the following function: +

      +
      makeStructure ([obj],[length],[width],[height],[name]) 
      +
      creates a structure element based on the given profile object and the given extrusion height. If no base object is given, you can also specify length and width for a cubic object.
      +

      Example: +

      +
      import Arch
      +Arch.makeStructure(0.5,1,3) 
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Arch_Structure.svg b/localwiki/Arch_Structure.svg new file mode 100644 index 0000000..bae94bf --- /dev/null +++ b/localwiki/Arch_Structure.svg @@ -0,0 +1,109 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [wmayer] + + + Arch_Structure + 2011-10-10 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Arch/Resources/icons/Arch_Structure.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Arch_Structure_Clone.svg b/localwiki/Arch_Structure_Clone.svg new file mode 100644 index 0000000..ffd8f2d --- /dev/null +++ b/localwiki/Arch_Structure_Clone.svg @@ -0,0 +1,738 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [Yorik van Havre] + + + Arch_Structure_Clone + 2016-06-15 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Arch/Resources/icons/Arch_Structure_Clone.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Arch_Structure_Tree.svg b/localwiki/Arch_Structure_Tree.svg new file mode 100644 index 0000000..54d1155 --- /dev/null +++ b/localwiki/Arch_Structure_Tree.svg @@ -0,0 +1,117 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [yorikvanhavre] + + + Arch_Structure_Tree + 2011-12-06 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Arch/Resources/icons/Arch_Structure_Tree.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Arch_Structure_example.jpg b/localwiki/Arch_Structure_example.jpg new file mode 100644 index 0000000..e62ca64 Binary files /dev/null and b/localwiki/Arch_Structure_example.jpg differ diff --git a/localwiki/Arch_Survey.html b/localwiki/Arch_Survey.html new file mode 100644 index 0000000..b41ad67 --- /dev/null +++ b/localwiki/Arch_Survey.html @@ -0,0 +1,98 @@ +Arch Survey

      Arch Survey

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Arch Survey.png Arch Survey

      +
      Menu location +
      Arch → Survey +
      Workbenches +
      Arch +
      Default shortcut +
      None +
      See also +
      FCInfo (macro) +

      + +
      +


      +

      +

      Description

      +

      The survey tool enters a special surveying mode, which allows you to quickly grab measures and information from a model, and transfer that information to other applications. Once you are in Survey mode, clicking on different subelements of 3D objects gathers the following information, depending on what you click: +

      +
      • If you click on an edge, you get its length
      • +
      • If you click on a vertex, you get its height (coordinate on the Z axis)
      • +
      • If you click on a face, you get its area
      • +
      • If you double-click anything, therefore select the whole object, you get its volume
      +

      When such a piece of information is gathered, several things happen: +

      +
      • A label is placed on top of the element you clicked, that displays the value (with "a" for area, "l" for length, "z" for height, or "v" for volume)
      • +
      • The numeric value is copied to the clipboard, so you can paste it in another application
      • +
      • A line is printed on the FreeCAD output window. After you exit the survey mode, those lines can be copied and pasted in another application (the values are comma-separated, making it easy to convert to spreadsheet data)
      • +
      • The total length or area of the elements you clicked so far is also printed in the output window
      • +
      • Each length or area is also recorded in the task dialog
      +

      Arch Survey example.jpg +

      The above image shows what happens when running the survey mode. +

      +

      How to use

      +
      1. Press the Arch Survey.png Arch Survey button
      2. +
      3. Click on vertices, edges, faces or double-click to select whole objects
      4. +
      5. Click outside any geometry (on the background of the 3D view) to remove existing labels, print a total line in the Task dialog, and restart counting lengths and areas from zero
      6. +
      7. Press ESC or the Close button to exit survey mode and remove all the labels.
      +

      Options

      +
      • You can add a custom label to any line in the Task dialog by clicking that line, then adding a text in the description field, then press the set description button.
      • +
      • Once you are done, before closing, you can export the contents of the Task dialog by pressing the "export CSV" button. The resulting CSV file can then be opened in any spreadsheet application such as Excel or LibreOffice Calc. The values and units will be separated in the resulting CSV file, and the totals are written as SUM() functions.
      +

      Arch Survey spreadsheet.jpg +

      +

      Scripting

      +

      The Survey mode cannot be used directly from python scripts, but gathering the same information from any selected Part-based object is easy reproduced with the following script: +

      +
      import FreeCADGui
      +selection = FreeCADGui.Selection.getSelectionEx()
      +for obj in selection:
      +   for element in obj.SubObjects:
      +       print "Area: ", element.Area
      +       print "Length: ", element.Length
      +       print "Volume: ", element.Volume
      +       print "Center of Mass: ", element.CenterOfMass 
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Arch_Survey.svg b/localwiki/Arch_Survey.svg new file mode 100644 index 0000000..58fb62c --- /dev/null +++ b/localwiki/Arch_Survey.svg @@ -0,0 +1,116 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [Yorik van Havre] + + + Arch_Survey + 2014-02-11 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Arch/Resources/icons/Arch_Survey.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + diff --git a/localwiki/Arch_Survey_spreadsheet.jpg b/localwiki/Arch_Survey_spreadsheet.jpg new file mode 100644 index 0000000..e773098 Binary files /dev/null and b/localwiki/Arch_Survey_spreadsheet.jpg differ diff --git a/localwiki/Arch_ToggleIfcBrepFlag.html b/localwiki/Arch_ToggleIfcBrepFlag.html new file mode 100644 index 0000000..f95705b --- /dev/null +++ b/localwiki/Arch_ToggleIfcBrepFlag.html @@ -0,0 +1,65 @@ +Arch ToggleIfcBrepFlag

      Arch ToggleIfcBrepFlag

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Arch ToggleIfcBrepFlag.png Arch ToggleIfcBrepFlag

      +
      Menu location +
      Arch → Utilities → Toggle Ifc Brep flag +
      Workbenches +
      Arch +
      Default shortcut +
      +
      See also +
      +

      + +
      +


      +

      +

      Description

      +

      This tool turns the IfcBrep flag of a selected Arch object on/off (the default is always off). If the flag in on, when exported to IFC, the object will be exported as an IfcFacetedBrep object, even if a higher-level kind of export such as IfcExtrudedAreaSolid or IfcBooleanResult is possible. Although IfcFacetedBrep objects are heavier and less editable (they loose some geometry information such as the modeling history), they are often less error-prone. Setting this flag allows to solve some cases of objects that are not exported correctly when the flag is not set. +

      +

      How to use

      +
      1. Select an Arch object
      2. +
      3. Select menu Arch → Utilities → Arch ToggleIfcBrepFlag.png Toggle IfcBrepFlag
      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Arch_ToggleIfcBrepFlag.svg b/localwiki/Arch_ToggleIfcBrepFlag.svg new file mode 100644 index 0000000..d5dd308 --- /dev/null +++ b/localwiki/Arch_ToggleIfcBrepFlag.svg @@ -0,0 +1,68 @@ + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [Yorik van Havre] + + + Arch_ToggleIfcBrepFlag + 2014-07-15 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Arch/Resources/icons/Arch_ToggleIfcBrep + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Arch_ToggleSubs.html b/localwiki/Arch_ToggleSubs.html new file mode 100644 index 0000000..07db03d --- /dev/null +++ b/localwiki/Arch_ToggleSubs.html @@ -0,0 +1,69 @@ +Arch ToggleSubs

      Arch ToggleSubs

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Arch ToggleSubs.png Arch ToggleSubs

      +
      Menu location +
      Arch → Utilities → Toggle Subcomponents +
      Workbenches +
      Arch +
      Default shortcut +
      ‏‎ +
      See also +
      +

      + +
      +


      +

      +

      Description

      +

      This tools toggles the visibility of all the subtractions of an Arch object between visible and hidden. If an Arch object contains some visible and some hidden subtracted objects, they will all become visible/hidden after running this command. +

      +

      How to use

      +
      1. Select an Arch object that has subtractions
      2. +
      3. Select menu Arch → Utilities → Arch ToggleSubs.png Toggle Subcomponents‏‎
      +

      Options

      +

      The Edit -> Preferences → Arch → Apply Construction style preference option allows to give all new subtractions the construction color given in Preferences → Draft → General Draft settings, which give better output with this command. +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Arch_ToggleSubs.svg b/localwiki/Arch_ToggleSubs.svg new file mode 100644 index 0000000..993c0e6 --- /dev/null +++ b/localwiki/Arch_ToggleSubs.svg @@ -0,0 +1,125 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [Yorik van Havre] + + + Arch_ToggleSubs + 2016-09-20 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Arch/Resources/icons/Arch_ToggleSubs.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Arch_Wall.html b/localwiki/Arch_Wall.html new file mode 100644 index 0000000..516ee32 --- /dev/null +++ b/localwiki/Arch_Wall.html @@ -0,0 +1,141 @@ +Arch Wall

      Arch Wall

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Arch Wall.png Arch Wall

      +
      Menu location +
      Arch → Wall +
      Workbenches +
      Arch +
      Default shortcut +
      W A +
      See also +
      Arch Structure +

      + +
      +


      +

      +

      Description

      +

      This tool builds a Wall object from scratch or on top of any other shape-based or mesh-based object. A wall can be built without any base object, in which case it behaves as a cubic volume, using length, width and height properties. When built on top of an existing shape, a wall can be based on: +

      +
      • A linear 2D object, such as lines, wires, arcs or sketches, in which case you can change thickness, alignment(right, left or centered) and height. The length property has no effect.
      • +
      • A flat face, in which case you can only change the height. Length and width properties have no effect. If the base face is vertical, however, the wall will use the width property instead of height, allowing you to build walls from space-like objects or mass studies.
      • +
      • A solid, in which case length, width and height properties have no effect. The wall simply uses the underlying solid as its shape.
      • +
      • A mesh, in which case the underlying mesh must be a closed, manifold solid.
      +

      Arch Wall example.jpg +Example of walls built from a line, a wire, a face, a solid and a sketch +

      Walls can also have additions or subtractions. Additions are other objects whose shapes are joined in this Wall's shape, while subtractions are subtracted. Additions and subtractions can be added with the Arch Add and Arch Remove tools. Additions and subtractions have no influence over wall parameters such as height and width, which can still be changed. Walls can also have their height automatic, if they are included into a higher-level object such as floors. The height must be kept at 0, then the wall will adopt the height specified in the parent object. +

      When several walls should intersect, you need to place them into a floor to have their geometry intersected. +

      +

      How to use

      +

      Drawing a wall from scratch

      +
      1. Press the Arch Wall.png Arch Wall button, or press W then A keys
      2. +
      3. Click a first point on the 3D view, or type a coordinate
      4. +
      5. Click a second point on the 3D view, or type a coordinate
      +

      Drawing a wall on top of a selected object

      +
      1. Select one or more base geometry objects (Draft object, sketch, etc)
      2. +
      3. Press the Arch Wall.png Arch Wall button, or press the W then A keys
      4. +
      5. Adjust needed properties such as height or width.
      +

      Options

      +
      • Walls share the common properties and behaviours of all Arch Components
      • +
      • The height, width and alignment of a wall can be set during drawing, via the task panel
      • +
      • When snapping a wall to an existing wall, both walls will be joined into one. The way the two walls are joined depends on their properties: If they have the same width, height and alignment, and if the option "join base sketches" is enabled in the Arch preferences, the resulting wall will be one object based on a sketch made of several segments. Otherwise, the latter wall will be added to the first one as addition.
      • +
      • Press X, Y or Z after the first point to constrain the second point on the given axis.
      • +
      • To enter coordinates manually, simply enter the numbers, then press ENTER between each X, Y and Z component.
      • +
      • Press R or click the checkbox to check/uncheck the Relative button. If relative mode is on, the coordinates of the second point are relative to the first one. If not, they are absolute, taken from the (0,0,0) origin point.
      • +
      • Press SHIFT while drawing to constrain your second point horizontally or vertically in relation to the first one.
      • +
      • Press ESC or the Cancel button to abort the current command.
      • +
      • Double-clicking on the wall in the tree view after it is created allows you to enter edit mode and access and modify its additions and subtractions
      • +
      • Multi-layer walls can be easily created by building several walls from the same baseline. By setting their Align property to either left or right, and specifying an Offset value, you can effectively construct several wall layers. Placing a window in such a wall layer will propagate the opening to the other wall layers based on the same baseline.
      • +
      • Walls can also make use of Multi-Materials. When using a multi-material, the wall will become multi-layer, using the thicknesses specified by the multi-material. Any layer with a thickness of zero will have its thickness defined automatically by the remaining space defined by the Wall's Width value, after subtracting the other layers.
      • +
      • Walls can be made to display blocks, instead of one single solid, by turning their Make Blocks property on. The size and offset of blocks can be configured with different properties, and the amount of blocks is automatically calculated. available in version 0.18
      +


      +

      +

      Snapping

      +

      Snapping works a bit differently with Arch walls than other Arch and Draft objects. If a wall has a baseline object, snapping will anchor to the base object, instead of the wall geometry, allowing to easily align walls by their baseline. If, however, you specifically want to snap to the wall geometry, pressing CTRL will switch snapping to the wall object. +

      Arch wall snap.jpg +

      +

      Properties

      +

      Wall objects inherit the properties of Part objects, and also have the following extra properties: +

      +
      • DATAAlign: The alignment of the wall on its baseline: Left, right or center
      • +
      • DATABase: The base object this wall is built on
      • +
      • DATAFace: The index of the face from the base object to use. If the vaue is not set or 0, the whole object is used
      • +
      • DATAForce Wire: If True, and the wall is based on a face, only the border wire of the face is used, resulting in a wall bordering the face
      • +
      • DATALength: The length of the wall (not used when the wall is based on an object)
      • +
      • DATAWidth: The width of the wall (not used when the wall is based on a face)
      • +
      • DATAHeight: The height of the wall (not used when the wall is based on a solid). If no height is given, and the wall is inside a floor object with its height defined, the wall will automatically take the value of the floor height.
      • +
      • DATANormal: An extrusion direction for the wall. If set to (0,0,0), the extrusion direction is automatic.
      • +
      • DATAOffset: This specifies the distance between the wall and its baseline. Works only if the Align property is set to Right or Left.
      +

      available in version 0.18 +

      +
      +
      • DATAMake Blocks: Enable this to make the wall generate blocks
      • +
      • DATABlock Length: The length of each block
      • +
      • DATABlock Height: The height of each block
      • +
      • DATAOffset First: The horizontal offset of the first line of blocks
      • +
      • DATAOffset Second: The horizontal offset of the second line of blocks
      • +
      • DATAJoint: The size of the joints between each block
      • +
      • DATACount Entire: The number of entire blocks (read-only)
      • +
      • DATACount Broken: The number of broken blocks (read-only)
      +

      Scripting

      +

      The Wall tool can by used in macros and from the python console by using the following function: +

      +
      makeWall ( [obj],[length],[width],[height],[align],[face],[name] ) 
      +
      • Creates a wall based on the given object, which can be a sketch, a draft object, a face or a solid. align can be "Center","Left" or "Right". If you provide no base object, then you can use numeric values for length, width and height. Face can be used to give the index of a face from the underlying object, to build this wall on, instead of using the whole object.
      • +
      • Returns the created wall, or None if the operation failed.
      +

      Example: +

      +
      import FreeCAD, Draft, Arch
      +baseline = Draft.makeLine(FreeCAD.Vector(0,0,0),FreeCAD.Vector(2,0,0))
      +Arch.makeWall(baseline,None,0.1,2) 
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Arch_Wall.svg b/localwiki/Arch_Wall.svg new file mode 100644 index 0000000..5065f45 --- /dev/null +++ b/localwiki/Arch_Wall.svg @@ -0,0 +1,100 @@ + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [wmayer] + + + Arch_Wall + 2011-10-10 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Arch/Resources/icons/Arch_Wall.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Arch_Wall_Tree.svg b/localwiki/Arch_Wall_Tree.svg new file mode 100644 index 0000000..a5d2f10 --- /dev/null +++ b/localwiki/Arch_Wall_Tree.svg @@ -0,0 +1,100 @@ + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [yorikvanhavre] + + + Arch_Wall_Tree + 2011-12-06 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Arch/Resources/icons/Arch_Wall_Tree.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Arch_Wall_Tree_Assembly.svg b/localwiki/Arch_Wall_Tree_Assembly.svg new file mode 100644 index 0000000..fb7ec5f --- /dev/null +++ b/localwiki/Arch_Wall_Tree_Assembly.svg @@ -0,0 +1,167 @@ + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [Yorik van Havre] + + + Arch_Wall_Tree_Assembly + 2013-04-17 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Arch/Resources/icons/Arch_Wall_Tree_Assembly.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Arch_Wikihouse_01.jpg b/localwiki/Arch_Wikihouse_01.jpg new file mode 100644 index 0000000..3534247 Binary files /dev/null and b/localwiki/Arch_Wikihouse_01.jpg differ diff --git a/localwiki/Arch_Wikihouse_02.jpg b/localwiki/Arch_Wikihouse_02.jpg new file mode 100644 index 0000000..e70e029 Binary files /dev/null and b/localwiki/Arch_Wikihouse_02.jpg differ diff --git a/localwiki/Arch_Wikihouse_03.jpg b/localwiki/Arch_Wikihouse_03.jpg new file mode 100644 index 0000000..29b2a05 Binary files /dev/null and b/localwiki/Arch_Wikihouse_03.jpg differ diff --git a/localwiki/Arch_Wikihouse_04.jpg b/localwiki/Arch_Wikihouse_04.jpg new file mode 100644 index 0000000..8a03868 Binary files /dev/null and b/localwiki/Arch_Wikihouse_04.jpg differ diff --git a/localwiki/Arch_Wikihouse_05.jpg b/localwiki/Arch_Wikihouse_05.jpg new file mode 100644 index 0000000..1d5179a Binary files /dev/null and b/localwiki/Arch_Wikihouse_05.jpg differ diff --git a/localwiki/Arch_Wikihouse_06.jpg b/localwiki/Arch_Wikihouse_06.jpg new file mode 100644 index 0000000..85600e6 Binary files /dev/null and b/localwiki/Arch_Wikihouse_06.jpg differ diff --git a/localwiki/Arch_Wikihouse_07.jpg b/localwiki/Arch_Wikihouse_07.jpg new file mode 100644 index 0000000..f61e388 Binary files /dev/null and b/localwiki/Arch_Wikihouse_07.jpg differ diff --git a/localwiki/Arch_Wikihouse_08.jpg b/localwiki/Arch_Wikihouse_08.jpg new file mode 100644 index 0000000..20f87b6 Binary files /dev/null and b/localwiki/Arch_Wikihouse_08.jpg differ diff --git a/localwiki/Arch_Wikihouse_09.jpg b/localwiki/Arch_Wikihouse_09.jpg new file mode 100644 index 0000000..e2c3a3a Binary files /dev/null and b/localwiki/Arch_Wikihouse_09.jpg differ diff --git a/localwiki/Arch_Wikihouse_10.jpg b/localwiki/Arch_Wikihouse_10.jpg new file mode 100644 index 0000000..6dbf788 Binary files /dev/null and b/localwiki/Arch_Wikihouse_10.jpg differ diff --git a/localwiki/Arch_Wikihouse_11.jpg b/localwiki/Arch_Wikihouse_11.jpg new file mode 100644 index 0000000..c976c50 Binary files /dev/null and b/localwiki/Arch_Wikihouse_11.jpg differ diff --git a/localwiki/Arch_Wikihouse_12.jpg b/localwiki/Arch_Wikihouse_12.jpg new file mode 100644 index 0000000..ebe6781 Binary files /dev/null and b/localwiki/Arch_Wikihouse_12.jpg differ diff --git a/localwiki/Arch_Window.html b/localwiki/Arch_Window.html new file mode 100644 index 0000000..3172025 --- /dev/null +++ b/localwiki/Arch_Window.html @@ -0,0 +1,193 @@ +Arch Window

      Arch Window

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Arch Window.png Arch Window

      +
      Menu location +
      Arch → Window +
      Workbenches +
      Arch +
      Default shortcut +
      W I +
      See also +
      Arch Wall +

      + +
      +


      +

      +

      Description

      +

      The Window is a base object for all kinds of "embeddable" objects, such as windows, doors, etc... It is designed to be either independent, or "hosted" inside another component such as a wall. It has its own geometry, that can be made of several solid components (the window frame, or inner panels for example), and also defines a volume to be subtracted to host objects, in order to create an opening. +

      Window objects are based on closed 2D objects, such as Draft Rectangles or Sketches, that are used to define their inner components. The base 2D object must therefore contain several closed wires, that can be combined to form filled panels (one wire) or frames (several wires). +

      The window tool features several presets, that allow to create full doors or windows from a list of parameters, without the need to create the base 2D objects and components manually. But windows can also be created from scratch, by drawing a base 2D object first. +

      Arch Window example.jpg +

      In the above image, a window is constructed on top of a Draft Rectangle, then inserted into a Wall. Adding a window to a wall automatically cuts a correct opening in the host wall. +

      Arch Window example2.jpg +

      The above image shows a more complex window being constructed on top of a sketch. When entering the window's edit mode, you can create different components, set their thickness, and select and assign wires from the sketch to them. +

      +

      How to use

      +

      Using a preset

      +
      1. Optionally, select an Arch object. If no object is selected, the window will be inserted in the object under the mouse when placing the window.
      2. +
      3. Press the Arch Window.png Arch Window button, or press W then I keys
      4. +
      5. Select one of the presets in the list
      6. +
      7. Fill out the desired parameters
      8. +
      9. Press the OK button
      +

      Creating from scratch

      +
      1. Optionally, select a face on the Arch object where you want the window to be incuded
      2. +
      3. Switch to the Sketcher Workbench
      4. +
      5. Create a new sketch
      6. +
      7. Draw one or more closed wires
      8. +
      9. Close the sketch
      10. +
      11. Switch back to the Arch Workbench
      12. +
      13. Press the Arch Window.png Arch Window button, or press W then I keys
      14. +
      15. Enter Edit mode by double-clicking the window in the tree view, to adjust the window components
      +

      Presets

      +

      The following presets are available: +

      + +

      Building components

      +

      Windows can include 3 types of components: panels, frames and louvres. Panels and louvres are made from one closed wire, which gets extruded, while frames are made from 2 or more closed wire, where each one is extruded, then the smaller ones are subtracted from the biggest one. You can access, create, modify and delete components of a window in edit mode (double-click the window in the Tree view). The components have the following properties: +

      +
      • Name: A name for the component
      • +
      • Type: The type of component. Can be "Frame", "Glass panel", "Solid panel" or "Louvres"
      • +
      • Wires: A comma-separated list of wires the component is based on
      • +
      • Thickness: The extrusion thickness of the component
      • +
      • Z Offset: The distance between the component and its base 2D wire(s)
      • +
      • Hinge: This allows you to select an edge from the base 2D object, then set that edge as a hinge for this component and the next ones in the list
      • +
      • Opening mode: If you defined a hinge in this component or any other earlier in the list, setting the opening mode will allow the window to appear open or to display 2D opening symbols in plan or elevation.
      +

      Arch Window options.jpg +

      +

      Options

      +
      • Windows share the common properties and behaviours of all Arch Components
      • +
      • If the Auto-includecheckbox on the Window creation task panel is unchecked, the window won't be inserted into any host object on creation.
      • +
      • Add a selected window to a wall by selecting both, then pressing the Arch Add.png Arch Add button.
      • +
      • Remove a selected window from a wall by selecting the window, then pressing the Arch Remove.png Arch Remove button.
      • +
      • When using presets, it is often convenient to turn the "Near" Draft Snap on, so you can snap your window to an existing face.
      • +
      • The hole created by a window in its host object is determined by two properties: Hole Depth and Hole Wire (available in version 0.17
      +

      ). The Hole Wire number can be picked in the 3D view from the window's task panel available when double-clicking the window in the tree view +

      +
      • Windows can make use of Multi-Materials. The window will search in the attached Multi-Material for material layers with a same name for each of its window component, and use it if any is found. For example, a component named "OuterFrame" will search in the attached Multi-Material, for a material layer named "OuterFrame". If such material layer is found, its material will be attributed to the OuterFrame component. The thickness value of the material layer is disregarded.
      +

      Doors

      +

      Doors can be made easily with the window tool, you only need to draw the base of the inner wire touching the exterior wire like in the image below. +

      Door +

      +

      Openings

      +

      Doors and windows can appear partially or fully open in the 3D model, or can display opening symbols both in plan and/or elevation. Consequently, these will also appear in extracted 2D views generated by Draft Shape2DView or TechDraw Workbench or Drawing Workbench. To obtain this, at least one of the window components must have a hinge and an opening mode defined (see the 'Building Components' section above). Then, using the Opening, Symbol Plan or Symbol Elevation properties, you can configure the appearance of the window: +

      A door showing from left to right the Symbol Plan, Symbol Elevation and Opening properties at work +

      +

      Properties

      +
      • DATAHeight: The height of this window
      • +
      • DATAWidth: The width of this window
      • +
      • DATAHole Depth: The depth of the hole created by this window in its host object
      • +
      • DATAHole Wire: The number of the wire from the base object that is used to create a hole in the host object of this window. This value can be set graphically when double-clicking the window in the tree view. Setting a value of 0 will make the window automatically pick its biggest wire for the hole.
      • +
      • DATAWindow Parts: A list of strings (5 strings per component, setting the component options above)
      • +
      • DATALouvre Width: If any of the components is set to "Louvres", this property defines the size of the louvre elements
      • +
      • DATALouvre Spacing: If any of the components is set to "Louvres", this property defines the spacing between the louvre elements
      • +
      • DATAOpening: All components that have their opening mode set, and provided a hinge is defined in them or in an earlier component in the list, will appear open by a percentage defined by this value
      • +
      • DATASymbol Plan: Shows 2D opening symbol in plan
      • +
      • DATASymbol Elevation: Shows 2D opening symbol in elevation
      +

      Scripting

      +

      The Window tool can by used in macros and from the python console by using the following function: +

      +
      makeWindow (obj,[name]) 
      +
      creates a window based on the given object
      +

      Example: +

      +
      import Draft, Arch
      +rect = Draft.makeRectangle(length=2,height=4)
      +Arch.makeWindow(rect) 
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Arch_Window.svg b/localwiki/Arch_Window.svg new file mode 100644 index 0000000..d3dcdb8 --- /dev/null +++ b/localwiki/Arch_Window.svg @@ -0,0 +1,144 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [wmayer] + + + Arch_Window + 2011-10-10 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Arch/Resources/icons/Arch_Window.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Arch_Window_Clone.svg b/localwiki/Arch_Window_Clone.svg new file mode 100644 index 0000000..108cf3c --- /dev/null +++ b/localwiki/Arch_Window_Clone.svg @@ -0,0 +1,972 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [Yorik van Havre] + + + Arch_Window_Clone + 2016-09-06 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Arch/Resources/icons/Arch_Window_Clone.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Arch_Window_Tree.svg b/localwiki/Arch_Window_Tree.svg new file mode 100644 index 0000000..d96ae5b --- /dev/null +++ b/localwiki/Arch_Window_Tree.svg @@ -0,0 +1,144 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [yorikvanhavre] + + + Arch_Window_Tree + 2011-12-06 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Arch/Resources/icons/Arch_Window_Tree.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Arch_Workbench.html b/localwiki/Arch_Workbench.html new file mode 100644 index 0000000..5302faa --- /dev/null +++ b/localwiki/Arch_Workbench.html @@ -0,0 +1,123 @@ +Arch Workbench

      Arch Workbench

      (Redirected from Arch Workbench)
      + +

      The Arch workbench provides modern BIM workflow to FreeCAD, with support for features like IFC support, fully parametric architectural entities such as walls, structural elements or windows, and rich 2D document production. The Arch workbench also feature all the tools from the Draft Workbench. +

      Note: The BIM functionality of FreeCAD is now progressively split into this Arch Workbench, which holds all the base BIM tools, and the BIM Workbench addon, that you can install via menu Tools->Addon Manager, that adds a new interface layer on top of the Arch tools, with the aim to make BIM workflow in FreeCAD more intuitive and user-friendly. +

      Screenshot arch window.jpg +

      + + +

      Tools

      +

      These are tools for creating architectural objects. +

      +
      • Arch Wall.png Wall: Creates a wall from scratch or using a selected object as a base
      • +
      • Arch Structure.png Structural element: Creates a structural element from scratch or using a selected object as a base
      +
      • Rebar tools +
        • Arch Rebar Straight.png Straight Rebar: Creates a Straight reinforcement bar in a selected structural element
        • +
        • Arch Rebar UShape.png UShape Rebar: Creates a UShape reinforcement bar in a selected structural element
        • +
        • Arch Rebar LShape.png LShape Rebar: Creates a LShape reinforcement bar in a selected structural element
        • +
        • Arch Rebar BentShape.png Bent Shape Rebar: Creates a Bent Shape reinforcement bar in a selected structural element
        • +
        • Arch Rebar Stirrup.png Stirrup Rebar: Creates a Stirrup reinforcement bar in a selected structural element
        • +
        • Arch Rebar Helical.png Helical Rebar: Creates a Helical reinforcement bar in a selected structural element
        • +
        • Arch Rebar.png Rebar: Creates a custom reinforcement bar in a selected structural element using a sketch
      +
      • Arch Floor.png Floor: Creates a floor including selected objects
      • +
      • Arch Building.png Building: Creates a building including selected objects
      • +
      • Arch Site.png Site: Creates a site including selected objects
      • +
      • Arch Window.png Window: Creates a window using a selected object as a base
      • +
      • Arch SectionPlane.png Section Plane: Adds a section plane object to the document
      +
      • Axis tools +
        • Arch Axis.png Axis: Adds a 1-direction array of axes to the document
        • +
        • Arch AxisSystem.png Axes system: Adds an axes system composed of several axes to the document
        • +
        • Arch Grid.png Grid: Adds a grid-like object to the document
      +
      • Arch Roof.png Roof: Creates a sloped roof from a selected face
      • +
      • Arch Space.png Space: Creates a space object in the document
      • +
      • Arch Stairs.png Stairs: Creates a stairs object in the document
      + + + +


      +

      +
      • Arch Frame.png Frame: Creates a frame object from a selected layout
      • +
      • Arch Equipment.png Equipment: Creates an equipment or furniture object
      + + + +


      +

      + +
      • Arch Schedule.png Schedule: Creates different types of schedules
      +

      Modification tools

      +

      These are tools for modifying architectural objects. +

      + +

      Utilities

      +

      These are additional tools to help you in specific tasks. +

      + +

      Preferences

      + +

      File formats

      +
      • IFC : Industry foundation Classes
      • +
      • DAE : Collada mesh format
      • +
      • OBJ : Obj mesh format (export only)
      • +
      • JSON : JavaScript Object Notation format (export only)
      • +
      • 3DS : 3DS format (import only)
      +

      API

      +

      The Arch module can be used in python scripts and macros using the Arch Python API functions. +

      +

      Tutorials

      + + +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Arch_equipment_example.jpg b/localwiki/Arch_equipment_example.jpg new file mode 100644 index 0000000..ed9b2dc Binary files /dev/null and b/localwiki/Arch_equipment_example.jpg differ diff --git a/localwiki/Arch_equipment_mesh.jpg b/localwiki/Arch_equipment_mesh.jpg new file mode 100644 index 0000000..ea6e940 Binary files /dev/null and b/localwiki/Arch_equipment_mesh.jpg differ diff --git a/localwiki/Arch_materials_01.jpg b/localwiki/Arch_materials_01.jpg new file mode 100644 index 0000000..17b3362 Binary files /dev/null and b/localwiki/Arch_materials_01.jpg differ diff --git a/localwiki/Arch_materials_02.jpg b/localwiki/Arch_materials_02.jpg new file mode 100644 index 0000000..104b71a Binary files /dev/null and b/localwiki/Arch_materials_02.jpg differ diff --git a/localwiki/Arch_multimaterial_example.png b/localwiki/Arch_multimaterial_example.png new file mode 100644 index 0000000..4b4abc0 Binary files /dev/null and b/localwiki/Arch_multimaterial_example.png differ diff --git a/localwiki/Arch_multimaterial_panel.png b/localwiki/Arch_multimaterial_panel.png new file mode 100644 index 0000000..5c561f5 Binary files /dev/null and b/localwiki/Arch_multimaterial_panel.png differ diff --git a/localwiki/Arch_panel_tutorial.html b/localwiki/Arch_panel_tutorial.html new file mode 100644 index 0000000..2174aa5 --- /dev/null +++ b/localwiki/Arch_panel_tutorial.html @@ -0,0 +1,211 @@ +Arch panel tutorial

      Arch panel tutorial

      + +
      + + + + + + + + + + + + + + + + + + + + + + + + + + + +
      +

      Base ExampleCommandModel.png Tutorial

      +
      Topic +
      Modeling an architectural panel +
      Level +
      Beginner +
      Time to complete +
      60 minutes +
      Author +
      Yorik +
      FreeCAD version +
      +
      Example File(s) +
      +

      + +
      +


      +

      This is a cross-post of a tutorial originally written for Open-Source Ecology. +

      +

      Presenting FreeCAD

      +

      Arch panel tutorial 01.jpg +

      FreeCAD is a parametric 3D modeler. Parametric modeling allows you to easily modify your design by going back into your model history and changing its parameters. FreeCAD is open source (LGPL license) and very modular, allowing for very advanced extension and customization, specially thanks to its intensive use of the Python language. +

      + +

      Installing FreeCAD

      +

      You have the choice to install the latest stable version (as of today, may 2015: version 0.15) or a development version (currently 0.16). In fact, development versions of FreeCAD are usually pretty stable, and you are strongly encouraged to try a development version, unless you have a specific reason not to do so. Since FreeCAD development is quite fast, be sure, if you are downloading manually, to check back from time to time and reinstall/update to benefit from latest improvements. +

      +
      • On Windows: Download the most recent version for your windows version (32 or 64bits) from https://github.com/FreeCAD/FreeCAD/releases. Double-click the file to install.
      • +
      • On Mac OS: Download the most recent version from https://github.com/FreeCAD/FreeCAD/releases. Double-click the file to install.
      • +
      • On Ubuntu: The version of FreeCAD provided by Ubuntu is usually out of date, so you are advised to use the PPA maintained by the FreeCAD community instead. To install, open the “Software Sources” application of Ubuntu, and add either ppa:freecad-maintainers/freecad-stable for the stable version, or ppa:freecad-maintainers/freecad-daily for the development version to the software sources.
      • +
      • On other platforms: On most mainstream Linux distributions (Debian, Fedora, etc), FreeCAD is included in the official software repositories. It might not always be the most up-to-date version, though. If the version you need is not available, your only option is to compile FreeCAD yourself (instructions on the FreeCAD website)
      +

      Additional optional contents

      +
      • Enabling IFC import/export: To import and export projects to/from the IFC file format, FreeCAD relies on the IfcOpenShell importer, that you must install separately from http://ifcopenshell.org/python.html. Be sure to choose a python2.7-based version, which is the same python version used by FreeCAD.
      • +
      • Drawing dimensioning workbench: An additional workbench for FreeCAD, that offer many convenient tools to add dimensions and annotations to FreeCAD's 2D drawing sheets: https://github.com/hamish2014/FreeCAD_drawing_dimensioning (Install instructions on the web page)
      • +
      • Assembly2 workbench: An additional workbench for FreeCAD, that offers a series of basic assembly tools: https://github.com/hamish2014/FreeCAD_assembly2 (Install instructions on the web page)
      +

      Quick startup tips

      +

      The collection of tutorials available on the FreeCAD wiki is still very sparse. However, many members of the FreeCAD community use youtube to publish video tutorials. Be sure to search for FreeCAD-related contents on youtube, that is certainly the best source of learning material. +

      FreeCAD is a very technical application, and its learning curve can be steep. Be sure to rely on tutorials, the documentation wiki and don't hesitate to ask questions on the forum if you meet a specific problem. Questions that are clearly enunciated usually receive very fast and extensive replies. +

      +

      A very rough list of things you must know

      +
      • The FreeCAD interface is divided into workbenches. Workbenches are simply collections of tools (toolbar buttons and menus) that are grouped together, usually for a certain task. When you switch to another workbench, the interface shows you the tools from that workbench. But the contents of your 3D document don't change. You are still working on the same document, and on the same objects.
      +
      • FreeCAD is still in development, there are still many bugs, and the application might crash sometimes. Save often, and enable backup files in Edit → Preferences → Document
      +
      • Most objects in FreeCAD are parametric. It means their geometry is created automatically from a series of parameters. These parameters are always editable in the Properties View. They are always divided between the parameters that affect the geometry itself (Data tab) and the parameters that only affect the display of the object (View tab). However, objects created with other applications, and imported into FreeCAD, will usually not be defined by parameters, and are therefore uneditable.
      +
      • Several workbenches (PartDesign and Arch) are made to work only with solid objects, and will refuse to work on objects that are not solid. A good rule of thumb is always try to work with solid objects.
      +
      • Although FreeCAD can import and work with mesh objects (Mesh workbench), it is primarily designed to work with a more advanced object type called brep, that is used by most of its workbenches (Part, PartDesign, Draft, Sketcher, Arch). When importing mesh-based files (.dae, .orb, .stl...) you will usually need to convert these objects to brep before being able to do something interesting with them. Solid-based file formats however (.step, .iges), when imported into FreeCAD, directly produce brep objects. 2D formats (.dxf, .svg) also produce brep contents.
      +
      • FreeCAD has different ways, or modes, to use the mouse buttons. These modes can be set in the preferences or changes on-the-fly by right-clicking on the 3D view background. They are described on http://www.freecadweb.org/wiki/index.php?title=Mouse_Model. The best suited modes for CAD work are CAD or Gestures.
      +

      Exercise: modeling a roof panel

      +

      To showcase a typical workflow in FreeCAD, let's model a roof panel as described on http://opensourceecology.org/wiki/MicroHouse_4_Roof_-_Module_-_Build_Instructions. To do that,we will start from drawing the different pieces in a 2D constrained sketch, then we will take advantage of the special Arch Window object, which is able to build complex 3D objects from a 2D sketch containing the contours of several pieces. Finally, since what we need is not a window but a roof panel, we will simply convert our window object to another Arch type. +

      +

      1. Open FreeCAD, then set your preferred units to “imperial”

      +

      In menu Edit → Preferences → General → Units +

      +

      2. Switch to the sketcher workbench and create a new sketch in the XY plane.

      +

      Arch panel tutorial 02.jpg +

      Usually, unless there is a specific reason not to do so,you'll always want to start drawing your 2D sketches on the ground plane, around the (0,0) origin point. Then, it is the 3D object generated from that, that will be moved/rotated into position. +

      +

      3. Draw two rectangles. On each of them, place a vertical constraint of 16 ft and an horizontal constraint of 2 in.

      +

      Arch panel tutorial 03.jpg +

      Don't worry about the dimensions your pieces have when you draw them, the constraints will resize them accordingly. To add a dimension constraint (vertical or horizontal), you can either select a line, or two points (with CTRL pressed). +

      +

      4. Once your two rectangles have the correct size, place a vertical constraint of 0 in between their corner points, and a horizontal constraint of 4 ft.

      +

      Arch panel tutorial 04.jpg +

      This ensures that our two rectangles are correctly positioned in relatin to each other. +

      +

      5. Add the two additional 2 in x 6 in pieces

      +

      Arch panel tutorial 05.jpg +

      Add two more rectangles and repeat the process. Note that in the example above, we didn't specify the length of these pieces, but rather placed a distance constraint between their extremities and the long vertical pieces, and we let a small gap of 0.05 inches between them. This is because if we make the rectangles touch each other, FreeCAD might deduce the loops wrongly, and we might get strange results with the Arch window tool. This little trick ensures that each rectangle will be recognized as an independent loop by the Arch window tool. +

      +

      6. Add the corner reinforcement pieces

      +

      Arch panel tutorial 06.jpg +

      Same thing. Make them 6 inches wide, and separated them from other rectangles by 0.05 inches. +

      +

      7. Draw 7 intermediary reinforcement pieces, set their width to 2 inches, and constrain their left and right endpoints at 0.05 inches of the vertical rectangles (or at 0 inch of the endpoints of the other horizontal rectangles)

      +

      Arch panel tutorial 07.jpg +

      Depending on your system, FreeCAD might begin to be slow to process new constraints. This is the disadvantage of using constrained objects, they quickly swallow up a lot of system resources. You must always consider if you absolutely need them. You can also delete constraints when they have done their job. These dimensions won't be fixed anymore, but unless you move the pieces around, they won't change. If needed, you can aslo always re-add constraints later. +

      +

      8. Calculate the spacing between the 7 reinforcement pieces and set vertical constraints between them.

      +

      In our case, our total length is 192 inches, minus the two end pieces (2 x 2 inches) and the two corner reinforcements (2 x 6 inches), = 192 – (4 + 12) = 176. Removing the 7 reinforcement pieces ( 7 x 2 ) = 162. Divinding this by 8 gives us the space between each reinforcement: 20.25. +

      Arch panel tutorial 08.jpg +

      +

      9. Obtaining a fully constrained sketcher

      +

      On the right panel, you can see the message “2 degrees of freedom”. This means that our sketch is not fully constrained (it still has two “ways” of being deformed). This is because, although no piece of it can now move in relation to the others, the whole sketch can still move vertically and horizontally. To prevent this, we can simply take one of its corner points, select the origin point of the grid (where the green and red axes intersect) and press the Point Constraint button. This turns our sketch green, meaning it is fully constrained, no part of it can move anymore. +

      Arch panel tutorial 09.jpg +

      This is actually not absolutely necessary. But it is always better to keep track of the exact position of objects (we are now certain that our corner is at the (0,0) point). In case something goes wrong later, or we need to figure out the position of an object built upon this sketch, this will be useful. +

      We can now press the “close” button and our base sketch is built: +

      Arch panel tutorial 10.jpg +

      +

      10. Switch to the Arch workbench and, with the sketch selected, press the “window” button

      +

      Our sketch has now vanished and one of its rectangles has been extruded slightly into a solid piece: +

      Arch panel tutorial 11.jpg +

      Although this seems wrong, it is simply because the Arch Window tool has created a default piece from the biggest loop it could find in the base sketch. We will fix that soon. Also, notice take note that the sketch has not disappeared, it has simply been turned off and “swallowed” by its new parent object. You can still find it in the tree view, by expanding the window object, and turn its display on/off by pressing the SPACE key. +

      +

      11. Edit the window components by double-clicking it in the tree view

      +

      Arch panel tutorial 12.jpg +

      When double-clicking the window, its base sketch becomes visible again, and we get its edit interface: At the left, a list of the loops found in the base sketch, at the right the solid pieces built on it. +

      Begin with removing the “Default” piece. +

      Then, select the first loop (Wire0). It will highlight in the 3D view. Press the “Add” button to create a new piece from it. Give it a name, make sure the correct wire is set, and give it a 6 inches extrusion. The offset should stay 0 since we want it placed “on the ground”. +

      The “Type” value will be used to attribute materials to the window (not implemented yet), so you can currently leave to “Frame”. +

      Arch panel tutorial 13.jpg +

      Then press the “Create component” button. Sometimes FreeCAD fails to guess correctly the direction of the extrusion, and you must therefore edit your component and change the 6 inches value by -6 inches. +

      Repeat this for all the needed pieces: +

      Arch panel tutorial 14.jpg +

      When closing the edit panel we obtain the object above. Note that by default, window objects are represented semi-transparent. Since this will actually not be a window, we can just turn that off by setting its Transparency value to 0 in its View properties. +

      +

      12. Add the cover panel

      +

      We now have our panel frame, but not the base panel itself. To do that, the best way is to open our base sketch, and add a new rectangle. Remember though to not make any of the corners of that rectangle coincident to corners of other rectangles, in order not to confuse our window object, which might require us to redo the whole series of components if the order of the loops would change. +

      We can therefore constrain this new rectangle 0.05 inches inside the perimeter. This will require us to place 4 new constraints. +

      We can then edit our window again, and add new components. We can see that a new Wire has been found. This time, we will use it to add a 8mm polycarbonate panel (note that you can mix units without problems in FreeCAD, and write “8mm” as the thickness, even if you are working in inches). We will also give it an offset of 0.05 inches, so it is slightly offsetted from the frame, just for consistency, as all the parts of our object have that offest between them. +

      Arch panel tutorial 15.jpg +

      We can now create another component based on the same Wire, in order to place another panel on top of our frame. This time, we will give it an offset of 6.05 inches. Our panel is finally complete: +

      Arch panel tutorial 16.jpg +

      +

      13. Turn the window into another type of Arch component

      +

      This is not really necessary at the moment, but it might become important later when we export or work to other construction-oriented applications, for example via IFC, we don't want our panel to be identified as a window. +

      The Arch workbench of FreeCAD provides an easy way to handle that, which is that any object type can always become another, by being the base of another type. In this case, let's turn our window into a Panel object, simply by selecting the window and pressing the Panel tool. +

      Arch panel tutorial 17.jpg +

      Notice that the color of the resulting panel has changed, that is because materials support in FreeCAD and the Arch module is still incomplete. When it is finished, this will be properly handled. +

      +

      14. Duplicating the panel

      +

      Our panel can then be duplicated and copied over in several ways, for example by using copy/paste. But a more interesting way is to use the Draft Clone tool (also present on the Arch workbench, like all other Draft tools). The Clone tool keeps the relationship between the base object and its clone, so any modification to the base object will reflect in all its clones. +

      Arch panel tutorial 18.jpg +

      In the current development version of FreeCAD, clones of Arch objects are now Arch objects themselves too. +

      +

      15. Rotating and positioning the panels.

      +

      While the assembly workbench of FreeCAD is not ready yet, we need to position our pieces manually, either by manipulating their Placement property, or by using the Draft Move and Rotate tools, which are actually only visual ways to modify the Placement of objects. +

      Both Draft Rotate and Move tools make use of the Draft Snapping system. Different snapping positions (endpoints, midpoints, etc) are available, that can be switched on/off, allowing to perform very precise positionning and rotations. +

      Arch panel tutorial 19.jpg +

      Arch panel tutorial 20.jpg +

      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Arch_panel_tutorial_02.jpg b/localwiki/Arch_panel_tutorial_02.jpg new file mode 100644 index 0000000..adca2d5 Binary files /dev/null and b/localwiki/Arch_panel_tutorial_02.jpg differ diff --git a/localwiki/Arch_panel_tutorial_03.jpg b/localwiki/Arch_panel_tutorial_03.jpg new file mode 100644 index 0000000..9030c4f Binary files /dev/null and b/localwiki/Arch_panel_tutorial_03.jpg differ diff --git a/localwiki/Arch_panel_tutorial_04.jpg b/localwiki/Arch_panel_tutorial_04.jpg new file mode 100644 index 0000000..3458377 Binary files /dev/null and b/localwiki/Arch_panel_tutorial_04.jpg differ diff --git a/localwiki/Arch_panel_tutorial_05.jpg b/localwiki/Arch_panel_tutorial_05.jpg new file mode 100644 index 0000000..59e0a93 Binary files /dev/null and b/localwiki/Arch_panel_tutorial_05.jpg differ diff --git a/localwiki/Arch_panel_tutorial_06.jpg b/localwiki/Arch_panel_tutorial_06.jpg new file mode 100644 index 0000000..409c88c Binary files /dev/null and b/localwiki/Arch_panel_tutorial_06.jpg differ diff --git a/localwiki/Arch_panel_tutorial_07.jpg b/localwiki/Arch_panel_tutorial_07.jpg new file mode 100644 index 0000000..b9d24a4 Binary files /dev/null and b/localwiki/Arch_panel_tutorial_07.jpg differ diff --git a/localwiki/Arch_panel_tutorial_08.jpg b/localwiki/Arch_panel_tutorial_08.jpg new file mode 100644 index 0000000..8fe82a2 Binary files /dev/null and b/localwiki/Arch_panel_tutorial_08.jpg differ diff --git a/localwiki/Arch_panel_tutorial_09.jpg b/localwiki/Arch_panel_tutorial_09.jpg new file mode 100644 index 0000000..8327966 Binary files /dev/null and b/localwiki/Arch_panel_tutorial_09.jpg differ diff --git a/localwiki/Arch_panel_tutorial_10.jpg b/localwiki/Arch_panel_tutorial_10.jpg new file mode 100644 index 0000000..3e6bca6 Binary files /dev/null and b/localwiki/Arch_panel_tutorial_10.jpg differ diff --git a/localwiki/Arch_panel_tutorial_11.jpg b/localwiki/Arch_panel_tutorial_11.jpg new file mode 100644 index 0000000..b8c8915 Binary files /dev/null and b/localwiki/Arch_panel_tutorial_11.jpg differ diff --git a/localwiki/Arch_panel_tutorial_12.jpg b/localwiki/Arch_panel_tutorial_12.jpg new file mode 100644 index 0000000..3e822b0 Binary files /dev/null and b/localwiki/Arch_panel_tutorial_12.jpg differ diff --git a/localwiki/Arch_panel_tutorial_13.jpg b/localwiki/Arch_panel_tutorial_13.jpg new file mode 100644 index 0000000..da49fa5 Binary files /dev/null and b/localwiki/Arch_panel_tutorial_13.jpg differ diff --git a/localwiki/Arch_panel_tutorial_14.jpg b/localwiki/Arch_panel_tutorial_14.jpg new file mode 100644 index 0000000..13225f4 Binary files /dev/null and b/localwiki/Arch_panel_tutorial_14.jpg differ diff --git a/localwiki/Arch_panel_tutorial_15.jpg b/localwiki/Arch_panel_tutorial_15.jpg new file mode 100644 index 0000000..8397b7c Binary files /dev/null and b/localwiki/Arch_panel_tutorial_15.jpg differ diff --git a/localwiki/Arch_panel_tutorial_16.jpg b/localwiki/Arch_panel_tutorial_16.jpg new file mode 100644 index 0000000..7d4f41e Binary files /dev/null and b/localwiki/Arch_panel_tutorial_16.jpg differ diff --git a/localwiki/Arch_panel_tutorial_17.jpg b/localwiki/Arch_panel_tutorial_17.jpg new file mode 100644 index 0000000..37e14f7 Binary files /dev/null and b/localwiki/Arch_panel_tutorial_17.jpg differ diff --git a/localwiki/Arch_panel_tutorial_18.jpg b/localwiki/Arch_panel_tutorial_18.jpg new file mode 100644 index 0000000..80f4c82 Binary files /dev/null and b/localwiki/Arch_panel_tutorial_18.jpg differ diff --git a/localwiki/Arch_panel_tutorial_19.jpg b/localwiki/Arch_panel_tutorial_19.jpg new file mode 100644 index 0000000..eb41389 Binary files /dev/null and b/localwiki/Arch_panel_tutorial_19.jpg differ diff --git a/localwiki/Arch_panel_tutorial_20.jpg b/localwiki/Arch_panel_tutorial_20.jpg new file mode 100644 index 0000000..7e15d94 Binary files /dev/null and b/localwiki/Arch_panel_tutorial_20.jpg differ diff --git a/localwiki/Arch_pipe_example_01.jpg b/localwiki/Arch_pipe_example_01.jpg new file mode 100644 index 0000000..1cbce8a Binary files /dev/null and b/localwiki/Arch_pipe_example_01.jpg differ diff --git a/localwiki/Arch_pipe_example_02.jpg b/localwiki/Arch_pipe_example_02.jpg new file mode 100644 index 0000000..20e2c23 Binary files /dev/null and b/localwiki/Arch_pipe_example_02.jpg differ diff --git a/localwiki/Arch_pipe_example_03.jpg b/localwiki/Arch_pipe_example_03.jpg new file mode 100644 index 0000000..0f122c9 Binary files /dev/null and b/localwiki/Arch_pipe_example_03.jpg differ diff --git a/localwiki/Arch_pipe_example_04.jpg b/localwiki/Arch_pipe_example_04.jpg new file mode 100644 index 0000000..6ea27c3 Binary files /dev/null and b/localwiki/Arch_pipe_example_04.jpg differ diff --git a/localwiki/Arch_pipe_example_05.jpg b/localwiki/Arch_pipe_example_05.jpg new file mode 100644 index 0000000..2dfeefc Binary files /dev/null and b/localwiki/Arch_pipe_example_05.jpg differ diff --git a/localwiki/Arch_pipe_example_06.jpg b/localwiki/Arch_pipe_example_06.jpg new file mode 100644 index 0000000..6b314a4 Binary files /dev/null and b/localwiki/Arch_pipe_example_06.jpg differ diff --git a/localwiki/Arch_pipe_example_07.jpg b/localwiki/Arch_pipe_example_07.jpg new file mode 100644 index 0000000..e0d4453 Binary files /dev/null and b/localwiki/Arch_pipe_example_07.jpg differ diff --git a/localwiki/Arch_presets_example.jpg b/localwiki/Arch_presets_example.jpg new file mode 100644 index 0000000..b659ff0 Binary files /dev/null and b/localwiki/Arch_presets_example.jpg differ diff --git a/localwiki/Arch_schedule_example01.jpg b/localwiki/Arch_schedule_example01.jpg new file mode 100644 index 0000000..32fc4e4 Binary files /dev/null and b/localwiki/Arch_schedule_example01.jpg differ diff --git a/localwiki/Arch_schedule_example02.jpg b/localwiki/Arch_schedule_example02.jpg new file mode 100644 index 0000000..f00b91a Binary files /dev/null and b/localwiki/Arch_schedule_example02.jpg differ diff --git a/localwiki/Arch_schedule_example03.jpg b/localwiki/Arch_schedule_example03.jpg new file mode 100644 index 0000000..0b7b2fb Binary files /dev/null and b/localwiki/Arch_schedule_example03.jpg differ diff --git a/localwiki/Arch_schedule_example04.jpg b/localwiki/Arch_schedule_example04.jpg new file mode 100644 index 0000000..423c3ea Binary files /dev/null and b/localwiki/Arch_schedule_example04.jpg differ diff --git a/localwiki/Arch_schedule_example05.jpg b/localwiki/Arch_schedule_example05.jpg new file mode 100644 index 0000000..d26548a Binary files /dev/null and b/localwiki/Arch_schedule_example05.jpg differ diff --git a/localwiki/Arch_screenshot.jpg b/localwiki/Arch_screenshot.jpg new file mode 100644 index 0000000..ecd1f27 Binary files /dev/null and b/localwiki/Arch_screenshot.jpg differ diff --git a/localwiki/Arch_site_example_01.jpg b/localwiki/Arch_site_example_01.jpg new file mode 100644 index 0000000..3f511ab Binary files /dev/null and b/localwiki/Arch_site_example_01.jpg differ diff --git a/localwiki/Arch_site_example_02.jpg b/localwiki/Arch_site_example_02.jpg new file mode 100644 index 0000000..3f898a9 Binary files /dev/null and b/localwiki/Arch_site_example_02.jpg differ diff --git a/localwiki/Arch_site_example_03.jpg b/localwiki/Arch_site_example_03.jpg new file mode 100644 index 0000000..4260b01 Binary files /dev/null and b/localwiki/Arch_site_example_03.jpg differ diff --git a/localwiki/Arch_structural_nodes.jpg b/localwiki/Arch_structural_nodes.jpg new file mode 100644 index 0000000..6aaca8e Binary files /dev/null and b/localwiki/Arch_structural_nodes.jpg differ diff --git a/localwiki/Arch_templates.html b/localwiki/Arch_templates.html new file mode 100644 index 0000000..7936421 --- /dev/null +++ b/localwiki/Arch_templates.html @@ -0,0 +1,138 @@ +Arch templates

      Arch templates

      + +

      This page lists the templates according to American National Standards Institute Arch standard +

      + + +

      Arch A

      +

      Arch_A_Landscape

      +

      Arch A Landscape.svg +

      +

      Arch_A_Portrait

      +

      Arch A Portrait.svg +

      +

      Arch B

      +

      Arch_B_Landscape

      +

      Arch B Landscape.svg +

      +

      Arch_B_Portrait

      +

      Arch B Portrait.svg +

      +

      Arch C

      +

      Arch_C_Landscape

      +

      Arch C Landscape.svg +

      +

      Arch_C_Portrait

      +

      Arch C Portrait.svg +

      +

      Arch D

      +

      Arch_D_Landscape

      +

      Arch D Landscape.svg +

      +

      Arch_D_Portrait

      +

      Arch D Portrait.svg +

      +

      Arch E

      +

      Arch_E_Landscape

      +

      Arch E Landscape.svg +

      +

      Arch_E_Portrait

      +

      Arch E Portrait.svg +

      +

      Arch E1

      +

      Arch_E1_Landscape

      +

      Arch E1 Landscape.svg +

      +

      Arch_E1_Portrait

      +

      Arch E1 Portrait.svg +

      +

      Arch E2

      +

      Arch_E2_Landscape

      +

      Arch E2 Landscape.svg +

      +

      Arch_E2_Portrait

      +

      Arch E2 Portrait.svg +

      +

      Arch E3

      +

      Arch_E3_Landscape

      +

      Arch E3 Landscape.svg +

      +

      Arch_E3_Portrait

      +

      Arch E3 Portrait.svg +


      +

      +

      Other standards available

      + +

      Credits

      +

      The templates are drawn by Quick61 and listed FreeCAD-Drawing-Templates. +

      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Arch_tutorial.html b/localwiki/Arch_tutorial.html new file mode 100644 index 0000000..fdf6771 --- /dev/null +++ b/localwiki/Arch_tutorial.html @@ -0,0 +1,391 @@ +Arch tutorial

      Arch tutorial

      + +
      + + + + + + + + + + + + + + + + + + + + + + + + + + + +
      +

      Base ExampleCommandModel.png Tutorial

      +
      Topic +
      Modeling +
      Level +
      Intermediate +
      Time to complete +
      +
      Author +
      Yorik +
      FreeCAD version +
      0.14 +
      Example File(s) +
      +

      + +
      +


      +Arch tutorial 00.jpg +

      +

      Introduction

      +

      This tutorial aims at giving you the basics to work with the Arch Workbench. I will try to make it simple enough so you don't need any previous experience with FreeCAD, but having some experience with 3D or BIM applications will be useful. In any case, you should be prepared to look for yourself for further information about how FreeCAD works on the FreeCAD documentation wiki. The Getting started page is a must read, if you have no previous experience with FreeCAD. Also check our tutorials section, and on youtube you will also find a lot more of FreeCAD tutorials. +

      The purpose of the Arch Workbench is to offer a complete BIM workflow inside FreeCAD. As it is still under development, don't expect to find here the same tools and level of completion as grown-up commercial alternatives such as Revit or ArchiCAD, but on the other hand, FreeCAD being used in a much bigger scope than these applications, the Arch Workbench greatly benefits from the other disciplines FreeCAD caters to, and offers some features rarely seen in traditional BIM applications. +

      Here are, for example, a couple of interesting features of FreeCAD's Arch Workbench that you'll hardly find in other BIM apps: +

      +
      • Architectural objects are always solids. From FreeCAD's strong mechanical background, we learned the importance of always working with solid objects. This ensures a much more error-free workflow, and very reliable boolean operations. Since cutting through 3D objects with a 2D plane, in order to extract sections, is also a boolean operation, you can immediately see the importance of this point.
      +
      • Architectural objects can always have any shape. No restrictions. Walls don't need to be vertical, slabs don't need to look like slab. Any solid object can always become any architectural object. Very complex things, usually hard to define in other BIM applications, like a floor slab curving up and becoming a wall (yes Zaha Hadid, it's you we're talking about), present no particular problem at all in FreeCAD.
      +
      • The whole power of FreeCAD is at your fingertips. You can design architectural objects with any other tool of FreeCAD, such as the PartDesign Workbench, and when they are ready, convert them to architectural objects. They will still retain their full modeling history, and continue totally editable. The Arch Workbench also inherits much of the Draft Workbench functionality, such as snapping and working planes.
      +
      • The Arch Workbench is very mesh-friendly. You can easily design an architectural model in a mesh-based application such as Blender or SketchUp and import it in FreeCAD. If you took care of the quality of your model and its objects are manifold solid shapes, turning them into architectural objects only requires the press of a button.
      +

      At the time I'm writing this, though, the Arch Workbench, as the rest of FreeCAD, suffers some limitations. Most are being worked on, though, and will disappear in the future. +

      +
      • FreeCAD is no 2D application. It is made for 3D. There is a reasonable set of tools for drawing and editing 2D objects with the Draft Workbench and Sketcher Workbench, but it is not made for handling very large (and sometimes badly drawn) 2D CAD files. You can usually successfully import 2D files, but don't expect very high performance if you want to keep working on them in 2D. You have been warned.
      +
      • No materials support. FreeCAD will have a complete Material system, able to define very complex materials, with all the goodies you can expect (custom properties, material families, rendering and visual aspect properties, etc), and the Arch Workbench will of course use it when it is ready.
      +
      • Very preliminary IFC support. You can already import IFC files, quite reliably, provided IfcOpenShell is installed on your system, but exporting is still not officially supported. This is worked on both by the FreeCAD and IfcOpenShell developers, and in the future we can expect full-powered IFC support.
      +
      • Most Arch tools are still in development. That means that automatic "wizard" tools that create complex geometry automatically, such as Arch Roof or Arch Stairs can only produce certain types of objects, and other tools that have presets, such as Arch Structure or Arch Window only have a couple of basic presets. This will of course grow over time.
      +
      • Relations between objects in FreeCAD are still not officially available. These, for example the relation between a window and its host wall, are currently implemented in the Arch Workbench with temporary (and therefore somewhat limited) methods. Many new possibilities will arise when this feature will be fully available.
      +
      • Units are being implemented in FreeCAD, which will allow you to work with any unit you wish (even imperial units, you guys from the USA can be eternally grateful for this to Jürgen, FreeCAD's godfather and dictator). But at the moment the implementation is not complete, and the Arch workbench still doesn't support them. You must consider it "unit-less".
      +


      +

      +
      FreeCAD version 0.14 required +

      This tutorial was written using FreeCAD version 0.14. You will need at least this version number in order to follow it. Earlier versions might not contain all the needed tools,or they could lack options presented here. +

      +
      +


      +

      +

      Typical workflows

      +

      The Arch Workbench is mainly made for two kinds of workflows: +

      +
      • Build your model with a faster, mesh-based application such as Blender or SketchUp, and import them in FreeCAD in order to extract plans and section views. FreeCAD being made for precision modeling, at a much higher level than what we usually need in architectural modeling, building your models directly in FreeCAD can be heavy and slow. For this reason, such a workflow has big advantages. I described it in this article on my blog. If you care to model correctly and precisely (clean, solid, non-manifold meshes), this workflow gives you the same performance and precision level as the other.
      +
      • Build your model directly in FreeCAD. That is what I will showcase in this tutorial. We will use mostly three workbenches: Arch, of course, but also Draft, whose tools are all included in Arch, so there is no need to switch workbenches, and Sketcher. Conveniently, you can do as I usually so, which is to create a custom toolbar in your Arch workbench, with Tools → Customize, and add the tools from the sketcher that you use often. This is my "customized" Arch workbench:
      +

      Arch tutorial 01.jpg +

      In this tutorial, we will model the house in 3D, based on the 2D drawings we'll download from the net, and extract from it 2D documents, such as plans, elevations and sections. +

      +

      Preparation

      +

      Instead of creating a project from scratch, Let's take an example project to model, it will save us time. I chose this wonderful house by the famous architect Vilanova Artigas (see a series of pictures by Pedro Kok), because it is close to where I live, it is simple, it's a wonderful example of the amazing modernist architecture of São Paulo (it is even for sale if you have "a few" Reals to spend), and dwg drawings are easily available. +

      We will use the 2D DWG drawings obtained from the link above (you need to register on the above site to download, but it's free, or grab directly a dxf version here) as a base to build our model. So the first thing you'll want to do is to download the file, unzip it, and open the DWG file inside with a dwg application such as DraftSight. Alternatively, you can convert it to DXF with a free autility such as the Teigha File Converter. If you have the Teigha converter installed (and its path set in the Arch preferences settings), FreeCAD is also able to import DWG files directly. But since these files can sometimes being of bad quality and very heavy, it's usually better open it first with a 2D CAD application and do some cleaning. +

      Here, I removed all the detail drawings, all the titleblocks and page layouts, did a "clean" ("purge" in AutoCAD slang) to remove all unused entities, reorganized the sections at a logical location in relation to the plan view, and moved everything to the (0,0) point. After that, our file can be opened quite efficiently in FreeCAD. Check the different options available in Edit → Preferences → Draft → Import/Export, they can affect how (and how quickly) DXF/DWG files are imported. +

      This is how the file looks after being opened in FreeCAD. I also changed the thickness of the walls (the contents of the "muros" group), and flipped a couple of doors that were imported with wrong X scale, with the Draft Scale tool: +

      Arch tutorial 02.jpg +

      The DXF importer (which also takes care of DWG files, since when importing DWG files, they are simpl converted to DXF first), groups the imported objects by layer. There is no layer in FreeCAD, but there are groups. Groups offer a similar way to organize the objects of your files, but don't have specific properties, like AutoCAD layers, that apply to their contents. But they can be placed inside other groups, which is very handy. The first thing we might want to do here, is to create a new group in the tree view, right-click on the document icon, add a group, right click on it to rename it as "base 2D plans", and drag and drop all the other objects into it. +

      +

      Building the walls

      +

      Like most Arch objects, walls can be built upon a big variety of other objects: lines, wires (polylines), sketches, faces or solid (or even on nothing at all, in which case they are defined by height, width and length). The resulting geometry of the wall depends on that base geometry, and the properties you fill in, such as width and height. As you might guess, a wall based on a line will use that line as its alignment line, while a wall based on a face will use that face as its base footprint, and a wall based on a solid will simply adopt the shape of that solid. This allows about any shape imaginable to become a wall. +

      There are different possible strategies to build walls in FreeCAD. One might want to build a complete "floor plan" with the sketcher, and build one, big, wall object from it. This technique works, but you can only give one thickness for all the walls of the project. Or, you can build each piece of wall from separate line segments. Or, this is what we will do here, a mix of both: We will build a couple of wires on top of the imported plan, one for each type of wall: +

      Arch tutorial 03.jpg +

      As you see, I've drawn in red the lines that will become concrete walls (a pictures search of the house can help you to see the different wall types), the green ones are the exterior brick walls, and the blue ones will become the inner walls. I passed the lines through the doors, because doors will be inserted in the walls later, and will create their openings automatically. Walls can also be aligned left, right or centrally on their baseline, so it doesn't matter which side you draw the baseline. I also took care on avoiding intersections as much as I could, because our model will be cleaner that way. But we'll take care of intersections later. +

      When this is done, place all those lines in a new group if you want, select each line one by one, and press the Arch Wall tool to build a wall from each of them. You can also select several lines at once. After doing that, and correcting widths (exterior walls are 25cm wide, inner walls are 15cm wide) and some alignments, we have our walls ready: +

      Arch tutorial 04.jpg +

      We could also have built our walls from scratch. If you press the Arch Wall button with no object selected, you will be able to click two points on the screen to draw a wall. But under the hood, the wall tool will actually draw a line and build a wall on it. In this case, I found it more didactic to show you how things work. +

      Did you notice that I took great care not to cross the walls? this will save us some headache later, for example if we export our work to other applications, that might not like it. I have only one intersection, where I was too lazy to draw two small line segments, and drew one big wire crossing another. This must be fixed. Fortunately, all Arch objects have a great feature: you can add one to another. Doing that will unite their geometries, but they are still editable independently after. To add one of our crossing walls to the other, just select one, CTRL + select the other, and press the Arch Add tool: +

      Arch tutorial 05.jpg +

      On the left is are the two intersecting walls, on the right the result after adding one to the other. +

      +
      An important note about parametric objects +

      Something is important to consider already. As you can see, in FreeCAD, everything is parametric: Our new "united" wall is made from two walls, each based on a baseline. When you expand them in the tree view, you can see all that chain of dependencies. As you can imagine, this little game can quickly become very complex. Furthermore, if you already know how to work with the sketcher, you might have wanted to draw the baselines with constrained sketches. This whole complexity has a cost: it raises exponentially the number of calculations that FreeCAD has to perform to keep your model geometry up to date. So, think about it, don't add unnecessary complexity when you don't need it. Keep a good balance between simple and complex objects, and keep these for the cases where you really need them. +

      +
      +


      +For example, I could have drawn all my baselines above without caring about what crosses what, and fix things with the Arch Add tool later. But I would have raised much the complexity of my model, for no gain at all. Better make them correct right from the start, and keeping them as very simple pieces of geometry. +

      Now that our walls are okay, we need to raise their height, until they intersect the roof. Then, since the wall object still cannot be cut automatically by roofs (this will happen some day, though), we will build a "dummy" object, that follows the shape of the roof, to be subtracted from our walls. +

      First, by looking at our 2D drawings, we can see that the highest point of the roof is 5.6m above the ground. So let's give all our walls a height of 6m, so we make sure they will be cut by our dummy roof volume. Why 6m and not 5.6m? You may ask. Well, if you already worked with boolean operations (additions, subtractions, intersections), you must already know that these operations usually don't like much "face-on-face" situations. They prefer clearly, frankly intersecting objects. So by doing this, we keep on the safe side. +

      To raise the height of our walls, simply select all of them (don't forget the one we added to the other) in the tree view, and change the value of their "height" property. +

      Before making our roof and cutting the walls, let's make the remaining objects that will need to be cut: The walls of the above studio, and the columns. The walls of the studio are made the same way as we did, on the superior floor plan, but they will be raised up to level 2.6m. So we will give them the needed height so their top is at 6m too, that is, 3.4m. Once this is done, let's move our walls up by 2.6m: Select them both, put yourself in frontal view (View → Standard Views → Front), press the Draft Move button, select a first point, then enter 0, 2.6, 0 as coordinates, and press enter. Your objects now have jumped 2.6m high: +

      Arch tutorial 06.jpg +

      +
      About coordinates +

      The Draft objects, and most Arch objects too, obey to a Draft system called working planes. This system defines a 2D plane where next operations will take place. If you don't specify any, that working plane adapts itself to the current view. This is why we switched to frontal view, and you see that we indicated a movement in X of 0 and in Y of 2.6. We could also have forced the working plane to stay on the ground, by using the Draft SelectPlane tool. Then, we would have entered a movement of X of 0, Y of 0 and Z of 2.6. +

      +
      +


      +Now let's move our walls horizontally, to their correct location. Since we have points to snap to, this is easier: Select both walls, press the Draft Move tool, and move them from one point to the other: +

      Arch tutorial 07.jpg +

      Finally, I changed the color of some walls to a brick-like color (so it's easier to differentiate), and made a small correction: Some walls don't go up to the roof, but stop at a height of 2.60m. I corrected the height of those walls. +

      +

      Raising the structure

      +

      Now, since we'll have to cut our walls with a subtraction volume, we might as well see if there aren't other objects that will need to be cut that way. There are, some of the columns. This is a good opportunity to introduce a second arch object: the Arch Structure. Structure objects behave more or less like walls, but they aren't made to follow a baseline. Rather, their prefer to work from a profile, that gets extruded (along a profile line or not). Any flat object can be a profile for a structure, with only one requirement: they must form a closed shape. +

      For our columns, we will use another strategy than with the walls. Instead of "drawing" on top of the 2D plans, we will directly use objects from it: the circles that represent the columns in the plan view. In theory, we could just select one of them, and press the Arch Structure button. However, if we do that, we produce an "empty" structural object. This is because you can never be too sure at how well objects were drawn in the DWG file, and often they are not closed shapes. So, before turning them into actual columns, let's turn them into faces, by using the Draft Upgrade tool twice on them. The first time to convert them into closed wires (polylines), the second time to convert those wires into faces. That second step is not mandatory, but, if you have a face, you are 100% sure that it is closed (otherwise a face cannot be made). +

      After we have converted all our columns to faces, we can use the Arch Structure tool on them, and adjust the height (some have 6m, other only 2.25m height): +

      Arch tutorial 08.jpg +

      On the image above, you can see two columns that are still as they were in the DWG file, two that were upgraded to faces, and two that were turned into structural objects, and their height set to 6m and 2.25m. +

      Note that those different Arch objects (walls, structures, and all the others we'll discover) all share a lot of things between them (for example all can be added one to another, like we already saw with walls, and any of them can be converted to another). So it's more a matter of taste, we could have made our columns with the wall tool too, and converted them if needed. In fact, some of our walls are concrete walls, we might want to convert them to structures later. +

      +

      Subtractions

      +

      Now it is time to build our subtraction volume. The easiest way will be to draw its profile on top of the section view. Then, we will rotate it and place it at its correct position. See why I placed the sections and elevations like that before beginning? It will be very handy for drawing stuff there, then moving it to its correct position on the model. +

      Let's draw a volume, bigger than the roof, that will be subtracted from our walls. To do that, I drew two lines on top of the base of the roof, then extended them a bit further with the Draft Trimex tool. Then, I drew a wire, snapping on these lines, and going well above our 6 meters. I also drew a blue line on the ground level (0.00), that will be or rotation axis. +

      Arch tutorial 09.jpg +

      Now is the tricky part: We will use the Draft Rotate tool to rotate our profile 90 degrees up, in the right position to be extruded. To do that, we must first change the working plane to the YZ plane. Once this is done, the rotation will happen in that plane. But if we do like we did a bit earlier, and set our view to side view, it will be hard to see and select our profile, and to know where is the basepoint around which it must rotate, right? Then we must set the working plane manually: Press the Draft SelectPlane button (it is in the "tasks" tab of the tree view), and set it to YZ (which is the "side" plane). Once you set the working plane manually, like that, it won't change depending on your view. You can now rotate your view until you have a good view of all the things you must select. To switch the working plane back to "automatic" mode later, press the Draft SelectPlane button again and set it to "None". +

      Now the rotation will be easy to do: Select the profile, press the Draft Rotate button, click on a point of the blue line, enter 0 as start angle, and 90 as rotation: +

      Arch tutorial 10.jpg +

      Now all we need to do it to move the profile a bit closer to the model (set the working plane to XY if needed), and extrude it. This can be done either with the Part Extrude tool, or Draft Trimex, which also has the special hidden power to extrude faces. Make sure your extrusion is larger than all the walls it will be subtracted from, to avoid face-on-face situations: +

      Arch tutorial 11.jpg +

      Now, here comes into action the contrary of the Arch Add tool: Arch Remove. As you might have guessed, it also makes an object a child of another, but its shape is subtracted from the host object, instead of being united. So now things are simple: Select the volume to subtract (I renamed it as "Roof volume to subtract" in the tree view so it is easy to spot), CTRL + select a wall, and press the Arch Remove button. You'll see that, after the subtraction happened, the volume to subtract disappeared from both the 3D view and the tree view. That is because it has been marked as child of the wall, and "swallowed" by that wall. Select the wall, expand it in the tree view, there is our volume. +

      Now, select the volume in the tree vieew, CTRL + select the next wall, press Arch Remove. Repeat for the next walls until you have everything properly cut: +

      Arch tutorial 12.jpg +

      Remember that for both Arch Add and Arch Remove, the order you select the objects is important. The host is always the last one, like in "Remove X from Y" or "Add X to Y" +

      +
      A note about additions and subtractions +

      Arch objects that support such additions and subtractions (all of them except the "visual" helper objects such as the axes) keep track of such objects by having two properties, respectively "Additions" and "Subtractions", that contains a list of links to other objects to be subtracted or added. A same object can be in thr lists of several other objects, as it is the case of our subtraction volume here. Each of the fathers will want to swallow it in the tree view, though, so it will usually "live" in the last one. But you can always edit those lists for any object, by double-clicking it in the tree view, which in FreeCAD enters edit mode. Pressing the escape key exits edit mode. +

      +
      +


      +

      +

      Making the roofs

      +

      Now, all we have to do to complete the structure, is to make the roof and the smaller inner slabs. Again, the easiest way is to draw their profiles on top of the section, with the Draft Wire tool. Here I drew 3 profiles on top of each other (I moved them apart in the image below so you see better). The green one will be used for the lateral borders of the roof slab, then the blue one for the side parts, and the red ones for the central part, that sits above the bathroom block: +

      Arch tutorial 13.jpg +

      Then, we must repeat the rotation operation above, to rotate the objects in a vertical position, then move them at their correct places, and copy some of them that will need to be extruded twice, with the Draft Move tool, with the ALT key pressed, which creates copies instead of moving the actual object. I also added two more profiles for the side walls of the bathroom opening. +

      Arch tutorial 14.jpg +

      When everything is in place, it's just a matter of using the Draft Trimex tool to extrude, then convert them to Arch Structure objects. +

      Arch tutorial 15.jpg +

      After that, we can see some problems arising: two of the columns on the right are too short (they should go up to the roof), and there is a gap between the slab and the walls of the studio on the far right (the 2.60 level symbol on the section view was obviously wrong). Thanks to the parametric objects, all this is very easy to solve: For the columns, just change their height to 6m, fish your roof subtraction volume from the tree view, and subtract it to the columns. For the walls, it's even easier: move them a bit down. Since the subtraction volume continues at the same place, the wall geometry will adapt automatically. +

      Now one last thing must be fixed, there is a small slab in the bathroom, that intersects some walls. Let's fix that by creating a new subtraction volume, and subtract it from those walls. Another feature of the Draft Trimex tool, that we use to extrude stuff, is that it can also extrude one single face of an existing object. This creates a new, separate object, so there is no risk to "harm" the other object. So we can select the base face of the small slab (look at it from beneath the model, you'll see it), then press the Draft Trimex button, and extrude it up to well above the roofs. Then, subtract it from the two inner bathroom walls with the Arch Remove tool: +

      Arch tutorial 16.jpg +

      +

      Floors, stairs and chimney

      +

      Now, our structure is complete, we just have a couple of smaller objects to do. +

      +

      The chimney

      +

      Let's start with the chimney. Now you already know how it works, right? Draw a couple of closed wires, move them up at their correct height with the Draft Move tool, extrude them with the Draft Trimex tool, turn the bigger one into a structure, and subtract the smaller ones. Notice how the chimney tube wasn't drawn on the plan view, but I found its position by dragging blue lines from the section views. +

      Arch tutorial 17.jpg +

      +

      The floors

      +

      The floors are not well represented in the base drawings. When looking at the sections, you cannot know where and how thick the floor slabs are. So I will suppose that the walls are sitting on top of foundation blocks, at level 0.00, and that there are floor slabs, also sitting on those blocks, 15cm thick. So the floor slabs don't run under the walls, but around them. We could do that by creating a big rectangular slab then subtracting the walls, but remember, subtraction operations cost us. Better do it in smaller pieces, it will be "cheaper" in terms of calculation, and also if we do it intelligently, room by room, these will also be useful to calculate floor areas later: +

      Arch tutorial 18.jpg +

      Once the wires are drawn, just turn them into structures, and give them a height of 0.15: +

      Arch tutorial 19.jpg +

      +

      The stairs

      +

      Now the stairs. Met the next of the Arch tools, the Arch Stairs. This tool is still in a very early stage of development, at the time I'm writing, so don't expect too much of it. But it is already pretty useful to make simple, straight stairs. One concept is important to know, the stairs tool is thought to build stairs from a flat floor up to a wall. In other words, when viewed from the top, the stairs object occupies exactly the space that it occupies on the plan view, so the last riser is not drawn (but it is of course taken into account when calculating heights). +

      In this case, I preferred to build the stairs on the section view, because we'll need many measurements that are easier to get from that view. Here, I drew a couple of red guidelines, then two blue lines that will be the base of our two pieces of stairs, and two green closed wires, that will form the missing parts. Now select the first blue line, press the Arch Stairs tool, set the number of steps to 5, the height to 0.875,the width to 1.30, the structure type to "massive" and the structure thickness to 0.12. Repeat for the other piece. +

      Then, extrude both green wires by 1.30, and rotate and move them to the right position: +

      Arch tutorial 20.jpg +

      On the elevation view, draw (then rotate) the border: +

      Arch tutorial 21.jpg +

      Then move everything into place: +

      Arch tutorial 22.jpg +

      Don't forget also to cut the column that crosses the stairs, because in BIM it's always bad to have intersecting objects. We are building like in the real world, remember, where solid objects cannot intersect. Here, I didn't want to subtract the column directly from the stairs (otherwise the column object would be swallowed by the stairs object in the tree view, and I didn't like that), so I took the face on which the column was built, and extruded it again. This new extrusion was then subtracted from the stairs. +

      Right! All the hard work is now done, let's go on with the very hard work! +

      +

      Doors and windows

      +

      Arch Windows are pretty complex objects. They are used to make all kinds of "inserted" objects, such as windows or doors. Yes, in FreeCAD, doors are just a special kind of window. In real life too, if you think of it, no? The Arch Window tool can still be a bit hard to use today, but consider this as a tradeoff, as it was built for maximum power. Almost any kind of window your imagination can produce can be done with it. But as the tool will gain more presets, this situation will certainly become better in the future. +

      The Arch Window object works like this: It is based on a 2D layout, any 2D object, but preferably a sketch, that contains closed wires (polylines). These wires define the different parts of the window: outer frames, inner frames, glass panels, solid panels, etc. The window objects then has a property that stores what to do with each of these wires: extrude it, place it at a certain offset, etc. Finally, a window can be inserted into a host object such as a wall or structure, and it will automatically create a hole in it. That hole will be calculated by extruding the biggest wire found in the 2D layout. +

      There are two ways to create such objects in FreeCAD: By using a preset, or drawing the window layout from scratch. We'll look at both methods here. But remember that the preset method does nothing else than creating the layout object and defining the necessary extrusions for you. +

      +

      Using presets

      +

      When pressing the Arch Window tool with no object selected, you are invited either to pick a 2D layout, or to use one of the presets. Let's use the "Simple Door" preset to place the main entrance door of our model. Give it a width of 1m, a height of 2.45m, a W1 size of 0.15m, and leave the other parameters to 0.05m. Then click the lower left corner of the wall, and your new door is created: +

      Arch tutorial 23.jpg +

      You will notice that your new door won't appear in the tree view. That is because, by snapping to a wall, we indicated that wall as its host object. Consequently, it has been "swallowed" by the wall. But a right click on it → Go to selection will find it in the tree. +

      In this case, as our window is not inserted in any wall (the opening was there already), we might as well detach our window from its host wall. This is done by double-clicking the host wall in the tree view to enter its edit mode. There, you will see the window in its "Subtractions" group. Simply select the window there, press the "remove element" button, then "OK". Our window has now been removed from its host wall, and lies at the bottom of the tree view. +

      We have a second door, exactly the same as this one, a bit on the left. Instead of creating a new door from scratch, we have two ways to make a copy of the previous one: By using the Draft Move tool, with the ALT key pressed, which, as you already know, copies an object instead of moving it. Or, even better, we can use the Draft Clone tool. The clone tool produces a "clone" of a selected object, that you can move around, but that retains the shape of the original object. If the original object changes, the clone changes too. +

      So all we need to do now is select the door, press the Draft Clone tool, then move the clone to its correct position with the Draft Move tool. +

      +

      Organizing your model

      +
      Arch tutorial 24.jpg
      +

      Now would be a good time to do a bit of housecleaning. Since we already have two windows, it is a good moment to do some cleaning in the tree view: Create a new group, rename it to "windows", and drop the 2 windows in it. I also recommend you to separate other elements that way, such as the walls and structures. Since you can also create groups inside groups, you can organize further, for example by placing all elements that form the roof into a separate group, so it is easy to turn on and off (turning a group visible or invisible does the same with all objects inside). +

      The Arch Workbench has some additional tools to organize your model: the Arch Site, Arch Building and Arch Floor. Those 3 objects are based on the standard FreeCAD group, so they behave exactly like groups, but they have a couple of additional properties. For example, floors have the ability to set and manage the height of the contained walls and structure, and when they are moved, all their contents are moved too. +

      But here, since we have only one building with only one (and a half) floor, there is no real need to use such objects, so let's stick with simple groups. +

      +
      +


      +Now, let's get back to work. Turn off the roof group, so we can see better inside, and switch the Display Mode of the floor objects to Wireframe (or use the Draft ToggleDisplayMode tool) so we can still snap to them, but we can see the plan view underneath. But you can also turn off the floors completely, then place your doors at level 0, then raise them of 15cm with the Draft Move tool. +

      Let's place the interior doors. Use the "Simple Door" preset again, make doors of 1.00m and 0.70m wide x 2.10m high, with W1 size of 0.1m. Make sure you snap to the correct wall when you place them, so they automatically create a hole in that wall. If it is hard to place them correctly, you can place them at an easier location, at the corner of the wall, for example, then move them. The "hole" will move together. +

      If by mistake you hosted a window in the wrong wall, it is easy to fix: Remove the window from the "Subtraction" group of the host wall in edit mode, as we saw above, then add it to the "Subtraction" group of the correct wall, by the same method, or, simply, using the Arch Remove tool. +

      A little work later, all our doors are there: +

      Arch tutorial 25.jpg +

      After a closer look at the elevation view, I now detected another error: The top of the brick walls is not as 2.60m, but 17.5cm lower, that is, 2.425m. Fortunately, windows based on presets have a facility: You can alter their general dimensions (width and height) from their properties. So let's change their height to 2.425 - 0.15, that is, 2.275. The second window, as it is a clone of the first one, will adapt too. This is basically where the true magic of parametric design appears. +

      Now we can look at the really interesting stuff: How to design your own custom windows. +

      +

      Creating custom windows

      +

      As I explained above, Arch Window objects are created from 2D layouts, made of closed elements (wires (polylines), circles, rectangles, anything). Since Draft objects cannot hold more than one of these elements, the preferred tool to draw window layouts is the Sketcher. Unfortunately, with the sketcher, it is not possible to snap to external objects like with the Draft workbench, which would be useful here, since our elevations are drawn already. Fortunately, a tool exists to convert Draft objects to a sketch: The Draft To Sketch tool. +

      So, let's start by building our first window layout. I drew it on the elevation, using several rectangles: One for the outer line, and 4 for the inner lines. I stopped before the door, because, remember, our door already has a frame there: +

      Arch tutorial 26.jpg +

      Then, select all the rectangles, and press the Draft To Sketch button (and delete the rectangles, because this tool doesn't delete the original objects, in case something goes wrong). Then, with the new sketch selected, press the Arch Window tool: +

      Arch tutorial 27.jpg +

      The tool will detect that the layout has one outer wire and several inner wires, and automatically proposes you a default configuration: One frame, made by subtracting the inner wires from the outer one, extruded by 1m. Let's change that, by entering the window's edit mode, by double-clicking on it in the tree view: +

      You will see a "Default" component, that has been created automatically by the Window tool, that uses the 5 wires (always subtracting the other ones from the biggest one), and has an extrusion value of 1. Let's change its extrusion value to 0.1, to match what we used in the doors. +

      Then, let's add 4 new glass panels, each using a single wire, and give them an extrusion of 0.01, and an offset of 0.05, so they are placed at the middle of the frame. This will be how your window looks like when you are finished: +

      Arch tutorial 28.jpg +

      I suppose now you must have understood the power of this system: Any combination of frames and panels of any shape is possible. If you can draw it in 2D, it can exist as a full valid 3D object. +

      Now, let's draw the other pieces, then we'll move everything into place together. But first. we'll need to do some corrections to the base 2D drawing, because some lines are clearly missing, where the windows meet the stairs. We can fix that by offsetting the stairs line by 2.5cm with the Draft Offset tool (with ALT pressed of course, to copy our lines instead of moving them). Now we can draw our layout, with wires, then convert them to a sketch, then making a window of it. +

      After doing that a couple of times (I made it in 4 separate pieces, but it's up to you to decide), we have our facade complete: +

      Arch tutorial 29.jpg +

      Now, as before, it's just a matter of rotating the pieces, and moving them to their correct position: +

      Arch tutorial 30.jpg +

      Last missing piece, there is a segment of wall that didn't appear on the plan view, that we need to add. We have several options for that, I chose to draw a line on the ground plane, then move it up to the correct height, then create a wall from it. Then, we also need to fish up our roof subtraction volume (it must have stayed in the last column), then subtract it. Now this side of the building is ready: +

      Arch tutorial 31.jpg +

      Ready? Not quite. Look at the image above, we did our doors with a 5cm frame, remember (it was the default from the preset). But the other windows have 2.5cm frames. This needs to be fixed. +

      +

      Editing windows

      +

      We already saw how to build and update window components, via the window's edit mode, but we can also edit the underlying sketch. Preset windows are not different than custom windows, the Arch Window tool only created the underlying sketch fo you. Select our door object (the original, not the copy, remember, we made a clone), and expand it in the tree view. There is our sketch. Double-click it to enter edit mode. +

      the Sketcher Workbench is an extremely powerful tool. It doesn't have some of the Draft conveniences, such as snapping or working planes, but it has many other advantages. In FreeCAD you will frequently use one or another depending on the need. The most important feature of the sketcher is constraints. Constraints allow you to automatically fix the position of some elements relative to others. For example, you can force a segment to always be vertical, or to always be at a certain distance to another. +

      When we edit our door sketch, we can see that it is made on a fully constrained sketch: +

      Arch tutorial 32.jpg +

      Now all we need to do is edit the 5cm distances between the outer line and the inner line, by double-clicking them, and changing their value to 2.5cm (Remember, the units are still not fully functional at the time I'm writing this). After clicking the "OK" button, our door (and its clone) have been updated. +

      +

      Working without 2D support

      +

      Until now our work has been relatively easy, because we had the underlying 2D drawings to base our work upon. But now, we must do the opposite facade and the glass atrium, and things are getting more complicated: The opposite facade drawing has a lot of wrong things, doesn't represent the atrium at all, and we have simply no drawing for the inner walls of the atrium. So we will need to invent a couple of things ourselves. Be sure to have a look at reference pictures to figure out how things are made. Or do it as you wish! +

      One thing we can already do: duplicate the complicated stairs window with the Draft Move tool, because it is equal on both sides: +

      Arch tutorial 33.jpg +

      Note that here, I preferred to duplicate with the Draft Move tool instead of using a clone, because the clone currently doesn't support different colors inside objects. The difference is that the clone is a copy of the final shape of the original object, while if you copy an object, you create a new object and give it all the same properties as the original one (therefore, also its base sketch and its window components definition, which are both stored as properties). +

      Now we must attack the parts that are not drawn anywhere. Let's start with the glass wall between the sitting room and the atrium. It'll be easier to draw it on the elevation view, because we'll get the correct height of the roof. Once you are in plan view, you can rotate the view from the menu View → Standard Views → Rotate left or right, until you get a comfortable view to work, like this: +

      Arch tutorial 34.jpg +

      Note how on the image above, I made a line from the model to the left section, to get the exact width of the window. Then, I reproduced that width on the elevation view and divided it into 4 pieces. Then I built one main window piece, plus 4 additional windows for the sliding doors. The sketcher sometimes has difficulties with overlapping wires, that's why I preferred to keep them separated like this: +

      Arch tutorial 35.jpg +

      After the necessary rotations, everything clicks perfectly into place: +

      Arch tutorial 36.jpg +

      We still need some corner piece there. A little useful trick with the Draft SelectPlane tool, if you have a face selected when you press the button, the working plane matches this face (at least its position, and if the face is rectangular, it also tries to match its axes). This is useful to draw 2D objects directly on the model, such as here, we can draw a rectangle to be extruded directly at its correct position: +

      Arch tutorial 37.jpg +

      Then let's do the two remaining pieces. One is easy, it is a copy of what's on the other side, so we can simply use the 2D drawing: +

      Arch tutorial 38.jpg +

      The other one is a bit tricky, by looking at the pictures, we see that it has many vertical divisions, like the stairs windows. By chance (or very good design from Vilanova Artigas), the width of our window, of 4.50m, is exactly the same as the stairs window, so we can use the exact same division: 15 pieces of 30cm. Here I used the Draft Array tool to copy over the two lines 15 times,and drew rectangles on top of them: +

      Arch tutorial 39.jpg +

      Once this is done, we can create our window with the same method we already know. Another small useful trick, in case you haven't found it yourself already: When editing a window, if you change the name of a component, it actually creates a duplicate of it. So to create the 15 inner glass panels, instead of clicking 15 times the "add" button and fill 15 times the data, you can just keep editing one, and change its name and wire, it will create a copy each time. +

      After the window is rotated and moved into place, the atrium is complete: +

      Arch tutorial 40.jpg +

      +

      Edits and fixes

      +

      Now when we look at our back elevation, and compare it with the plan, we see that there are some differences that need to be fixed. Namely, the bedroom windows are smaller than I first thought, and we'll need to add some more walls. In order to do that properly, some floors need to be cut: +

      Arch tutorial 41.jpg +

      We have of course several ways to do that, making a subtraction volume would be an easy way, but it would add unnecessary complexity to the model. Better to edit the base wire of each floors. This is where the Draft Edit mode comes into action. By expanding these floors in the tree view, then making their base wire visible, we can then double-click them to enter edit mode. There, we can move their points, or add or remove points. With this,editing our floor plates becomes easy. +

      Arch tutorial 42.jpg +

      After some more sweat (the person who made those drawings obviously became pretty lazy when did this last elevation, much is drawn wrong), we finally have our complete house: +

      Arch tutorial 43.jpg +

      Note the chimney tube, which is made from a circle I used to make a hole in the chimney block, that I extruded, then converted into a tube with the Part Offset tool. +

      +
      Problems in objects +

      Sometimes an object you made can have problems. For example, the object it was based onto has been deleted, and the object can therefore not recalculate its shape. These are usually shown to you by a little red sign on their icon, and/or a warning in the output window. There is no generic recipe to fix these problems, because they can have many origins. But, the easiest way to solve them is often to delete them, and, if you didn't delete their base objects, recreate them. +

      +
      +


      +

      +

      Output

      +

      Now, after all the hard work we passed through to build this model, comes the reward: What can we do with it? Basically, this is the big advantage of working with BIM, all our traditional architectural needs, such as 2d drawings (plans, sections, etc), renderings, and calculations (bills of quantities, etc) can all be extracted from the model. And, even better, regenerated every time the model changes. I'll show you here how to obtain these different documents. +

      +

      Preparations

      +

      Before starting to export stuff, one consideration is interesting to do: As you saw, our model is becoming increasingly complex, with a lot of relationships between objects. This can make subsequent calculation operations, such as cutting through the model, heavy. One quick way to magically "simplify" drastically your model, is to remove all of this complexity, by exporting it to the STEP format. That format will preserve all your geometry, but will discard all the relationships and parametric constructions, keeping only the final shape. When reimporting that STEP file into FreeCAD, you will get a model that has no relationship, and a much smaller file size. Think of it as an "output" file, that you can regenerate anytime from your "master" file: +

      Arch tutorial 44.jpg +

      +

      Exporting to IFC and other applications

      +
      Arch tutorial 45.jpg
      +

      One of the very fundamental things you need when working with BIM is to be able to import and export IFC files. This is still a work in progress in FreeCAD. IFC format is already supported, and importing IFC files into FreeCAD is already pretty reliable. Exporting is still experimental, though, and has currently many limitations. However, things are bettering and we should get proper IFC export very soon. +

      IFC export requires very little setup, once the necessary software libraries are installed. You only need to recreate the building structure, which is needed in all IFC files, by adding an Arch Building to your file, then an Arch Floor, then moving all the groups of objects that compose your model in it. Make sure you leave your construction geometry (all the 2D stuff we've been drawing) out of it to avoid making your IFC file unnecessarily heavy. +

      Another thing to set, is to check the "Role" property of structural elements. Since IFC has no "generic" structural element, like FreeCAD, we need to assign them roles (column, beam, etc...) so the exporter knows what element to create in the IFC file. +

      In this case, we need our whole architectural system, so the IFC exporter can know if an object must be exported as a wall or a column, so we are using our "master" model, not our "output" model. +

      Once this is done, simply select your building object, and choose the "Industry Foundation Classes" format. Exporting to non-BIM applications, such as Sketchup is also easy, you have several export formats at your disposal, such as Collada, STEP, IGES ou OBJ. +

      +
      +


      +

      +

      Rendering

      +

      FreeCAD also features a rendering module, the Raytracing Workbench. That workbench currently supports two render engines, PovRay and LuxRender. Since FreeCAD is not designed for image rendering, the features that the Raytracing workbench offer to you are somewhat limited. The best course of action when you want to do proper rendering, is to export your model to a mesh-based format such as OBJ or STL, and open it in an application more suited to rendering, such as blender. The image below has been rendered with blender's cycles engine: +

      Arch tutorial 47.jpg +

      But, for a quick rendering, the Raytracing workbench can already do a good job, with the advantage of being very easy to setup, thanks to its templates system. This is a rendering of our model fully made within FreeCAD, with the Luxrender engine, using the "indoor" template. +

      Arch tutorial 48.jpg +

      The Raytracing workbench still offers you very limited control over materials, but lighting and environments are defined in templates, so they can be fully customized. +

      +

      2D drawings

      +

      Certainly the most important use of BIM is to produce 2D drawings automatically. This is done in FreeCAD with the Arch SectionPlane tool. This tool allows you to place a section plane object in the 3D view, that you can orient to produce plans, sections and elevations. Section planes must know what objects they must consider, so once you have created one, you must add objects to it with the Arch Add tool. You can add individual objects, or, more conveniently, a group, a floor or a whole building. This allows you to easily change the scope of a certain section plane later, by adding or removing objects to/from that group. Any change to these objects gets reflected in the views produced by the section plane. +

      The section plane automatically produces cut views of the objects it intersects. In other words, to produce views instead of sections, you just need to place the section plane outside of your objects. +

      Arch tutorial 49.jpg +

      The section planes can produce two different outputs: shape objects, that live in the same document as your 3D model, or drawing views, that are made to use on a drawing sheet produced by the Drawing workbench. Each of these behave differently, and has its own advantages. +

      Shape views +

      This output is produced by using the Draft Shape2DView tool with a section plane selected. You produce a 2D view of the model directly in the 3D space, like on the image above. The main advantage here is that you can work on them using the Draft tools (or any other standard tool of FreeCAD), so you can add texts, dimensions, symbols, etc: +

      Arch tutorial 50.jpg +

      On the image above, two Shape2D views have been produced for each section, one showing everything, the other showing only the cut lines. This allows us to give it a different line weight, and turn hatching on. Then, dimensions, texts and symbols have been added, and a couple of DXF blocks have been imported to represent the furniture. These views are then easy to export to DXF or DWG, and open in your favorite 2D CAD application, such as LibreCAD or DraftSight, where you can work further on them: +

      Arch tutorial 51.jpg +

      Note that some features are still not supported by the DXF/DWG exporter so the result in your 2D application might differ a bit. For example, in the image above, I had to redo the hatching, and correct the position of some dimension texts. If you place your objects in different groups in FreeCAD, these become layers in your 2D CAD application. +

      Drawing views +

      The other kind of output that can be produced from section planes is a Drawing view. These are produced by using the Draft Drawing tool with a section plane selected. This method has one big limitation compared to the previous one: you have limited possibilities to edit the results, and at the moment, things like dimensioning or hatching are still not natively supported. +

      On the other hand, the final output being easier to manipulate, and the graphical possibilities of the SVG format being huge, in the future, undoubtedly this will be the preferred method. At the moment, though, you'll get better results using the previous one. +

      Arch tutorial 52.jpg +

      On the image above, the geometry is the direct output of the section plane, but some other Draft objects have been added, such as dimensions and hatched polygons, and another view object with same scale and offset values has been produced from them with the Draft Drawing tool. In the future, such operations will be done directly on the Drawing page, leaving your model totally clean. +

      +

      Quantities extraction

      +

      This is another very important task to be performed on BIM models. In FreeCAD, things look good right from the start, since the OpenCasCade kernel of FreeCAD already takes care of calculating lengths, areas and volumes for all the shapes it produces. Since all Arch objects are solids, you are always guaranteed to be able to obtain a volume from them. +

      Using spreadsheets +

      There is a brand-new workbench in FreeCAD, the Spreadsheet Workbench, that is the perfect tool for collecting such information about our model. It can count objects of a certain name or a certain type, or display a specific properties of those objects. The spreadsheet workbench features two objects: The spreadsheet object is a simple spreadsheet container, that you can edit, and place values inside the cells, but has no automation. The cell controller, on the other hand, is an object that you must insert in a spreadsheet, that controls a series of cells of its host spreadsheet, filling them according to what you specify. This, provided that you organized your model well, allows you to easily retrieve individual values: +

      Arch tutorial 53.jpg +

      Note that the spreadsheet workbench is still very new, and like everything very new, still contains many bugs and limitations. But for simple summaries like this, it already works well. The resulting spreadsheet can then be exported to a CSV file, which can be imported in any spreadsheet application. +

      The survey mode +

      Another way to survey your model and extract values, is to use the Arch Survey mode. In this mode, you can click on points, edges, faces or double-click to select whole objects, and you get altitude, length, area or volume values, shown on the model, printed on the FreeCAD output window, and copied to the clipboard, so you can easily pick and paste values in another opened application +

      Arch tutorial 54.jpg +

      +

      Conclusion

      +

      I hope this gives you a good overview of the available tools, be sure to refer to the Arch Workbench and Draft Workbench documentation for more (there are more tools that I didn't mention here), and, more generally, to the rest of the FreeCAD documentation. Pay a visit to the forum too, many problems can usually be solved there in no time, and follow my blog for news about he Arch workbench development. +

      The file created during this tutorial can be found here +


      +


      +

      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Arch_tutorial_00.jpg b/localwiki/Arch_tutorial_00.jpg new file mode 100644 index 0000000..19eaed3 Binary files /dev/null and b/localwiki/Arch_tutorial_00.jpg differ diff --git a/localwiki/Arch_tutorial_01.jpg b/localwiki/Arch_tutorial_01.jpg new file mode 100644 index 0000000..1c663be Binary files /dev/null and b/localwiki/Arch_tutorial_01.jpg differ diff --git a/localwiki/Arch_tutorial_02.jpg b/localwiki/Arch_tutorial_02.jpg new file mode 100644 index 0000000..b69faaa Binary files /dev/null and b/localwiki/Arch_tutorial_02.jpg differ diff --git a/localwiki/Arch_tutorial_03.jpg b/localwiki/Arch_tutorial_03.jpg new file mode 100644 index 0000000..70c8976 Binary files /dev/null and b/localwiki/Arch_tutorial_03.jpg differ diff --git a/localwiki/Arch_tutorial_04.jpg b/localwiki/Arch_tutorial_04.jpg new file mode 100644 index 0000000..c136b34 Binary files /dev/null and b/localwiki/Arch_tutorial_04.jpg differ diff --git a/localwiki/Arch_tutorial_05.jpg b/localwiki/Arch_tutorial_05.jpg new file mode 100644 index 0000000..8d46739 Binary files /dev/null and b/localwiki/Arch_tutorial_05.jpg differ diff --git a/localwiki/Arch_tutorial_06.jpg b/localwiki/Arch_tutorial_06.jpg new file mode 100644 index 0000000..4bbe223 Binary files /dev/null and b/localwiki/Arch_tutorial_06.jpg differ diff --git a/localwiki/Arch_tutorial_07.jpg b/localwiki/Arch_tutorial_07.jpg new file mode 100644 index 0000000..49a5f63 Binary files /dev/null and b/localwiki/Arch_tutorial_07.jpg differ diff --git a/localwiki/Arch_tutorial_08.jpg b/localwiki/Arch_tutorial_08.jpg new file mode 100644 index 0000000..f414d44 Binary files /dev/null and b/localwiki/Arch_tutorial_08.jpg differ diff --git a/localwiki/Arch_tutorial_09.jpg b/localwiki/Arch_tutorial_09.jpg new file mode 100644 index 0000000..c2c6cd0 Binary files /dev/null and b/localwiki/Arch_tutorial_09.jpg differ diff --git a/localwiki/Arch_tutorial_10.jpg b/localwiki/Arch_tutorial_10.jpg new file mode 100644 index 0000000..bd4afab Binary files /dev/null and b/localwiki/Arch_tutorial_10.jpg differ diff --git a/localwiki/Arch_tutorial_11.jpg b/localwiki/Arch_tutorial_11.jpg new file mode 100644 index 0000000..1b6eb1e Binary files /dev/null and b/localwiki/Arch_tutorial_11.jpg differ diff --git a/localwiki/Arch_tutorial_12.jpg b/localwiki/Arch_tutorial_12.jpg new file mode 100644 index 0000000..f6b51db Binary files /dev/null and b/localwiki/Arch_tutorial_12.jpg differ diff --git a/localwiki/Arch_tutorial_13.jpg b/localwiki/Arch_tutorial_13.jpg new file mode 100644 index 0000000..30a1794 Binary files /dev/null and b/localwiki/Arch_tutorial_13.jpg differ diff --git a/localwiki/Arch_tutorial_14.jpg b/localwiki/Arch_tutorial_14.jpg new file mode 100644 index 0000000..cf0e958 Binary files /dev/null and b/localwiki/Arch_tutorial_14.jpg differ diff --git a/localwiki/Arch_tutorial_15.jpg b/localwiki/Arch_tutorial_15.jpg new file mode 100644 index 0000000..c61c0e2 Binary files /dev/null and b/localwiki/Arch_tutorial_15.jpg differ diff --git a/localwiki/Arch_tutorial_16.jpg b/localwiki/Arch_tutorial_16.jpg new file mode 100644 index 0000000..1a59b6b Binary files /dev/null and b/localwiki/Arch_tutorial_16.jpg differ diff --git a/localwiki/Arch_tutorial_17.jpg b/localwiki/Arch_tutorial_17.jpg new file mode 100644 index 0000000..ff0ee0c Binary files /dev/null and b/localwiki/Arch_tutorial_17.jpg differ diff --git a/localwiki/Arch_tutorial_18.jpg b/localwiki/Arch_tutorial_18.jpg new file mode 100644 index 0000000..3605f0c Binary files /dev/null and b/localwiki/Arch_tutorial_18.jpg differ diff --git a/localwiki/Arch_tutorial_19.jpg b/localwiki/Arch_tutorial_19.jpg new file mode 100644 index 0000000..d9cfe66 Binary files /dev/null and b/localwiki/Arch_tutorial_19.jpg differ diff --git a/localwiki/Arch_tutorial_20.jpg b/localwiki/Arch_tutorial_20.jpg new file mode 100644 index 0000000..a4fcdaf Binary files /dev/null and b/localwiki/Arch_tutorial_20.jpg differ diff --git a/localwiki/Arch_tutorial_21.jpg b/localwiki/Arch_tutorial_21.jpg new file mode 100644 index 0000000..8d6c4a8 Binary files /dev/null and b/localwiki/Arch_tutorial_21.jpg differ diff --git a/localwiki/Arch_tutorial_22.jpg b/localwiki/Arch_tutorial_22.jpg new file mode 100644 index 0000000..116e42f Binary files /dev/null and b/localwiki/Arch_tutorial_22.jpg differ diff --git a/localwiki/Arch_tutorial_23.jpg b/localwiki/Arch_tutorial_23.jpg new file mode 100644 index 0000000..65ccaa6 Binary files /dev/null and b/localwiki/Arch_tutorial_23.jpg differ diff --git a/localwiki/Arch_tutorial_24.jpg b/localwiki/Arch_tutorial_24.jpg new file mode 100644 index 0000000..6b0a4bd Binary files /dev/null and b/localwiki/Arch_tutorial_24.jpg differ diff --git a/localwiki/Arch_tutorial_25.jpg b/localwiki/Arch_tutorial_25.jpg new file mode 100644 index 0000000..71e1bcf Binary files /dev/null and b/localwiki/Arch_tutorial_25.jpg differ diff --git a/localwiki/Arch_tutorial_26.jpg b/localwiki/Arch_tutorial_26.jpg new file mode 100644 index 0000000..1cdbd89 Binary files /dev/null and b/localwiki/Arch_tutorial_26.jpg differ diff --git a/localwiki/Arch_tutorial_27.jpg b/localwiki/Arch_tutorial_27.jpg new file mode 100644 index 0000000..28c9e2d Binary files /dev/null and b/localwiki/Arch_tutorial_27.jpg differ diff --git a/localwiki/Arch_tutorial_28.jpg b/localwiki/Arch_tutorial_28.jpg new file mode 100644 index 0000000..a6ebd53 Binary files /dev/null and b/localwiki/Arch_tutorial_28.jpg differ diff --git a/localwiki/Arch_tutorial_29.jpg b/localwiki/Arch_tutorial_29.jpg new file mode 100644 index 0000000..a08097c Binary files /dev/null and b/localwiki/Arch_tutorial_29.jpg differ diff --git a/localwiki/Arch_tutorial_30.jpg b/localwiki/Arch_tutorial_30.jpg new file mode 100644 index 0000000..02a3bfc Binary files /dev/null and b/localwiki/Arch_tutorial_30.jpg differ diff --git a/localwiki/Arch_tutorial_31.jpg b/localwiki/Arch_tutorial_31.jpg new file mode 100644 index 0000000..179cc57 Binary files /dev/null and b/localwiki/Arch_tutorial_31.jpg differ diff --git a/localwiki/Arch_tutorial_32.jpg b/localwiki/Arch_tutorial_32.jpg new file mode 100644 index 0000000..f7fe2fb Binary files /dev/null and b/localwiki/Arch_tutorial_32.jpg differ diff --git a/localwiki/Arch_tutorial_33.jpg b/localwiki/Arch_tutorial_33.jpg new file mode 100644 index 0000000..34530c0 Binary files /dev/null and b/localwiki/Arch_tutorial_33.jpg differ diff --git a/localwiki/Arch_tutorial_34.jpg b/localwiki/Arch_tutorial_34.jpg new file mode 100644 index 0000000..a47ad1b Binary files /dev/null and b/localwiki/Arch_tutorial_34.jpg differ diff --git a/localwiki/Arch_tutorial_35.jpg b/localwiki/Arch_tutorial_35.jpg new file mode 100644 index 0000000..8829649 Binary files /dev/null and b/localwiki/Arch_tutorial_35.jpg differ diff --git a/localwiki/Arch_tutorial_36.jpg b/localwiki/Arch_tutorial_36.jpg new file mode 100644 index 0000000..f327392 Binary files /dev/null and b/localwiki/Arch_tutorial_36.jpg differ diff --git a/localwiki/Arch_tutorial_37.jpg b/localwiki/Arch_tutorial_37.jpg new file mode 100644 index 0000000..29e6b72 Binary files /dev/null and b/localwiki/Arch_tutorial_37.jpg differ diff --git a/localwiki/Arch_tutorial_38.jpg b/localwiki/Arch_tutorial_38.jpg new file mode 100644 index 0000000..49865e7 Binary files /dev/null and b/localwiki/Arch_tutorial_38.jpg differ diff --git a/localwiki/Arch_tutorial_39.jpg b/localwiki/Arch_tutorial_39.jpg new file mode 100644 index 0000000..b7af4ef Binary files /dev/null and b/localwiki/Arch_tutorial_39.jpg differ diff --git a/localwiki/Arch_tutorial_40.jpg b/localwiki/Arch_tutorial_40.jpg new file mode 100644 index 0000000..6d759c4 Binary files /dev/null and b/localwiki/Arch_tutorial_40.jpg differ diff --git a/localwiki/Arch_tutorial_41.jpg b/localwiki/Arch_tutorial_41.jpg new file mode 100644 index 0000000..c31d688 Binary files /dev/null and b/localwiki/Arch_tutorial_41.jpg differ diff --git a/localwiki/Arch_tutorial_42.jpg b/localwiki/Arch_tutorial_42.jpg new file mode 100644 index 0000000..849426c Binary files /dev/null and b/localwiki/Arch_tutorial_42.jpg differ diff --git a/localwiki/Arch_tutorial_43.jpg b/localwiki/Arch_tutorial_43.jpg new file mode 100644 index 0000000..c3cd0af Binary files /dev/null and b/localwiki/Arch_tutorial_43.jpg differ diff --git a/localwiki/Arch_tutorial_44.jpg b/localwiki/Arch_tutorial_44.jpg new file mode 100644 index 0000000..76654a3 Binary files /dev/null and b/localwiki/Arch_tutorial_44.jpg differ diff --git a/localwiki/Arch_tutorial_45.jpg b/localwiki/Arch_tutorial_45.jpg new file mode 100644 index 0000000..af7b1d8 Binary files /dev/null and b/localwiki/Arch_tutorial_45.jpg differ diff --git a/localwiki/Arch_tutorial_47.jpg b/localwiki/Arch_tutorial_47.jpg new file mode 100644 index 0000000..f0f8512 Binary files /dev/null and b/localwiki/Arch_tutorial_47.jpg differ diff --git a/localwiki/Arch_tutorial_48.jpg b/localwiki/Arch_tutorial_48.jpg new file mode 100644 index 0000000..339ab16 Binary files /dev/null and b/localwiki/Arch_tutorial_48.jpg differ diff --git a/localwiki/Arch_tutorial_49.jpg b/localwiki/Arch_tutorial_49.jpg new file mode 100644 index 0000000..227d163 Binary files /dev/null and b/localwiki/Arch_tutorial_49.jpg differ diff --git a/localwiki/Arch_tutorial_50.jpg b/localwiki/Arch_tutorial_50.jpg new file mode 100644 index 0000000..beb2b57 Binary files /dev/null and b/localwiki/Arch_tutorial_50.jpg differ diff --git a/localwiki/Arch_tutorial_51.jpg b/localwiki/Arch_tutorial_51.jpg new file mode 100644 index 0000000..18b5fc1 Binary files /dev/null and b/localwiki/Arch_tutorial_51.jpg differ diff --git a/localwiki/Arch_tutorial_52.jpg b/localwiki/Arch_tutorial_52.jpg new file mode 100644 index 0000000..f5a761f Binary files /dev/null and b/localwiki/Arch_tutorial_52.jpg differ diff --git a/localwiki/Arch_tutorial_53.jpg b/localwiki/Arch_tutorial_53.jpg new file mode 100644 index 0000000..1f39139 Binary files /dev/null and b/localwiki/Arch_tutorial_53.jpg differ diff --git a/localwiki/Arch_tutorial_54.jpg b/localwiki/Arch_tutorial_54.jpg new file mode 100644 index 0000000..5cf355f Binary files /dev/null and b/localwiki/Arch_tutorial_54.jpg differ diff --git a/localwiki/Arrow-ccw.svg b/localwiki/Arrow-ccw.svg new file mode 100644 index 0000000..c5ca60b --- /dev/null +++ b/localwiki/Arrow-ccw.svg @@ -0,0 +1,70 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + Mon Oct 10 13:44:52 2011 +0000 + + + [wmayer] + + + + + FreeCAD LGPL2+ + + + + + FreeCAD + + + FreeCAD/src/Mod/Draft/Resources/icons/Draft_Rotate.svg + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + [agryson] Alexander Gryson + + + An arrow in a circular shape with the head curving towards the tail + + + arrow + curved + refresh + rotate + + + arrow-ccw + https://www.gnu.org/copyleft/lesser.html + + + + diff --git a/localwiki/Arrow-cw.svg b/localwiki/Arrow-cw.svg new file mode 100644 index 0000000..e2f4aae --- /dev/null +++ b/localwiki/Arrow-cw.svg @@ -0,0 +1,172 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + Mon Oct 10 13:44:52 2011 +0000 + + + [wmayer] + + + + + FreeCAD LGPL2+ + + + + + FreeCAD + + + FreeCAD/src/Mod/Draft/Resources/icons/Draft_Rotate.svg + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + [agryson] Alexander Gryson + + + An arrow in a circular shape with the head curving towards the tail + + + arrow + curved + refresh + rotate + + + arrow-cw + https://www.gnu.org/copyleft/lesser.html + + + + diff --git a/localwiki/Arrow-down.svg b/localwiki/Arrow-down.svg new file mode 100644 index 0000000..c69ad2c --- /dev/null +++ b/localwiki/Arrow-down.svg @@ -0,0 +1,311 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [WandererFan] + + + arrow-down + 2016-11-24 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/TechDraw/Gui/Resources/icons/arrow-down.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + arrow + down + + + Arrow pointing down + + + + + + + + diff --git a/localwiki/Arrow-left.svg b/localwiki/Arrow-left.svg new file mode 100644 index 0000000..9bc5365 --- /dev/null +++ b/localwiki/Arrow-left.svg @@ -0,0 +1,311 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [WandererFan] + + + arrow-left + 2016-11-24 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/TechDraw/Gui/Resources/icons/arrow-left.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + arrow + left + + + Arrow pointing left + + + + + + + + diff --git a/localwiki/Arrow-right.svg b/localwiki/Arrow-right.svg new file mode 100644 index 0000000..7b25dbf --- /dev/null +++ b/localwiki/Arrow-right.svg @@ -0,0 +1,311 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [WandererFan] + + + arrow-right + 2016-11-24 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/TechDraw/Gui/Resources/icons/arrow-right.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + arrow + right + + + Arrow pointing right + + + + + + + + diff --git a/localwiki/Arrow-up.svg b/localwiki/Arrow-up.svg new file mode 100644 index 0000000..a5a3b0d --- /dev/null +++ b/localwiki/Arrow-up.svg @@ -0,0 +1,311 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [WandererFan] + + + arrow-up + 2016-11-24 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/TechDraw/Gui/Resources/icons/arrow-up.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + arrow + up + + + Arrow pointing upwards + + + + + + + + diff --git a/localwiki/Arrowdot.svg b/localwiki/Arrowdot.svg new file mode 100644 index 0000000..61bf988 --- /dev/null +++ b/localwiki/Arrowdot.svg @@ -0,0 +1,49 @@ + + + + + + + + + image/svg+xml + + + + + + + + + + + + diff --git a/localwiki/Arrowfilled.svg b/localwiki/Arrowfilled.svg new file mode 100644 index 0000000..17c58bb --- /dev/null +++ b/localwiki/Arrowfilled.svg @@ -0,0 +1,61 @@ + + + + + + + + + image/svg+xml + + + + + + + + + + + + + + + diff --git a/localwiki/Arrowopen.svg b/localwiki/Arrowopen.svg new file mode 100644 index 0000000..2eddb2f --- /dev/null +++ b/localwiki/Arrowopen.svg @@ -0,0 +1,84 @@ + + + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Arrowopendot.svg b/localwiki/Arrowopendot.svg new file mode 100644 index 0000000..e60f4a4 --- /dev/null +++ b/localwiki/Arrowopendot.svg @@ -0,0 +1,58 @@ + + + + + + + + + image/svg+xml + + + + + + + + + + + + + diff --git a/localwiki/Arrowtick.svg b/localwiki/Arrowtick.svg new file mode 100644 index 0000000..b3f8ac3 --- /dev/null +++ b/localwiki/Arrowtick.svg @@ -0,0 +1,74 @@ + + + + + + + + + image/svg+xml + + + + + + + + + + + + + + diff --git a/localwiki/Artwork.html b/localwiki/Artwork.html new file mode 100644 index 0000000..b7ebf4e --- /dev/null +++ b/localwiki/Artwork.html @@ -0,0 +1,1801 @@ +Artwork

      Artwork

      + +

      Here is the artwork that has been created for FreeCAD. Feel free to reuse in other applications. If you would like to contribute with icons, please read the guidelines at the bottom of this page first. +


      +

      +

      Contents

      + +
      + +

      Application Icons Common To Multiple WorkBenches

      +

      The FreeCAD Icon

      +

      Freecad.svg Freecad16.svg +


      +

      +

      File Menu and Toolbar Icons

      +

      Document-new.svg +Document-open.svg +Document-save.svg +Document-save-as.svg +Document-print.svg +Document-print-preview.svg +Edit-cut.svg +Edit-copy.svg +Edit-paste.svg +Edit-undo.svg +Edit-redo.svg +View-refresh.svg +WhatsThis.svg +System-log-out.svg +


      +

      +

      Edit Toolbar Icons

      +

      Edit-undo.svg +Edit-redo.svg +Edit-cut.svg +Edit-copy.svg +Edit-paste.svg +View-refresh.svg +Edit-select-box.svg +Edit-select-all.svg +Edit-delete.svg +Std Edit.svg +Preferences-general.svg +


      +

      +

      Edit > Preferences Sub-menu Icons

      +

      Not all of these Preferences icons will be displayed in FreeCAD at once, unless the user has previously switched to all the WorkBenches. +

      Preferences-system.svg +Preferences-general.svg +Preferences-display.svg +Preferences-arch.svg +Preferences-draft.svg +Preferences-fem.svg +Preferences-import-export.svg +Preferences-openscad.svg +Preferences-part design.svg +Preferences-path.svg +Preferences-raytracing.svg +Sketcher NewSketch.svg +Preferences-techdraw.svg +


      +

      +

      View Menu Icons

      +

      Window-new.svg +View-isometric.svg +View-perspective.svg +View-fullscreen.svg +Std Tool1.svg +View-measurement.svg +


      +

      +

      View > Standard Views Sub-menu and Toolbar Icons

      +

      View-zoom-all.svg +View-zoom-selection.svg +View-axonometric.svg +View-front.svg +View-top.svg +View-right.svg +View-rear.svg +View-bottom.svg +View-left.svg +View-rotate-left.svg +View-rotate-right.svg +


      +

      +

      View > Draw Style Sub-menu and Toolbar Icons

      +

      DrawStyleAsIs.svg +DrawStyleFlatLines.svg +DrawStyleShaded.svg +DrawStyleWireFrame.svg +DrawStylePoints.svg +


      +

      +

      View > Stereo Sub-menu Icons

      +

      Std Tool7.svg +Std Tool6.svg +Std Tool8.svg +


      +

      +

      View > Zoom Sub-menu Icons

      +

      View-zoom-in.svg +View-zoom-out.svg +View-zoom-border.svg +


      +

      +

      View > Visibility Sub-menu Icons

      +

      View-unselectable.svg +Part Measure Toggle All.svg +Part Measure Clear All.svg +


      +

      +

      View > Workbench Sub-menu Icons

      +

      Workbench Arch.svg +Workbench Complete.svg +Workbench Draft.svg +Workbench Drawing.svg +Workbench FEM.svg +Workbench Image.svg +Workbench Mesh.svg +Workbench Part.svg +Workbench PartDesign.svg +Workbench Plot.svg +PointsWorkbench.svg +Workbench Raytracing.svg +ReverseEngineeringWorkbench.svg +Workbench Robot.svg +Workbench Sketcher.svg +Workbench Start.svg +Workbench Test.png +Workbench Web.svg +


      +

      +

      Tools Menu Icons

      +

      Camera-photo.svg +View-measurement.svg +Accessories-calculator.svg +Applications-accessories.svg +AddonManager.svg +


      +

      +

      Macro Menu and Toolbar Icons

      +

      Media-record.svg +Media-playback-stop.svg +MacroEditor.svg +Media-playback-start.svg +Debug-start.svg +Debug-stop.svg +


      +

      +

      Windows Menu Icons

      +

      Std WindowNext.svg +Std WindowPrev.svg +Std WindowTileVer.svg +Std WindowCascade.svg +


      +

      +

      Help Menu Icons

      +

      Help-browser.svg +Internet-web-browser.svg +Applications-python.svg +Freecad.svg +WhatsThis.svg +


      +

      +

      Structure Menu and Toolbar Icons

      +

      Geofeaturegroup.svg +Group.svg +


      +

      +

      Other/General Icons

      +

      Emot icons

      +

      FreeCAD05 Tango Face-angel.svg +FreeCAD05 Tango Face-blush.svg +FreeCAD05 Tango Face-crying.svg +FreeCAD05 Tango Face-devil-grin.svg +FreeCAD05 Tango Face-glasses.svg +FreeCAD05 Tango Face-grin.svg +FreeCAD05 Tango Face-grin-braces.svg +FreeCAD05 Tango Face-kiss.svg +FreeCAD05 Tango Face-plain.svg +FreeCAD05 Tango Face-sad.svg +FreeCAD05 Tango Face-smile.svg +FreeCAD05 Tango Face-smile-big.svg +FreeCAD05 Tango Face-surprise.svg +FreeCAD05 Tango Face-wink.svg +


      +FreeCAD05 Tango Anaglyph.svg +FreeCAD05 Tango Applications-games.svg +FreeCAD05 Tango Applications-ristretto.svg +FreeCAD05 Tango Dialog-error.svg +FreeCAD05 Tango Dialog-warning.svg +FreeCAD05 Tango Measure.svg +FreeCAD05 Tango Process-stop.svg +FreeCAD05 Tango Text-x-python.svg +FreeCAD05 Tango Camera-photo.svg +FreeCAD05 Tango Preferences-system.svg +FreeCAD05 Tango Camera-video.svg +FreeCAD05 Tango Applications-graphics.svg +FC Christmas.svg +

      +

      Splash screens

      +

      Splashscreen09.png +

      Splashscreen010.png +

      Splash011.png +

      Splashscreen012.png +

      Splash013.jpg +

      Freecadsplash14.png +

      Freecadsplash15.png +

      Freecadsplash016.png +

      Freecadsplash017.png +


      +

      +

      All Icons by their location in source code

      +

      From \src\Gui\Icons

      +

      Accessories-calculator.svg +Accessories-text-editor.svg +AddonManager.svg +Application-exit.svg +Applications-accessories.svg +Applications-python.svg +Background.png +Bound-expression.svg +Bound-expression-unset.svg +Breakpoint.svg +Bulb.svg +Button add all.svg +Button down.svg +Button invalid.svg +Button left.svg +Button right.svg +Button sort.svg +Button up.svg +Button valid.svg +Camera-photo.svg +Colors.svg +CoordinateSystem.svg +DagViewFail.svg +DagViewPass.svg +DagViewPending.svg +DagViewVisible.svg +Debug marker.svg +Debug-start.svg +Debug-stop.svg +Delete.svg +Document.svg +Document-new.svg +Document-open.svg +Document-print.svg +Document-print-preview.svg +Document-properties.svg +Document-save.svg +Document-save-as.svg +DrawStyleAsIs.svg +DrawStyleFlatLines.svg +DrawStylePoints.svg +DrawStyleShaded.svg +DrawStyleWireFrame.svg +Edit Cancel.svg +Edit-cleartext.svg +Edit-copy.svg +Edit-cut.svg +Edit-delete.svg +Edit-edit.svg +Edit OK.svg +Edit-paste.svg +Edit-redo.svg +Edit-select-all.svg +Edit-select-box.svg +Edit-undo.svg +Feature.svg +Freecad.svg +Freecad-doc.svg +Freecadsplash017.png +Geofeaturegroup.svg +Group.svg +Help-browser.svg +Internet-web-browser.svg +List-add.svg +List-remove.svg +MacroEditor.svg +Material.svg +Media-playback-start.svg +Media-playback-stop.svg +Media-record.svg +Mouse pointer.svg +Param Bool.svg +Param Float.svg +Param Int.svg +Param Text.svg +Param UInt.svg +Part Measure Clear All.svg +Part Measure Toggle All.svg +PolygonPick.svg +Preferences-display.svg +Preferences-general.svg +Preferences-import-export.svg +Preferences-system.svg +Process-stop.svg +Px.svg +Python.svg +Spaceball button.svg +SpNav-PanLR.svg +SpNav-PanUD.svg +SpNav-Roll.svg +SpNav-Spin.svg +SpNav-Tilt.svg +SpNav-Zoom.svg +Std Axis.svg +Std Plane.svg +Std Tool1.svg +Std Tool2.svg +Std Tool3.svg +Std Tool4.svg +Std Tool5.svg +Std Tool6.svg +Std Tool7.svg +Std Tool8.svg +Std Tool9.svg +Std Tool10.svg +Std Tool11.svg +Std Tool12.svg +Std ViewScreenShot.svg +Std WindowCascade.svg +Std WindowNext.svg +Std WindowPrev.svg +Std WindowTileVer.svg +TextDocument.svg +Tree Annotation.svg +Tree Dimension.svg +Tree Python.svg +User.svg +Utilities-terminal.svg +View-axonometric.svg +View-bottom.svg +View-front.svg +View-fullscreen.svg +View-isometric.svg +View-left.svg +View-measurement.svg +View-perspective.svg +View-rear.svg +View-refresh.svg +View-right.svg +View-rotate-left.svg +View-rotate-right.svg +View-select.svg +View-top.svg +View-unselectable.svg +WhatsThis.svg +Window-new.svg +Zoom-all.svg +Zoom-border.svg +Zoom-fit-best.svg +Zoom-in.svg +Zoom-out.svg +Zoom-selection.svg +


      +The Background has been re-sized to a display width of 240 pixels: +

      Background.png +


      +

      +

      From \src\Gui\Icons\ClassBrowser

      +

      Const member.svg +Member.svg +Method.svg +Property.svg +Type class.svg +Type enum.svg +Type module.svg +

      +

      From \src\Mod\Arch\Resources\icons

      +

      Arch 3Views.svg +Arch Add.svg +Arch Axis.svg +Arch Axis System.svg +Arch Axis System Tree.svg +Arch Axis Tree.svg +Arch Bimserver.svg +Arch Building.svg +Arch Building Tree.svg +Arch Cell.svg +Arch Cell Tree.svg +Arch Check.svg +Arch CloseHoles.svg +Arch Component.svg +Arch Component Clone.svg +Arch CutPlane.svg +Arch Equipment.svg +Arch Equipment Clone.svg +Arch Equipment Tree.svg +Arch Fixture.svg +Arch Floor.svg +Arch Floor Tree.svg +Arch Frame.svg +Arch Frame Tree.svg +Arch Grid.svg +Arch Material.svg +Arch Material Group.svg +Arch Material Multi.svg +Arch MergeWalls.svg +Arch MeshToShape.svg +Arch Nest.svg +Arch Panel.svg +Arch Panel Clone.svg +Arch Panel Cut.svg +Arch Panel Sheet.svg +Arch Panel Tree.svg +Arch Pipe.svg +Arch PipeConnector.svg +Arch Pipe Tree.svg +Arch Rebar.svg +Arch Rebar Tree.svg +Arch Remove.svg +Arch RemoveShape.svg +Arch Roof.svg +Arch Roof Tree.svg +Arch Schedule.svg +Arch SectionPlane.svg +Arch SectionPlane Tree.svg +Arch SelectNonManifold.svg +Arch Site.svg +Arch Site Tree.svg +Arch Space.svg +Arch Space Tree.svg +Arch SplitMesh.svg +Arch Stairs.svg +Arch Stairs Tree.svg +Arch StructuralSystem.svg +Arch StructuralSystem Tree.svg +Arch Structure.svg +Arch Structure Clone.svg +Arch Structure Tree.svg +Arch Survey.svg +Arch ToggleIfcBrepFlag.svg +Arch ToggleSubs.svg +Arch Wall.svg +Arch Wall Tree.svg +Arch Wall Tree Assembly.svg +Arch Window.svg +Arch Window Clone.svg +Arch Window Tree.svg +ArchWorkbench.svg +Git.svg +IFC.svg +Preferences-arch.svg +


      +

      +

      From \src\Mod\Arch\Resources\ui

      +

      ParametersBeam.svg +ParametersDent.svg +ParametersDoorGlass.svg +ParametersDoorSimple.svg +ParametersIbeam.svg +ParametersPanel.svg +ParametersPillar.svg +ParametersSlab.svg +ParametersStairs.svg +ParametersWindowDouble.svg +ParametersWindowFixed.svg +ParametersWindowSimple.svg +ParametersWindowStash.svg +


      +

      +

      From src\Mod\Assembly\Gui\Resources\icons

      +

      Assembly Add Existing Part.svg +Assembly Add New Part.svg +Assembly Assembly Constraints Tree.svg +Assembly Assembly Create New.svg +Assembly Assembly Part Tree.svg +Assembly Assembly Tree.svg +Assembly Demo.svg +AssemblyWorkbench.svg +

      +

      From src\Mod\Assembly\Gui\Resources\icons\actions

      +

      Axle constraint.svg +

      +

      From src\Mod\Assembly\Gui\Resources\icons\constraints

      +

      Assembly ConstraintAlignment.svg +Assembly ConstraintAngle.svg +Assembly ConstraintBidirectional.svg +Assembly ConstraintCoincidence.svg +Assembly ConstraintDistance.svg +Assembly ConstraintEqual.svg +Assembly ConstraintGeneral.svg +Assembly ConstraintLock.svg +Assembly ConstraintOpposite.svg +Assembly ConstraintOrientation.svg +Assembly ConstraintParallel.svg +Assembly ConstraintPerpendicular.svg +Assembly ConstraintUnidirectional1.svg +Assembly ConstraintUnidirectional2.svg +

      +

      From src\Mod\Complete\Gui\Resources\icons

      +

      CompleteWorkbench.svg +


      +

      +

      From \src\Mod\Draft\Resources\Icons

      +

      Draft 2DShapeView.svg +Draft AddPoint.svg +Draft AddToGroup.svg +Draft Apply.svg +Draft Arc.svg +Draft Array.svg +Draft AutoGroup.svg +Draft AutoGroup off.svg +Draft AutoGroup on.svg +Draft BezCurve.svg +Draft BezSharpNode.svg +Draft BezSymNode.svg +Draft BezTanNode.svg +Draft BSpline.svg +Draft Circle.svg +Draft Clone.svg +Draft Construction.svg +Draft Cursor.svg +Draft DelPoint.svg +Draft Dimension.svg +Draft Dot.svg +Draft Downgrade.svg +Draft Draft.svg +Draft Draft2Sketch.svg +Draft Drawing.svg +Draft Edit.svg +Draft Ellipse.svg +Draft Facebinder.svg +Draft Finish.svg +Draft FlipDimension.svg +Draft Grid.svg +Draft Heal.svg +Draft Label.svg +Draft Line.svg +Draft Lock.svg +Draft Macro.svg +Draft Mirror.svg +Draft Move.svg +Draft Offset.svg +Draft PathArray.svg +Draft Point.svg +Draft Polygon.svg +Draft Rectangle.svg +Draft Rotate.svg +Draft Scale.svg +Draft SelectGroup.svg +Draft SelectPlane.svg +Draft ShapeString.svg +Draft Slope.svg +Draft Snap.svg +Draft Stretch.svg +Draft SwitchMode.svg +Draft Text.svg +Draft Trimex.svg +Draft Upgrade.svg +Draft VisGroup.svg +Draft Wipe.svg +Draft Wire.svg +Draft WireToBSpline.svg +DraftWorkbench.svg +Preferences-draft.svg +Snap Angle.svg +Snap Center.svg +Snap Dimensions.svg +Snap Endpoint.svg +Snap Extension.svg +Snap Grid.svg +Snap Intersection.svg +Snap Lock.svg +Snap Midpoint.svg +Snap Near.svg +Snap Ortho.svg +Snap Parallel.svg +Snap Perpendicular.svg +Snap Special.svg +Snap WorkingPlane.svg +


      +

      +

      From \src\Mod\Draft\Resources\Patterns

      +

      Brick01.svg +Concrete.svg +Cross.svg +Diagonal1.svg +Diagonal2.svg +Earth.svg +Hbone.svg +Line.svg +Plus.svg +Simple.svg +Solid.svg +Square.svg +Steel.svg +Wood.svg +Woodgrain.svg +


      +

      +

      From \src\Mod\Drawing\Gui\Resources\Icons

      +

      DrawingWorkbench.svg +Page.svg +Pages.svg +View.svg +


      +

      +

      From \src\Mod\Drawing\Gui\Resources\Icons\Actions

      +

      Document-new.svg +Drawing-annotation.svg +Drawing-clip.svg +Drawing-draft-view.svg +Drawing-landscape.svg +Drawing-landscape-A0.svg +Drawing-landscape-A1.svg +Drawing-landscape-A2.svg +Drawing-landscape-A3.svg +Drawing-landscape-A4.svg +Drawing-landscape-new.svg +Drawing-openbrowser.svg +Drawing-orthoviews.svg +Drawing-portrait-A0.svg +Drawing-portrait-A1.svg +Drawing-portrait-A2.svg +Drawing-portrait-A3.svg +Drawing-portrait-A4.svg +Drawing-spreadsheet.svg +Drawing-symbol.svg +Drawing-view.svg +


      +

      +

      From \src\Mod\Drawing\Templates

      +

      A0 Landscape ISO7200.svg +A0 Landscape plain.svg +A0 Portrait plain.svg +A1 Landscape ISO7200.svg +A1 Landscape plain.svg +A1 Portrait plain.svg +A2 Landscape ISO7200.svg +A2 Landscape plain.svg +A2 Portrait plain.svg +A3 Landscape.svg +A3 Landscape ISO7200.svg +A3 Landscape plain.svg +A3 Portrait plain.svg +A4 Landscape.svg +A4 Landscape ISO7200.svg +A4 Landscape plain.svg +A4 Portrait ISO7200.svg +A4 Portrait plain.svg +The following image is "A4_Simple.svg": +

      A4 Simple.svg +


      +

      +

      From \src\Mod\Fem\Gui\Resources\Icons

      +

      Fem-add-fem-mesh.svg +Fem-add-material.svg +Fem-add-part.svg +Fem-analysis.svg +Fem-beam-rotation.svg +Fem-beam-section.svg +Fem-box.svg +Fem-cfd-analysis.svg +Fem-clip.svg +Fem-clip-scalar.svg +Fem-constraint-bearing.svg +Fem-constraint-contact.svg +Fem-constraint-displacement.svg +Fem-constraint-electrostatic-potential.svg +Fem-constraint-fixed.svg +Fem-constraint-flow-velocity.svg +Fem-constraint-fluid-boundary.svg +Fem-constraint-force.svg +Fem-constraint-gear.svg +Fem-constraint-heatflux.svg +Fem-constraint-initial-flow-velocity.svg +Fem-constraint-InitialTemperature.svg +Fem-constraint-planerotation.svg +Fem-constraint-pressure.svg +Fem-constraint-pulley.svg +Fem-constraint-selfweight.svg +Fem-constraint-temperature.svg +Fem-constraint-transform.svg +Fem-control-solver.svg +Fem-cut.svg +Fem-cylinder.svg +Fem-data.svg +Fem-DataAlongLine.svg +Fem-elmer.svg +Fem-equation-elasticity.svg +Fem-equation-electrostatic.svg +Fem-equation-flow.svg +Fem-equation-fluxsolver.svg +Fem-equation-heat.svg +Fem-femmesh-boundary-layer.svg +Fem-femmesh-clear-mesh.svg +Fem-femmesh-create-node-by-poly.svg +Fem-femmesh-from-shape.svg +Fem-femmesh-gmsh-from-shape.svg +Fem-femmesh-netgen-from-shape.svg +Fem-femmesh-print-info.svg +Fem-femmesh-region.svg +Fem-femmesh-result.svg +Fem-femmesh-to-mesh.svg +Fem-fluid-section.svg +Fem-frequency-analysis.svg +Fem-inp-editor.svg +Fem-isosurface.svg +Fem-linearizedstresses.svg +Fem-material.svg +Fem-material-fluid.svg +Fem-material-nonlinear.svg +Fem-plane.svg +Fem-purge-results.svg +Fem-result.svg +Fem-run-solver.svg +Fem-shell-thickness.svg +Fem-solver.svg +Fem-sphere.svg +Fem-static-analysis.svg +Fem-thermomechanical-analysis.svg +Fem-warp.svg +FemWorkbench.svg +Preferences-fem.svg +


      +

      +

      From \src\Mod\Image\Gui\Resources\Icons

      +

      Image-import.svg +ImageWorkbench.svg +

      +

      From \src\Mod\Inspection\Gui\Resources\Icons

      +

      InspectionWorkbench.svg +Inspect pipette.svg +


      +

      +

      From \src\Mod\Material\Gui\Resources\Icons

      +

      Preview-rendered.svg +Preview-vector.svg +

      +

      From \src\Mod\Mesh\Gui\Resources\Icons

      +

      Mesh boundary.svg +Mesh Curvature Plot.svg +Mesh cut.svg +Mesh Export Mesh.svg +Mesh Flip Normals.svg +Mesh Harmonize Normals.svg +Mesh Import Mesh.svg +Mesh Mesh from Shape.svg +Mesh pipette.svg +Mesh Regular Solid.svg +Mesh Remove Components.svg +Mesh Tree Curvature Plot.svg +MeshWorkbench.svg +Tree Mesh.svg +


      +

      +

      From \src\Mod\Mesh\Gui\Resources\Icons\RegularSolids

      +

      Mesh Cone.svg +Mesh Cube.svg +Mesh Cylinder.svg +Mesh Ellipsoid.svg +Mesh Sphere.svg +Mesh Torus.svg +

      +

      From \src\Mod\MeshPart\Gui\Resources\Icons\Actions

      +

      MeshFace.svg +

      +

      From \src\Mod\OpenSCAD\Resources\Icons\

      +

      OpenSCAD AddOpenSCADElement.svg +OpenSCAD ColorCodeShape.svg +OpenSCAD Explode Group.svg +OpenSCAD Hull.svg +OpenSCAD IncreaseToleranceFeature.svg +OpenSCAD MeshBooleans.svg +OpenSCAD Minkowski.svg +OpenSCAD RefineShapeFeature.svg +OpenSCAD RemoveSubtree.svg +OpenSCAD ReplaceObject.svg +OpenSCADWorkbench.svg +Preferences-openscad.svg +


      +

      +

      From \src\Mod\Part\Gui\Resources\icons\

      +

      Part Attachment.svg +Part BooleanFragments.svg +Part Booleans.svg +Part Box.svg +Part Chamfer.svg +Part CheckGeometry.svg +Part Circle Parametric.svg +Part Common.svg +Part CompoundFilter.svg +Part Cone.svg +Part CreatePrimitives.svg +Part CrossSections.svg +Part Cut.svg +Part Cylinder.svg +Part Ellipse Parametric.svg +Part Export.svg +Part Extrude.svg +PartFeature.svg +Part Fillet.svg +Part Fuse.svg +Part Helix Parametric.svg +Part Import.svg +Part JoinBypass.svg +Part JoinConnect.svg +Part JoinCutout.svg +Part JoinEmbed.svg +Part Line Parametric.svg +Part Loft.svg +Part Measure Angular.svg +Part Measure Linear.svg +Part Measure Step Active.svg +Part Measure Step Done.svg +Part Measure Toggle 3d.svg +Part Measure Toggle Delta.svg +Part Mirror.svg +Part Offset.svg +Part Offset2D.svg +Part Point Parametric.svg +Part Polygon Parametric.svg +Part Refine Shape.svg +Part Revolve.svg +Part RuledSurface.svg +Part Section.svg +Part Shapebuilder.svg +Part Shape from Mesh.svg +Part ShapeInfo.svg +Part Slice.svg +Part Sphere.svg +Part Spiral Parametric.svg +Part Spline Parametric.svg +Part Sweep.svg +Part Thickness.svg +Part Torus.svg +Part Workbench.svg +Part XOR.svg +Preferences-part design.svg +Tree Part.svg +Tree Part Box Parametric.svg +Tree Part Cone Parametric.svg +Tree Part Cylinder Parametric.svg +Tree Part Ellipsoid Parametric.svg +Tree Part Plane Parametric.svg +Tree Part Prism.svg +Tree Part Sphere Parametric.svg +Tree Part Torus Parametric.svg +Tree Part Wedge.svg +


      +

      +

      From \src\Mod\PartDesign\FeatureHole

      +

      PartDesign Hole.svg +


      +

      +

      From \src\Mod\PartDesign\Gui\Resources\icons\

      +

      PartDesign Additive Box.svg +PartDesign Additive Cone.svg +PartDesign Additive Cylinder.svg +PartDesign Additive Ellipsoid.svg +PartDesign Additive Loft.svg +PartDesign Additive Pipe.svg +PartDesign Additive Prism.svg +PartDesign Additive Sphere.svg +PartDesign Additive Torus.svg +PartDesign Additive Wedge.svg +PartDesign BaseFeature.svg +PartDesign Body.svg +PartDesign Body Create New.svg +PartDesign Body Tree.svg +PartDesign Boolean.svg +PartDesign Chamfer.svg +PartDesign Clone.svg +PartDesign CoordinateSystem.svg +PartDesign Draft.svg +PartDesign Fillet.svg +PartDesign Groove.svg +PartDesign Hole.svg +PartDesign InternalExternalGear.svg +PartDesign InvoluteGear.svg +PartDesign Line.svg +PartDesign LinearPattern.svg +PartDesign Mirrored.svg +PartDesign MoveTip.svg +PartDesign MultiTransform.svg +PartDesign Pad.svg +PartDesign Plane.svg +PartDesign Pocket.svg +PartDesign Point.svg +PartDesign PolarPattern.svg +PartDesign Revolution.svg +PartDesign Scaled.svg +PartDesign ShapeBinder.svg +PartDesign Subtractive Box.svg +PartDesign Subtractive Cone.svg +PartDesign Subtractive Cylinder.svg +PartDesign Subtractive Ellipsoid.svg +PartDesign Subtractive Loft.svg +PartDesign Subtractive Pipe.svg +PartDesign Subtractive Prism.svg +PartDesign Subtractive Sphere.svg +PartDesign Subtractive Torus.svg +PartDesign Subtractive Wedge.svg +PartDesign Thickness.svg +PartDesignWorkbench.svg +Tree PartDesign Pad.svg +Tree PartDesign Revolution.svg +


      +

      +

      From \src\Mod\PartDesign\WizardShaft\

      +

      WizardShaft.svg +

      +

      From \src\Mod\Path\Gui\Resources\icons

      +

      Path-3DPocket.svg +Path-3DSurface.svg +Path-Area.svg +Path-Area-View.svg +Path-Area-Workplane.svg +Path-Array.svg +Path-Axis.svg +Path-BaseGeometry.svg +Path-BFastForward.svg +Path-BPause.svg +Path-BPlay.svg +Path-BStep.svg +Path-BStop.svg +Path-Comment.svg +Path-Compound.svg +Path-Contour.svg +Path-Copy.svg +Path-Custom.svg +Path-Datums.svg +Path-Depths.svg +Path-Dressup.svg +Path-Drilling.svg +Path-Engrave.svg +Path-ExportTemplate.svg +Path-Face.svg +Path-FacePocket.svg +Path-FaceProfile.svg +Path-Heights.svg +Path-Helix.svg +Path-Holding.svg +Path-Hop.svg +Path-Inspect.svg +Path-Job.svg +Path-Kurve.svg +Path-LengthOffset.svg +Path-Machine.svg +Path-MachineLathe.svg +Path-MachineMill.svg +Path-Machine-test1.svg +Path-OpCopy.svg +Path-OperationA.svg +Path-OperationB.svg +Path-Plane.svg +Path-Pocket.svg +Path-Post.svg +Path-Profile.svg +Path-Profile-Edges.svg +Path-Profile-Face.svg +Path-Sanity.svg +Path-SelectLoop.svg +Path-SetupSheet.svg +Path-Shape.svg +Path-Simple copy.svg +Path-Simulator.svg +Path-Speed.svg +Path-Stock.svg +Path-Stop.svg +Path-Tags.svg +Path-ToolChange.svg +Path-ToolController.svg +Path-Toolpath.svg +Path-ToolTable.svg +Path-Workbench.svg +Preferences-path.svg +


      +

      +

      From \src\Mod\Plot\resources\icons

      +

      Axes.svg +Grid.svg +Icon.svg +Labels.svg +Legend.svg +PlotWorkbench.svg +Positions.svg +Save.svg +Series.svg +


      +

      +

      From \src\Mod\Points\Gui\Resources\icons

      +

      Points Export Point cloud.svg +Points Import Point cloud.svg +PointsWorkbench.svg +


      +

      +

      From \src\Mod\Raytracing\Gui\Resources\icons

      +

      Preferences-raytracing.svg +Raytrace Camera.svg +Raytrace Export.svg +Raytrace ExportProject.svg +Raytrace Lux.svg +Raytrace New.svg +Raytrace NewPartSegment.svg +Raytrace Part.svg +Raytrace Render.svg +Raytrace ResetCamera.svg +RaytracingWorkbench.svg +


      +

      +

      From \src\Mod\ReverseEngineering\Gui\Resources\icons\

      +

      ReverseEngineeringWorkbench.svg +


      +

      +

      From \src\Mod\ReverseEngineering\Gui\Resources\icons\actions

      +

      FitSurface.svg +


      +

      +

      From \src\Mod\Robot\Gui\Resources\icons

      +

      Robot CreateRobot.svg +Robot CreateTrajectory.svg +Robot Edge2Trac.svg +Robot Export.svg +Robot InsertWaypoint.svg +Robot InsertWaypointPre.svg +Robot RestoreHomePos.svg +Robot SetDefaultOrientation.svg +Robot SetDefaultValues.svg +Robot SetHomePos.svg +Robot Simulate.svg +Robot TrajectoryCompound.svg +Robot TrajectoryDressUp.svg +Robot Workbench.svg +


      +

      +

      From \src\Mod\Ship\Resources\icons

      +

      Ship AreaCurve.svg +Ship CapacityCurve.svg +Ship GZ.svg +Ship Hydrostatics.svg +Ship Instance.svg +Ship Load.svg +Ship LoadCondition.svg +Ship Logo.svg +Ship Module.svg +Ship OutlineDraw.svg +Ship Tank.svg +Ship Wieght.svg +ShipWorkbench.svg +


      +

      +

      From \src\Mod\Sketcher\Gui\Resources\icons

      +

      Constraint Concentric.svg +Constraint Ellipse Axis Angle.svg +Constraint Ellipse Major Radius.svg +Constraint Ellipse Minor Radius.svg +Constraint Ellipse Radii.svg +Constraint EqualLength.svg +Constraint ExternalAngle.svg +Constraint Horizontal.svg +Constraint HorizontalDistance.svg +Constraint HorizontalDistance Driven.svg +Constraint InternalAlignment.svg +Constraint InternalAlignment Ellipse Focus1.svg +Constraint InternalAlignment Ellipse Focus2.svg +Constraint InternalAlignment Ellipse MajorAxis.svg +Constraint InternalAlignment Ellipse MinorAxis.svg +Constraint InternalAngle.svg +Constraint InternalAngle Driven.svg +Constraint Length.svg +Constraint Length Driven.svg +Constraint Parallel.svg +Constraint Perpendicular.svg +Constraint PointOnEnd.svg +Constraint PointOnMidPoint.svg +Constraint PointOnObject.svg +Constraint PointOnPoint.svg +Constraint PointOnStart.svg +Constraint PointToObject.svg +Constraint Radius.svg +Constraint Radius Driven.svg +Constraint SnellsLaw.svg +Constraint SnellsLaw Driven.svg +Constraint Symmetric.svg +Constraint Tangent.svg +Constraint TangentToEnd.svg +Constraint TangentToStart.svg +Constraint Vertical.svg +Constraint VerticalDistance.svg +Constraint VerticalDistance Driven.svg +Sketcher AlterConstruction.svg +Sketcher AlterFillet.svg +Sketcher BSplineApproximate.svg +Sketcher BSplineComb.svg +Sketcher BSplineDecreaseDegree.svg +Sketcher BSplineDecreaseKnotMultiplicity.svg +Sketcher BSplineDegree.svg +Sketcher BSplineIncreaseDegree.svg +Sketcher BSplineIncreaseKnotMultiplicity.svg +Sketcher BSplineKnotMultiplicity.svg +Sketcher BSplinePolygon.svg +Sketcher CarbonCopy.svg +Sketcher CarbonCopy Constr.svg +Sketcher Clone.svg +Sketcher CloseShape.svg +Sketcher Conics.svg +Sketcher Conics Constr.svg +Sketcher Conics Ellipse 3points.svg +Sketcher Conics Ellipse Center.svg +Sketcher ConnectLines.svg +Sketcher ConstrainBlock.svg +Sketcher ConstrainCoincident.svg +Sketcher ConstrainDistance.svg +Sketcher ConstrainHorizontal.svg +Sketcher ConstrainLock.svg +Sketcher ConstrainLock Driven.svg +Sketcher ConstrainParallel.svg +Sketcher ConstrainVertical.svg +Sketcher Copy.svg +Sketcher Create3PointArc.svg +Sketcher Create3PointArc Constr.svg +Sketcher Create3PointCircle.svg +Sketcher Create3PointCircle Constr.svg +Sketcher CreateArc.svg +Sketcher CreateArc Constr.svg +Sketcher CreateBSpline.svg +Sketcher CreateBSpline Constr.svg +Sketcher CreateCircle.svg +Sketcher CreateCircle Constr.svg +Sketcher CreateEllipse.svg +Sketcher CreateEllipse Constr.svg +Sketcher CreateEllipse 3points.svg +Sketcher CreateEllipse 3points Constr.svg +Sketcher CreateFillet.svg +Sketcher CreateHeptagon.svg +Sketcher CreateHeptagon Constr.svg +Sketcher CreateHexagon.svg +Sketcher CreateHexagon Constr.svg +Sketcher CreateLine.svg +Sketcher CreateLine Constr.svg +Sketcher CreateOctagon.svg +Sketcher CreateOctagon Constr.svg +Sketcher CreatePentagon.svg +Sketcher CreatePentagon Constr.svg +Sketcher Create Periodic BSpline.svg +Sketcher Create Periodic BSpline Constr.svg +Sketcher CreatePoint.svg +Sketcher CreatePolyline.svg +Sketcher CreatePolyline Constr.svg +Sketcher CreateRectangle.svg +Sketcher CreateRectangle Constr.svg +Sketcher CreateRegularPolygon.svg +Sketcher CreateRegularPolygon Constr.svg +Sketcher CreateSlot.svg +Sketcher CreateSlot Constr.svg +Sketcher CreateSquare.svg +Sketcher CreateSquare Constr.svg +Sketcher CreateText.svg +Sketcher CreateTriangle.svg +Sketcher CreateTriangle Constr.svg +Sketcher DraftLine.svg +Sketcher EditSketch.svg +Sketcher Element Arc Edge.svg +Sketcher Element Arc EndPoint.svg +Sketcher Element Arc MidPoint.svg +Sketcher Element Arc StartingPoint.svg +Sketcher Element BSpline Edge.svg +Sketcher Element BSpline EndPoint.svg +Sketcher Element BSpline StartPoint.svg +Sketcher Element Circle Edge.svg +Sketcher Element Circle MidPoint.svg +Sketcher Element Ellipse All.svg +Sketcher Element Ellipse CentrePoint.svg +Sketcher Element Ellipse Edge 1.svg +Sketcher Element Ellipse Edge 2.svg +Sketcher Element Ellipse Focus1.svg +Sketcher Element Ellipse Focus2.svg +Sketcher Element Ellipse MajorAxis.svg +Sketcher Element Ellipse MinorAxis.svg +Sketcher Element Elliptical Arc Centre Point.svg +Sketcher Element Elliptical Arc Edge.svg +Sketcher Element Elliptical Arc End Point.svg +Sketcher Element Elliptical Arc Start Point.svg +Sketcher Element Hyperbolic Arc Centre Point.svg +Sketcher Element Hyperbolic Arc Edge.svg +Sketcher Element Hyperbolic Arc End Point.svg +Sketcher Element Hyperbolic Arc Start Point.svg +Sketcher Element Line Edge.svg +Sketcher Element Line EndPoint.svg +Sketcher Element Line StartingPoint.svg +Sketcher Element Parabolic Arc Centre Point.svg +Sketcher Element Parabolic Arc Edge.svg +Sketcher Element Parabolic Arc End Point.svg +Sketcher Element Parabolic Arc Start Point.svg +Sketcher Element Point StartingPoint.svg +Sketcher Element SelectionTypeInvalid.svg +Sketcher Elliptical Arc.svg +Sketcher Elliptical Arc Constr.svg +Sketcher Extend.svg +Sketcher External.svg +Sketcher Hyperbolic Arc.svg +Sketcher Hyperbolic Arc Constr.svg +Sketcher LeaveSketch.svg +Sketcher MapSketch.svg +Sketcher MergeSketch.svg +Sketcher MirrorSketch.svg +Sketcher NewSketch.svg +Sketcher Parabolic Arc.svg +Sketcher Parabolic Arc Constr.svg +Sketcher ProfilesHexagon1.svg +Sketcher RectangularArray.svg +Sketcher SelectConflictingConstraints.svg +Sketcher SelectConstraints.svg +Sketcher SelectElementsAssociatedWithConstraints.svg +Sketcher SelectHorizontalAxis.svg +Sketcher SelectOrigin.svg +Sketcher SelectRedundantConstraints.svg +Sketcher SelectVerticalAxis.svg +Sketcher Sketch.svg +Sketcher SwitchVirtualSpace.svg +Sketcher Symmetry.svg +Sketcher ToggleConstraint.svg +Sketcher ToggleConstraint Driven.svg +Sketcher ToggleConstraint Driving.svg +Sketcher ToggleConstruction.svg +Sketcher ToggleNormal.svg +Sketcher Trimming.svg +Sketcher ViewSketch.svg +SketcherWorkbech.svg +


      +

      +

      From \src\Mod\Sketcher\Gui\Resources\icons\small

      +

      Files in this folder cannot be uploaded because the file extension is .xpm. +

      +

      From \src\Mod\Spreadsheet\Gui\Resources\icons

      +

      Spreadsheet.svg +SpreadsheetAlias.svg +SpreadsheetAlignBottom.svg +SpreadsheetAlignCenter.svg +SpreadsheetAlignLeft.svg +SpreadsheetAlignRight.svg +SpreadsheetAlignTop.svg +SpreadsheetAlignVCenter.svg +SpreadsheetController.svg +SpreadsheetExport.svg +SpreadsheetImport.svg +SpreadsheetMergeCells.svg +SpreadsheetSplitCell.svg +SpreadsheetStyleBold.svg +SpreadsheetStyleItalic.svg +SpreadsheetStyleUnderline.svg +SpreadsheetWorkbench.svg +


      +

      +

      From \src\Mod\Start\Gui\Resources\icons

      +

      StartWorkbench.svg +

      +

      From \src\Mod\Start\StartPage\Images

      +

      ArchDesign.png +Blank.png +Complete.png +Freecad.png +Freecad-doc.png +Mesh.png +PartDesign.png +Ship.png +Web.png +


      +ArchExample.png +

      The following image has been re-sized to a display width of 480 pixels: +

      Background.jpg +

      Banner.jpeg +

      Complete.jpg +

      PartDesignExample.png +

      ShipExample.png +


      +

      +

      From \src\Mod\Surface\Gui\Resources\icons

      +

      BezSurf.svg +BSplineSurf.svg +Cut.svg +Filling.svg +Sewing.svg +Surface.svg +

      +

      From \src\Mod\TechDraw\Gui\Resources\icons

      +

      Arrow-ccw.svg +Arrow-cw.svg +Arrowdot.svg +Arrow-down.svg +Arrowfilled.svg +Arrow-left.svg +Arrowopen.svg +Arrowopendot.svg +Arrow-right.svg +Arrowtick.svg +Arrow-up.svg +Preferences-techdraw.svg +TechDraw Dimension.svg +TechDraw Dimension Angle.svg +TechDraw Dimension Diameter.svg +TechDraw Dimension Horizontal.svg +TechDraw Dimension Length.svg +TechDraw Dimension Link.svg +TechDraw Dimension Radius.svg +TechDraw Dimension Vertical.svg +TechDraw Pages.svg +TechDraw ProjBottom.svg +TechDraw ProjFront.svg +TechDraw ProjFrontBottomLeft.svg +TechDraw ProjFrontBottomRight.svg +TechDraw ProjFrontTopLeft.svg +TechDraw ProjFrontTopRight.svg +TechDraw ProjLeft.svg +TechDraw ProjRear.svg +TechDraw ProjRight.svg +TechDraw ProjTop.svg +TechDraw Tree Annotation.svg +TechDraw Tree Hatch.svg +TechDraw Tree Multi.svg +TechDraw Tree Page.svg +TechDraw Tree Page Sync.svg +TechDraw Tree PageTemplate.svg +TechDraw Tree Page Unsync.svg +TechDraw Tree ProjGroup.svg +TechDraw Tree Section.svg +TechDraw Tree Spreadsheet.svg +TechDraw Tree Symbol.svg +TechDraw Tree View.svg +

      +

      From \src\Mod\TechDraw\Gui\Resources\icons\actions

      +

      Section-down.svg +Section-left.svg +Section-right.svg +Section-up.svg +Techdraw-annotation.svg +Techdraw-arch-view.svg +Techdraw-clip.svg +Techdraw-clipminus.svg +Techdraw-clipplus.svg +Techdraw-draft-view.svg +Techdraw-geomhatch.svg +Techdraw-hatch.svg +Techdraw-image.svg +Techdraw-multiview.svg +Techdraw-new-default.svg +Techdraw-new-pick.svg +Techdraw-projgroup.svg +Techdraw-saveSVG.svg +Techdraw-spreadsheet.svg +Techdraw-symbol.svg +Techdraw-toggleframe.svg +Techdraw-view.svg +Techdraw-viewdetail.svg +Techdraw-viewsection.svg +

      +

      From \src\Mod\TechDraw\Gui\Resources\ToleranceSymbols

      +

      Angularity.svg +Circularity.svg +Circular run-out.svg +Concentricity.svg +Cylindricity.svg +Flatness.svg +Flatness editable.svg +Parallelism.svg +Perpendicularity.svg +Position.svg +Profile of line.svg +Profile of surface.svg +Reference editable.svg +Straightness.svg +Symmetrie.svg +Tolerance editable.svg +Total run-out.svg +

      +

      From \src\Mod\TechDraw\Templates

      +

      A0 Landscape ISO7200TD.svg +A1 Landscape ISO7200TD.svg +A2 Landscape ISO7200TD.svg +A3 Landscape ISO7200TD.svg +A3 LandscapeTD.svg +A4 Landscape ISO7200TD.svg +A4 LandscapeTD.svg +A4 Portrait ISO7200TD.svg +

      +

      From \src\Mod\Test\Gui\Resources\icons

      +

      TestWorkbench.svg +

      +

      From \src\Mod\Tux\Resources\icons

      +

      NavigationBlender.svg +NavigationBlender Pan.svg +NavigationBlender PanAlt.svg +NavigationBlender Rotate.svg +NavigationBlender Select.svg +NavigationBlender Zoom.svg +NavigationCAD.svg +NavigationCADAlt.svg +NavigationCAD Pan.svg +NavigationCAD Rotate.svg +NavigationCAD RotateAlt.svg +NavigationCAD Select.svg +NavigationCAD Zoom.svg +NavigationGesture.svg +NavigationGesture Pan.svg +NavigationGesture PanTouch.svg +NavigationGesture PanTouchAlt.svg +NavigationGesture Rotate.svg +NavigationGesture RotateAlt.svg +NavigationGesture RotateTouch.svg +NavigationGesture Select.svg +NavigationGesture SelectTouch.svg +NavigationGesture Tilt.svg +NavigationGesture TiltTouch.svg +NavigationGesture Zoom.svg +NavigationGesture ZoomTouch.svg +NavigationMayaGesture.svg +NavigationMayaGesture Pan.svg +NavigationMayaGesture PanTouch.svg +NavigationMayaGesture PanTouchAlt.svg +NavigationMayaGesture Rotate.svg +NavigationMayaGesture RotateTouch.svg +NavigationMayaGesture Select.svg +NavigationMayaGesture SelectTouch.svg +NavigationMayaGesture Tilt.svg +NavigationMayaGesture TiltTouch.svg +NavigationMayaGesture Zoom.svg +NavigationMayaGesture ZoomAlt.svg +NavigationMayaGesture ZoomTouch.svg +NavigationOpenCascade.svg +NavigationOpenCascade Pan.svg +NavigationOpenCascade PanAlt.svg +NavigationOpenCascade Rotate.svg +NavigationOpenCascade Select.svg +NavigationOpenCascade Zoom.svg +NavigationOpenCascade ZoomAlt.svg +NavigationOpenInventor.svg +NavigationOpenInventor Pan.svg +NavigationOpenInventor Rotate.svg +NavigationOpenInventor Select.svg +NavigationOpenInventor Zoom.svg +NavigationOpenInventor ZoomAlt.svg +NavigationTouchpad.svg +NavigationTouchpad Pan.svg +NavigationTouchpad PanTouch.svg +NavigationTouchpad Rotate.svg +NavigationTouchpad RotateAlt.svg +NavigationTouchpad RotateTouch.svg +NavigationTouchpad RotateTouchAlt.svg +NavigationTouchpad Select.svg +NavigationTouchpad SelectTouch.svg +NavigationTouchpad Zoom.svg +NavigationTouchpad ZoomAlt.svg +NavigationTouchpad ZoomTouch.svg +NavigationUndefined.svg +

      +

      From \src\Mod\Web\Gui\Resources\icons

      +

      Sketchfab.svg +WebWorkbench.svg +

      +

      From \src\Mod\Web\Gui\Resources\icons\actions

      +

      Web-browser.svg +Web-home.svg +Web-next.svg +Web-previous.svg +Web-refresh.svg +Web-sketchfab.svg +Web-stop.svg +Web-zoom-in.svg +Web-zoom-out.svg +


      +

      +

      Guidelines

      +

      Introduction

      +

      A FreeCAD icon is composed of 6 elements which can be remembered easily using the awkward acronym "SALCHO": +Stroke, Alignment, Lighting, Color, Highlighting, Outline +

      Here's a concrete, yet arbitrary example: +

      +
      An icon that's taken all its vitamins
      + + + + + + + + + + + + + + + + + + + +
      A +The highlight color is used for this entire surface to indicate light falling from above +
      B +The obligatory dark outline surrounds the icon shape to provide form contrast +
      C +Just inside the outline, the highlight stroke (using the highlight color) provides contrast on dark backgrounds +
      D +This face is primarily the base color, but a light gradient from highlight (top left) to base (bottom right) gives the impression of light falling from above left +
      E +The highlight here is the base color (one tone down) to give the impression of this being the face furthest from the light +
      F +This face is like D but goes from Base (top left) to Dark (bottom right), to indicate that this is the face furthest from the light +
      +

      The following sections explain these elements in a more structured way. +

      +

      Colors

      +

      [Obligatory] +FreeCAD uses a palette adapted from the Tango palette. Each main color comes in 4 tones: Highlight, Base, Dark and Outline. +

      +
      Example of a 4 tone color family (Chameleon)
      + + + + + + + + + + + + + + + + + + + + + + + + + +
      A selection of some key colors. (See the palette for the full range) +
      + + + +Use the Yellow tones for tools that create objects. +
      + + + +Use the Blue tones for tools that modify objects +
      + + + +Use the Teal tones for view-related tools +
      + + + +Use the Red tones for Constraint related tools +
      + + + + + + + +
      +

      Why limit myself to these colors? +

      +
      Restricting the colors to a defined palette helps avoid heterogeneous iconography and improves readability when there are many icons. +
      How? +Installing the palette is as easy as copying it into your Inkscape palette folder. +
      +

      Grid & Stroke Width

      +

      [Obligatory] +FreeCAD Icons are 64px*64px nominal size (Though I like to leave a 2px margin all around to prevent funky antialiasing things from happening on the image edge). When creating or editing an icon, make sure your document size is 64 x 64 with the units being px. This gives you 60px * 60px of useable space. +

      +
      Stay inside the blue area and everything will work out just fine
      +

      It's also strongly recommended to apply at least one grid to the document that has a grid line every pixel and a major grid line every 2 pixels. Feel free to add other grids to help out, but you should have at least that one. You're strokes would then be aligned along the minor grid intersections. (See image) +

      Strokes should be no thinner than 2px, with rounded caps and corners in most cases. Strokes can be thicker, but aim for a multiple of two to minimise scaling fuzziness. +

      +
      Orderly grid, all strokes 2px, perfection achieved
      + + + + + + + +
      +

      Why use this grid and stroke size? +

      +
      For historical reasons, FreeCAD uses a 64px icon that then gets scaled down. Not ideal, but it adds character. As a result, keeping things aligned to a power of two grid with thicknesses that are powers of two helps to avoid or at least mitigate anti-aliasing issues upon rescaling. +
      How? +Go to "File > Document Properties" and confirm the width, height and units of your page are correct. Then go to the "Grids" tab and click "New", setting the units to "px", "Spacing X" and "Spacing Y" to 1 and "Major grid line every" to 2 +
      +

      Outline

      +

      [Obligatory] +Basing yourself on the main color of the icon, ensure that there is a dark outline (of 2px as mentioned earlier). This works in union with the highlight to ensure good form contrast on multiple background tones. +

      +
      Wow, much clear, so contrast
      + + + + + + + +
      +

      Why is the outline needed? +

      +
      The outline is the skeleton on which everything else hangs by adding form contrast. Using the Outline color or the Dark color depends on the situation, but without this line, the range of backgrounds on which the icon is visible gets drastically limited +
      How? +Simply add an external stroke of 2px around every part of the icon that will be adjacent to the background color. In the case of a donut shape for example, you would also do the interior hole. Snap your path's nodes to the grid whenever possible, aiming for the minor grid intersections. +
      +

      Highlight

      +

      [Strongly Advised] +Using the Highlight color, add an internal stroke (again, 2px) to help make that outline pop. On dark backgrounds, it's this highlight that will be providing the form to the icon. +

      +
      That highlight will save our socks on a dark background.
      + + + + + + + +
      +

      Why use the highlight? +

      +
      The highlight works in unison with the outline to improve form contrast - especially on dark backgrounds. It is never a bad idea, but if you don't have the space (on a thin line for example) you can opt out of it provided you have ensured enough contrast between the main color and the outline +
      How? +Just like the outline, simply trace a stroke of 2px around the internal side of the outline, snapping nodes to the grid when possible, aiming for the minor grid intersections. +
      +

      Lighting

      +

      [Optional] +As per Tango guidelines, if you're adding a gradient lighting effect, try to make it look like the light is coming from the top left. This is done by adding the highlight color up top left and the Base or Dark color bottom right (notice that I haven't played around trying to use a non-palette color) +

      +
      Subtle but effective.
      + + + + + + + +
      +

      Why use lighting? +

      +
      Lighting is just another way to tie icons together and ensure that there are varying levels of 'value' to improve their readability. Provided the outline and highlight are present though, it can be considered optional +
      How? +Set the fill to be a linear or a radial gradient. (Available in the stroke and fill settings). Remember that using "F2" to set direct select, you can move the nodes of the gradient around to make sure they are at the right angle. +
      +

      Closing Remarks

      +

      That's it - that's all there is to making sure that there's a unified look to all the icons. +Remember: SALCHO +Stroke, Alignment, Lighting, Color, Highlight, Outline +

      Here's a collection of tips to be able to check your work: +

      +

      Checking Size

      +

      Inkscape has a super handy tool to check your icon at various sizes. +Go to "View > Icon Preview..." and it'll show you previews of your icon resized to 16,24,32 and 64px! +

      +

      Checking Your Outline

      +

      1. Put your icon on a big rectangle that is the same color as the darkest color in your icon. +

      2. Still looks OK? Great! Go to step 3. If not, see the frowny face +

      3. Do the same but this time using the lightest color. +

      4. Still looks OK? Great! Outlines and highlights have been used appropriately! +

      + + + + +
      +

      My icon is barely visible! +

      +
      You have poor form contrast. Double check the outline and highlight, one of these is probably missing or improperly applied. +
      +

      Checking Your Contrast

      +

      1. Get your icon and export it to either .png or .jpg, whichever you prefer +

      2. Open an image program and change it to grayscale. In GIMP for example you would go to "Image > Mode > Grayscale" (This is excellent for testing for color blind users) +

      3. Can you still clearly make out any internal details? Great! You have good contrast! +

      + + + + +
      +

      I can't make out all the wonderful detail! +

      +
      The colors you've chosen have poor value contrast. Try using colors that are further apart in your 4 tone palette. i.e. A Highlight green beside a highlight yellow will be difficult to see, knock one of those colors down to Base or Dark. +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Artwork_Grid.png b/localwiki/Artwork_Grid.png new file mode 100644 index 0000000..1058657 Binary files /dev/null and b/localwiki/Artwork_Grid.png differ diff --git a/localwiki/Assemblage_Imprimante_3D.gif b/localwiki/Assemblage_Imprimante_3D.gif new file mode 100644 index 0000000..766bddb Binary files /dev/null and b/localwiki/Assemblage_Imprimante_3D.gif differ diff --git a/localwiki/Assembly2_example.jpg b/localwiki/Assembly2_example.jpg new file mode 100644 index 0000000..e667c53 Binary files /dev/null and b/localwiki/Assembly2_example.jpg differ diff --git a/localwiki/AssemblyWorkbench.svg b/localwiki/AssemblyWorkbench.svg new file mode 100644 index 0000000..735efc4 --- /dev/null +++ b/localwiki/AssemblyWorkbench.svg @@ -0,0 +1,863 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [jmaustpc] + + + Assembly_Assembly_Tree + 2013-12-24 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Assembly/Gui/Resources/icons/Assembly_Assembly_Tree.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Assembly_Add_Existing_Part.svg b/localwiki/Assembly_Add_Existing_Part.svg new file mode 100644 index 0000000..a8470b9 --- /dev/null +++ b/localwiki/Assembly_Add_Existing_Part.svg @@ -0,0 +1,176 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [jmaustpc] + + + Assembly_Add_Existing_Part + 2013-12-24 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Assembly/Gui/Resources/icons/Assembly_Add_Existing_Part.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Assembly_Add_New_Part.svg b/localwiki/Assembly_Add_New_Part.svg new file mode 100644 index 0000000..aaf133e --- /dev/null +++ b/localwiki/Assembly_Add_New_Part.svg @@ -0,0 +1,188 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [jmaustpc] + + + Assembly_Add_New_Part + 2013-12-24 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Assembly/Gui/Resources/icons/Assembly_Add_New_Part.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Assembly_Assembly_Constraints_Tree.svg b/localwiki/Assembly_Assembly_Constraints_Tree.svg new file mode 100644 index 0000000..13b8cf3 --- /dev/null +++ b/localwiki/Assembly_Assembly_Constraints_Tree.svg @@ -0,0 +1,196 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [jmaustpc] + + + Assembly_Assembly_Constraints_Tree + 2013-12-24 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Assembly/Gui/Resources/icons/Assembly_Assembly_Constraints_Tree.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Assembly_Assembly_Create_New.svg b/localwiki/Assembly_Assembly_Create_New.svg new file mode 100644 index 0000000..8dab281 --- /dev/null +++ b/localwiki/Assembly_Assembly_Create_New.svg @@ -0,0 +1,222 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [jmaustpc] + + + Assembly_Assembly_Create_New + 2013-12-24 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Assembly/Gui/Resources/icons/Assembly_Assembly_Create_New.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Assembly_Assembly_Part_Tree.svg b/localwiki/Assembly_Assembly_Part_Tree.svg new file mode 100644 index 0000000..7e313f6 --- /dev/null +++ b/localwiki/Assembly_Assembly_Part_Tree.svg @@ -0,0 +1,174 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [jmaustpc] + + + Assembly_Assembly_Part_Tree + 2013-12-24 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Assembly/Gui/Resources/icons/Assembly_Assembly_Part_Tree.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Assembly_Assembly_Tree.svg b/localwiki/Assembly_Assembly_Tree.svg new file mode 100644 index 0000000..abf87cd --- /dev/null +++ b/localwiki/Assembly_Assembly_Tree.svg @@ -0,0 +1,195 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [jmaustpc] + + + Assembly_Assembly_Tree + 2013-12-24 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Assembly/Gui/Resources/icons/Assembly_Assembly_Tree.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Assembly_Basic_Tutorial.html b/localwiki/Assembly_Basic_Tutorial.html new file mode 100644 index 0000000..ab85893 --- /dev/null +++ b/localwiki/Assembly_Basic_Tutorial.html @@ -0,0 +1,81 @@ +Assembly Basic Tutorial

      Assembly Basic Tutorial

      + +
      This tutorial is for a very old and no longer available development version of FreeCAD. Is this page still relevant? +
      +Code may possibly be found in the no-longer updated Sourceforge Git repository https://sourceforge.net/p/free-cad/code/ci/master/tree/ in either the jriegel/dev-assembly-old or jriegel/dev-assembly2 branch. Compilation of its code will be required as there is no available installer for it.
      +


      +

      This tutorial shall give some insides in the current assembly workflow while providing theoretical background of the used design. Goal is to achieve a understanding of the assembly workbench's working, it's structure and how to use it. +

      This workbench is in an early development stage, therefore you will experience inconsistent behavior and all kinds of errors/crashs. Please report reproducible problems to the [assembly sub-forum] or the [mantis bug tracker]. +
      +

      + + +

      How to move things: Coordinate Systems

      +

      The goal of an assembly workbench is to move parts around. It's therefore obvious that there needs to be a way to achieve this transformation of parts, and this part of the introduction is about this basic functionality. +

      In FreeCAD every object in 3D space has its own coordinate system. This local system is set in relation to its parent system by a transformation, its placement. The object's placement defines how the local geometry needs to be translated and rotated to be expressed in the parents system. Hence if you move a part by editing its placement property, you don't change the part, only the transformation of its coordinate system into the parent system. Imagine a simple box created in the Part workbench. Once created, the length parameter changes the box's dimension in the local x direction. As the placement is empty, it's also the global x direction. If you rotate the part by setting a rotation axis and an angle, the length will still be in local x direction, however, visually it will not change on x anymore as the visuals are presented in the global coordinate system. The box geometry has not changed, just the visualization is transformed. +

      +
      Transformation Feature to Body
      +


      +

      This would make it easy to move single parts around: just adopt its placement. However, in FreeCAD most designs are done with many features (pads, pockets etc.), how would one handle that? Move every feature? Only the last one? Both ways would introduce some very problematic modeling behavior, therefore a third way is used: don't move features at all! Instead the concept of a Body was introduced into general modeling, everything done in part design is now grouped beneath it. This object has a placement property too and can be transformed. +

      Coming back to local and parent coordinate systems: the body is the perfect incarnation of that concept! Every feature beneath the body can't be moved directly, its placement is always empty. That means, the feature's geometry doesn't need to be rotated or translated if we want to express it in the bodies coordinate system. But we can move the body inside the global coordinate system by setting its placement, and then the global value of the feature's geometry is calculated by applying this transformation too. Remember, we rotate coordinate systems. That means if we transform the body system, everything beneath uses it as its personal global system. There is no need to move features at all. You want your whole design at a different place? Just set the body's placement! +


      +To summarize: Coordinate systems can be stacked, every object uses its parents system as personal global one. If the parents coordinate system is transformed, all children get transformed too without changing their local systems. +
      +

      +

      What can be assembled: Object model

      +

      With the Body object we have everything we want for assembly: we can move complex designs in a comprehensible way, right?. Not quite! What would happen if you want to have your design many times inside the assembly? For example if you modeled a screw, you don't want to remodel it again every time you need one. Copying may work, however, what if you change your screw design: change all copies? That would be very annoying. To overcome this, again a new object is introduced: the part. A part is a pure assembly object and can only be created inside this workbench. Its purpose is to reference a body object and provide another coordinate system. +

      To understand why it's introduced we have to consider how things are moved in FreeCAD. Lets extend the body chart above with two parts referencing the same body as shown in the next picture. +

      +
      Transformation Feature to Part
      +


      +

      The bodys local system is the same in both parts, however, the parts have their own placements and therefore can be transformed in respect to the global system. As placements get applied recursively, the very same features can end up on different positions. Imagine you change the parts placement P4 and P5 to different values, your design would appear in two total different places inside the global system without any changes to the features or the body holding them. And then imagine changing the body's coordinate system P3: You would change the position of all incarnations of your design in the same manner! +

      You may wonder how you design can be in two places while being only one geometry. Thats simple: The part shows only a visual representation of the geometry inside the body, and you can have many pictures of your single part. Also those visuals representations are transformed if you set the placement. A part holds absolutely no modeling information. +

      Back to our use case: if you need 100 screws you will model only one body with your design. Then you can add as much parts as you want holding this one body. By applying different placements to the parts only you can move the screws around as you want. And if you change something in your design, the body gets updated and every part too, as they all reference it. Awesome! +


      +Now imagine another use case: you have a nice electrical motor assembly consisting of multiple parts, are all moved to the right position. Afterwards you want to create a bigger machine and you need multiple electrical motors for it. What we want is to reuse the motor assembly, the same reasoning as with the multiple body incarnations apply. For simple designs we were able to create multiple parts from one body, however, we can't create a part from multiple parts. Therefore we need another object which can do that! FreeCAD introduces the product object for this. A product is basically a full assembly with multiple parts, but also has a placement property. What does that mean? It becomes clear when we again extend the coordinate system chart with our new product object. +

      +
      Transformation Feature to Product
      +

      Now our parts are not anymore beneath the global coordinate system, but they are grouped beneath the product. For the parts nothing change: they works as before. And in fact, if our Product1 would have been the top-level object, absolutely nothing would change at all. The global system is just replaced by a product coordinate system which acts as global one. In our example however, we added the product to another product, together with a third part. Now it gets interesting: As a product has a placement property, it can be moved! And we already learned that such a transformation is applied to all children. Therefore parts 1 and 2 would move when you change the placement of Product1. +

      Back to our example: Product1 would be the electrical motor, Product2 the big machine. Now you can add multiple products to the machine which all reference the same parts as Product1, hence all representing a electrical motor. And as every product can be placed diffrently, you can move all motors to diffrent positions. Combine it with other parts and assemblies and you can build a complex machine. Again, if you update one body, all parts and therefore all products referencing it get updated. +

      At last you may ask why there is no global coordinate system in the last picture. Thats because nothing like a global coordinate system exists, it was just a concept for easy explaining. If you assembly your electrical motor, the top-level coordinate system would be the Product1 system. However, this is not a general global one, as you can add it to a another product which is the top-level cs afterwards. And this can be added to another, and so on. There is nothing like a global coordinate system, just a top-level one. +

      +To summarize: In the assembly workbench you can combine parts to assemblies (products). These products can be staked together with other parts in arbitrary numbers.
      +

      How to set Relations: Assembly Constraints

      +

      Up to now we discussed all details of moving things around with placements and the objects involved in it. It is however very tedious to calculate all placements by hand and set them manual via the property editor. It would be more pleasant if it would be possible to set simple relations between parts instead of abstract rotations and translations. Therefore FreeCAD introduces assembly constraints. As the name indicates, they work the same way as in the sketcher: the user applies different attributes to geometries of the parts. This can be for example the distance between two points, or their orientation (parallel, perpendicular) of lines etc. FreeCAD trys then to find placements which satisfy all given constraints. +

      +
      Geometry which is supported by FreeCAD assembly constraints
      +

      To assemble things in the real world, one would use the parts structure to fit the counterpart into its place, for example a bolt which belongs into a hole. Or surfaces which touch each other and therefore define the parts exact position. In FreeCAD it works exactly like that: you use the parts geometry to specify where the second part belongs to. At your disposal are points, straight lines, planes and cylinders. The picture to the right shows them all in the FreeCAD environment. But of course, the geometry alone is not enough to calculate the parts positions, the kind of relation needs to be known too. For example two faces: They can touch each other, or just be parallel, maybe even perpendicular. This relation is set in FreeCAD through the already mentioned assembly constraints. You have 6 diffrent types at your hand: Fix, Distance, Orientation, Angle, Align and Coincident. Lets see what they all do and how to use them. +

      +

      Fix

      +

      The fix constraint is the simplest of all constraints. It only needs one part to be selected and then it fixes its position and its rotation. No matter what you do to this part afterwards: it will hold its place. And thats the whole purpose of that type. It's most useful to have always one fixed part per assembly, as it can be annoying if all parts get moved to satisfy other constraints. If you fix the most basic part in your assembly, all other parts will move towards it which gives you a pleasant experience. Note that this constraint works only in the assembly it is created in, the part will not be fixed in any parent assembly (remember: assemblies can be stacked). +

      +

      Distance

      +

      As you already guessed from the name, with this constraint you can specify the distance between two geometries. This works for two points, but also for a point and a line, or a line and a cylinder and many more combinations. This constraint is pretty simple, but two points need mentioning: First, if there are multiple possible distances between geometries, for example the last mentioned line and cylinder, then the shortest distance is used. Second, sometimes multiple solutions exist even for the shortest distance. This is the case for the point-plane distance: every value can be satisfied with the point above AND below the plane. So if you only specify the value, it can happen that FreeCAD puts the point at the wrong side of the plane. To control this, the distance constraint has a special option, the solution space. This option allows to reduce the space of possible solutions, so that it matches your wishes. Lets see how this works on our small example: +


      +

      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Assembly_ConstraintAlignment.svg b/localwiki/Assembly_ConstraintAlignment.svg new file mode 100644 index 0000000..957a7e6 --- /dev/null +++ b/localwiki/Assembly_ConstraintAlignment.svg @@ -0,0 +1,190 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [jmaustpc] + + + Assembly_ConstraintAlignment + 2013-12-24 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Assembly/Gui/Resources/icons/constraints/Assembly_ConstraintAlignment.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Assembly_ConstraintAngle.svg b/localwiki/Assembly_ConstraintAngle.svg new file mode 100644 index 0000000..0bb9ca5 --- /dev/null +++ b/localwiki/Assembly_ConstraintAngle.svg @@ -0,0 +1,151 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [jmaustpc] + + + Assembly_ConstraintAngle + 2013-12-24 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Assembly/Gui/Resources/icons/constraints/Assembly_ConstraintAngle.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Assembly_ConstraintBidirectional.svg b/localwiki/Assembly_ConstraintBidirectional.svg new file mode 100644 index 0000000..e5b0ff5 --- /dev/null +++ b/localwiki/Assembly_ConstraintBidirectional.svg @@ -0,0 +1,186 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [jmaustpc] + + + Assembly_ConstraintBidirectional + 2013-12-24 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Assembly/Gui/Resources/icons/constraints/Assembly_ConstraintBidirectional.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Assembly_ConstraintCoincidence.svg b/localwiki/Assembly_ConstraintCoincidence.svg new file mode 100644 index 0000000..251f0b6 --- /dev/null +++ b/localwiki/Assembly_ConstraintCoincidence.svg @@ -0,0 +1,158 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [jmaustpc] + + + Assembly_ConstraintCoincidence + 2013-12-24 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Assembly/Gui/Resources/icons/constraints/Assembly_ConstraintCoincidence.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Assembly_ConstraintDistance.svg b/localwiki/Assembly_ConstraintDistance.svg new file mode 100644 index 0000000..8c60ab9 --- /dev/null +++ b/localwiki/Assembly_ConstraintDistance.svg @@ -0,0 +1,161 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [jmaustpc] + + + Assembly_ConstraintDistance + 2013-12-24 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Assembly/Gui/Resources/icons/constraints/Assembly_ConstraintDistance.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Assembly_ConstraintEqual.svg b/localwiki/Assembly_ConstraintEqual.svg new file mode 100644 index 0000000..e84580c --- /dev/null +++ b/localwiki/Assembly_ConstraintEqual.svg @@ -0,0 +1,158 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [jmaustpc] + + + Assembly_ConstraintEqual + 2013-12-24 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Assembly/Gui/Resources/icons/constraints/Assembly_ConstraintEqual.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Assembly_ConstraintGeneral.svg b/localwiki/Assembly_ConstraintGeneral.svg new file mode 100644 index 0000000..ded06a1 --- /dev/null +++ b/localwiki/Assembly_ConstraintGeneral.svg @@ -0,0 +1,167 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [jmaustpc] + + + Assembly_ConstraintGeneral + 2013-12-24 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Assembly/Gui/Resources/icons/constraints/Assembly_ConstraintGeneral.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Assembly_ConstraintLock.svg b/localwiki/Assembly_ConstraintLock.svg new file mode 100644 index 0000000..badd045 --- /dev/null +++ b/localwiki/Assembly_ConstraintLock.svg @@ -0,0 +1,175 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [jmaustpc] + + + Assembly_ConstraintLock + 2013-12-24 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Assembly/Gui/Resources/icons/constraints/Assembly_ConstraintLock.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Assembly_ConstraintOpposite.svg b/localwiki/Assembly_ConstraintOpposite.svg new file mode 100644 index 0000000..90c6e4b --- /dev/null +++ b/localwiki/Assembly_ConstraintOpposite.svg @@ -0,0 +1,164 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [jmaustpc] + + + Assembly_ConstraintOpposite + 2013-12-24 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Assembly/Gui/Resources/icons/constraints/Assembly_ConstraintOpposite.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Assembly_ConstraintOrientation.svg b/localwiki/Assembly_ConstraintOrientation.svg new file mode 100644 index 0000000..62a3351 --- /dev/null +++ b/localwiki/Assembly_ConstraintOrientation.svg @@ -0,0 +1,167 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [jmaustpc] + + + Assembly_ConstraintOrientation + 2013-12-24 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Assembly/Gui/Resources/icons/constraints/Assembly_ConstraintOrientation.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Assembly_ConstraintParallel.svg b/localwiki/Assembly_ConstraintParallel.svg new file mode 100644 index 0000000..5130ec1 --- /dev/null +++ b/localwiki/Assembly_ConstraintParallel.svg @@ -0,0 +1,180 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [jmaustpc] + + + Assembly_ConstraintParallel + 2013-12-24 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Assembly/Gui/Resources/icons/constraints/Assembly_ConstraintParallel.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Assembly_ConstraintPerpendicular.svg b/localwiki/Assembly_ConstraintPerpendicular.svg new file mode 100644 index 0000000..3937f65 --- /dev/null +++ b/localwiki/Assembly_ConstraintPerpendicular.svg @@ -0,0 +1,174 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [jmaustpc] + + + Assembly_ConstraintPerpendicular + 2013-12-24 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Assembly/Gui/Resources/icons/constraints/Assembly_ConstraintPerpendicular.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Assembly_ConstraintUnidirectional1.svg b/localwiki/Assembly_ConstraintUnidirectional1.svg new file mode 100644 index 0000000..2ddc410 --- /dev/null +++ b/localwiki/Assembly_ConstraintUnidirectional1.svg @@ -0,0 +1,182 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [jmaustpc] + + + Assembly_ConstraintUnidirectional1 + 2013-12-24 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Assembly/Gui/Resources/icons/constraints/Assembly_ConstraintUnidirectional1.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Assembly_ConstraintUnidirectional2.svg b/localwiki/Assembly_ConstraintUnidirectional2.svg new file mode 100644 index 0000000..5a6ebb9 --- /dev/null +++ b/localwiki/Assembly_ConstraintUnidirectional2.svg @@ -0,0 +1,184 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [jmaustpc] + + + Assembly_ConstraintUnidirectional2 + 2013-12-24 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Assembly/Gui/Resources/icons/constraints/Assembly_ConstraintUnidirectional2.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Assembly_Demo.svg b/localwiki/Assembly_Demo.svg new file mode 100644 index 0000000..efc07f4 --- /dev/null +++ b/localwiki/Assembly_Demo.svg @@ -0,0 +1,411 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + Path-Stock + 2015-07-04 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Path/Gui/Resources/icons/Path-Stock.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Assembly_Workbench.html b/localwiki/Assembly_Workbench.html new file mode 100644 index 0000000..bae4a26 --- /dev/null +++ b/localwiki/Assembly_Workbench.html @@ -0,0 +1,175 @@ +Assembly Workbench

      Assembly Workbench

      (Redirected from Assembly Workbench)
      + +

      Here the project plan for the Assembly modul as part of the Development roadmap +

      + + +

      Purpose and principles

      +

      This is a software development project aimed to implement a Assembly and product creation capabilities. Its about implementing some core features into the CAD modules of FreeCAD, Part and Assembly. +

      The development steps are planed here and tracked in the Issue tracking system to get a well formed change log: +Issue tracker +

      +

      Outcome

      +

      Aim of the project is to enable FreeCAD accomplish a design task like this one: +

      Gripper.jpg +

      This will be achived by using the Assembly to put all the different kind of parts together with constraints and stay as close as possible to the ISO 10303 specification to allow easy model exchange. +

      Another aim is to utilize ODE for kinematics. +

      +

      Brainstorming

      +

      Multi model

      +
      MultiModel.png
      +

      A key feature to real world designs is the ability to split a design into handleable pieces. Its impossible to work on all aspects of a design at the same time or alone. That is true for the geometry and also for engineering tasks like FEM or CAM. There for FreeCAD need the ability to split models. That opens some possibilities: +

      +
      • Late loading - Only need resources like Graphics and main memory for the piece you work on.
      • +
      • Concurrent engineering - allows many people to work on the same design
      • +
      • Fine grained Version control - better control over various aspects of the design
      • +
      • and many more....
      +

      A multi model design could look like that: +

      +

      Project management

      +

      Multi model means a lot of files belonging to one project, most likely under a common directory. A project file and a project browser can help organizing the files. Also it can save additional information about the project or a project website. +

      1. Two modes, the "Simple" and the "Project" mode. Simple mean only one document and all the assemblies and parts go in one document. If a Project is opened or created FreeCAD is in project mode. +

      2. Projects. The position of the FCPrj file on the drive defines a root directory. All Files below this dir are defined with relative paths to the root dir. A additional view on the left side will hold the ProjectExplorer which shows the dir tree with the handled files. This root dir is also used as root for a SVN sand box, which allows later ease sharing and Version control. External references (towards a dir outside root, a sever share or a web resource) will handled and showed separably in the ProjectExplorer (one pseudo dir for each file server or web server). This makes it possible to get a fast overview about external references and re-route them. +

      +

      Copyright

      +

      Now copyright of 3D models is a interesting field. 3D models do fall under the copyright. The copyright falls to the creator of the model. Its only possible to protect the shape, which is represented by the model, by a patent or a design patent (US). But patents cover only the creation of a physical part to earn money. As an example the Microsoft Mouse design patent. +

      So we have to remember the creator (copyright holder) and any kind of license for each model/product/file of a design. +For the license I would use the CC type licenses. http://creativecommons.org/ +

      Abbreviation Keys for CC licenses: +

      +
      • BY = Attribution only
      • +
      • BY-ND = Attribution-NoDerivatives
      • +
      • BY-NC-ND = Attribution-NonCommercial- NoDerivatives
      • +
      • BY-NC = Attribution-NonCommercial
      • +
      • BY-NC-SA = Attribution-NonCommercial- ShareAlike
      • +
      • BY-SA = Attribution-ShareAlike
      • +
      • PD = Dedicated to or marked as being in the public domain via one of our public domain tools, or other public domain work; adaptations of works in the public domain may be built upon and licensed by the creator under any license terms desired
      +

      Additional a URL link to the full license document (in case of custom licenses) +

      +

      ISO 10303

      +

      The ISO 10303 (STEP) is very important in this field. Its the only good standardized and widely discussed and recognized definition of product structures I know of. +

      +
      Product structure modeling Process-Data diagram.gif
      +

      Here some links with info: +

      + +

      Assembly constraints

      +

      An important role in building up large models and products take the assembly constraints, which formulate certain rules how parts assemble a product. Mainly these are Fix, FaceToFace, Angle, Offset and some kind of pattern instantiation. This constraints need a specialized solver to keep them up if the parts change. This solver is fundamentally different to the Sketch solver. I think we have to go for a graph based approach on this... +

      +

      Kinematics

      +

      A further step would be to use ODE, or similar libs, to put the parts and the assembly constraints together to do a kinematic simulation of machines. That would allow checking for collisions and exploring the conditions of +a mechanical system. +

      +

      Revision control

      +

      An important point is the version control and distributed development. With multi model design we are able to split designs in smaller pieces and can distribute work among a team. For a software developer "distributed" and "Version" sounds familiar, so why not use a DVCS. A good comparison is here. +

      Since we deal with big data, and data which can not be easily diffed, we are limited to those which use the snapshot persistence model. Any system storing just diffs will have grave problems with our data (personally tested with Mercurial and Catia files). After sorting out commercial and non-free, basically only Git and SVN remains. +

      Using Git for the task leaves us with two big frontiers: +

      +
      • Git is very complicated; Branching merging and tagging along a non linear development path let alone merging with remote repositories (push, pull)
      +

      will put a lot of complexity in that matter. To hide it from the user will be a challenging task. +

      +
      • Git allow Merge and Diff handlers for certain file types; We need one for .fcstd. This handler has to examine two FreeCAD
      +

      documents and show and merge differences in the objects, features and parameters. Also not easy. +

      But using git would open a lot of possibilities even high class PLM system would dream of... +

      +

      Organizing

      +

      Here some development task needed for a decent Assembly/Product design: +

      +

      Infrastructure

      +

      The assembly will demand some changes in the base system and infrastructure layer of FreeCAD. +

      +

      Multi model

      +

      Multi-Model was in mind from the beginning of FreeCADs design. There fore we have a multi document interface and can load unlimited documents. But we need to upgrade especially the 3D-Viewer to handle showing more the one document in its view (Part-Trees). +

      +

      Part-Trees

      +

      Since in Assembly the composition of parts and sub-assemblies is the main workflow, the tools to stack (group) Parts in a tree have to be implemented. Unlike a DocumentObjectGroup the Assembly group has to deal with visibility and placement of the children. Best done by stacking ViewProvider on each other. That need a kind of ClaimChildren() interface to the ViewProviders. +

      +

      Unified Drag/Drop/Copy/Paste interface

      +

      A interface allow ViewProvider and Workbenches full control about Drag/Drop/Copy/Paste operations in the tree or the 3D view. +

      +

      External resources

      +

      Handling of doped links (from internal or external browsers). Means loading resources over (potential) slow connections (http). +

      +

      Material

      +

      Describing material and its properties is a vital part of a CAD/CAE system. Material has a lot of properties and names heavily dependent on the field its use. E.g. FEM and mechanical engineering have different frameworks and standards to describe Material. +

      For the Material description a special article is made: Material +

      +

      Object model

      +

      Class tree to deal with concepts needed. References, interfaces, document links, views, compounds, constraints, configurations, and many more... +

      +

      STEP check loop

      +

      Implementing a first STEP importer for more then geometry and color to check if the object model holds for a wider usage. +

      +

      Assembly constraint solver

      +

      Define a interface to a assembly constraint solver, very similar to the Sketcher solver interface. +

      +

      Physics simulation interface

      +

      Interface to allow a (external) (multi)physics simulation software to take control over the positioning of the Parts of a assembly. This would allow to use "bullet" or "ODE" to do kinematic tests and DMU. +

      +

      Next actions

      +
      • Object model
      • +
      • Wait for the 0.12 release branch happened
      +

      Tutorial

      + +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Assembly_project.html b/localwiki/Assembly_project.html new file mode 100644 index 0000000..0a9fdc9 --- /dev/null +++ b/localwiki/Assembly_project.html @@ -0,0 +1,175 @@ +Assembly project

      Assembly project

      + +

      Here the project plan for the Assembly modul as part of the Development roadmap +

      + + +

      Purpose and principles

      +

      This is a software development project aimed to implement a Assembly and product creation capabilities. Its about implementing some core features into the CAD modules of FreeCAD, Part and Assembly. +

      The development steps are planed here and tracked in the Issue tracking system to get a well formed change log: +Issue tracker +

      +

      Outcome

      +

      Aim of the project is to enable FreeCAD accomplish a design task like this one: +

      Gripper.jpg +

      This will be achived by using the Assembly to put all the different kind of parts together with constraints and stay as close as possible to the ISO 10303 specification to allow easy model exchange. +

      Another aim is to utilize ODE for kinematics. +

      +

      Brainstorming

      +

      Multi model

      +
      MultiModel.png
      +

      A key feature to real world designs is the ability to split a design into handleable pieces. Its impossible to work on all aspects of a design at the same time or alone. That is true for the geometry and also for engineering tasks like FEM or CAM. There for FreeCAD need the ability to split models. That opens some possibilities: +

      +
      • Late loading - Only need resources like Graphics and main memory for the piece you work on.
      • +
      • Concurrent engineering - allows many people to work on the same design
      • +
      • Fine grained Version control - better control over various aspects of the design
      • +
      • and many more....
      +

      A multi model design could look like that: +

      +

      Project management

      +

      Multi model means a lot of files belonging to one project, most likely under a common directory. A project file and a project browser can help organizing the files. Also it can save additional information about the project or a project website. +

      1. Two modes, the "Simple" and the "Project" mode. Simple mean only one document and all the assemblies and parts go in one document. If a Project is opened or created FreeCAD is in project mode. +

      2. Projects. The position of the FCPrj file on the drive defines a root directory. All Files below this dir are defined with relative paths to the root dir. A additional view on the left side will hold the ProjectExplorer which shows the dir tree with the handled files. This root dir is also used as root for a SVN sand box, which allows later ease sharing and Version control. External references (towards a dir outside root, a sever share or a web resource) will handled and showed separably in the ProjectExplorer (one pseudo dir for each file server or web server). This makes it possible to get a fast overview about external references and re-route them. +

      +

      Copyright

      +

      Now copyright of 3D models is a interesting field. 3D models do fall under the copyright. The copyright falls to the creator of the model. Its only possible to protect the shape, which is represented by the model, by a patent or a design patent (US). But patents cover only the creation of a physical part to earn money. As an example the Microsoft Mouse design patent. +

      So we have to remember the creator (copyright holder) and any kind of license for each model/product/file of a design. +For the license I would use the CC type licenses. http://creativecommons.org/ +

      Abbreviation Keys for CC licenses: +

      +
      • BY = Attribution only
      • +
      • BY-ND = Attribution-NoDerivatives
      • +
      • BY-NC-ND = Attribution-NonCommercial- NoDerivatives
      • +
      • BY-NC = Attribution-NonCommercial
      • +
      • BY-NC-SA = Attribution-NonCommercial- ShareAlike
      • +
      • BY-SA = Attribution-ShareAlike
      • +
      • PD = Dedicated to or marked as being in the public domain via one of our public domain tools, or other public domain work; adaptations of works in the public domain may be built upon and licensed by the creator under any license terms desired
      +

      Additional a URL link to the full license document (in case of custom licenses) +

      +

      ISO 10303

      +

      The ISO 10303 (STEP) is very important in this field. Its the only good standardized and widely discussed and recognized definition of product structures I know of. +

      +
      Product structure modeling Process-Data diagram.gif
      +

      Here some links with info: +

      + +

      Assembly constraints

      +

      An important role in building up large models and products take the assembly constraints, which formulate certain rules how parts assemble a product. Mainly these are Fix, FaceToFace, Angle, Offset and some kind of pattern instantiation. This constraints need a specialized solver to keep them up if the parts change. This solver is fundamentally different to the Sketch solver. I think we have to go for a graph based approach on this... +

      +

      Kinematics

      +

      A further step would be to use ODE, or similar libs, to put the parts and the assembly constraints together to do a kinematic simulation of machines. That would allow checking for collisions and exploring the conditions of +a mechanical system. +

      +

      Revision control

      +

      An important point is the version control and distributed development. With multi model design we are able to split designs in smaller pieces and can distribute work among a team. For a software developer "distributed" and "Version" sounds familiar, so why not use a DVCS. A good comparison is here. +

      Since we deal with big data, and data which can not be easily diffed, we are limited to those which use the snapshot persistence model. Any system storing just diffs will have grave problems with our data (personally tested with Mercurial and Catia files). After sorting out commercial and non-free, basically only Git and SVN remains. +

      Using Git for the task leaves us with two big frontiers: +

      +
      • Git is very complicated; Branching merging and tagging along a non linear development path let alone merging with remote repositories (push, pull)
      +

      will put a lot of complexity in that matter. To hide it from the user will be a challenging task. +

      +
      • Git allow Merge and Diff handlers for certain file types; We need one for .fcstd. This handler has to examine two FreeCAD
      +

      documents and show and merge differences in the objects, features and parameters. Also not easy. +

      But using git would open a lot of possibilities even high class PLM system would dream of... +

      +

      Organizing

      +

      Here some development task needed for a decent Assembly/Product design: +

      +

      Infrastructure

      +

      The assembly will demand some changes in the base system and infrastructure layer of FreeCAD. +

      +

      Multi model

      +

      Multi-Model was in mind from the beginning of FreeCADs design. There fore we have a multi document interface and can load unlimited documents. But we need to upgrade especially the 3D-Viewer to handle showing more the one document in its view (Part-Trees). +

      +

      Part-Trees

      +

      Since in Assembly the composition of parts and sub-assemblies is the main workflow, the tools to stack (group) Parts in a tree have to be implemented. Unlike a DocumentObjectGroup the Assembly group has to deal with visibility and placement of the children. Best done by stacking ViewProvider on each other. That need a kind of ClaimChildren() interface to the ViewProviders. +

      +

      Unified Drag/Drop/Copy/Paste interface

      +

      A interface allow ViewProvider and Workbenches full control about Drag/Drop/Copy/Paste operations in the tree or the 3D view. +

      +

      External resources

      +

      Handling of doped links (from internal or external browsers). Means loading resources over (potential) slow connections (http). +

      +

      Material

      +

      Describing material and its properties is a vital part of a CAD/CAE system. Material has a lot of properties and names heavily dependent on the field its use. E.g. FEM and mechanical engineering have different frameworks and standards to describe Material. +

      For the Material description a special article is made: Material +

      +

      Object model

      +

      Class tree to deal with concepts needed. References, interfaces, document links, views, compounds, constraints, configurations, and many more... +

      +

      STEP check loop

      +

      Implementing a first STEP importer for more then geometry and color to check if the object model holds for a wider usage. +

      +

      Assembly constraint solver

      +

      Define a interface to a assembly constraint solver, very similar to the Sketcher solver interface. +

      +

      Physics simulation interface

      +

      Interface to allow a (external) (multi)physics simulation software to take control over the positioning of the Parts of a assembly. This would allow to use "bullet" or "ODE" to do kinematic tests and DMU. +

      +

      Next actions

      +
      • Object model
      • +
      • Wait for the 0.12 release branch happened
      +

      Tutorial

      + +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Assy.gif b/localwiki/Assy.gif new file mode 100644 index 0000000..480255f Binary files /dev/null and b/localwiki/Assy.gif differ diff --git a/localwiki/Axes.svg b/localwiki/Axes.svg new file mode 100644 index 0000000..25233a0 --- /dev/null +++ b/localwiki/Axes.svg @@ -0,0 +1,175 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [Jose Luis Cercos Pita] + + + Axes + 2012-11-02 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Plot/resources/icons/Axes.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Axle_constraint.svg b/localwiki/Axle_constraint.svg new file mode 100644 index 0000000..5aa30ac --- /dev/null +++ b/localwiki/Axle_constraint.svg @@ -0,0 +1,119 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + New Document + + + Jakub Steiner + + + http://jimmac.musichall.cz + + 2011-10-10 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Assembly/Gui/Resources/icons/actions/Axle_constraint.svg + + + FreeCAD LGPL2+ + + + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Axoview-r.JPG b/localwiki/Axoview-r.JPG new file mode 100644 index 0000000..5b439c6 Binary files /dev/null and b/localwiki/Axoview-r.JPG differ diff --git a/localwiki/BSplineSurf.svg b/localwiki/BSplineSurf.svg new file mode 100644 index 0000000..801a3e8 --- /dev/null +++ b/localwiki/BSplineSurf.svg @@ -0,0 +1,307 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + + + + + + + + + diff --git a/localwiki/Banner.jpeg b/localwiki/Banner.jpeg new file mode 100644 index 0000000..512b855 Binary files /dev/null and b/localwiki/Banner.jpeg differ diff --git a/localwiki/Base_API.html b/localwiki/Base_API.html new file mode 100644 index 0000000..47dd8f3 --- /dev/null +++ b/localwiki/Base_API.html @@ -0,0 +1,55 @@ +Base API

      Base API

      + +

      The Base module is contained inside the FreeCAD module and contains constructors for different types of objects heavily used in FreeCAD. +


      +

      +
      +
      Class.png BoundBox ( [Xmin,Ymin,Zmin,Xmax,Ymax,Zmax] ) or ( Tuple, Tuple ) or ( Vector, Vector )
      +
      +

      Description: Creates a bounding box. A bounding box is an orthographic cube which is a way to describe outer boundaries. You get a bounding box from a lot of 3D types. It is often used to check if a 3D entity lies in the range of another object. Checking for bounding interference first can save a lot of computing time! +

      +
      +
      +


      +

      +
      +
      Class.png Matrix ( )
      +
      +

      Description: Creates a 4x4 Matrix, that can be used to apply transformations to objects. +

      +
      +
      +


      +

      +
      +
      Class.png Vector ( ) or ( x,y,z )
      +
      +

      Description: Creates a FreeCAD 3D Vector, representing a 3D point or a direction. +

      +
      +
      +


      +

      +
      +
      Class.png Placement ( )
      +
      +

      Description: Creates a Placement. +

      +
      +
      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Basic_Part_Design_Tutorial.html b/localwiki/Basic_Part_Design_Tutorial.html new file mode 100644 index 0000000..d2cc2f2 --- /dev/null +++ b/localwiki/Basic_Part_Design_Tutorial.html @@ -0,0 +1,205 @@ +Basic Part Design Tutorial

      Basic Part Design Tutorial

      + +
      + + + + + + + + + + + + + + + + + + + + + + + + + + + +
      +

      Base ExampleCommandModel.png Tutorial

      +
      Topic +
      Modeling +
      Level +
      Beginner +
      Time to complete +
      Less than an hour +
      Author +
      Mark Stephen (Quick61) +
      FreeCAD version +
      0.14.3700 to 0.16 +
      Example File(s) +
      None +

      + +
      +


      +

      +
      This tutorial is obsolete. It is valid for FC v0.16 and below. For 0.17+, see Basic Part Design Tutorial 017.
      +


      +This tutorial introduces new user to some of the tools and techniques used in the Part Design Workbench. This tutorial is not a complete and comprehensive guide to the Part Design Workbench and many of the tools and capabilities are not covered. This tutorial will take user through the steps needed to model the part shown in the image below using sketches. +

      +
      PD WB Tutorial018.png
      +

      Before You Begin

      +

      The pictures shown in this tutorial were produced in FreeCAD with "auto refine" turned on, which removes the "extra" unneeded lines in faces. This setting is potentially dangerous, should not be used by new users and can corrupt your models. The best advise is, do not change these settings from their default "off". +

      +

      The Task

      +

      In this tutorial, you will be using the Part Design Workbench to create a 3D solid model of the part shown in the Drawing below. All of the necessary dimensions to complete this task are given. You will start by creating a core shape from a base Sketch and then build on that shape, adding what is known as Features. These features will either add material to, or remove material from the solid by use of additional sketches and accompanying feature operations. This Tutorial will not use every feature and tool available within the Part Design Workbench, but should use enough to give the user of this tutorial a basic foundation upon which to build their knowledge and skills. +

      +

      The Part

      +

      Tutorial Drawing Sheet.png +

      +

      Constructing The Part

      +

      Main part with pad

      +

      First begin by making sure you are in the Part Design Workbench. Once there, you will want to create a new document if you have not done so already. It is a good habit to save your work often, so before anything else save the new document, giving it any name you might like. Now that it is saved, we will start with out base sketch. To start this Sketch, click on the Sketcher NewSketch.png New sketch icon on the tool bar or from the Part Design menu, New sketch. Once invoked, you should see a dialog that prompts you to choose sketch orientation and provide an offset. We will not be using offset, but for our base sketch we want to pick the YZ plane as shown in the image below. Once the YZ plane is selected click OK and we can start to construct the first sketch. +

      +
      PD WB Tutorial001.png
      +

      Next you will want to use Sketcher CreatePolyline.png the Polyline tool and make a shape roughly like that in the next image. It does not need to be perfect as the final shape is done with constraints. Once you have the basic shape, we will start applying the constraints. If you had Auto constraints on, some of these constraints will have been applied automatically, if not, do the following. +

      +
      1. Select the two horizontal lines with your mouse by clicking on them, and once selected, click on the Constraint Horizontal.png horizontal constraint.
      2. +
      3. Select the vertical line on the right and then click on the Constraint Vertical.pngvertical constraint.
      4. +
      5. Select the start and end points of your polyline and click on the Constraint PointOnPoint.png coincident constraint to close the polyline.
      6. +
      7. Select the bottom horizontal line and the right vertical line and apply and Constraint EqualLength.png equal constraint.
      8. +
      9. Select either the horizontal or vertical line and apply either a corresponding Constraint HorizontalDistance.png horizontal or Constraint VerticalDistance.png vertical distance constraint and give it a value of 26 mm.
      10. +
      11. Select the top horizontal line and apply the horizontal distance constraint and give it a value of 5 mm
      12. +
      13. Select the lower left point, (vertice) of the horizontal line and the upper right point of the vertical line, then select the center point of the grid and apply the Constraint Symmetric.png symmetry constraint.
      +

      At this point you should have a fully constrained sketch as indicated by it changing color and the message shown in the Combo View. It should now look just like the image below. +

      +
      PD WB Tutorial002.png
      +

      Now in the Combo View, click on the Close button to leave the sketch edit mode and select PartDesign Pad.png Pad from the toolbar or from the Part Design menu. This will give you a Pad dialog in the Combo View. Using that dialog, first using the Type pulldown menu, select Two dimensions. Drawing presented at the beginning of this tutorial says the part is 53 mm long. We do it by Padding our sketch both ways from the center plane to make up that distance i.e. make the pad symmetric in relation of sketch-plane. The reason for is seen later when creating features. For now, given we want it to be 53 mm long in total we will input 26.5 for Length, and 26.5 again for the Second length. Alternatively, you can provide a single length of 53 mm and click the Symmetric to plane check box. Once that is done we now have our base solid upon which we will add additional features to construct our part. +

      A video of the steps used in this portion of the tutorial is here: +https://www.youtube.com/watch?v=UacO5Pa4gIM +

      +

      Features with pocket and external geometry

      +

      Using the mouse or the view icons turn the model around so you can see its back. Once the back of the part is visible, select the back face by clicking on it as seen in the next image. +

      +
      PD WB Tutorial003.png
      +

      After the face is selected, click on the New sketch icon in the toolbar or from the Part Design menu and that will map our next sketch to the back face of the part. Now select Sketcher CreateRectangle.png rectangle tool and place a rectangle on the rear face of the part in a similar fashion as shown below. Now following the steps listed, constrain the sketch. +

      +
      1. Select one of the horizontal lines apply a horizontal distance constraint and a value of 5 mm.
      2. +
      3. Select one of the vertical lines and give it a vertical distance constraint and a value of 11 mm.
      4. +
      5. Use Sketcher External.png External geometry tool and select the upper right vertex of the face and click it so you are provided a point from the external geometry to link our sketch to.
      +
      PD WB Tutorial004.png
      +

      Select that point you just made available with the External geometry tool and then select the upper right vertex of the rectangle and click on the coincident constraint. At this point the sketch should be fully constrained and look like the next image. +

      +
      PD WB Tutorial005.png
      +

      Once that is done, click the Close button at the top of the Tasks tab in the Combo View window, then select PartDesign Pocket.png Pocket tool from the toolbar or Part Design menu. Using this tool is the opposite of the Pad tool. As the Pad tool adds material to the part, the Pocket tool removes material from the part. Both operations are called features. In this Pocket operation we want to select Through all from the type pulldown-menu and then click the OK button. +

      For the next operation, make sure that “Pocket” is selected in the Model tree view and once done, click on PartDesign Mirrored.png the Mirror feature on the toolbar or from the Part Design menu. In the Mirror dialog in the Combo View, select Horizontal sketch axis from the Plane pulldown menu. Then click OK. The Mirror feature works in this way because the base feature of our model was Padded both ways from the horizontal plane in the first operation with the base sketch. If all has gone well, you should now have a part that looks like the image below after you orbit it around to the front. +

      +
      PD WB Tutorial006.png
      +

      A video of the steps used in this portion of the tutorial is here: +https://www.youtube.com/watch?v=nnVQDjUpS3o +

      +

      Features with pad and external geometry

      +

      After taking a look, orbit back around and once again select the back face of the part and select that face to map the next sketch to. +

      +
      PD WB Tutorial007.png
      +

      Select New sketch and make a new rectangle in the manner similar to what is shown below in the next image. Then proceed to add dimensional constraints to the rectangle. +

      +
      1. Select a horizontal line and apply a horizontal distance constraint with a value of 16.7.
      2. +
      3. Select a vertical line and apply a vertical distance constraint of 7 mm
      4. +
      5. Using the External geometry tool, select the upper left vertex of the part face.
      +
      PD WB Tutorial008.png
      +

      Now selecting the upper left vertex of the rectangle and the external geometry point, click on the coincident constraint to fully constrain the sketch. +

      +
      PD WB Tutorial009.png
      +

      Next we will click on the Pad feature and in the Pad dialog in the Combo View we want a length of 26 mm leaving the type as Dimension and then placing a check on the Reversed checkbox. Using the Reversed checkbox will cause the Pad to go into the part instead of away from the part. This operation provides with the following result. +

      +
      PD WB Tutorial010.png
      +

      Once again use the Mirror feature to get the second pad. First ensure that created Pad is selected in the tree view, then click on Mirror in the toolbar of select it from the Part Design menu. We will repeat the operation we did for Pocket above and select Horizontal sketch axis from the Plane pulldown menu. +

      A video of the steps used in this portion of the tutorial is here: +https://www.youtube.com/watch?v=DZOF21fNVDs +

      +

      Feature with pocket and external geometry

      +

      At this point orbiting the part around to the front, we can see that our part is now starting to look like the part in the dimensioned drawing at the beginning of this tutorial. Once you have the view of the front, click on the sloped face with your mouse to select the face we will use for the next sketch. +

      +
      PD WB Tutorial011.png
      +

      Here we will use the rectangle tool and place a rectangle in our sketch and once having done so, apply the following constraints. +

      +
      1. Select a horizontal line and a vertical line, and after both are selected, click on the Equals constraint.
      2. +
      3. Select either a horizontal or vertical line and apply a corresponding horizontal or vertical distance constraint with a value of 17 mm
      4. +
      5. Using the External geometry tool, select the top right vertex as shown in the image below.
      +
      PD WB Tutorial012.png
      +

      Now using the dimensions from the drawing, apply the following constraints. +

      +
      1. Select the external geometry point and the upper right vertex of the now square sketch and apply a horizontal distance constraint of 7 mm
      2. +
      3. Select the external geometry point and the upper right vertex of the now square sketch and apply a vertical distance constraint of 11 mm
      +

      The result should be as follows. +

      +
      PD WB Tutorial013.png
      +

      At this point if we were to simply Pocket this sketch, the resulting hole would be perpendicular to the sloped face that it is mapped to, and this is not what we want. We want the hole to be perpendicular to the back face, but it's projected dimensions are not the 17 mm x 17 mm dimensions that are given in the drawing. Now we could do the math and calculate the dimensions needed, or we can use the tools provided in FreeCAD to make that projection for us. To do that, we are going to create a small Pad feature from the sketch we just made as a helper. We will use the External geometry tool to project the points of the base of that helper Pad on to the back face where we will place our final sketch that will pocket the hole through to finish the model. +

      So first, after clicking Close to exit the Sketch edit dialog, select Pad and provide a distance of 1 mm. Click OK and you should see the following result. +

      +
      PD WB Tutorial014.png
      +

      A video of the steps used in this portion of the tutorial is here: +https://www.youtube.com/watch?v=a0hsJtbFW4Y +

      Next we will orbit back around to see the back face of the part once again and select the back face to map the final sketch to. +

      +
      PD WB Tutorial015.png
      +

      Select New sketch from the toolbar or Part Design menu. Now in sketch edit mode, we will orbit back around to the front so we can see two perpendicular edges of the Pad we made in the last operation. Using the External geometry tool, select the connected horizontal and vertical edges at the base of the Pad with the External geometry tool. The image below shows the base edges to be selected with the External geometry tool. +

      +
      PD WB Tutorial016.png
      +

      Now orbiting around to the back face, or alternatively double clicking on the active sketch in the Model tree view, you will see the two external geometry lines that we provided from the front of the model. Make a rectangle and using the coincident constraint, do the following. +

      +
      1. Select the upper left vertex of the rectangle and the upper left point of the external geometry and click on the coincident constraint.
      2. +
      3. Click on the lower right vertex of the rectangle and the lower right point of the external geometry and click on the coincident constraint.
      +

      And we should end up with this. +

      +
      PD WB Tutorial017.png
      +

      For the final step in this tutorial, we will select the Pocket feature from the toolbar or from the Part Design menu and from the Type pulldown select Through all and click toe OK button. +

      +
      PD WB Tutorial019.png
      +

      A video of these steps of the tutorial is here: +https://www.youtube.com/watch?v=dlQV9OkXWOI +

      Your model will have some extra lines on it compared to the images in this tutorial. To remove these extra lines, change to the OpenSCAD workbench, select Pocket001 (in v0.17 and later select Body) from the hierarchy tree, and click the Refine Shape tool: OpenSCAD RefineShapeFeature.png. This creates a refined version of the model that is parametrically linked to Pocket001 and so is also linked to the entire history of the model. If we change, for example, the numerical value of a distance constraint the Refined Shape will update. In contrast, the Part WorkBench also has a Refine Shape tool in the pulldown menu, and it creates a Refined Shape that is more like a snapshot of the model as it existed when the Refine Shape tool was used. If we change (for example again) the numerical value of a distance constraint, Refine Shape created from the Part Workbench remains the same and does not update. +

      This tutorial and your model are complete. +

      +

      Additional Resources

      +
      • Links to accompanying video have been included.
      • +
      • FreeCAD file for comparison (made with 0.16.6706) Download
      +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Basic_Part_Design_Tutorial_017.html b/localwiki/Basic_Part_Design_Tutorial_017.html new file mode 100644 index 0000000..0073a24 --- /dev/null +++ b/localwiki/Basic_Part_Design_Tutorial_017.html @@ -0,0 +1,232 @@ +Basic Part Design Tutorial 017

      Basic Part Design Tutorial 017

      + +
      + + + + + + + + + + + + + + + + + + + + + + + + + + + +
      +

      Base ExampleCommandModel.png Tutorial

      +
      Topic +
      Modeling +
      Level +
      Beginner +
      Time to complete +
      Less than an hour +
      Author +
      HarryGeier (HarryGeier) +
      FreeCAD version +
      0.17 or higher +
      Example File(s) +
      Basic Part Design for v0.17 +

      + +
      +


      +

      This tutorial introduces the new user to some of the tools and techniques used in the Part Design Workbench. This tutorial is not a complete and comprehensive guide to the Part Design Workbench and many of the tools and capabilities are not covered. This tutorial will take user through the steps needed to model the part shown in the image below using sketches. +

      This tutorial is based on Basic Part Design Tutorial by Quick61 with updates for v0.17. +

      +
      Tut17 final refined.png
      +

      A video of the whole construction is here: +https://youtu.be/geIrH1cOCzc +

      ( each section has its own split Video below ) +

      +

      Before You Begin

      +

      The Task

      +

      In this tutorial, you will be using the Part Design Workbench to create a 3D solid model of the part shown in the Drawing below. All of the necessary dimensions to complete this task are given. You will start by creating a core shape from a base Sketch and then build on that shape, adding what is known as Features. These features will either add material to, or remove material from the solid by use of additional sketches and accompanying feature operations. This Tutorial will not use every feature and tool available within the Part Design Workbench, but should use enough to give the user of this tutorial a basic foundation upon which to build their knowledge and skills. +

      +

      The Part

      +

      Tutorial Drawing Sheet.png +

      +

      Constructing The Part

      +

      Startup

      +

      First begin by making sure you are in the Part Design Workbench. Once there, you will want to create a new document if you have not done so already. It is a good habit to save your work often, so before anything else save the new document, giving it any name you might like. +

      All work in Part Design begins with a Body. Then we will build the solid inside the body by starting with a sketch. +

      +
      1. Click on PartDesign Body.png Create new body to create and activate a new Body Container. Note: this step can be omitted. When creating a sketch, if no existing Body is found, a new one will be automatically created and activated.
      2. +
      3. Click on PartDesign NewSketch.png Create new sketch. This will create the sketch within the just created body.
      4. +
      5. We need to define where the sketch will be attached. We will attach it to a plane from the Body´s Origin.
      6. +
      7. In the Tasks tab from the Combo view, select YZ_Plane in the list and press OK:
      +
      Tut17 sketchplanes.png
      +

      Note: it's possible that the OK button may not be visible if the side panel is not wide enough. You can make it wider by dragging its right border. Place your mouse pointer over the border; when the pointer changes to a two-way arrow, press and hold the left mouse button and drag. +

      Once you click OK, FreeCAD automatically switches to the Sketcher workbench and opens the sketch in editing mode: +

      +
      Tut17 sketcherempty.png
      +

      Create the sketch

      +

      Next you will want to use the Sketcher CreatePolyline.png Polyline tool and make a shape roughly like that in the next image. It does not need to be perfect as the final shape is done with constraints. Once you have the basic shape, we will start applying the constraints. If you had Auto constraints on, some of these constraints will have been applied automatically, if not, do the following. +

      +
      1. Select the two horizontal lines with your mouse by clicking on them, and once selected, click on the Constraint Horizontal.png horizontal constraint.
      2. +
      3. Select the vertical line on the right and then click on the Constraint Vertical.pngvertical constraint.
      4. +
      5. Select the start and end points of your polyline and click on the Constraint PointOnPoint.png coincident constraint to close the polyline.
      6. +
      7. Select the bottom horizontal line and the right vertical line and apply and Constraint EqualLength.png equal constraint.
      8. +
      9. Select either the horizontal or vertical line and apply either a corresponding Constraint HorizontalDistance.png horizontal or Constraint VerticalDistance.png vertical distance constraint and give it a value of 26 mm.
      10. +
      11. Select the top horizontal line and apply the horizontal distance constraint and give it a value of 5 mm
      12. +
      13. Select the lower right point, (vertice) of the horizontal line Origin and then the center point of the grid and apply the Constraint PointOnPoint.png coincidence constraint to fix your shape.
      +

      At this point you should have a fully constrained sketch as indicated by it changing color and the message shown in the Combo View. It should now look just like the image below. +

      +
      Tut17 profile.png
      +

      Now in the Combo View, click on the Close button to leave the sketch edit mode and select PartDesign Pad.png Pad from the toolbar or from the Part Design menu. This will give you a Pad dialog in the Combo View. Using that dialog, first using the Type pulldown menu, select Two dimensions. Drawing presented at the beginning of this tutorial says the part is 53 mm long. We do it by Padding our sketch both ways from the center plane to make up that distance i.e. make the pad symmetric in relation of sketch-plane. The reason for is seen later when creating features. For now, given we want it to be 53 mm long in total we will input 26.5 for Length, and 26.5 again for the Second length. Alternatively, you can provide a single length of 53 mm and click the Symmetric to plane check box. Once that is done we now have our base solid upon which we will add additional features to construct our part. +

      A video of the steps used in this portion of the tutorial is here: +https://youtu.be/cUyPnCMeTgg +

      +

      Features with pocket and external geometry

      +

      Using the mouse or the view icons turn the model around so you can see its back. Once the back of the part is visible, select the back face by clicking on it as seen in the next image. +

      +
      PD WB Tutorial003.png
      +

      After the face is selected, click on the New sketch icon in the toolbar or from the Part Design menu and that will map our next sketch to the back face of the part. Now select Sketcher CreateRectangle.png rectangle tool and place a rectangle on the rear face of the part in a similar fashion as shown below. Now following the steps listed, constrain the sketch. +

      +
      1. Select one of the horizontal lines apply a horizontal distance constraint and a value of 5 mm.
      2. +
      3. Select one of the vertical lines and give it a vertical distance constraint and a value of 11 mm.
      4. +
      5. Use Sketcher External.png External geometry tool and select the upper right vertex of the face and click it so you are provided a point from the external geometry to link our sketch to.
      +
      Tut17 slot unconstrained.png
      +

      Select that point you just made available with the External geometry tool and then select the upper right vertex of the rectangle and click on the coincident constraint. At this point the sketch should be fully constrained and look like the next image. +

      +
      Tut17 slote constrained.png
      +

      Once that is done, click the Close button at the top of the Tasks tab in the Combo View window, then select PartDesign Pocket.png Pocket tool from the toolbar or Part Design menu. Using this tool is the opposite of the Pad tool. As the Pad tool adds material to the part, the Pocket tool removes material from the part. Both operations are called features. In this Pocket operation we want to select Through all from the type pulldown-menu and then click the OK button. +

      For the next operation, make sure that “Pocket” is selected in the Model tree view and once done, click on PartDesign Mirrored.png the Mirror feature on the toolbar or from the Part Design menu. In the Mirror dialog in the Combo View, select Horizontal sketch axis from the Plane pulldown menu. Then click OK. The Mirror feature works in this way because the base feature of our model was Padded both ways from the horizontal plane in the first operation with the base sketch. If all has gone well, you should now have a part that looks like the image below after you orbit it around to the front. +


      +

      +
      Tut17 profilewithslots.png
      +


      +


      +


      +

      A video of the steps used in this portion of the tutorial is here: +https://youtu.be/wiGXV9G7mrM +


      +

      +

      Features with pad and external geometry

      +

      After taking a look, orbit back around and once again select the back face of the part and select that face to map the next sketch to. +

      +
      Tut17 profilewithslotsrearplane.png
      +

      Select New sketch and make a new rectangle in the manner similar to what is shown below in the next image. Then proceed to add dimensional constraints to the rectangle. +

      +
      1. Select a horizontal line and apply a horizontal distance constraint with a value of 16.7.
      2. +
      3. Select a vertical line and apply a vertical distance constraint of 7 mm
      4. +
      5. Using the External geometry tool, select the upper left vertex of the part face.
      +
      Tut17 sidblockunconstrained.png
      +

      Now selecting the upper left vertex of the rectangle and the external geometry point, click on the coincident constraint to fully constrain the sketch. +

      +
      Tut17 sideblockconstraind.png
      +

      Next we will click on the Pad feature and in the Pad dialog in the Combo View we want a length of 26 mm leaving the type as Dimension and then placing a check on the Reversed checkbox. Using the Reversed checkbox will cause the Pad to go into the part instead of away from the part. This operation provides with the following result. +

      +
      Tut17 sideblock.png
      +

      Once again use the Mirror feature to get the second pad. First ensure that created Pad is selected in the tree view, then click on Mirror in the toolbar of select it from the Part Design menu. We will repeat the operation we did for Pocket above and select Horizontal sketch axis from the Plane pulldown menu. +

      +
      Tut17 profilewithsideblocks.png
      +

      A video of the steps used in this portion of the tutorial is here: +https://youtu.be/Ido1owp8ubc +


      +

      +

      Feature with pocket and external geometry

      +

      At this point orbiting the part around to the front, we can see that our part is now starting to look like the part in the dimensioned drawing at the beginning of this tutorial. Once you have the view of the front, click on the sloped face with your mouse to select the face we will use for the next sketch. +

      +
      Tut17 innerplane.png
      +

      Here we will use the rectangle tool and place a rectangle in our sketch and once having done so, apply the following constraints. +

      +
      1. Select a horizontal line and a vertical line, and after both are selected, click on the Equals constraint.
      2. +
      3. Select either a horizontal or vertical line and apply a corresponding horizontal or vertical distance constraint with a value of 17 mm
      4. +
      5. Using the External geometry tool, select the top right vertex as shown in the image below.
      +
      Tut17 rechtangleholeunconstrained.png
      +

      Now using the dimensions from the drawing, apply the following constraints. +

      +
      1. Select the external geometry point and the upper right vertex of the now square sketch and apply a horizontal distance constraint of 7 mm
      2. +
      3. Select the external geometry point and the upper right vertex of the now square sketch and apply a vertical distance constraint of 11 mm
      +

      The result should be as follows. +

      +
      Tut17 rectangleholeconstrained.png
      +

      At this point if we were to simply Pocket this sketch, the resulting hole would be perpendicular to the sloped face that it is mapped to, and this is not what we want. +

      +
      Tut17 wrongplaneforpocket.png
      +


      +We want the hole to be perpendicular to the back face, but it's projected dimensions are not the 17 mm x 17 mm dimensions that are given in the drawing. Now we could do the math and calculate the dimensions needed, or we can use the tools provided in FreeCAD to make that projection for us. +

      A video of the steps used in this portion of the tutorial is here: +https://youtu.be/x4d5nZPWCLQ +


      +To create pocket which has the sloped rectangle as it´s outlet, we draw a new rectangle on the rear side, using the projection of the sloped rectangle as an external reference. +Orbit the Solid around to see the rear face of the part once again and select the back face to map the final sketch to. +

      +
      Tut17 profilewithsideblocksrearplane.png
      +

      Select New Sketch PartDesign NewSketch.png from the toolbar or Part Design menu. Now in sketch edit mode, we do not see the sketched rectangle of the slope. To make it selectable , we switch the combo view to model tab and select the last sketch made (Sketch003) on the sloped plane. Then using the spacebar, make it visible. Next, select the mirror feature above (mirrored001) and again using spacebar, hide it. Then you should see the rectangle inside the 3D View. You may continue to work with the model tab visible, or switch back to tasks tab. Using the Sketcher External.png External geometry tool, select the upper and lower horizontal edges of the sloped rectangle. +

      +
      Tut17 rectangleunconstrained.png
      +
      1. Select the upper left vertex of the rectangle and the upper left point of the external geometry and click on the coincident constraint.
      2. +
      3. Click on the lower right vertex of the rectangle and the lower right point of the external geometry and click on the coincident constraint.
      +

      And we should end up with this. +

      +
      Tut17 rectangleconstrained.png
      +

      For the final step in this tutorial, close the sketcher window using close or fish editing from the context menu of sketch004 and then select the PartDesign Pocket.png Pocket feature from the toolbar or from the Part Design menu. From the Type pulldown select Through all and click the OK button. +

      +
      Tut17 final.png
      +

      At this point, you will see some lines which come from intersecting features. In this case the side block intersects with the base profile letting it appear as a triangular block above the profile. To remove these lines, you can either switch on "refine shape" in your Part Design Settings or , to save some processing speed and still have these lines while constructing, individually switch it on at each feature, which will create such lines. The Setting on feature level can be done in the "data" tab of the feature. Set the refine property to TRUE to invoke refining. +

      +
      Tut17 refine.png
      +
      Tut17 final refined.png
      +


      +


      +


      +

      A video of these steps of the tutorial is here: +https://youtu.be/UYI0gvxCYeI +


      +This tutorial and your model are complete. +

      +

      Additional Resources

      +
      • Links to accompanying video have been included.
      +
      • FreeCAD file for comparison (made with 0.17) Download
      +
      +


      +

      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Basic_modeling_tutorial.html b/localwiki/Basic_modeling_tutorial.html new file mode 100644 index 0000000..424bbdb --- /dev/null +++ b/localwiki/Basic_modeling_tutorial.html @@ -0,0 +1,170 @@ +Basic modeling tutorial

      Basic modeling tutorial

      + +
      + + + + + + + + + + + + + + + + + + + + + + + + + + + +
      +

      Base ExampleCommandModel.png Tutorial

      +
      Topic +
      Introduction to modelling +
      Level +
      Beginner +
      Time to complete +
      15 minutes +
      Author +
      NormandC +
      FreeCAD version +
      any +
      Example File(s) +
      none +

      + +
      +


      +

      This Basic Modeling Tutorial will show you how to model an iron angle. One thing to know is that FreeCAD is modular by design, and like for many other CAD software, there are always more than one way to do things. We will explore two methods here. +

      +

      Before we begin

      +

      Keep in mind that FreeCAD is still in an early stage of development, so you might not be as productive as with another CAD application, and you will certainly encounter bugs, or experience crashes. FreeCAD now has the ability to save backup files. The number of those backup files can be specified in the preferences dialog. Don't hesitate to allow 2 or 3 backup files until you know well how to deal with FreeCAD. +

      Save your work often, from time to time save your work under a different name, so you have a "safe" copy to fall back to, and be prepared to the possibility that some commands might not give you the expected results. +

      +

      Modeling Techniques Intro

      +

      The first (and basic) technique of solid modeling is Constructive Solid Geometry (CSG). You work with primitive shapes like cubes, cylinders, spheres and cones to construct your geometry by combining them, subtracting one shape from the other, or intersecting them. These tools are part of the Part Workbench. You can also apply transformations on shapes, like applying rounds or chamfers on edges. These tools are also in the Part Workbench. +

      Then there are more advanced tools. You start by drawing a 2D profile which you'll either extrude or revolve. +

      So let's start by trying to do some iron feet for a table with these 2 methods. +

      +

      1st Method - By Constructive Solid Geometry

      +
      1. Start with the Part Workbench Switch PartWorkbench.JPG.
      2. +
      3. If you haven't opened a new FreeCAD document (most of the FreeCAD window looks greyed-out), from the pull-down menu click File 🡢 New or click the Document-new.png Create a new empty document icon.
      4. +
      5. Click on the Part Box.png Box button to create a box
      6. +
      7. Change its dimensions by selecting it either in the 3D space, or by clicking it in the Project tab to the left, then
      8. +
      9. Click on the Data tab at the bottom, and change values for Length, Width and Height to 50mm, 50 and 750 (see Fig. 1.1) Note: back when these captures were taken, the properties were ordered differently, with Height being first.
      10. +
      11. The box now fills most of the 3D view. Click on Std ViewFitAll.png Fit All to fit the view to the newly created box.
      12. +
      13. Create a second box the same way, but with values L=40, W=40 and H=750mm. By default this box will be superimposed on the first one. (see Fig. 1.2)
      14. +
      15. You'll now subtract the second box from the first. Select the first shape first (named Box), then the second one (named Box001), the selection order is important! (Make sure that both shapes are selected in the Project tree. One thing to remember: in Inventor navigation mode, Ctrl + click does not work for multiple selection. Switch to either CAD or Blender selection.)
      16. +
      17. On the Part Workbench toolbar, click on the Part Cut.png Cut tool.
      +
      Fig. 1.1 The first box
      +
      Fig. 1.2 The second box on top of the first one, ready to be subtracted
      +
      Fig. 1.3 After the subtraction
      +

      You now have your first iron angle (Fig. 1.3). You'll notice that, in the Project tab on the left, both boxes have been replaced by a "Cut" object. Actually, they're not disappeared, but rather grouped under the Cut object. Click on the + in front of it, and you'll see that both boxes are still there, but greyed out (Fig. 1.4). If you click on either of them and hit the space bar, it will show up. The space bar toggles visibility of selected objects. (Fig. 1.5) +

      Don't want the angle oriented that way? You just need to change the placement of the Box001 shape. Select it, unhide it, and in the Data tab, click on the + in front of Placement, then expand the Position parameter, and change its X and Y coordinates. Hit Enter, hide the Box001 shape again, and your angle orientation is now different. (Fig. 1.5) You can even change either of your shapes dimensions, and the Cut object will be updated. +

      +
      Fig. 1.4 The cut operation retains its original objects (the boxes)
      +
      Fig. 1.5 You can still make the original boxes visible
      +

      By the way, we can add rounds to the angle so it is more realistic, using the Part Fillet.png Fillet tool. (Fig. 1.6) +

      +
      Fig. 1.6 The filleted edges
      +

      2nd Method - By extruding a profile

      +

      This method requires that you start by drawing a 2D profile. You need to activate the Draft workbench Switch DraftWorkbench.JPG. +

      +
      • If you haven't opened a new FreeCAD document (most of the FreeCAD window looks greyed-out), from the pull-down menu click File 🡢 New or click the Document-new.png Create a new empty document icon.
      +

      Setting the working plane

      +

      First we need to define on which working plane to draft our profile. +

      +
      1. Locate the toolbar displayed below. Depending on your Draft preferences, it may be below the main toolbar, to the left or to the right. +
        DraftPlaneAuto.png
      2. +
      3. Press the Auto button (it may be labeled "None").
      4. +
      5. Depending on your Draft preferences, this expands a Select Plane dialog in the Tasks side panel, or a horizontal toolbar labeled "active command: Select Plane". See the Note on Draft Working Plane Button for screen captures showing the two expanded modes.
      6. +
      7. We will leave the Offset field at a value of zero.
      8. +
      9. Press the XY button to set the working plane to XY. This closes the Tasks panel or the expanded buttons. The "Auto" button will now be relabeled as "Top" to show it is the active plane.
      +

      Drafting the profile

      +
      1. Select the Draft Wire.png DWire (multiple-point DraftWire) tool.
      2. +
      3. Check the "Relative" and "Filled" boxes.
      4. +
      5. Rather than drawing the shape in the 3D view, we'll enter coordinates in the Global X, Global Y and Global Z input fields. The process is the following: +
        1. Click in the Global X input field;
        2. +
        3. Enter a value as listed in the bullet list below and press TAB to go to the Global Y input field;
        4. +
        5. Enter the Global Y value and press TAB to go to the Global Z input field;
        6. +
        7. In the Global Z field, leave the zero value and press ENTER to validate the coordinates for the point;
        8. +
        9. Repeat for the next 5 points. +
          • Coordinates (X, Y, Z)
          • +
          • 1st point: 0, 0, 0
          • +
          • 2nd point: 50, 0, 0
          • +
          • 3rd point: 0,10, 0
          • +
          • 4th point: -40, 0, 0 Note: in FreeCAD 0.16, there is a bug that removes the previous point when entering the minus sign in the input field. A workaround is to enter a positive value, then place the cursor before the number and add the minus sign. (This bug is resolved in v0.17)
          • +
          • 5th point: 0, 40, 0
          • +
          • 6th point: -10, 0, 0
      6. +
      7. Press the Close button to close the profile. You should now have this profile, titled DWire in the Model tab:
      +
      Fig. 1.7 The base DWire
      +

      Hit the zero key on the numerical keypad to set the view to axonometric. +

      +

      Extruding the profile

      +

      Activate the Part Workbench either from the workbench selector, or from the View 🡢 Workbench 🡢 Part menu. +

      Click on the Part Extrude.png Extrude tool. +

      On the Tasks tab on the left, select the Wire object. Then enter the desired length, say 750mm. Leave the direction at Z = 1. Press OK. You should now have an Extrude object in the Model tab (fig. 1.8) +

      +
      Fig. 1.8 The extruded object
      +

      This method has a minor caveat compared to the other one: to edit the shape, you need to edit the Wire, it's not as easy to do as the previous method. +

      And there are a few other ways to do it too! I hope these two examples get you started. You'll sure hit some snags along the way (I did when I first learned FreeCAD, and I do have 3D CAD experience), but don't hesitate to ask questions on the FreeCAD forum! +


      +

      +

      Note on Draft Working Plane Button

      +

      The label on your button may be different, depending on your version and also on what you were doing beforehand. The button label could read: "Top", "Front", "Side", "None" or a Vector representation such as d(0.0,0.0,1.0). It can also be blank. For example: +

      +
      Select Plane None
      +
      Select Plane Top
      +
      Select Plane View
      +
      +

      After pressing the button, the options will be expanded into either of the following configurations. +

      +
      Select Plane parameters as shown in Tasks panel mode.
      +
      Select Plane parameters as shown in Toolbar mode.
      +
      +


      +The above instructions will work, no matter what label your button has. +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/BezSurf.svg b/localwiki/BezSurf.svg new file mode 100644 index 0000000..6c5c093 --- /dev/null +++ b/localwiki/BezSurf.svg @@ -0,0 +1,329 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + diff --git a/localwiki/Blank.png b/localwiki/Blank.png new file mode 100644 index 0000000..ef2a9d0 Binary files /dev/null and b/localwiki/Blank.png differ diff --git a/localwiki/Bound-expression-unset.svg b/localwiki/Bound-expression-unset.svg new file mode 100644 index 0000000..fdf5184 --- /dev/null +++ b/localwiki/Bound-expression-unset.svg @@ -0,0 +1,135 @@ + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + diff --git a/localwiki/Bound-expression.svg b/localwiki/Bound-expression.svg new file mode 100644 index 0000000..574efc7 --- /dev/null +++ b/localwiki/Bound-expression.svg @@ -0,0 +1,135 @@ + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + diff --git a/localwiki/BoundBoxTracing.png b/localwiki/BoundBoxTracing.png new file mode 100644 index 0000000..e288e2d Binary files /dev/null and b/localwiki/BoundBoxTracing.png differ diff --git a/localwiki/Braga-primoPad.png b/localwiki/Braga-primoPad.png new file mode 100644 index 0000000..32d9a54 Binary files /dev/null and b/localwiki/Braga-primoPad.png differ diff --git a/localwiki/Braga-secondo_Pad.png b/localwiki/Braga-secondo_Pad.png new file mode 100644 index 0000000..0396d00 Binary files /dev/null and b/localwiki/Braga-secondo_Pad.png differ diff --git a/localwiki/Braga-secondoschizzo.png b/localwiki/Braga-secondoschizzo.png new file mode 100644 index 0000000..0992d70 Binary files /dev/null and b/localwiki/Braga-secondoschizzo.png differ diff --git a/localwiki/Branding.html b/localwiki/Branding.html new file mode 100644 index 0000000..5ff5da5 --- /dev/null +++ b/localwiki/Branding.html @@ -0,0 +1,86 @@ +Branding

      Branding

      + +

      This article describes the Branding of FreeCAD. Branding means to start your own application on base of FreeCAD. That can be only your own executable or splash screen till a complete reworked program. On base of the flexible architecture of FreeCAD it's easy to use it as base for your own special purpose program. +

      +

      General

      +

      Most of the branding is done in the MainCmd.cpp or MainGui.cpp. These Projects generate the executable files of FreeCAD. To make your own Brand just copy the Main or MainGui projects and give the executable an own name, e.g. FooApp.exe. +The most important settings for a new look can be made in one place in the main() function. Here is the code section that controls the branding: +

      +
       int main( int argc, char ** argv )
      + {
      +   // Name and Version of the Application
      +   App::Application::Config()["ExeName"] = "FooApp";
      +   App::Application::Config()["ExeVersion"] = "0.7";
      + 
      +   // set the banner (for loging and console)
      +   App::Application::Config()["CopyrightInfo"] = sBanner;
      +   App::Application::Config()["AppIcon"] = "FooAppIcon";
      +   App::Application::Config()["SplashScreen"] = "FooAppSplasher";
      +   App::Application::Config()["StartWorkbench"] = "Part design";
      +   App::Application::Config()["HiddenDockWindow"] = "Property editor";
      +   App::Application::Config()["SplashAlignment" ] = "Bottom|Left";
      +   App::Application::Config()["SplashTextColor" ] = "#000000"; // black
      + 
      +   // Inits the Application 
      +   App::Application::Config()["RunMode"] = "Gui";
      +   App::Application::init(argc,argv);
      + 
      +   Gui::BitmapFactory().addXPM("FooAppSplasher", ( const char** ) splash_screen);
      + 
      +   Gui::Application::initApplication();
      +   Gui::Application::runApplication();
      +   App::Application::destruct();
      + 
      +   return 0;
      + }
      +

      The first Config entry defines the program name. This is not the executable name, which can be changed by renaming or by compiler settings, but the name that is displayed in the task bar on windows or in the program list on Unix systems. +

      The next lines define the Config entries of your FooApp Application. A description of the Config and its entries you find in Start up and Configuration. +

      +

      Images

      +

      Image resources are compiled into FreeCAD using Qt's resource system. Therefore you have to write a .qrc file, an XML-based file format that lists image files on the disk but also any other kind of resource files. To load the compiled resources inside the application you have to add a line +

      +
       Q_INIT_RESOURCE(FooApp);
      +

      into the main() function. Alternatively, if you have an image in XPM format you can directly include it into your main.cpp and add the following line to register it: +

      +
       Gui::BitmapFactory().addXPM("FooAppSplasher", ( const char** ) splash_screen);
      +

      Branding XML

      +

      In FreeCAD there is also a method supported without writing a customized main() function. For this method you must write a file name called branding.xml and put it into the installation directory of FreeCAD. Here is an example with all supported tags: +

      +
       <?xml version="1.0" encoding="utf-8"?>
      + <Branding>
      + <Application>FooApp</Application>
      + <WindowTitle>Foo App in title bar</WindowTitle>
      + <BuildVersionMajor>1</BuildVersionMajor>
      + <BuildVersionMinor>0</BuildVersionMinor>
      + <BuildRevision>1234</BuildRevision>
      + <BuildRevisionDate>2014/1/1</BuildRevisionDate>
      + <CopyrightInfo>(c) My copyright</CopyrightInfo>
      + <MaintainerUrl>Foo App URL</MaintainerUrl>
      + <ProgramLogo>Path to logo (appears in bottom right corner)</ProgramLogo>
      + <WindowIcon>Path to icon file</WindowIcon>
      + <ProgramIcons>Path to program icons</ProgramIcons>
      + <SplashScreen>splashscreen.png</SplashScreen>
      + <SplashAlignment>Bottom|Left</SplashAlignment>
      + <SplashTextColor>#ffffff</SplashTextColor>
      + <SplashInfoColor>#c8c8c8</SplashInfoColor>
      + <StartWorkbench>PartDesignWorkbench</StartWorkbench>
      + </Branding>
      +

      All of the listed tags are optional. +

      + +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Breakpoint.svg b/localwiki/Breakpoint.svg new file mode 100644 index 0000000..858b7d5 --- /dev/null +++ b/localwiki/Breakpoint.svg @@ -0,0 +1,588 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + + + + + + + diff --git a/localwiki/Brga-spessore.png b/localwiki/Brga-spessore.png new file mode 100644 index 0000000..717a04f Binary files /dev/null and b/localwiki/Brga-spessore.png differ diff --git a/localwiki/Brick01.svg b/localwiki/Brick01.svg new file mode 100644 index 0000000..3ce8edc --- /dev/null +++ b/localwiki/Brick01.svg @@ -0,0 +1,206 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + Pablo Gil + + + + + SVG + template + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Bug_Triage.html b/localwiki/Bug_Triage.html new file mode 100644 index 0000000..29fd7a6 --- /dev/null +++ b/localwiki/Bug_Triage.html @@ -0,0 +1,163 @@ +Bug Triage

      Bug Triage

      + +
      + +

      Why

      +

      Triageː +

      1a : the sorting of and allocation of treatment to patients and especially battle and disaster victims according to a system of priorities designed to maximize the number of survivors +

      1b : the sorting of patients (as in an emergency room) according to the urgency of their need for care +

      2: the assigning of priority order to projects on the basis of where funds and other resources can be best used, are most needed, or are most likely to achieve success +

      Bug triage is important to organize and prioritize bugs/features/patches in respect to the FreeCAD Bug Tracker. If this task is neglected a project can suffer from what is called 'Bugtracker Bloat' which is essentially neglected tickets accumulating and rotting. Triage also helps to identify duplicate tickets that have a tendency to accumulate especially if there is a long standing unresolved issue that the FC team is well aware of but doesn't have the resources for whatever reason to fix at the time. +

      +

      How to Triage

      +

      Ticket Status

      +

      New

      +

      Per MantisBT docsː +This is the landing status for new issues. Issues stay in this status until they areː assigned, acknowledged, confirmed or resolved. +

      In other words, NEW status indicates several thingsː +

      +
      1. Ticket hasn't been confirmed.
      2. +
      3. Ticket is still in process, i.e. Triage/Devs still evaluating/clarifying details of ticket from OP.
      4. +
      5. FreeCAD team hasn't decided what to do with this ticket yet.
      +

      All current open FreeCAD tickets with NEW status. +

      +

      Acknowledged

      +

      Feedback

      +

      Tickets get designated this status when OP is being requested to provide more information. +

      The ticket is pending based on the participation of OP. For exampleː the ticket is missing FC version info; or perhaps a certain 3rd party library name or version is required etc... Devs need to set this status whenever replying to OP in order to indicate that the ticket is pending. This is important due to the possibilit that OP neglects to respond which has a high probability for the ticket to 'rot' in the tracker. +

      When OP responds the ticket status changes back to New automatically. Then ticket needs to be re-examined to decide what is needed. +

      Further discussion on this topic in the FreeCAD forum. +

      All current open FreeCAD tickets with FEEDBACK status in the FC bugtracker. +

      +

      Confirmed

      +

      When a ticket is confirmed it has been eitherː +

      +
      • a bug that has been reproduced
      • +
      • a feature that has been greenlit to be considered valid.
      +

      It is now ready to be assigned to or by a dev. +

      All current open FreeCAD tickets with CONFIRMED status in the FC tracker. +

      +

      Assigned

      +

      Self-explanatory, these tickets that have been assigned to a specific developer. +

      All current open FreeCAD tickets with ASSIGNED status in the FC tracker. +

      +

      Resolved

      +

      These tickets have been resolved but not closed yet, most likely because they need confirmation that the ticket has been fixed. +

      +
      +

      Ticket Resolutioɲ

      +

      Open

      +

      Self-explanatory, all tickets remain as 'open' if they are still relevant at the discretion of the FC team. +

      +

      Fixed

      +

      Tickets that have been fixed. +

      +

      Unable to reproduce

      +

      Tickets deemed un-reproducible +

      +

      Duplicate

      +

      Tickets that are or have a duplicate ticket. +

      +

      No change required

      +

      Tickets were it has been ascertained that no modifications are necessary. +

      +

      Won't fix

      +

      FC team has rejected the ticket request for whatever reason stated. +

      +

      Not fixable

      +

      Reopened

      +

      Tickets that have been closed me then re-opened for a relevant reason. Most likely that the issue has resurfaced or wasn't totally fixed. +

      +

      Suspended

      +

      Ticket Priority

      +

      Immediatə

      +

      Urgent

      +

      High

      +

      Normal

      +

      Low

      +

      None

      +

      Ticket Severity

      +

      Block

      +

      Crash

      +

      Major

      +

      Minor

      +

      Tweak

      +

      Text

      +

      Trivial

      +

      Feature

      +

      Tagging Tickets

      +

      An important methodology to track tickets by a certain subject/theme/category. It's important that Existing Tags be used to tag issues before new tags are created. If duplicate or superfluous tags are created the bug tracker admin is responsible to remove them and if possible retag said tickets. +

      +

      Related

      +

      Bugtracker +

      + + + + +
      + +
      +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Bugreport-workflow.png b/localwiki/Bugreport-workflow.png new file mode 100644 index 0000000..55175e8 Binary files /dev/null and b/localwiki/Bugreport-workflow.png differ diff --git a/localwiki/Bugtracker.html b/localwiki/Bugtracker.html new file mode 100644 index 0000000..6a0a842 --- /dev/null +++ b/localwiki/Bugtracker.html @@ -0,0 +1,188 @@ +Bugtracker

      Bugtracker

      (Redirected from Bugtracker)
      + +
      link=https://freecadweb.org/tracker/MantisBT is the bugtracker framework FreeCAD uses
      +

      The address of our bug tracker is: +

      https://www.freecadweb.org/tracker +

      The Tracker is the place toː report bugs, submit feature requests, patches, or request to merge your branch if you developed something using Git. The tracker is divided into 'Workbenches', so please be specific and file your request in the appropriate subsection. In case of doubt, leave it in the "FreeCAD" section. +


      +

      + + +

      Recommended Workflow

      +
      Bugreport-workflow.png
      +

      As shown in the above flowchart, before creating tickets, please always first search the forums and bugtracker to discover if your issue is a known issue. This saves a lot of time/work for developers and volunteers that could be spending said time making FreeCAD even more awesome. +

      +

      Reporting bugs

      +

      If you think you might have found a bug, you are welcome to report it as long as you have followed our step-by-step guidelinesː +

      +
      • Make sure you're using the most up to date version of FreeCAD. NOTEː your bug may be fixed in the Development (unstable) version. The average user runs the stable version of FC.
      • +
      • Make sure your bug is really a bug, that is, something that should be working but isn't. Make sure the same bug hasn't been reported before by first searching the bugtracker and forum. +
        • Rememberː if you aren't sure, please don't hesitate to explain your problem/bug in the Help forum and ask what to do.
        • +
        • Noteː before posting to the forum please read the Forum Guidelines.
      • +
      • Describe as clearly as possible the problem, and how it can be reproduced. If we can not verify the bug, we might not be able to fix it. +
        • This means reporting in a clear, well-formatted, step-by-step fashion so even an amateur user could reproduce.
        • +
        • Recommendedː Screenshots of the bug are also very helpful to include. Windows users: please do not attach screen captures in Word or PDF format. Use the Windows Snipping tool to save your capture as a PNG image.
        • +
        • Recommendedː Even better, an Animated gif or Screencast would also increase the likelihood of reproducing the issue.
      • +
      • Add an example FreeCAD file (.FCStd file) so devs/testers can quickly reproduce the bug. +
        • Please don't zip your *.FCStd file, it is already zipped.
        • +
        • File attachments are limited in size. If your *.FCStd file is too big to attach, you can use an online storage service (many are free like Google Drive, Microsoft OneDrive, Dropbox).
      • +
      • Include all the information from the "Copy to Clipboard" button in the Help (menu) -> About FreeCAD dialogue. Make sure your data includes your OCC or OCE version.
      • +
      • Please file one separate report for each bug.
      • +
      • If your bug causes a crash in FreeCAD and you're on a system that supports it you can try running a debug backtrace and attach said trace to the ticket. This can save devs a lot of time pinpointing the source of the crash. See Debugging for more details.
      +

      Requesting features

      +

      If you want something to appear in FreeCAD that is not implemented yet, it is not a bug but a feature request. +

      +
      1. IMPORTANTː Before requesting a potential Feature Request please be certain that you are the first one doing so by searching the forums and the bugtracker. If you have concluded that there are no pre-existing tickets/discussions the next step is toː
      2. +
      3. Start a forum thread to discuss your feature request with the community via the Open Discussion forum.
      4. +
      5. Once the community agrees that this is a valid Feature, you then can open a ticket on the tracker (file it under feature request instead of bug).
      +
      • NOTE #1 To keep things organized please remember to link the forum thread URL into the ticket and the ticket number (as a link) in to the forum thread.
      • +
      • NOTE #2 Keep in mind there are no guarantees that your wish will be fulfilled.
      +
      FreeCAD Bugtracker report page - use the dropdown to correctly designate what the ticket is
      +

      Submitting patches

      +

      In case you have programmed a bug fix, an extension or something else that can be of public use in FreeCAD, create a patch using the Git diff tool and submit it on the same tracker (file it as patch). +

      Addendumː FreeCAD development has switched to the GitHub development model so the workflow for submitting patches has been greatly enhanced/streamlined by submitting Pull Requests. +

      +
      • Open a forum thread in the Developer subforum to announce and discuss your patch.
      • +
      • Submit your PR to the FreeCAD GitHub repo. Be sure to link the forum thread in to the git commit summary.
      • +
      • Paste the PR link in to the forum thread for the devs/testers to test.
      • +
      • Be present for the discussion so that your code can potentially be merged more effectively.
      +

      NOTEː the FreeCAD community recommends to first discuss any large revision to the source code in advance to save everyone time. +

      +

      Requesting merge

      +

      (Same guidelines as Submiting patches) +

      If you have created a git branch containing changes that you would like to see merged into the FreeCAD code, you can ask there to have your branch reviewed and merged if the FreeCAD developers are OK with it. You must first publish your branch to a public git repository (github, gitlab, bitbucket, sourceforge etc...) and then give the URL of your branch in your merge request. +

      +

      MantisBT Tips and Tricks

      +

      MantisBT Markup

      +

      MantisBT (Mantis Bug Tracker) has it's own unique markup. +

      +
      • @mention - works just like on GitHub where if you prepend '@' to someone's username they will receive an email that they have been 'mentioned' in a ticket thread
      +
      Mantisbt-mention-example.jpg
      +
      • #1234 - By adding a hash tag in front of a number a shortcut to link to another ticket within MantisBT will present. +
        Note: if you hover over a ticket it will show you the summary + if the ticket is closed, it will be struck-through like #1234.
      +
      Mantisbt-ticket-shortcut-example.jpg
      +
      • ~5678 - a shortcut that links to a bug note within a ticket. This can be used to reference someone's response within the thread. Each person that posts will show a unique ~#### number next to their username. If you look at the image in the example, you see that the shortcut is referencing the ticket number:comment number of said ticket
      +
      Mantisbt-comment-shortcut-example.jpg
      +
      • <del></del> - Using these tags will strikeout text.
      +
      Mantisbt-strikeout-text-example.jpg
      +
      • <code></code> - To present a line or block of code, use this tag and it will colorize and differentiate it elegantly.
      +
      Mantisbt-colorized-code-example.jpg
      +

      MantisBT BBCode

      +

      In addition to the above Tracker/MantisBT ̠Markup one also has the possibility to use BBCode format. For a comprehensive list see the BBCode plus plugin page. Here is a list of supported BBCode tagsː +
      +[img][/img] - Images
      +[url][/url] - Links
      +[email][/email] - Email addresses
      +[color=red][/color] - Colored text
      +[highlight=yellow][/highlight] - Highlighted text
      +[size][/size] - Font size
      +[list][/list] - Lists
      +[list=1][/list] - Numbered lists (number is starting number)
      +[*] - List items
      +[b][/b] - Bold
      +[u][/u] - underline
      +[i][/i] - Italic
      +[s][/s] - Strikethrough
      +[left][/left] - Left align
      +[center][/center] - Center
      +[right][/right] - Right align
      +[justify][/justify] - Justify
      +[hr] - Horizontal rule
      +[sub][/sub] - Subscript
      +[sup][/sup] - Superscript
      +[table][/table] - Table
      +[table=1][/table] - Table with border of specified width
      +[tr][/tr] - Table row
      +[td][/td] - Table column
      +[code][/code] - Code block
      +[code=sql][/code] - Code block with language definition
      +[code start=3][/code] - Code block with line numbers starting at number
      +[quote][/quote] - Quote by *someone* (no name)
      +[quote=name][/quote] - Quote by *name*
      +
      +
      +

      +

      MantisBT <=> GitHub Markup

      +

      Below are special MantisBT Source-Integration plugin keywords which will link to the FreeCAD GitHub repo. See Tracker#GitHub_and_MantisBT. +

      +
      • c:FreeCAD:git commit hash: - c stands for 'commit'. FreeCAD stands for the FreeCAD GitHub repo. 'git commit hash' is the specific git commit hash to reference. Note: the trailing colon is necessary. Exampleː cːFreeCADː709d2f325db0490016807b8fa6f49d1c867b6bd8ː
      • +
      • d:FreeCAD:git commit hash: - similar to the above, d stands for 'diff' which will provide a Diff view of the commit. Exampleː dːFreeCADː709d2f325db0490016807b8fa6f49d1c867b6bd8ː
      • +
      • p:FreeCAD:pullrequest: - similar to the above, p stands for Pull Request. Exampleː pːFreeCADː498ː
      +
      Mantisbt-source-integration-markup.jpg
      +
      +


      +

      +

      GitHub and MantisBT

      +

      The FreeCAD bugtracker has a plug-in called Source Integration which essentially ties both the FreeCAD GitHub repo to our MantisBT tracker. It makes it easier to track and associate git commits with their respective MantisBT tickets. The Source Integration plugin scans the git commit messages for specific keywords in order to execute the following actions: +

      Note The below keywords need to be added in the git commit message and not the PR subject +

      +

      Attaching a git commit to a ticket

      +

      The format MantisBT will recognize: +

      +
      • bug #1234
      • +
      • bugs #1234, #5678
      • +
      • issue #1234
      • +
      • issues #1234, #5678
      • +
      • report #1234
      • +
      • reports #1234, #5678
      +

      For the inquisitive here is the regex MantisBT uses for this operation:
      +/(?:bugs?|issues?|reports?)+\s*:?\s+(?:#(?:\d+)[,\.\s]*)+/i
      +

      +

      Remotely resolving a ticket

      +

      The format MantisBT will recognize: +

      +
      • fix #1234
      • +
      • fixed #1234
      • +
      • fixes #1234
      • +
      • fixed #1234, #5678
      • +
      • fixes #1234, #5678
      • +
      • resolve #1234
      • +
      • resolved #1234
      • +
      • resolves #1234
      • +
      • resolved #1234, #5678
      • +
      • resolves #1234, #5678
      +

      For the inquisitive here is the regex MantisBT uses for this operation:
      +/(?:fixe?d?s?|resolved?s?)+\s*:?\s+(?:#(?:\d+)[,\.\s]*)+/i
      +

      +

      Related

      + + +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Builtin_modules.html b/localwiki/Builtin_modules.html new file mode 100644 index 0000000..6bb5d7f --- /dev/null +++ b/localwiki/Builtin_modules.html @@ -0,0 +1,30 @@ +Builtin modules

      Builtin modules

      + +

      This page presents more in-depth information over the built-in FreeCAD modules, and what are the functions and properties availible to you. This page is not a complete list of all the contents of these modules, and, because of the fast evolution of FreeCAD, the information presented here might be slightly outdated, but it should give you a good overview of the possibilities. For complete list of the modules content, use the dir(module) function in the interpreter. +

      +

      The FreeCAD module

      +

      Base

      +

      Vectors

      +

      Matrixes

      +

      Console module

      +

      The FreeCADGui Module

      +

      Selection module

      +

      Placement

      +

      Document Objects

      +

      View Objects

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Bulb.svg b/localwiki/Bulb.svg new file mode 100644 index 0000000..4f4b923 --- /dev/null +++ b/localwiki/Bulb.svg @@ -0,0 +1,840 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + Lapo Calamandrei + + + + + + media + stop + playback + video + music + + + + + Jakub Steiner + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Button_add_all.svg b/localwiki/Button_add_all.svg new file mode 100644 index 0000000..19ffc8d --- /dev/null +++ b/localwiki/Button_add_all.svg @@ -0,0 +1,776 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Button_down.svg b/localwiki/Button_down.svg new file mode 100644 index 0000000..e2e0542 --- /dev/null +++ b/localwiki/Button_down.svg @@ -0,0 +1,706 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Button_invalid.svg b/localwiki/Button_invalid.svg new file mode 100644 index 0000000..97df868 --- /dev/null +++ b/localwiki/Button_invalid.svg @@ -0,0 +1,264 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Button_left.svg b/localwiki/Button_left.svg new file mode 100644 index 0000000..db662f6 --- /dev/null +++ b/localwiki/Button_left.svg @@ -0,0 +1,706 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Button_right.svg b/localwiki/Button_right.svg new file mode 100644 index 0000000..e397165 --- /dev/null +++ b/localwiki/Button_right.svg @@ -0,0 +1,716 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Button_sort.svg b/localwiki/Button_sort.svg new file mode 100644 index 0000000..27fcb64 --- /dev/null +++ b/localwiki/Button_sort.svg @@ -0,0 +1,785 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Button_up.svg b/localwiki/Button_up.svg new file mode 100644 index 0000000..821c1be --- /dev/null +++ b/localwiki/Button_up.svg @@ -0,0 +1,716 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Button_valid.svg b/localwiki/Button_valid.svg new file mode 100644 index 0000000..fe9d791 --- /dev/null +++ b/localwiki/Button_valid.svg @@ -0,0 +1,131 @@ + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + + + + + + + + diff --git a/localwiki/CAD_Modeling.gif b/localwiki/CAD_Modeling.gif new file mode 100644 index 0000000..2bc9768 Binary files /dev/null and b/localwiki/CAD_Modeling.gif differ diff --git a/localwiki/CAM_project.html b/localwiki/CAM_project.html new file mode 100644 index 0000000..82cec4b --- /dev/null +++ b/localwiki/CAM_project.html @@ -0,0 +1,20 @@ +CAM project

      CAM project

      + +

      The CAM workbench and project is deprecated. See instead Path Workbench +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Cabinetside.png b/localwiki/Cabinetside.png new file mode 100644 index 0000000..1843859 Binary files /dev/null and b/localwiki/Cabinetside.png differ diff --git a/localwiki/Cabinettop.png b/localwiki/Cabinettop.png new file mode 100644 index 0000000..b85f929 Binary files /dev/null and b/localwiki/Cabinettop.png differ diff --git a/localwiki/Caliper-ico.png b/localwiki/Caliper-ico.png new file mode 100644 index 0000000..0f35e29 Binary files /dev/null and b/localwiki/Caliper-ico.png differ diff --git a/localwiki/Camera-photo.svg b/localwiki/Camera-photo.svg new file mode 100644 index 0000000..41dd772 --- /dev/null +++ b/localwiki/Camera-photo.svg @@ -0,0 +1,679 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + Jakub Steiner + + + http://jimmac.musichall.cz + Photo Camera + + + camera + photo + SLR + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/CameraPosition1_it.png b/localwiki/CameraPosition1_it.png new file mode 100644 index 0000000..58230e8 Binary files /dev/null and b/localwiki/CameraPosition1_it.png differ diff --git a/localwiki/Captura_de_pantalla_de_2015-09-10_11-17-30.png b/localwiki/Captura_de_pantalla_de_2015-09-10_11-17-30.png new file mode 100644 index 0000000..99fec5c Binary files /dev/null and b/localwiki/Captura_de_pantalla_de_2015-09-10_11-17-30.png differ diff --git a/localwiki/Cartouche_01_Convention_EU.svg b/localwiki/Cartouche_01_Convention_EU.svg new file mode 100644 index 0000000..c245abe --- /dev/null +++ b/localwiki/Cartouche_01_Convention_EU.svg @@ -0,0 +1,112 @@ + + + + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Cartouche_01_Convention_US.svg b/localwiki/Cartouche_01_Convention_US.svg new file mode 100644 index 0000000..dbfc649 --- /dev/null +++ b/localwiki/Cartouche_01_Convention_US.svg @@ -0,0 +1,107 @@ + + + + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Cartouche_01_US.svg b/localwiki/Cartouche_01_US.svg new file mode 100644 index 0000000..fee0bf6 --- /dev/null +++ b/localwiki/Cartouche_01_US.svg @@ -0,0 +1,809 @@ + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + AUTHOR NAME + CREATION DATE + SUPERVISOR NAME + CHECK DATE + A3 + SCALE + WEIGHT + NUMBER + SHEET + TITLE + SUBTITLE + COMPANY NAME + COPYRIGHT + _a_______ + _b_______ + _c_______ + _d_______ + _e_______ + _f_______ + _g_______ + _h_______ + _i_______ + + + AUTHOR NAME : + SUPERVISOR NAME : + FORMAT : + COMPANY : + SCALE : + WEIGHT (kg) : + VERSION : + SHEET : + DATE : + DATE : + + + + + + + + + + + + + + + diff --git a/localwiki/Cartouche_02_US.svg b/localwiki/Cartouche_02_US.svg new file mode 100644 index 0000000..a3ca686 --- /dev/null +++ b/localwiki/Cartouche_02_US.svg @@ -0,0 +1,1184 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + Scale : + Part name: + Project number / Id: + Company name: + + + + + + + + + + + + + + + + + + + + + + + + + + + + Drawn by: + DRAW_BY + Controlled by: + CONTROLLED_BY + Date: + DATE + Controlled 2: + CONTROLLED 2 + Controlled 3: + CONTROLLED 3 + SCALE + MOD + COMPANY + ADRESS + COUNTRY + PART NAME + Project number / Id + A: + A_ + B: + B_ + C: + C_ + D: + D_ + E: + E_ + Quantity + Part ID / number + Fabrication tolerances + Material + 01 + 001 - 001 + ISO2768 - fH + IRON + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Cartouche_03_US.svg b/localwiki/Cartouche_03_US.svg new file mode 100644 index 0000000..89d53b2 --- /dev/null +++ b/localwiki/Cartouche_03_US.svg @@ -0,0 +1,467 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + + TITLE + DESCRIPTION + Scale : + SCALE + Title 0 : + TITLE 0 + Date : + DATE + Made With : + FreeCAD + www.freecadweb.org + TEXT 1 + TEXT 2 + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Cartouche_04_US.svg b/localwiki/Cartouche_04_US.svg new file mode 100644 index 0000000..5491ab3 --- /dev/null +++ b/localwiki/Cartouche_04_US.svg @@ -0,0 +1,652 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + + + + + + myLogo + + + + PROJECT : + SCALE : + PHASE : + AUTHOR : + DATE : + REVISION : + + + + + + + + TITLE + PROJECT + PHASE + DATE + SCALE + AUTHOR NAME + REVISION + _A________ + _B________ + _C________ + _D________ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Center-align-Body-objects.gif b/localwiki/Center-align-Body-objects.gif new file mode 100644 index 0000000..026625e Binary files /dev/null and b/localwiki/Center-align-Body-objects.gif differ diff --git a/localwiki/Center-align-faces-in-action.gif b/localwiki/Center-align-faces-in-action.gif new file mode 100644 index 0000000..fc25c25 Binary files /dev/null and b/localwiki/Center-align-faces-in-action.gif differ diff --git a/localwiki/Center-align-faces.png b/localwiki/Center-align-faces.png new file mode 100644 index 0000000..f217a3d Binary files /dev/null and b/localwiki/Center-align-faces.png differ diff --git a/localwiki/CenterFace.png b/localwiki/CenterFace.png new file mode 100644 index 0000000..74e2ae1 Binary files /dev/null and b/localwiki/CenterFace.png differ diff --git a/localwiki/Chamfer-example.png b/localwiki/Chamfer-example.png new file mode 100644 index 0000000..6b4ce27 Binary files /dev/null and b/localwiki/Chamfer-example.png differ diff --git a/localwiki/Chord_length.png b/localwiki/Chord_length.png new file mode 100644 index 0000000..4f71bce Binary files /dev/null and b/localwiki/Chord_length.png differ diff --git a/localwiki/Circel.png b/localwiki/Circel.png new file mode 100644 index 0000000..f466567 Binary files /dev/null and b/localwiki/Circel.png differ diff --git a/localwiki/Circle_on_3_points.png b/localwiki/Circle_on_3_points.png new file mode 100644 index 0000000..1e912e0 Binary files /dev/null and b/localwiki/Circle_on_3_points.png differ diff --git a/localwiki/Circular_run-out.svg b/localwiki/Circular_run-out.svg new file mode 100644 index 0000000..a2f3505 --- /dev/null +++ b/localwiki/Circular_run-out.svg @@ -0,0 +1,122 @@ + + + + + Circular run-out + + + + + + image/svg+xml + + Circular run-out + + + bavariaSHAPE + + + + + bavariaSHAPE + + + + + bavariaSHAPE + + + 15.10.2016 + Geometric dimensioning and tolerancing symbols +All symbols in this repository are licensed under CC-BY 3.0 + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Circularity.svg b/localwiki/Circularity.svg new file mode 100644 index 0000000..90cb5a3 --- /dev/null +++ b/localwiki/Circularity.svg @@ -0,0 +1,113 @@ + + + + + Circularity + + + + + + image/svg+xml + + Circularity + + + bavariaSHAPE + + + + + bavariaSHAPE + + + + + bavariaSHAPE + + + 15.10.2016 + Geometric dimensioning and tolerancing symbols +All symbols in this repository are licensed under CC-BY 3.0 + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Civil_Engineering_Workbench.html b/localwiki/Civil_Engineering_Workbench.html new file mode 100644 index 0000000..77fa2f3 --- /dev/null +++ b/localwiki/Civil_Engineering_Workbench.html @@ -0,0 +1,35 @@ +Civil Engineering Workbench

      Civil Engineering Workbench

      + +

      Description

      +

      Civil Engineering is a broad category of engineering and covers several subjects, primarily environmental (wastewater), geotechnical, transportation, and structural. At present, the primary focus of the civil engineering effort in FreeCAD is focused on transportation engineering, or more specifically 3D Highway design. +

      At present, only two components of civil engineering are represented in FreeCAD: +

      +
      1. Rebar Workbench
      2. +
      3. Transportation Workbench
      +

      The Rebar tools are currently part of the Arch Workbench +

      +

      Related Forum Threads

      +
      • Civil engineering feature implementation (Transportation Engineering) thread
      • +
      • Civil Engineering Design functions thread
      • +
      • Thread tracking FreeCAD & QGIS integration thread
      +

      Related Links

      + +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Class.png b/localwiki/Class.png new file mode 100644 index 0000000..66f139d Binary files /dev/null and b/localwiki/Class.png differ diff --git a/localwiki/ClippingPlane1_it.png b/localwiki/ClippingPlane1_it.png new file mode 100644 index 0000000..0c19f10 Binary files /dev/null and b/localwiki/ClippingPlane1_it.png differ diff --git a/localwiki/ClippingPlane2_it.png b/localwiki/ClippingPlane2_it.png new file mode 100644 index 0000000..17fe49c Binary files /dev/null and b/localwiki/ClippingPlane2_it.png differ diff --git a/localwiki/Clone.png b/localwiki/Clone.png new file mode 100644 index 0000000..eb8b328 Binary files /dev/null and b/localwiki/Clone.png differ diff --git a/localwiki/Closed_triangle_with_pointer_small.png b/localwiki/Closed_triangle_with_pointer_small.png new file mode 100644 index 0000000..b1338fa Binary files /dev/null and b/localwiki/Closed_triangle_with_pointer_small.png differ diff --git a/localwiki/Code_snippets.html b/localwiki/Code_snippets.html new file mode 100644 index 0000000..8b5c774 --- /dev/null +++ b/localwiki/Code_snippets.html @@ -0,0 +1,1124 @@ +Code snippets

      Code snippets

      + +
      + + + + + + + + + + + + + + + + + + + + + + + + + + + +
      +

      Base ExampleCommandModel.png Tutorial

      +
      Topic +
      Python +
      Level +
      Beginner +
      Time to complete +
      +
      Author +
      +
      FreeCAD version +
      +
      Example File(s) +
      +

      + +
      +


      +

      This page contains examples, pieces, chunks of FreeCAD python code collected from users experiences and discussions on the forums. Read and use it as a start for your own scripts... +


      +

      +

      A typical InitGui.py file

      +

      Every module must contain, besides your main module file, an InitGui.py file, responsible for inserting the module in the main Gui. This is an example of a simple one. +

      +
      class ScriptWorkbench (Workbench): 
      +    MenuText = "Scripts"
      +    def Initialize(self):
      +        import Scripts # assuming Scripts.py is your module
      +        list = ["Script_Cmd"] # That list must contain command names, that can be defined in Scripts.py
      +        self.appendToolbar("My Scripts",list) 
      +        
      +Gui.addWorkbench(ScriptWorkbench()) 
      +

      A typical module file

      +

      This is an example of a main module file, containing everything your module does. It is the Scripts.py file invoked by the previous example. You can have all your custom commands here. +

      +
      import FreeCAD, FreeCADGui 
      + 
      +class ScriptCmd: 
      +   def Activated(self): 
      +       # Here your write what your ScriptCmd does...
      +       FreeCAD.Console.PrintMessage('Hello, World!')
      +   def GetResources(self): 
      +       return {'Pixmap' : 'path_to_an_icon/myicon.png', 'MenuText': 'Short text', 'ToolTip': 'More detailed text'} 
      +       
      +FreeCADGui.addCommand('Script_Cmd', ScriptCmd()) 
      +

      Import a new filetype

      +

      Making an importer for a new filetype in FreeCAD is easy. FreeCAD doesn't consider that you import data in an opened document, but rather that you simply can directly open the new filetype. So what you need to do is to add the new file extension to FreeCAD's list of known extensions, and write the code that will read the file and create the FreeCAD objects you want: +

      This line must be added to the InitGui.py file to add the new file extension to the list: +

      +
      # Assumes Import_Ext.py is the file that has the code for opening and reading .ext files
      +FreeCAD.addImportType("Your new File Type (*.ext)","Import_Ext") 
      +

      Then in the Import_Ext.py file: +

      +
      def open(filename): 
      +   doc=App.newDocument()
      +   # here you do all what is needed with filename, read, classify data, create corresponding FreeCAD objects
      +   doc.recompute() 
      +

      To export your document to some new filetype works the same way, except that you use: +

      +
      FreeCAD.addExportType("Your new File Type (*.ext)","Export_Ext") 
      +
      +

      Adding a line

      +

      A line simply has 2 points. +

      +
      import Part,PartGui 
      +doc=App.activeDocument() 
      +# add a line element to the document and set its points 
      +l=Part.Line()
      +l.StartPoint=(0.0,0.0,0.0)
      +l.EndPoint=(1.0,1.0,1.0)
      +doc.addObject("Part::Feature","Line").Shape=l.toShape() 
      +doc.recompute() 
      +

      Adding a polygon

      +

      A polygon is simply a set of connected line segments (a polyline in AutoCAD). It doesn't need to be closed. +

      +
      import Part,PartGui 
      +doc=App.activeDocument()
      +n=list() 
      +# create a 3D vector, set its coordinates and add it to the list 
      +v=App.Vector(0,0,0) 
      +n.append(v) 
      +v=App.Vector(10,0,0) 
      +n.append(v) 
      +#... repeat for all nodes 
      +# Create a polygon object and set its nodes 
      +p=doc.addObject("Part::Polygon","Polygon") 
      +p.Nodes=n 
      +doc.recompute() 
      +

      Adding and removing an object to a group

      +
      doc=App.activeDocument() 
      +grp=doc.addObject("App::DocumentObjectGroup", "Group") 
      +lin=doc.addObject("Part::Feature", "Line")
      +grp.addObject(lin) # adds the lin object to the group grp
      +grp.removeObject(lin) # removes the lin object from the group grp 
      +

      Note: You can even add other groups to a group... +

      +

      Adding a Mesh

      +
      import Mesh
      +doc=App.activeDocument()
      +# create a new empty mesh
      +m = Mesh.Mesh()
      +# build up box out of 12 facets
      +m.addFacet(0.0,0.0,0.0, 0.0,0.0,1.0, 0.0,1.0,1.0)
      +m.addFacet(0.0,0.0,0.0, 0.0,1.0,1.0, 0.0,1.0,0.0)
      +m.addFacet(0.0,0.0,0.0, 1.0,0.0,0.0, 1.0,0.0,1.0)
      +m.addFacet(0.0,0.0,0.0, 1.0,0.0,1.0, 0.0,0.0,1.0)
      +m.addFacet(0.0,0.0,0.0, 0.0,1.0,0.0, 1.0,1.0,0.0)
      +m.addFacet(0.0,0.0,0.0, 1.0,1.0,0.0, 1.0,0.0,0.0)
      +m.addFacet(0.0,1.0,0.0, 0.0,1.0,1.0, 1.0,1.0,1.0)
      +m.addFacet(0.0,1.0,0.0, 1.0,1.0,1.0, 1.0,1.0,0.0)
      +m.addFacet(0.0,1.0,1.0, 0.0,0.0,1.0, 1.0,0.0,1.0)
      +m.addFacet(0.0,1.0,1.0, 1.0,0.0,1.0, 1.0,1.0,1.0)
      +m.addFacet(1.0,1.0,0.0, 1.0,1.0,1.0, 1.0,0.0,1.0)
      +m.addFacet(1.0,1.0,0.0, 1.0,0.0,1.0, 1.0,0.0,0.0)
      +# scale to a edge langth of 100
      +m.scale(100.0)
      +# add the mesh to the active document
      +me=doc.addObject("Mesh::Feature","Cube")
      +me.Mesh=m 
      +

      Adding an arc or a circle

      +
      import Part
      +doc = App.activeDocument()
      +c = Part.Circle() 
      +c.Radius=10.0  
      +f = doc.addObject("Part::Feature", "Circle") # create a document with a circle feature 
      +f.Shape = c.toShape() # Assign the circle shape to the shape property 
      +doc.recompute() 
      +

      Accessing and changing representation of an object

      +

      Each object in a FreeCAD document has an associated view representation object that stores all the parameters that define how the object appear, like color, linewidth, etc... +

      +
      gad=Gui.activeDocument()   # access the active document containing all 
      +                          # view representations of the features in the
      +                          # corresponding App document 
      +
      +v=gad.getObject("Cube")    # access the view representation to the Mesh feature 'Cube' 
      +v.ShapeColor               # prints the color to the console 
      +v.ShapeColor=(1.0,1.0,1.0) # sets the shape color to white 
      +

      Observing mouse events in the 3D viewer via Python

      +

      The Inventor framework allows to add one or more callback nodes to the scenegraph of the viewer. By default in FreeCAD one callback node is installed per viewer which allows to add global or static C++ functions. In the appropriate Python binding some methods are provided to make use of this technique from within Python code. +

      +
      App.newDocument()
      +v=Gui.activeDocument().activeView()
      + 
      +#This class logs any mouse button events. As the registered callback function fires twice for 'down' and
      +#'up' events we need a boolean flag to handle this.
      +class ViewObserver:
      +   def logPosition(self, info):
      +       down = (info["State"] == "DOWN")
      +       pos = info["Position"]
      +       if (down):
      +           FreeCAD.Console.PrintMessage("Clicked on position: ("+str(pos[0])+", "+str(pos[1])+")\n")
      +       
      +o = ViewObserver()
      +c = v.addEventCallback("SoMouseButtonEvent",o.logPosition) 
      +

      Now, pick somewhere on the area in the 3D viewer and observe the messages in the output window. To finish the observation just call +

      +
      v.removeEventCallback("SoMouseButtonEvent",c) 
      +

      The following event types are supported +

      +
      • SoEvent -- all kind of events
      • +
      • SoButtonEvent -- all mouse button and key events
      • +
      • SoLocation2Event -- 2D movement events (normally mouse movements)
      • +
      • SoMotion3Event -- 3D movement events (normally spaceball)
      • +
      • SoKeyboardEvent -- key down and up events
      • +
      • SoMouseButtonEvent -- mouse button down and up events
      • +
      • SoSpaceballButtonEvent -- spaceball button down and up events
      +

      The Python function that can be registered with addEventCallback() expects a dictionary. Depending on the watched event the dictionary can contain different keys. +

      For all events it has the keys: +

      +
      • Type -- the name of the event type i.e. SoMouseEvent, SoLocation2Event, ...
      • +
      • Time -- the current time as string
      • +
      • Position -- a tuple of two integers, mouse position
      • +
      • ShiftDown -- a boolean, true if Shift was pressed otherwise false
      • +
      • CtrlDown -- a boolean, true if Ctrl was pressed otherwise false
      • +
      • AltDown -- a boolean, true if Alt was pressed otherwise false
      +

      For all button events, i.e. keyboard, mouse or spaceball events +

      +
      • State -- A string 'UP' if the button was up, 'DOWN' if it was down or 'UNKNOWN' for all other cases
      +

      For keyboard events: +

      +
      • Key -- a character of the pressed key
      +

      For mouse button event +

      +
      • Button -- The pressed button, could be BUTTON1, ..., BUTTON5 or ANY
      +

      For spaceball events: +

      +
      • Button -- The pressed button, could be BUTTON1, ..., BUTTON7 or ANY
      +

      And finally motion events: +

      +
      • Translation -- a tuple of three floats
      • +
      • Rotation -- a quaternion for the rotation, i.e. a tuple of four floats
      +

      Display keys pressed and Events command

      +

      This macro displays in the report view the keys pressed and all events command +

      +
      App.newDocument()
      +v=Gui.activeDocument().activeView()
      +class ViewObserver:
      +   def logPosition(self, info):
      +       try:
      +           down = (info["Key"])
      +           FreeCAD.Console.PrintMessage(str(down)+"\n") # here the character pressed
      +           FreeCAD.Console.PrintMessage(str(info)+"\n") # list all events command
      +           FreeCAD.Console.PrintMessage("_______________________________________"+"\n")
      +       except Exception:
      +           None
      + 
      +o = ViewObserver()
      +c = v.addEventCallback("SoEvent",o.logPosition)
      +
      +#v.removeEventCallback("SoEvent",c) # remove ViewObserver
      +

      Manipulate the scenegraph in Python

      +

      It is also possible to get and change the scenegraph in Python, with the 'pivy' module -- a Python binding for Coin. +

      +
      from pivy.coin import *                # load the pivy module
      +view = Gui.ActiveDocument.ActiveView   # get the active viewer
      +root = view.getSceneGraph()            # the root is an SoSeparator node
      +root.addChild(SoCube())
      +view.fitAll() 
      +

      The Python API of pivy is created by using the tool SWIG. As we use in FreeCAD some self-written nodes you cannot create them directly in Python. +However, it is possible to create a node by its internal name. An instance of the type 'SoFCSelection' can be created with +

      +
      type = SoType.fromName("SoFCSelection")
      +node = type.createInstance() 
      +

      Adding and removing objects to/from the scenegraph

      +

      Adding new nodes to the scenegraph can be done this way. Take care of always adding a SoSeparator to contain the geometry, coordinates and material info of a same object. The following example adds a red line from (0,0,0) to (10,0,0): +

      +
      from pivy import coin
      +sg = Gui.ActiveDocument.ActiveView.getSceneGraph()
      +co = coin.SoCoordinate3()
      +pts = [[0,0,0],[10,0,0]]
      +co.point.setValues(0,len(pts),pts)
      +ma = coin.SoBaseColor()
      +ma.rgb = (1,0,0)
      +li = coin.SoLineSet()
      +li.numVertices.setValue(2)
      +no = coin.SoSeparator()
      +no.addChild(co)
      +no.addChild(ma)
      +no.addChild(li)
      +sg.addChild(no) 
      +

      To remove it, simply issue: +

      +
      sg.removeChild(no) 
      +

      Saves the sceneGraph with a rotation in a series of 36 files in the X Y Z axis

      +
      import math
      +import time
      +from FreeCAD import Base
      +from pivy import coin
      +
      +size=(1000,1000)
      +dirname = "C:/Temp/animation/"
      +steps=36
      +angle=2*math.pi/steps
      +
      +matX=Base.Matrix()
      +matX.rotateX(angle)
      +stepsX=Base.Placement(matX).Rotation
      +
      +matY=Base.Matrix()
      +matY.rotateY(angle)
      +stepsY=Base.Placement(matY).Rotation
      +
      +matZ=Base.Matrix()
      +matZ.rotateZ(angle)
      +stepsZ=Base.Placement(matZ).Rotation
      +
      +view=Gui.ActiveDocument.ActiveView
      +cam=view.getCameraNode()
      +rotCamera=Base.Rotation(*cam.orientation.getValue().getValue())
      +
      +# this sets the lookat point to the center of circumsphere of the global bounding box
      +view.fitAll()
      +
      +# the camera's position, i.e. the user's eye point
      +position=Base.Vector(*cam.position.getValue().getValue())
      +distance=cam.focalDistance.getValue()
      +
      +# view direction
      +vec=rotCamera.multVec(Base.Vector(0,0,-1))
      +
      +# this is the point on the screen the camera looks at
      +# when rotating the camera we should make this point fix
      +lookat=position+vec*distance
      +
      +# around x axis
      +for i in range(steps):
      +    rotCamera=stepsX.multiply(rotCamera)
      +    cam.orientation.setValue(*rotCamera.Q)
      +    vec=rotCamera.multVec(Base.Vector(0,0,-1))
      +    pos=lookat-vec*distance
      +    cam.position.setValue(pos.x,pos.y,pos.z)
      +    Gui.updateGui()
      +    time.sleep(0.3)
      +    view.saveImage(dirname+"x-%d.png" % i,*size)
      +
      +# around y axis
      +for i in range(steps):
      +    rotCamera=stepsY.multiply(rotCamera)
      +    cam.orientation.setValue(*rotCamera.Q)
      +    vec=rotCamera.multVec(Base.Vector(0,0,-1))
      +    pos=lookat-vec*distance
      +    cam.position.setValue(pos.x,pos.y,pos.z)
      +    Gui.updateGui()
      +    time.sleep(0.3)
      +    view.saveImage(dirname+"y-%d.png" % i,*size)
      +
      +# around z axis
      +for i in range(steps):
      +    rotCamera=stepsZ.multiply(rotCamera)
      +    cam.orientation.setValue(*rotCamera.Q)
      +    vec=rotCamera.multVec(Base.Vector(0,0,-1))
      +    pos=lookat-vec*distance
      +    cam.position.setValue(pos.x,pos.y,pos.z)
      +    Gui.updateGui()
      +    time.sleep(0.3)
      +    view.saveImage(dirname+"z-%d.png" % i,*size) 
      +

      Adding custom widgets to the interface

      +

      You can create custom widgets with Qt designer, transform them into a python script, and then load them into the FreeCAD interface with PySide. +

      The python code produced by the Ui python compiler (the tool that converts qt-designer .ui files into python code) generally looks like this (it is simple, you can also code it directly in python): +

      +
      class myWidget_Ui(object):
      + def setupUi(self, myWidget):
      +   myWidget.setObjectName("my Nice New Widget")
      +   myWidget.resize(QtCore.QSize(QtCore.QRect(0,0,300,100).size()).expandedTo(myWidget.minimumSizeHint())) # sets size of the widget
      + 
      +   self.label = QtGui.QLabel(myWidget) # creates a label
      +   self.label.setGeometry(QtCore.QRect(50,50,200,24)) # sets its size
      +   self.label.setObjectName("label") # sets its name, so it can be found by name
      +
      + def retranslateUi(self, draftToolbar): # built-in QT function that manages translations of widgets
      +   myWidget.setWindowTitle(QtGui.QApplication.translate("myWidget", "My Widget", None, QtGui.QApplication.UnicodeUTF8))
      +   self.label.setText(QtGui.QApplication.translate("myWidget", "Welcome to my new widget!", None, QtGui.QApplication.UnicodeUTF8)) 
      +

      Then, all you need to do is to create a reference to the FreeCAD Qt window, insert a custom widget into it, and "transform" this widget into yours with the Ui code we just made: +

      +
      app = QtGui.qApp
      +FCmw = app.activeWindow() # the active qt window, = the freecad window since we are inside it
      +# FCmw = FreeCADGui.getMainWindow() # use this line if the 'addDockWidget' error is declared
      +myNewFreeCADWidget = QtGui.QDockWidget() # create a new dckwidget
      +myNewFreeCADWidget.ui = myWidget_Ui() # load the Ui script
      +myNewFreeCADWidget.ui.setupUi(myNewFreeCADWidget) # setup the ui
      +FCmw.addDockWidget(QtCore.Qt.RightDockWidgetArea,myNewFreeCADWidget) # add the widget to the main window 
      +

      Adding a Tab to the Combo View

      +

      The following code allows you to add a tab to the FreeCAD ComboView, besides the "Project" and "Tasks" tabs. It also uses the uic module to load an ui file directly in that tab. +

      +
      # create new Tab in ComboView
      +from PySide import QtGui,QtCore
      +#from PySide import uic
      +
      +def getMainWindow():
      +   "returns the main window"
      +   # using QtGui.qApp.activeWindow() isn't very reliable because if another
      +   # widget than the mainwindow is active (e.g. a dialog) the wrong widget is
      +   # returned
      +   toplevel = QtGui.qApp.topLevelWidgets()
      +   for i in toplevel:
      +       if i.metaObject().className() == "Gui::MainWindow":
      +           return i
      +   raise Exception("No main window found")
      +
      +def getComboView(mw):
      +   dw=mw.findChildren(QtGui.QDockWidget)
      +   for i in dw:
      +       if str(i.objectName()) == "Combo View":
      +           return i.findChild(QtGui.QTabWidget)
      +       elif str(i.objectName()) == "Python Console":
      +           return i.findChild(QtGui.QTabWidget)
      +   raise Exception ("No tab widget found")
      +
      +mw = getMainWindow()
      +tab = getComboView(getMainWindow())
      +tab2=QtGui.QDialog()
      +tab.addTab(tab2,"A Special Tab")
      +
      +#uic.loadUi("/myTaskPanelforTabs.ui",tab2)
      +tab2.show()
      +#tab.removeTab(2) 
      +

      Enable or disable a window

      +
      from PySide import QtGui
      +mw=FreeCADGui.getMainWindow()
      +dws=mw.findChildren(QtGui.QDockWidget)
      +
      +# objectName may be :
      +# "Report view"
      +# "Tree view"
      +# "Property view"
      +# "Selection view"
      +# "Combo View"
      +# "Python console"
      +# "draftToolbar"
      +
      +for i in dws:
      +  if i.objectName() == "Report view":
      +    dw=i
      +    break
      +
      +va=dw.toggleViewAction()
      +va.setChecked(True)        # True or False
      +dw.setVisible(True)        # True or False 
      +

      Opening a custom webpage

      +
      import WebGui
      +WebGui.openBrowser("http://www.example.com") 
      +

      Getting the HTML contents of an opened webpage

      +
      from PyQt4 import QtGui,QtWebKit
      +a = QtGui.qApp
      +mw = a.activeWindow()
      +v = mw.findChild(QtWebKit.QWebFrame)
      +html = unicode(v.toHtml())
      +print html 
      +

      Retrieve and use the coordinates of 3 selected points or objects

      +
      # -*- coding: utf-8 -*-
      +# the line above to put the accentuated in the remarks
      +# If this line is missing, an error will be returned
      +# extract and use the coordinates of 3 objects selected
      +import Part, FreeCAD, math, PartGui, FreeCADGui
      +from FreeCAD import Base, Console
      +sel = FreeCADGui.Selection.getSelection() # " sel " contains the items selected
      +if len(sel)!=3 :
      +  # If there are no 3 objects selected, an error is displayed in the report view
      +  # The \r and \n at the end of line mean return and the newline CR + LF.
      +  Console.PrintError("Select 3 points exactly\r\n")
      +else :
      +  points=[]
      +  for obj in sel:
      +    points.append(obj.Shape.BoundBox.Center)
      +
      +  for pt in points:
      +    # display of the coordinates in the report view
      +    Console.PrintMessage(str(pt.x)+"\r\n")
      +    Console.PrintMessage(str(pt.y)+"\r\n")
      +    Console.PrintMessage(str(pt.z)+"\r\n")
      +
      +  Console.PrintMessage(str(pt[1]) + "\r\n") 
      +

      List all objects

      +
      # -*- coding: utf-8 -*-
      +import FreeCAD,Draft
      +# List all objects of the document
      +doc = FreeCAD.ActiveDocument
      +objs = FreeCAD.ActiveDocument.Objects
      +#App.Console.PrintMessage(str(objs) + "\n")
      +#App.Console.PrintMessage(str(len(FreeCAD.ActiveDocument.Objects)) + " Objects"  + "\n")
      +
      +for obj in objs:
      +    a = obj.Name                                             # list the Name  of the object  (not modifiable)
      +    b = obj.Label                                            # list the Label of the object  (modifiable)
      +    try:
      +        c = obj.LabelText                                    # list the LabeText of the text (modifiable)
      +        App.Console.PrintMessage(str(a) +" "+ str(b) +" "+ str(c) + "\n") # Displays the Name the Label and the text
      +    except:
      +        App.Console.PrintMessage(str(a) +" "+ str(b) + "\n") # Displays the Name and the Label of the object
      +
      +#doc.removeObject("Box") # Clears the designated object 
      +

      List the dimensions of an object, given its name

      +
      for edge in FreeCAD.ActiveDocument.MyObjectName.Shape.Edges: # replace "MyObjectName" for list
      +    print edge.Length
      +


      +

      +

      Function resident with the mouse click action

      +

      Here with SelObserver on a object select +

      +
      # -*- coding: utf-8 -*-
      +# causes an action to the mouse click on an object
      +# This function remains resident (in memory) with the function "addObserver(s)"
      +# "removeObserver(s) # Uninstalls the resident function
      +class SelObserver:
      +    def setPreselection(self,doc,obj,sub):                # Preselection object
      +        App.Console.PrintMessage(str(sub)+ "\n")          # The part of the object name
      +
      +    def addSelection(self,doc,obj,sub,pnt):               # Selection object
      +        App.Console.PrintMessage("addSelection"+ "\n")
      +        App.Console.PrintMessage(str(doc)+ "\n")          # Name of the document
      +        App.Console.PrintMessage(str(obj)+ "\n")          # Name of the object
      +        App.Console.PrintMessage(str(sub)+ "\n")          # The part of the object name
      +        App.Console.PrintMessage(str(pnt)+ "\n")          # Coordinates of the object
      +        App.Console.PrintMessage("______"+ "\n")
      +
      +    def removeSelection(self,doc,obj,sub):                # Delete the selected object
      +        App.Console.PrintMessage("removeSelection"+ "\n")
      +
      +    def setSelection(self,doc):                           # Selection in ComboView
      +        App.Console.PrintMessage("setSelection"+ "\n")
      +
      +    def clearSelection(self,doc):                         # If click on the screen, clear the selection
      +        App.Console.PrintMessage("clearSelection"+ "\n")  # If click on another object, clear the previous object
      +s =SelObserver()
      +FreeCADGui.Selection.addObserver(s)                       # install the function mode resident
      +#FreeCADGui.Selection.removeObserver(s)                   # Uninstall the resident function 
      +

      Other example with ViewObserver on a object select or view +

      +
      App.newDocument()
      +v=Gui.activeDocument().activeView()
      + 
      +#This class logs any mouse button events. As the registered callback function fires twice for 'down' and
      +#'up' events we need a boolean flag to handle this.
      +class ViewObserver:
      +   def __init__(self, view):
      +       self.view = view
      +   
      +   def logPosition(self, info):
      +       down = (info["State"] == "DOWN")
      +       pos = info["Position"]
      +       if (down):
      +           FreeCAD.Console.PrintMessage("Clicked on position: ("+str(pos[0])+", "+str(pos[1])+")\n")
      +           pnt = self.view.getPoint(pos)
      +           FreeCAD.Console.PrintMessage("World coordinates: " + str(pnt) + "\n")
      +           info = self.view.getObjectInfo(pos)
      +           FreeCAD.Console.PrintMessage("Object info: " + str(info) + "\n")
      +
      +o = ViewObserver(v)
      +c = v.addEventCallback("SoMouseButtonEvent",o.logPosition)
      +

      Finding-selecting all elements below cursor

      +
      from pivy import coin
      +import FreeCADGui
      +
      +def mouse_over_cb( event_callback):
      +    event = event_callback.getEvent()
      +    pos = event.getPosition().getValue()
      +    listObjects = FreeCADGui.ActiveDocument.ActiveView.getObjectsInfo((int(pos[0]),int(pos[1])))
      +    obj = []
      +    if listObjects:
      +        FreeCAD.Console.PrintMessage("\n *** Objects under mouse pointer ***")
      +        for o in listObjects:
      +            label = str(o["Object"])
      +            if not label in obj:
      +                obj.append(label)
      +        FreeCAD.Console.PrintMessage("\n"+str(obj))
      +
      +
      +view = FreeCADGui.ActiveDocument.ActiveView
      +
      +mouse_over = view.addEventCallbackPivy( coin.SoLocation2Event.getClassTypeId(), mouse_over_cb )
      +
      +# to remove Callback :
      +#view.removeEventCallbackPivy( coin.SoLocation2Event.getClassTypeId(), mouse_over)
      +
      +####
      +#The easy way is probably to use FreeCAD's selection.
      +#FreeCADGui.ActiveDocument.ActiveView.getObjectsInfo(mouse_coords)
      +
      +####
      +#you get that kind of result :
      +#'Document': 'Unnamed', 'Object': 'Box', 'Component': 'Face2', 'y': 8.604081153869629, 'x': 21.0, 'z': 8.553047180175781
      +
      +####
      +#You can use this data to add your element to FreeCAD's selection :
      +#FreeCADGui.Selection.addSelection(FreeCAD.ActiveDocument.Box,'Face2',21.0,8.604081153869629,8.553047180175781) 
      +

      List the components of an object

      +
      # -*- coding: utf-8 -*-
      +# This function list the components of an object
      +# and extract this object its XYZ coordinates,
      +# its edges and their lengths center of mass and coordinates
      +# its faces and their center of mass
      +# its faces and their surfaces and coordinates
      +# 8/05/2014
      +
      +import Draft,Part
      +def detail():
      +    sel = FreeCADGui.Selection.getSelection()   # Select an object
      +    if len(sel) != 0:                           # If there is a selection then
      +        Vertx=[]
      +        Edges=[]
      +        Faces=[]
      +        compt_V=0
      +        compt_E=0
      +        compt_F=0
      +        pas    =0
      +        perimetre = 0.0   
      +        EdgesLong = []
      +
      +        # Displays the "Name" and the "Label" of the selection
      +        App.Console.PrintMessage("Selection > " + str(sel[0].Name) + "  " + str(sel[0].Label) +"\n"+"\n")
      +
      +        for j in enumerate(sel[0].Shape.Edges):                                     # Search the "Edges" and their lengths
      +            compt_E+=1
      +            Edges.append("Edge%d" % (j[0]+1))
      +            EdgesLong.append(str(sel[0].Shape.Edges[compt_E-1].Length))
      +            perimetre += (sel[0].Shape.Edges[compt_E-1].Length)                     # calculates the perimeter
      +
      +            # Displays the "Edge" and its length
      +            App.Console.PrintMessage("Edge"+str(compt_E)+" Length > "+str(sel[0].Shape.Edges[compt_E-1].Length)+"\n")
      +
      +            # Displays the "Edge" and its center mass
      +            App.Console.PrintMessage("Edge"+str(compt_E)+" Center > "+str(sel[0].Shape.Edges[compt_E-1].CenterOfMass)+"\n")
      +
      +            num = sel[0].Shape.Edges[compt_E-1].Vertexes[0]
      +            Vertx.append("X1: "+str(num.Point.x))
      +            Vertx.append("Y1: "+str(num.Point.y))
      +            Vertx.append("Z1: "+str(num.Point.z))
      +            # Displays the coordinates 1
      +            App.Console.PrintMessage("X1: "+str(num.Point[0])+" Y1: "+str(num.Point[1])+" Z1: "+str(num.Point[2])+"\n")
      +
      +            try:
      +                num = sel[0].Shape.Edges[compt_E-1].Vertexes[1]
      +                Vertx.append("X2: "+str(num.Point.x))
      +                Vertx.append("Y2: "+str(num.Point.y))
      +                Vertx.append("Z2: "+str(num.Point.z))
      +            except:
      +                Vertx.append("-")
      +                Vertx.append("-")
      +                Vertx.append("-")
      +            # Displays the coordinates 2
      +            App.Console.PrintMessage("X2: "+str(num.Point[0])+" Y2: "+str(num.Point[1])+" Z2: "+str(num.Point[2])+"\n")
      +
      +            App.Console.PrintMessage("\n")
      +        App.Console.PrintMessage("Perimeter of the form  : "+str(perimetre)+"\n") 
      +
      +        App.Console.PrintMessage("\n")
      +        FacesSurf = []
      +        for j in enumerate(sel[0].Shape.Faces):                                      # Search the "Faces" and their surface
      +            compt_F+=1
      +            Faces.append("Face%d" % (j[0]+1))
      +            FacesSurf.append(str(sel[0].Shape.Faces[compt_F-1].Area))
      +
      +            # Displays 'Face' and its surface
      +            App.Console.PrintMessage("Face"+str(compt_F)+" >  Surface "+str(sel[0].Shape.Faces[compt_F-1].Area)+"\n")
      +
      +            # Displays 'Face' and its CenterOfMass
      +            App.Console.PrintMessage("Face"+str(compt_F)+" >  Center  "+str(sel[0].Shape.Faces[compt_F-1].CenterOfMass)+"\n")
      +
      +            # Displays 'Face' and its Coordinates
      +            FacesCoor = []
      +            fco = 0
      +            for f0 in sel[0].Shape.Faces[compt_F-1].Vertexes:                        # Search the Vertexes of the face
      +                fco += 1
      +                FacesCoor.append("X"+str(fco)+": "+str(f0.Point.x))
      +                FacesCoor.append("Y"+str(fco)+": "+str(f0.Point.y))
      +                FacesCoor.append("Z"+str(fco)+": "+str(f0.Point.z))
      +
      +            # Displays 'Face' and its Coordinates
      +            App.Console.PrintMessage("Face"+str(compt_F)+" >  Coordinate"+str(FacesCoor)+"\n")
      +
      +            # Displays 'Face' and its Volume
      +            App.Console.PrintMessage("Face"+str(compt_F)+" >  Volume  "+str(sel[0].Shape.Faces[compt_F-1].Volume)+"\n")
      +            App.Console.PrintMessage("\n")
      +
      +        # Displays the total surface of the form
      +        App.Console.PrintMessage("Surface of the form    : "+str(sel[0].Shape.Area)+"\n")
      +
      +        # Displays the total Volume of the form
      +        App.Console.PrintMessage("Volume  of the form    : "+str(sel[0].Shape.Volume)+"\n")
      +
      +detail() 
      +

      List the PropertiesList

      +
      import FreeCADGui
      +from FreeCAD import Console
      +o = App.ActiveDocument.ActiveObject
      +op = o.PropertiesList
      +for p in op:
      +    Console.PrintMessage("Property: "+ str(p)+ " Value: " + str(o.getPropertyByName(p))+"\r\n") 
      +

      Adding one Property "Comment"

      +
      import Draft
      +obj = FreeCADGui.Selection.getSelection()[0]
      +obj.addProperty("App::PropertyString","GComment","Draft","Font name").GComment = "Comment here"
      +App.activeDocument().recompute() 
      +

      Search and data extraction

      +

      Examples of research and decoding information on an object. +

      Each section is independently and is separated by "############" can be copied directly into the Python console, or in a macro or use this macro. The description of the macro in the commentary. +

      Displaying it in the "View Report" window (View > Views > View report) +

      +
      # -*- coding: utf-8 -*-
      +from __future__ import unicode_literals
      + 
      +# Exemples de recherche et de decodage d'informations sur un objet
      +# Chaque section peut etre copiee directement dans la console Python ou dans une macro ou utilisez la macro tel quel
      +# Certaines commandes se repetent seul l'approche est differente
      +# L'affichage se fait dans la Vue rapport : Menu Affichage > Vues > Vue rapport
      +#
      +# Examples of research and decoding information on an object
      +# Each section can be copied directly into the Python console, or in a macro or uses this macro
      +# Certain commands as repeat alone approach is different
      +# Displayed on Report view : Menu View > Views > report view
      +#
      +# rev:30/08/2014:29/09/2014:17/09/2015
      + 
      +from FreeCAD import Base
      +import DraftVecUtils, Draft, Part
      + 
      +mydoc = FreeCAD.activeDocument().Name                                     # Name of active Document
      +App.Console.PrintMessage("Active docu    : "+(mydoc)+"\n")
      +##################################################################################
      + 
      +sel = FreeCADGui.Selection.getSelection()                                 # select object with getSelection()
      +object_Label = sel[0].Label                                               # Label of the object (modifiable)
      +App.Console.PrintMessage("object_Label   : "+(object_Label)+"\n")
      +##################################################################################
      + 
      +sel = FreeCADGui.Selection.getSelection()                                 # select object with getSelection()
      +App.Console.PrintMessage("sel            : "+str(sel[0])+"\n\n")          # sel[0] first object selected
      +##################################################################################
      + 
      +sel = FreeCADGui.Selection.getSelection()                                 # select object with getSelection()
      +object_Name  = sel[0].Name                                                # Name of the object (not modifiable)
      +App.Console.PrintMessage("object_Name    : "+str(object_Name)+"\n\n")
      +##################################################################################
      + 
      +try:
      +    SubElement = FreeCADGui.Selection.getSelectionEx()                    # sub element name with getSelectionEx()
      +    element_ = SubElement[0].SubElementNames[0]                           # name of 1 element selected
      +    App.Console.PrintMessage("elementSelec   : "+str(element_)+"\n\n")            
      +except:
      +    App.Console.PrintMessage("Oups"+"\n\n")            
      +##################################################################################
      + 
      +sel = FreeCADGui.Selection.getSelection()                                 # select object with getSelection()
      +App.Console.PrintMessage("sel            : "+str(sel[0])+"\n\n")          # sel[0] first object selected
      +##################################################################################
      + 
      +SubElement = FreeCADGui.Selection.getSelectionEx()                        # sub element name with getSelectionEx()
      +App.Console.PrintMessage("SubElement     : "+str(SubElement[0])+"\n\n")   # name of sub element
      +##################################################################################
      + 
      +sel = FreeCADGui.Selection.getSelection()                                 # select object with getSelection()
      +i = 0
      +for j in enumerate(sel[0].Shape.Edges):                                   # list all Edges
      +    i += 1
      +    App.Console.PrintMessage("Edges n : "+str(i)+"\n")
      +    a = sel[0].Shape.Edges[j[0]].Vertexes[0]
      +    App.Console.PrintMessage("X1             : "+str(a.Point.x)+"\n")     # coordinate XYZ first point
      +    App.Console.PrintMessage("Y1             : "+str(a.Point.y)+"\n")
      +    App.Console.PrintMessage("Z1             : "+str(a.Point.z)+"\n")
      +    try:
      +        a = sel[0].Shape.Edges[j[0]].Vertexes[1]
      +        App.Console.PrintMessage("X2             : "+str(a.Point.x)+"\n") # coordinate XYZ second point
      +        App.Console.PrintMessage("Y2             : "+str(a.Point.y)+"\n")
      +        App.Console.PrintMessage("Z2             : "+str(a.Point.z)+"\n")
      +    except:
      +        App.Console.PrintMessage("Oups"+"\n")    
      +App.Console.PrintMessage("\n")    
      +##################################################################################
      + 
      +try:
      +    SubElement = FreeCADGui.Selection.getSelectionEx()                                        # sub element name with getSelectionEx()
      +    subElementName = Gui.Selection.getSelectionEx()[0].SubElementNames[0]                     # sub element name with getSelectionEx()
      +    App.Console.PrintMessage("subElementName : "+str(subElementName)+"\n")
      +    
      +    subObjectLength = Gui.Selection.getSelectionEx()[0].SubObjects[0].Length                  # sub element Length
      +    App.Console.PrintMessage("subObjectLength: "+str(subObjectLength)+"\n\n")
      +    
      +    subObjectX1 = Gui.Selection.getSelectionEx()[0].SubObjects[0].Vertexes[0].Point.x         # sub element coordinate X1
      +    App.Console.PrintMessage("subObject_X1   : "+str(subObjectX1)+"\n")
      +    subObjectY1 = Gui.Selection.getSelectionEx()[0].SubObjects[0].Vertexes[0].Point.y         # sub element coordinate Y1
      +    App.Console.PrintMessage("subObject_Y1   : "+str(subObjectY1)+"\n")
      +    subObjectZ1 = Gui.Selection.getSelectionEx()[0].SubObjects[0].Vertexes[0].Point.z         # sub element coordinate Z1
      +    App.Console.PrintMessage("subObject_Z1   : "+str(subObjectZ1)+"\n\n")
      +    
      +    subObjectX2 = Gui.Selection.getSelectionEx()[0].SubObjects[0].Vertexes[1].Point.x         # sub element coordinate X2
      +    App.Console.PrintMessage("subObject_X2   : "+str(subObjectX2)+"\n")
      +    subObjectY2 = Gui.Selection.getSelectionEx()[0].SubObjects[0].Vertexes[1].Point.y         # sub element coordinate Y2
      +    App.Console.PrintMessage("subObject_Y2   : "+str(subObjectY2)+"\n")
      +    subObjectZ2 = Gui.Selection.getSelectionEx()[0].SubObjects[0].Vertexes[1].Point.z         # sub element coordinate Z2
      +    App.Console.PrintMessage("subObject_Z2   : "+str(subObjectZ2)+"\n\n")
      +    
      +    subObjectBoundBox = Gui.Selection.getSelectionEx()[0].SubObjects[0].BoundBox              # sub element BoundBox coordinates
      +    App.Console.PrintMessage("subObjectBBox  : "+str(subObjectBoundBox)+"\n")
      +    
      +    subObjectBoundBoxCenter = Gui.Selection.getSelectionEx()[0].SubObjects[0].BoundBox.Center # sub element BoundBoxCenter
      +    App.Console.PrintMessage("subObjectBBoxCe: "+str(subObjectBoundBoxCenter)+"\n")
      +    
      +    surfaceFace = Gui.Selection.getSelectionEx()[0].SubObjects[0].Area                        # Area of the face selected
      +    App.Console.PrintMessage("surfaceFace    : "+str(surfaceFace)+"\n\n")
      +except:
      +    App.Console.PrintMessage("Oups"+"\n\n")            
      +##################################################################################
      + 
      +sel = FreeCADGui.Selection.getSelection()                                 # select object with getSelection()
      +surface = sel[0].Shape.Area                                               # Area object complete
      +App.Console.PrintMessage("surfaceObjet   : "+str(surface)+"\n\n")
      +##################################################################################
      + 
      +sel = FreeCADGui.Selection.getSelection()                                 # select object with getSelection()
      +CenterOfMass = sel[0].Shape.CenterOfMass                                  # Center of Mass of the object
      +App.Console.PrintMessage("CenterOfMass   : "+str(CenterOfMass)+"\n")
      +App.Console.PrintMessage("CenterOfMassX  : "+str(CenterOfMass[0])+"\n")   # coordinates [0]=X [1]=Y [2]=Z
      +App.Console.PrintMessage("CenterOfMassY  : "+str(CenterOfMass[1])+"\n")
      +App.Console.PrintMessage("CenterOfMassZ  : "+str(CenterOfMass[2])+"\n\n")
      +##################################################################################
      + 
      +sel = FreeCADGui.Selection.getSelection()                                 # select object with getSelection()
      +for j in enumerate(sel[0].Shape.Faces):                                   # List alles faces of the object
      +    App.Console.PrintMessage("Face           : "+str("Face%d" % (j[0]+1))+"\n")
      +App.Console.PrintMessage("\n\n")
      +##################################################################################
      + 
      +sel = FreeCADGui.Selection.getSelection()                                 # select object with getSelection()
      +volume_ = sel[0].Shape.Volume                                             # Volume of the object
      +App.Console.PrintMessage("volume_        : "+str(volume_)+"\n\n")
      +##################################################################################
      + 
      +sel = FreeCADGui.Selection.getSelection()                                 # select object with getSelection()
      +boundBox_= sel[0].Shape.BoundBox                                          # BoundBox of the object
      +App.Console.PrintMessage("boundBox_      : "+str(boundBox_)+"\n")
      + 
      +boundBoxLX  = boundBox_.XLength                                           # Length x boundBox rectangle
      +boundBoxLY  = boundBox_.YLength                                           # Length y boundBox rectangle
      +boundBoxLZ  = boundBox_.ZLength                                           # Length z boundBox rectangle
      +boundBoxDiag= boundBox_.DiagonalLength                                    # Diagonal Length boundBox rectangle
      +
      +App.Console.PrintMessage("boundBoxLX     : "+str(boundBoxLX)+"\n")
      +App.Console.PrintMessage("boundBoxLY     : "+str(boundBoxLY)+"\n")
      +App.Console.PrintMessage("boundBoxLZ     : "+str(boundBoxLZ)+"\n")
      +App.Console.PrintMessage("boundBoxDiag   : "+str(boundBoxDiag)+"\n\n")
      +##################################################################################
      + 
      +sel = FreeCADGui.Selection.getSelection()                                 # select object with getSelection()
      +pl = sel[0].Shape.Placement                                               # Placement Vector XYZ and Yaw-Pitch-Roll
      +App.Console.PrintMessage("Placement      : "+str(pl)+"\n")
      +##################################################################################
      + 
      +sel = FreeCADGui.Selection.getSelection()                                 # select object with getSelection()
      +pl = sel[0].Shape.Placement.Base                                          # Placement Vector XYZ
      +App.Console.PrintMessage("PlacementBase  : "+str(pl)+"\n\n")
      +##################################################################################
      + 
      +sel = FreeCADGui.Selection.getSelection()                                 # select object with getSelection()
      +Yaw = sel[0].Shape.Placement.Rotation.toEuler()[0]                        # decode angle Euler Yaw
      +App.Console.PrintMessage("Yaw            : "+str(Yaw)+"\n")
      +Pitch = sel[0].Shape.Placement.Rotation.toEuler()[1]                      # decode angle Euler Pitch
      +App.Console.PrintMessage("Pitch          : "+str(Pitch)+"\n")
      +Roll = sel[0].Shape.Placement.Rotation.toEuler()[2]                       # decode angle Euler Yaw
      +App.Console.PrintMessage("Roll           : "+str(Roll)+"\n\n")
      +##################################################################################
      + 
      +sel = FreeCADGui.Selection.getSelection()                                 # select object with getSelection()
      +oripl_X = sel[0].Placement.Base[0]                                        # decode Placement X
      +oripl_Y = sel[0].Placement.Base[1]                                        # decode Placement Y
      +oripl_Z = sel[0].Placement.Base[2]                                        # decode Placement Z
      + 
      +App.Console.PrintMessage("oripl_X        : "+str(oripl_X)+"\n")
      +App.Console.PrintMessage("oripl_Y        : "+str(oripl_Y)+"\n")
      +App.Console.PrintMessage("oripl_Z        : "+str(oripl_Z)+"\n\n")
      +##################################################################################
      + 
      +sel = FreeCADGui.Selection.getSelection()                                 # select object with getSelection()
      +rotation = sel[0].Placement.Rotation                                      # decode Placement Rotation
      +App.Console.PrintMessage("rotation              : "+str(rotation)+"\n\n")
      +##################################################################################
      + 
      +sel = FreeCADGui.Selection.getSelection()                                 # select object with getSelection()
      +pl = sel[0].Shape.Placement.Rotation                                      # decode Placement Rotation other method
      +App.Console.PrintMessage("Placement Rot         : "+str(pl)+"\n\n")
      +##################################################################################
      + 
      +sel = FreeCADGui.Selection.getSelection()                                 # select object with getSelection()
      +pl = sel[0].Shape.Placement.Rotation.Angle                                # decode Placement Rotation Angle
      +App.Console.PrintMessage("Placement Rot Angle   : "+str(pl)+"\n\n")
      +##################################################################################
      + 
      +sel = FreeCADGui.Selection.getSelection()                                 # select object with getSelection()
      +Rot_0 = sel[0].Placement.Rotation.Q[0]                                    # decode Placement Rotation 0
      +App.Console.PrintMessage("Rot_0         : "+str(Rot_0)+ " rad ,  "+str(180 * Rot_0 / 3.1416)+" deg "+"\n")
      + 
      +Rot_1 = sel[0].Placement.Rotation.Q[1]                                    # decode Placement Rotation 1
      +App.Console.PrintMessage("Rot_1         : "+str(Rot_1)+ " rad ,  "+str(180 * Rot_1 / 3.1416)+" deg "+"\n")
      + 
      +Rot_2 = sel[0].Placement.Rotation.Q[2]                                    # decode Placement Rotation 2
      +App.Console.PrintMessage("Rot_2         : "+str(Rot_2)+ " rad ,  "+str(180 * Rot_2 / 3.1416)+" deg "+"\n")
      + 
      +Rot_3 = sel[0].Placement.Rotation.Q[3]                                    # decode Placement Rotation 3
      +App.Console.PrintMessage("Rot_3         : "+str(Rot_3)+"\n\n")
      +################################################################################## 
      +

      Manual search of an element with label

      +
      # Extract the coordinate X,Y,Z and Angle giving the label 
      +App.Console.PrintMessage("Base.x       : "+str(FreeCAD.ActiveDocument.getObjectsByLabel("Cylindre")[0].Placement.Base.x)+"\n")
      +App.Console.PrintMessage("Base.y       : "+str(FreeCAD.ActiveDocument.getObjectsByLabel("Cylindre")[0].Placement.Base.y)+"\n")
      +App.Console.PrintMessage("Base.z       : "+str(FreeCAD.ActiveDocument.getObjectsByLabel("Cylindre")[0].Placement.Base.z)+"\n")
      +App.Console.PrintMessage("Base.Angle   : "+str(FreeCAD.ActiveDocument.getObjectsByLabel("Cylindre")[0].Placement.Rotation.Angle)+"\n\n")
      +################################################################################## 
      +

      PS: Usually the angles are given in Radian to convert : +

      +
      1. angle in Degrees to Radians : +
        • Angle in radian = pi * (angle in degree) / 180
        • +
        • Angle in radian = math.radians(angle in degree)
      2. +
      3. angle in Radians to Degrees : +
        • Angle in degree = 180 * (angle in radian) / pi
        • +
        • Angle in degree = math.degrees(angle in radian)
      +

      Cartesian coordinates

      +

      This code displays the Cartesian coordinates of the selected item. +

      Change the value of "numberOfPoints" if you want a different number of points (precision) +

      +
      numberOfPoints = 100                                                         # Decomposition number (or precision you can change)
      +selectedEdge = FreeCADGui.Selection.getSelectionEx()[0].SubObjects[0].copy() # select one element
      +points  = selectedEdge.discretize(numberOfPoints)                            # discretize the element
      +i=0
      +for p in points:                                                             # list and display the coordinates
      +    i+=1
      +    print i, " X", p.x, " Y", p.y, " Z", p.z 
      +

      Other method display on "Int" and "Float" +

      +
      import Part
      +from FreeCAD import Base
      +
      +c=Part.makeCylinder(2,10)        # create the circle
      +Part.show(c)                     # display the shape
      +
      +# slice accepts two arguments:
      +#+ the normal of the cross section plane
      +#+ the distance from the origin to the cross section plane. Here you have to find a value so that the plane intersects your object
      +s=c.slice(Base.Vector(0,1,0),0)  # 
      +
      +# here the result is a single wire
      +# depending on the source object this can be several wires
      +s=s[0]
      +
      +# if you only need the vertexes of the shape you can use
      +v=[]
      +for i in s.Vertexes:
      +    v.append(i.Point)
      +
      +# but you can also sub-sample the section to have a certain number of points (int) ...
      +p1=s.discretize(20)
      +ii=0
      +for i in p1:
      +    ii+=1
      +    print i                                              # Vector()
      +    print ii, ": X:", i.x, " Y:", i.y, " Z:", i.z        # Vector decode
      +Draft.makeWire(p1,closed=False,face=False,support=None)  # to see the difference accuracy (20)
      +
      +## uncomment to use
      +#import Draft
      +#Draft.downgrade(App.ActiveDocument.ActiveObject,delete=True)  # first transform the DWire in Wire         "downgrade"
      +#Draft.downgrade(App.ActiveDocument.ActiveObject,delete=True)  # second split the Wire in single objects   "downgrade"
      +#
      +##Draft.upgrade(FreeCADGui.Selection.getSelection(),delete=True) # to attach lines contiguous SELECTED use "upgrade"
      +
      +
      +# ... or define a sampling distance (float)
      +p2=s.discretize(0.5)
      +ii=0
      +for i in p2:
      +    ii+=1
      +    print i                                              # Vector()
      +    print ii, ": X:", i.x, " Y:", i.y, " Z:", i.z        # Vector decode 
      +Draft.makeWire(p2,closed=False,face=False,support=None)  # to see the difference accuracy (0.5)
      +
      +## uncomment to use
      +#import Draft
      +#Draft.downgrade(App.ActiveDocument.ActiveObject,delete=True)  # first transform the DWire in Wire         "downgrade"
      +#Draft.downgrade(App.ActiveDocument.ActiveObject,delete=True)  # second split the Wire in single objects   "downgrade"
      +#
      +##Draft.upgrade(FreeCADGui.Selection.getSelection(),delete=True) # to attach lines contiguous SELECTED use "upgrade" 
      +

      Select all objects in the document

      +
      import FreeCAD
      +for obj in FreeCAD.ActiveDocument.Objects:
      +    print obj.Name                                # display the object Name
      +    objName = obj.Name
      +    obj = App.ActiveDocument.getObject(objName)
      +    Gui.Selection.addSelection(obj)               # select the object 
      +

      Selecting a face of an object

      +
      # select one face of the object
      +import FreeCAD, Draft
      +App=FreeCAD
      +nameObject = "Box"                             # objet
      +faceSelect = "Face3"                           # face to selection
      +loch=App.ActiveDocument.getObject(nameObject)  # objet
      +Gui.Selection.clearSelection()                 # clear all selection
      +Gui.Selection.addSelection(loch,faceSelect)    # select the face specified
      +s = Gui.Selection.getSelectionEx()
      +#Draft.makeFacebinder(s)                       # 
      +

      Create one object to the position of the Camera

      +
      # create one object of the position to camera with "getCameraOrientation()"
      +# the object is still facing the screen
      +import Draft
      +
      +plan = FreeCADGui.ActiveDocument.ActiveView.getCameraOrientation()
      +plan = str(plan)
      +###### extract data
      +a    = ""
      +for i in plan:
      +    if i in ("0123456789e.- "):
      +        a+=i
      +a = a.strip(" ")
      +a = a.split(" ")
      +####### extract data
      +
      +#print a
      +#print a[0]
      +#print a[1]
      +#print a[2]
      +#print a[3]
      +
      +xP = float(a[0])
      +yP = float(a[1])
      +zP = float(a[2])
      +qP = float(a[3])
      +
      +pl = FreeCAD.Placement()
      +pl.Rotation.Q = (xP,yP,zP,qP)         # rotation of object
      +pl.Base = FreeCAD.Vector(0.0,0.0,0.0) # here coordinates XYZ of Object
      +rec = Draft.makeRectangle(length=10.0,height=10.0,placement=pl,face=False,support=None) # create rectangle
      +#rec = Draft.makeCircle(radius=5,placement=pl,face=False,support=None)                   # create circle
      +print rec.Name 
      +

      here same code simplified +

      +
      import Draft
      +pl = FreeCAD.Placement()
      +pl.Rotation = FreeCADGui.ActiveDocument.ActiveView.getCameraOrientation()
      +pl.Base = FreeCAD.Vector(0.0,0.0,0.0)
      +rec = Draft.makeRectangle(length=10.0,height=10.0,placement=pl,face=False,support=None) 
      +

      Find normal vector on the surface

      +

      This example show how to find normal vector on the surface by find the u,v parameters of one point on the surface and use u,v parameters to find normal vector +

      +
      def normal(self):
      +   ss=FreeCADGui.Selection.getSelectionEx()[0].SubObjects[0].copy()#SubObjects[0] is the edge list
      +   points  = ss.discretize(3.0)#points on the surface edge, 
      +             #this example just use points on the edge for example. 
      +             #However point is not necessary on the edge, it can be anywhere on the surface. 
      +   face=FreeCADGui.Selection.getSelectionEx()[0].SubObjects[1]
      +   for pp in points:
      +      pt=FreeCAD.Base.Vector(pp.x,pp.y,pp.z)#a point on the surface edge
      +      uv=face.Surface.parameter(pt)# find the surface u,v parameter of a point on the surface edge
      +      u=uv[0]
      +      v=uv[1]
      +      normal=face.normalAt(u,v)#use u,v to find normal vector
      +      print normal
      +      line=Part.makeLine((pp.x,pp.y,pp.z), (normal.x,normal.y,normal.z))
      +      Part.show(line) 
      +

      Read And write one Expression

      +
      import Draft
      +doc = FreeCAD.ActiveDocument
      +
      +pl=FreeCAD.Placement()
      +pl.Rotation.Q=(0.0,-0.0,-0.0,1.0)
      +pl.Base=FreeCAD.Vector(0.0,0.0,0.0)
      +obj = Draft.makeCircle(radius=1.0,placement=pl,face=False,support=None)    # create circle
      +
      +print obj.PropertiesList                                                   # properties disponible in the obj
      +
      +doc.getObject(obj.Name).setExpression('Radius', u'2mm')                    # modify the radius
      +doc.getObject(obj.Name).setExpression('Placement.Base.x', u'10mm')         # modify the placement 
      +doc.getObject(obj.Name).setExpression('FirstAngle', u'90')                 # modify the first angle
      +doc.recompute()
      +
      +expressions = obj.ExpressionEngine                                         # read the expression list
      +print expressions
      +
      +for i in expressions:                                                      # list and separate the data expression
      +    print i[0]," = ",i[1] 
      +


      +

      + +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Colors.svg b/localwiki/Colors.svg new file mode 100644 index 0000000..07d832d --- /dev/null +++ b/localwiki/Colors.svg @@ -0,0 +1,243 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + + + + + + + + + diff --git a/localwiki/Command.html b/localwiki/Command.html new file mode 100644 index 0000000..8359fdc --- /dev/null +++ b/localwiki/Command.html @@ -0,0 +1,75 @@ +Command

      Command

      + +

      A FreeCAD command is what is being executed when you press a toolbar button or type a keyboard shortcut. It can be a very simple action, like changing the zoom level of the 3D view or rotating the point of view, or a complex system that will open dialog boxes and wait for the user to perform specific tasks. +

      Each FreeCAD command has a unique name, that appears in the Command_Reference page. Commands can be launched by a toolbar button, a menu item, or from a python script or the python console, by running: +

      +
      FreeCADGui.runCommand("my_Command_Name")
      +
      +

      FreeCAD commands are defined per workbench. Workbenches will normally add their command definitions at FreeCAD init time, so the command exists and is available as soon as FreeCAD is started, no matter if the corresponding workbench has been activated yet or not. In some cases, however, the workbench author might have decided, to not overload too much the FreeCAD startup process, to load the command definitions only at workbench init. In those cases, the command will only be available after the workbench has been activated (you have switched to it at least once with the workbench selector). +

      As most of them require user interaction, FreeCAD commands are only available in GUI-mode, and not in console mode. However, for convenience, most FreeCAD commands will either have a corresponding python function (like Part.makeBox or Draft.makeLine), or will execute code that is very easy to replicate in a python script. +

      Commands can be defined either in C++ or in Python. +

      Example of a C++ command definition (usually defined in /Mod/ModuleName/Gui/Command.cpp): +

      +
      DEF_STD_CMD_A(StdCmdMyCommand);
      +
      +StdCmdMyCommand::StdCmdMyCommand()
      +  : Command("Std_My_Command")
      +{
      +    sGroup        = QT_TR_NOOP("File");
      +    sMenuText     = QT_TR_NOOP("My Command");
      +    sToolTipText  = QT_TR_NOOP("Runs my command in the active document");
      +    sWhatsThis    = "Std_MyCommand";
      +    sStatusTip    = QT_TR_NOOP("Runs my command in the active document");
      +    sPixmap       = "MyCommand.svg";
      +    sAccel        = "Ctrl+A";
      +}
      +
      +void StdCmdExport::activated(int iMsg)
      +{
      +    // place here the code to be executed when the command is ran
      +}
      +
      +bool StdCmdMyCommand::isActive(void)
      +{
      +    // here you have a chance to return true or false depending if your command must be shown as active or inactive (greyed).
      +}
      +
      +// the command must be "registered" in FreeCAD's command system
      +CommandManager &rcCmdMgr = Application::Instance->commandManager();
      +rcCmdMgr.addCommand(new StdCmdMyCommand()); 
      +

      and a similar command in python (no rule for where it must be done, each python workbench does as it sees fit...) +

      +
      class MyCommand:
      +
      +    def __init__(self):
      +        # you can add things here like defining some variables that must exist at all times
      +
      +    def GetResources(self):
      +        return {'Pixmap'  : 'MyCommand.svg',
      +                    'Accel' : "Ctrl+A",
      +                    'MenuText': QtCore.QT_TRANSLATE_NOOP("My_Command", "My Command"),
      +                   'ToolTip': QtCore.QT_TRANSLATE_NOOP("My_Command", "Runs my command in the active document")}
      +
      +    def Activated(self):
      +        # place here the code to be executed when the command is ran
      +
      +    def isActive(self):
      +        # here you have a chance to return True or False depending if your command must be shown as active or inactive (greyed).
      +
      +# the command must be "registered" in FreeCAD's command system
      +FreeCADGui.addCommand('My_Command',MyCommand()) 
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Command_Reference.html b/localwiki/Command_Reference.html new file mode 100644 index 0000000..310a02e --- /dev/null +++ b/localwiki/Command_Reference.html @@ -0,0 +1,221 @@ +Category:Command Reference

      Category:Command Reference

      + +

      This category contains the help pages of each of FreeCAD Command. +

      + + +
      + +
      +

      Pages in category "Command Reference"

      +

      The following 200 pages are in this category, out of 630 total. +

      (previous page) (next page)

      D

      +
      (previous page) (next page) +
      +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Common_Airfoil_Data_Import.html b/localwiki/Common_Airfoil_Data_Import.html new file mode 100644 index 0000000..fb7a0e7 --- /dev/null +++ b/localwiki/Common_Airfoil_Data_Import.html @@ -0,0 +1,46 @@ +Common Airfoil Data Import

      Common Airfoil Data Import

      + +

      Importing Airfoil Data

      +

      FreeCAD can import airfoil data such as that found on the UIUC Airfoil Coordinates Database or files produced by airfoil creation and annalizing software like XFLR5 +

      +

      How To

      +

      From the File menu, select either Open for a new document or Import for existing document. From the Open or Import dialog "Files of type: pull down menu select Common airfoil data (*.dat), select your file and click Open. +

      When opening airfoil data files, FreeCAD reads the file and imports then in FreeCAD units. Airfoil data files provide XY coordinates in numbers between 0 and 1. As a result, the imported airfoil will have a chord length of 1 mm by default. Here is a tunicated sample of a typical airfoil .dat file. Notice that all data points fall between 0 and 1. +

      +
      AG35
      +     0.999998    0.002490
      +     0.994759    0.003346
      +     0.985091    0.004927
      +     0.973580    0.006810
      +     0.961032    0.008862
      +     0.948054    0.010984
      +     0.934900    0.013135
      +
      +~ ~ ~ ~ ~ ~ ~ ~
      +
      +     0.947640   -0.000001
      +     0.960660   -0.000001
      +     0.973282    0.000000
      +     0.984898    0.000000
      +     0.994724   -0.000001
      +     1.000001    0.000000 
      +

      Enhanced Import

      +

      There is a macro available that will import the airfoil with a user defined chord length. This macro will first allow the user to select the airfoil data file to import and then take an input for the chord length. It will then properly scale the airfoil for use. The macro can be found in the Macros recipes section of this Wiki under Macro Airfoil Import & Scale. +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/CompassRose.svg b/localwiki/CompassRose.svg new file mode 100644 index 0000000..91b65cf --- /dev/null +++ b/localwiki/CompassRose.svg @@ -0,0 +1,2677 @@ + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + + + + + + + + + + W + + + N + + + S + + + E + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/CompileOnCygwin.html b/localwiki/CompileOnCygwin.html new file mode 100644 index 0000000..eaa424f --- /dev/null +++ b/localwiki/CompileOnCygwin.html @@ -0,0 +1,131 @@ +CompileOnCygwin

      CompileOnCygwin

      + +
      Warning, the contents of this page may be obsolete. Please help us to keep it updated!
      +


      +

      + + +

      How to build and run FreeCAD under Cygwin

      +

      Prerequisites

      +

      To compile FreeCAD, you will need, besides functioning Cygwin environment +and programming tools (like compiler), the following libraries: +

      + +

      As far as I know, except of Coin3D and SoQt all libraries are available as prebuilt +binary packages from one of the Cygwin mirrors. To install them, first download the +latest version of setup.exe from www.cygwin.com and run it with administrator rights. +Then follow the instructions of the wizard until the list of all available packages +appears. Select the devel files of all the required libraries and install them. +

      Then download the source tarballs of Coin3D and SoQt and unpack them into a directory +of your choice. +The Coin library can be built with ./configure --disable-msvc;make; make install. +

      Building SoQt is a bit tricky and I haven't managed yet to build it in a proper way. +There are various problems with X11 functions and Windows API functions which I +don't know how to solve. +

      And for the Mesh module of FreeCAD the additional libraries +

      + +

      are required. OpenCASCADE is also needed by the Part and Raytracing modules. +

      +

      Note 1

      +

      As OpenCASCADE that is also required by the Mesh, Part and Raytracing +modules is not available for Cygwin it is not possible to build them +for this platform. It is planned for the future to move all OpenCASCADE +dependencies of the Mesh module into a separate module so that at least +this module can be built under Cygwin. +

      +

      Note 2

      +

      All libraries listed above must be built as shared library. Refer to their +documentation to see how to do. +

      +

      Note 3

      +

      If possible you should enable thread support for the libraries. At least for +Qt thread support is strongly recommended, otherwise you will run into linker +errors at build time of FreeCAD. +

      +

      Note 4

      +

      zlib might be already on your system, as this is a library that is used +from a lot of other libraries. +

      +

      Note 5

      +

      There seems to be various problems with Qt's uic tool of the Cygwin port. +

      Due to these problems it is not possible to run the GUI under Cygwin at the +moment. It is only possible to run the commandline version. +

      +

      Configuration

      +

      For the build process of FreeCAD we make use of configure scripts. +To have an overview of all options type in ./configure --help, first. +

      If you have installed all libraries above into standard paths you need not any of the +'--with' options at all. Unless you have installed any library into a non-standard path, +then make use of the --with-XXX-includes or --with-XXX-libs options. +(XXX represents the corresponding library.) +

      +

      Note 1

      +

      Due to some limitations of the Windows platform it is not possible to build +libraries with unresolved symbols at link time. Thus it is strongly recommended to run +./configure with the option LDFLAGS=-no-undefined, otherwise the creation of shared +libraries fails. For more details see section 11.2.1 Creating Libtool Libraries with +Automake of the libtool documentation. +

      +

      Note 2

      +

      To specify FreeCAD's root directory it is recommended to use only the '--prefix' +option from the configure script but not the --bindir, --libdir, ... options, because +at startup FreeCAD makes assumptions where its lib-, doc-, .. directories reside. +The default root directory is located in ~/FreeCAD. +

      If you know how to work with GNU autoconf, feel free to contribute improvements +to our configuration scripts --- that would be great. +


      +

      +

      Installation

      +

      Once you have built the sources successfully using 'make' with 'make install' you can +install FreeCAD onto your machine whereever you want. Go to the directory FreeCAD/bin +and just type in ./FreeCADCmd. +FreeCAD's default root directory resides under ~/FreeCAD, so you don't need root privileges +therefore. +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/CompileOnMac.html b/localwiki/CompileOnMac.html new file mode 100644 index 0000000..8a04d85 --- /dev/null +++ b/localwiki/CompileOnMac.html @@ -0,0 +1,210 @@ +CompileOnMac

      CompileOnMac

      + +

      This page describes how to compile the latest FreeCAD source on macOS X. Latest means the most recent commit to the master branch of the FreeCAD github repository. +

      This page serves as a quick start, and is not intended to be comprehensive with regard to describing all the available build options. +

      If you just want to evaluate the latest pre-release build of FreeCAD, you can download pre-built binaries from here. +

      + + +

      Install Prerequisites

      +

      The following software must be installed to support the build process. +

      +

      Homebrew Package Manager

      +

      Homebrew is a command line based package manager for macOS. The Homebrew main page provides an installation command line that you simply paste into a terminal window. +

      +

      CMake

      +

      CMake is build tool that generates a build configuration based on variables you specify. You then issue the 'make' command to actually build that configuration. The command-line version of CMake is automatically installed as part of the Homebrew installation, above. If you prefer to use a GUI version of CMake, you can download it from here. +

      +

      Install Dependencies

      +

      FreeCAD maintains a Homebrew 'tap' which installs the required formulas and dependencies. Issue the following brew commands in your terminal. +


      +

      +
      +brew tap homebrew/science
      +brew tap freecad/freecad
      +brew install eigen
      +brew install --only-dependencies freecad --with-packaging-utils
      +
      +

      Notes: +

      +
      1. 'brew install' may take quite a while, so you may want go grab a beverage. :-)
      +

      Get the source

      +

      In the following instructions, the source and build folders are created side-by-side under +

      /Users/username/FreeCAD +

      but you can use whatever folders you want. +

      +
      +mkdir ~/FreeCAD
      +cd ~/FreeCAD
      +
      +

      The following command will clone the FreeCAD git repository into a directory called FreeCAD-git. +

      +
      +git clone https://github.com/FreeCAD/FreeCAD FreeCAD-git
      +
      +

      Create the build folder. +

      +
      +mkdir ~/FreeCAD/build
      +
      +


      +

      +

      Run CMake

      +

      Next, we will run CMake to generate the build configuration. Several options must be passed to CMake. The following table describes the options and gives some background. +

      +

      CMake Options

      + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
      Name Value Notes +
      CMAKE_BUILD_TYPE Release (STRING) Release or Debug. Debug is generally used for developer-level testing but may also be required for user-level testing and troubleshooting. +
      BUILD_QT5 1 (BOOL) Required to build with Qt5. +
      CMAKE_PREFIX_PATH "/usr/local/Cellar/qt@5.6/5.6.2/lib/cmake" (PATH) Required to build with Qt5. See note below. +
      FREECAD_CREATE_MAC_APP 1 (BOOL) Create a FreeCAD.app bundle at the location specified in CMAKE_INSTALL_PREFIX, when the 'make install' command issued. +
      CMAKE_INSTALL_PREFIX "./.." (PATH) Path where you want to generate the FreeCAD.app bundle. +
      FREECAD_USE_EXTERNAL_KDL 1 (BOOL) Required. +
      BUILD_FEM_NETGEN 1 (BOOL) Required. +
      +

      Note: Command line to generate CMAKE_PREFIX_PATH: +

      +
      +ls -d $(brew list -1 | grep qt | tail -1 | xargs brew --cellar)/*/lib/cmake
      +
      +

      CMake GUI

      +

      Open the CMake app, and fill in the source and build folder fields. In this example, it would be /Users/username/FreeCAD/FreeCAD-git for the source, and /Users/username/FreeCAD/build for the build folder. +

      Next, click the Configure button to populate the list of configuration options. This will display a dialog asking you to specify what generator to use. Leave it at the default Unix Makefiles. Configuring will fail the first time because there are some options that need to be changed. Note: You will need to check the Advanced checkbox to get all of the options. +

      Set options from the table above, then click Configure again and then Generate. +

      +

      CMake command line

      +

      Enter the following in the terminal. +

      +
      +$cd ~/FreeCAD/build
      +$cmake \
      +  -DCMAKE_BUILD_TYPE="Release"   \
      +  -DBUILD_QT5=1                  \
      +  -DCMAKE_PREFIX_PATH="/usr/local/Cellar/qt@5.6/5.6.2/lib/cmake"  \
      +  -DFREECAD_USE_EXTERNAL_KDL=1   \
      +  -DBUILD_FEM_NETGEN=1           \
      +  -DFREECAD_CREATE_MAC_APP=1     \
      +  -DCMAKE_INSTALL_PREFIX="./.."  \
      +  ../FreeCAD-git/
      +
      +
      +

      Run make

      +

      Finally, from a terminal run make to compile and link FreeCAD, and generate the app bundle. +

      +
      +cd ~/FreeCAD/build
      +make –j5 install
      +
      +

      The -j option specifies how many make processes to run at once. One plus the number of CPU cores is usually a good number to use. However, if compiling fails for some reason, it is useful to rerun make without the -j option, so that you can see exactly where the error occurred. +

      See also Compiling - Speeding up. +

      If make finishes without any errors, you can now launch FreeCAD by double clicking the executable in the Finder. +

      +

      Updating from Github

      +

      FreeCAD development happens fast; every day or so there are bug fixes or new features. To get the latest changes, use git to update the source directory (see Source code management), then re-run the CMake and make steps above. It is not usually necessary to start with a clean build directory in this case, and subsequent compiles will generally go much faster than the first one. +

      +

      Building with Qt4

      +

      FreeCAD has transitioned from Qt 4 to Qt 5. If you need to build with Qt4, the following additional steps are required. +

      +
      1. Append '--with-qt4' to the 'brew install' command.
      2. +
      3. Do not specify BUILD_QT5 CMake option.
      4. +
      5. Do not specify CMAKE_PREFIX_PATH CMake option
      +

      After you install Qt4, if you want to switch to building with Qt5, you will need to uninstall Qt4. +

      +
      +brew uninstall --ignore-dependencies --force cartr/qt4/shiboken@1.2 cartr/qt4/pyside@1.2 cartr/qt4/pyside-tools@1.2 cartr/qt4/qt
      +
      +

      Troubleshooting

      +

      Segfault on Qt5 launch

      +

      If Qt4 was previously installed via brew, and you then build with Qt5, you may get a EXC_BAD_ACCESS (SEGSEGV) exception when launching the new Qt5 build. The fix for this is to manually uninstall Qt4. +

      +
      +brew uninstall --ignore-dependencies --force cartr/qt4/shiboken@1.2 cartr/qt4/pyside@1.2 cartr/qt4/pyside-tools@1.2 cartr/qt4/qt-legacy-formula
      +
      +

      Fortran

      +

      "No CMAKE_Fortran_COMPILER could be found." during configuration - Older versions of FreeCAD will need a fortran compiler installed. With Homebrew, do "brew install gcc" and try configuring again, giving cmake the path to Fortran ie -DCMAKE_Fortran_COMPILER=/opt/local/bin/gfortran-mp-4.9 . Or, preferably use a more current version of FreeCAD source! +

      +

      OpenGL

      +

      See OpenGL on MacOS for OpenGL issues when Qt 4.8 and earlier are used on MacOS. +

      +

      FreeType

      +

      When using CMake versions older than 3.1.0, it's necessary to set CMake variable FREETYPE_INCLUDE_DIR_freetype2 manually, eg /usr/local/include/freetype2 +

      + +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/CompileOnMinGW.html b/localwiki/CompileOnMinGW.html new file mode 100644 index 0000000..9335552 --- /dev/null +++ b/localwiki/CompileOnMinGW.html @@ -0,0 +1,382 @@ +CompileOnMinGW

      CompileOnMinGW

      + +
      Warning, the contents of this page may be obsolete. Please help us to keep it updated!
      +


      +

      + + +

      How to build and run FreeCAD under MSYS/MinGW

      +

      Prerequisites

      +

      Here comes a short introduction how to setup a MSYS/MinGW environment +on a Windows system, to build all needed libraries and finally to build +the FreeCAD sources. +

      +

      MSYS/MinGW

      +

      If not already installed get a MinGW installer from the Sourceforge page at +http://sourceforge.net/projects/mingw. When writing this tutorial the latest +version was mingw-get-inst-20100831.exe. Download and just double-click the +excutable. This installs the compiler and a minimal Windows developer environment. +Make sure to also install the Fortran compiler because there is a single Fortran +file in the 3rd party folder of the FreeCAD sources. +

      Then as second step MSYS needs to be installed to have an environment to run +./configure scripts which we make heavy use of in order to build all needed +libraries. From the Soureforge page the file MSYS-1.0.11.exe was taken. +

      A virginal MSYS/MinGW installation lacks of a few modules we later need. +First, we need the utility pexport which can be found in the file +pexports-0.44-1-mingw32-bin.tar.lzma. I don't know where to put this file +and how to make MSYS to install the stuff inside. But the file can be opened +with a ZIP program and the content can be copied to their destination manually. +Here, the pexports utility can go to the bin directory of your MinGW installation. +

      Then, we also need the development files for the pthreads module which is part +of the file pthreads-w32-2.8.0-3-mingw32-dev.tar.lzma. Just download and copy +the files inside to your MinGW installation. +


      +

      +

      CMake

      +

      Download the CMake utility from http://www.cmake.org/cmake/resources/software.html. +Get the archive with the binaries for the Windows platform and unpack whereever you +want. There is nothing further to do for this. +

      +

      SWIG

      +

      Download the SWIG utility from www.swig.org and extract it somewhere on your harddisk. +


      +

      +

      Third party libraries

      +

      Here is a description which libraries we need for FreeCAD and how to build them from +the sources. In order not to pollute our MinGW installation with too many files from +the 3rd party libraries we have to build you can e.g. create a sub-directory "local" +in your MSYS installation. If you have installed MSYS under C:\MSYS then simply create +the directory C:\MSYS\1.0\local. +


      +

      +

      zlib

      +

      For zlib there is already a ready package for MinGW. So, therefore simply download +the file libz-1.2.3-1-mingw32-dev.tar.gz from the Sourceforge site and extract the +two directories lib and include to C:\MSYS\1.0\local. +


      +

      +

      Python

      +

      It seems to be nearly impossible to build the Python sources directly with the MinGW +compiler. This is because some Python modules require some features which are not +implemented on the MinGW platform. Fortunately, the Python sources are plain C code +and instead of trying to build it with MinGW you can get a ready binary package built +with the MSVC compiler. You can install the Python stuff whereever you want. Afterwards +copy the include folder to C:\MSYS\1.0\local, the DLL can go to C:\MSYS\1.0\local\bin. +

      Now we also need the so called import library. There we cannot use the .lib file which +comes together with the installer. But it's easy to create one with the pexports/dlltool +utilities. Assuming the Python version is 2.6 do these two steps: +

      +
       pexports python26.dll > python26.def
      + dlltool -D python26.dll -d python26.def -l libpython26.dll.a
      + 
      +
      +

      The file libpython26.dll.a can now be moved to C:\MSYS\1.0\local\lib. +


      +

      +

      f2c

      +

      For this library we don't need any header files but only the import library to build the +Salome SMESH sources. The easiest way to build this file is: +

      +
       pexports libgfortran-3.dll > f2c.def
      + dlltool -D libgfortran-3.dll -d f2c.def -l libf2c.dll.a
      +
      +

      The file libf2c.dll.a can now be moved to C:\MSYS\1.0\local\lib. +


      +

      +

      xerces-c

      +

      Download a source archive from http://xml.apache.org/dist/xerces-c/ and extract it. +Open a MSYS command line window and change to the xerces-c sources. From there run +

      +
      ./configure LDFLAGS=-no-undefined 
      +
      +

      Once ./configure has finished it's best to move to the source directory because we +don't need to build the dozens of test applications and other stuff. So, do this: +

      +
       cd src
      + make
      + make install
      +
      +
      +

      This takes a few minutes to be done. +


      +

      +

      boost

      +

      For boost there exists a testing package with cmake support. This, however, seems to be +stable enough to build with the MinGW compiler. So, get the file boost-1.41.0.cmake0.zip +from http://sodium.resophonic.com/boost-cmake/1.41.0.cmake0/ and unpack it. +

      Now, start the cmake-gui.exe from within the MSYS command line. This is necessary for cmake +in order to find the compiler and other stuff. Select the folder of the boost sources with +the CMakeLists.txt file, select a build directory and start Configure. You'll be asked for +which system you want to generate the Makefiles. Select MSYS/Makefiles, not MinGW/Makefiles. +

      When the configuration step has finished go to the options and search for WINMANGLE_LIBNAMES. +Switch this off because otherwise the boost library names contain the compiler name. This +causes the boost cmake check to fail later when we try to build the FreeCAD sources. And for +the installtion folder choose the directory C:\MSYS\1.0\local. +

      So, reconfigure boost and press on Generate once it has finished. Close the CMake GUI window +and enter +

      +
       make
      + make install
      +
      +

      into the command line. This will take a couple of minutes. +


      +

      +

      eigen2

      +

      Download eigen-2.0.15.tar.gz or any later version from http://eigen.tuxfamily.org/index.php?title=Main_Page. +Unpack the files and start again cmake-gui. Set the installation directory to C:\MSYS\1.0\local +and press on Configure and Generate. Close the window and start the installation with +

      +
       make
      + make install
      +
      +


      +o Qt4 +From the Qt website at ftp://ftp.trollech.com you can download already prebuilt packages for the +MinGW platform. But depending on the version you have installed it can happen that they don't fit +together. In this case the source tarball must be downloaded. Use version 4.5.3 or higher. Unpack +the sources and start the configure.exe you'll find inside the sources. +

      +
       ./configure
      +
      +
      +

      By default the build the debug and release version. If you only want the release version use the +option "-release". +

      Configure will ask you some questions under which license you want to use Qt. Choose LGPL here. +Now run the build with +

      +
       make
      + 
      +
      +

      This can take quite some time because Qt has become a really huge library over the years. Once the +build has finished run a +

      +
       make install
      + 
      +
      +

      to copy the header files to their right place. All the binaries and header files are still inside +the source folder. If you like you can copy all the .dll, .a, and the direcories under "include" to +the subdirectories of C:\MSYS\1.0\local. +


      +

      +

      Coin

      +

      Get a source archive from www.coin3d.org. Unpack the sources and run +

      +
       ./confiure
      + make
      + make install
      +
      +

      It may happen that a message dialog pops up due to a missing cygwin1.dll. You simply ignore this. +


      +

      +

      SoQt

      +

      Get a source archive from www.coin3d.org. Unpack the sources and run +

      +
       ./configure CXXFLAGS="-DCOIN_DLL" --with-qt=/usr/local
      + make
      + make install
      +
      +

      In case your Qt development files are not under /usr/local choose the correct directory there. +Again a message dialog may pop up due to the missing cygwin1.dll. +


      +

      +

      PyQt/sip

      +

      Warning: the following is obsoleted from version 0.14, since FreeCAD is now using +pySide instead of PyQt. At the moment, PySide suport for MingW seems still not complete: +https://bugreports.qt-project.org/browse/PYSIDE-113?page=com.atlassian.jira.plugin.system.issuetabpanels%3aall-tabpanel +

      Download the sources archives for sip and PyQt4 from www.riverbankcomputing.co.uk. +

      In order to build sip extract the archive and open a MSYS command line. From within +its source archive call +

      +
       python configure.py --platform win32-g++ --destdir=/usr/local
      + make
      +
      +

      It may happen that this step aborts because the Python include headers cannot be found. +In this case edit the Makefile and add the include path for the ython headers and also +the path and filename of the Python library. +

      Unfortunately, the 'make install' command doesn't work because the Makefile was generated +to use Windows batch commands instead of bash commands. Thus, copy the following files to +a path where Python can find it, e.g. /usr/local/bin. +

      +
       sipconfig.py
      + sipdistutils.py
      + siputils.py
      + sip.pyd
      + sip.exe
      +
      +

      In order to build PyQt4 extract the source archive and open a MSYS command line. Go to the +directory and start +

      +
       export PATH=/usr/local/lib/:$PATH
      + python configure.py --destdir=/usr/local/lib/site-packages
      + make
      +
      +

      Since the Makefile doesn't find the Python header files copy them all and also the file sip.h +to a directory where they can be found. A good place seems to be the directory of the Qt sources. +There copy the files to $QTDIR/include. The Python library file python26.dll.a can go $QTDIR/lib. +

      After the build has finished you have to copy all files that end with .pyd to their destination, +e.g. /usr/local/lib/site-packages/PyQt4. Lateron when you have built the FreeCAD sources you have +to copy the PyQt4 directory and sip.pyd to the FreeCAD bin directory or set a symlink. +


      +

      +

      ODE

      +

      TODO: Still not clear if this will be used. (http://www.ode.org), >= 0.10.x +


      +

      +

      OpenCASCADE

      +

      For the build of the OpenCASCADE libraries get the sources from www.opencascade.org or alternatively +it is also possible to download a stripped source tarball from the Debian mirrors which don't include +any fonts and other resource files. +

      Unpack the sources and download a CMake script from http://opencascade-cmake.googlecode.com/svn/trunk/ +and the file occ_config.h.cmake. Copy both files into the 'ros' directory, start cmake-gui from +within a MSYS command line and select MSYS Makefiles. In the options the following switches can be +disabled: +

      +
       OPENCASCADE_WRAPPERS
      + OPENCASCADE_VISUALISATION
      + OPENCASCADE_OCAF
      + OPENCASCADE_DRAW
      + 
      +
      +

      Then specify for OPENCASCADE_INSTALL_PREFIX C:/MSYS/1.0/local as destination directory- +

      Now click the Configure button which takes a while and afterwards the Generate button. +

      +

      Note 1

      +

      The original sources don't completely compile with MinGW. Therefore you have to apply the patch +OpenCASCADE6.3.0-MinGW.patch from http://code.google.com/p/opencascade-cmake/source/browse/trunk +

      +

      Note 2

      +

      The original sources includes also a configure script and the Makefile.am files. +But it appeared to be very hard to build the libraries this way. Thus, it highly +recommended to do it the CMake way. +

      +

      Note 3

      +

      For a couple of libraries the arguments passed to the linker exceeds the number of +allowed characters and thus the linker stops with an error: "Bad file number". +To solve this issue you can open the file build.make of the according library and +split the block (e.g. TKGeomAlgo_OBJECTS) into several smaller ones and modify the +build rule this way that you create first a static library, add the other object +files to the group and then unpack the static archive into one directory. This +trick solves the problem to reduce the whole number of characters. +Afterwards the shared library can be built out of these object files. +

      Example: +If the build.make file has a line of the form +

      +
         g++ <options> -shared -o libTKGeomAlgo.dll $(TKGeomAlgo_OBJECTS) <libs>
      +
      +

      then change it into +

      +
         ar rcs win32/libTKGeomAlgo.a $(TKGeomAlgo_OBJECTS1)
      +   ar q win32/libTKGeomAlgo.a $(TKGeomAlgo_OBJECTS2)
      +   ...
      +   ar x win32/libTKGeomAlgo.a
      +   g++ <options> -shared -o libTKGeomAlgo.dll *.obj  <libs>
      +   rm -f *.obj
      +
      +

      Netgen

      +

      Modify the following files: +

      +
      • libsrc/meshing/improve2.hpp
      +
       Add  DLL_HEADER to class MeshOptimize2d
      +
      +
      • libsrc/meshing/meshclass.hpp
      +
       Add  DLL_HEADER to CalcSurfacesOfNode
      +
      +
      • libsrc/meshing/meshtype.hpp
      +
       Add  DLL_HEADER to classes SurfaceElementIndex, MeshPoint, Element2d (int anp), 
      +
      +
      • libsrc/occ/occgeom.hpp
      +
       Add  DLL_HEADER to classes Line, OCCGeometry, OCCParameters, OCCGenerateMesh
      +
      +
      • libsrc/occ/occmeshsurf.hpp
      +
       Add  DLL_HEADER to classes OCCSurface, Meshing2OCCSurfaces, MeshOptimize2dOCCSurfaces, OCCRefinementSurfaces
      + 
      +
      +

      Run the configure script with these arguments +

      +
       ./configure --prefix=/usr/local --enable-shared --enable-occ --with-occ=/usr/local --with-tcl=/usr/local/lib --enable-nglib CXXFLAGS="-DNGLIB_EXPORTS -DWNT"
      + make && make install
      +
      +


      +

      +

      Building the FreeCAD sources

      +

      In order build the FreeCAD sources either get the developer sources from the SVN repository +or get one of the .tar.gz tarballs and extract it. +Now start cmake-gui.exe from within a MSYS command line window and browse to the FreeCAD +sources and also define the build directory. Now run Configure. It may happen that cmake +complains about some not found libraries. In this case go through the listed libraries and +choose the include directory and/or the path to the library where needed. Once Confgiure +accepts all your input create the Makefiles by clicking on Generate. Now close the window +and enter +

      +
       make
      + make install
      +
      +

      This will take a couple of minutes. From the command line window change to the FreeCAD bin +folder and start the application with ./FreeCAD. In case it complains about some DLLs it cannot +find you have to extend your PATH environment variable with +

      +
       export PATH=$PATH:/usr/local/bin:/usr/local/lib
      +
      +

      If no grave problems remains repeating ./FreeCAD should start the application now. +

      +

      Note

      +

      In order to let CMake detect the boost libraries you must make sure that the +DLLs are in the system path because the check builds some test applications +and tries to start them. If the DLLs are not in path CMake says that it cannot +find boost. In this case do a export PATH=/usr/local/lib:$PATH +

      Have fun! +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/CompileOnUnix.html b/localwiki/CompileOnUnix.html new file mode 100644 index 0000000..31ba3a8 --- /dev/null +++ b/localwiki/CompileOnUnix.html @@ -0,0 +1,594 @@ +CompileOnUnix

      CompileOnUnix

      + +

      On recent linux distributions, FreeCAD is generally easy to build, since all dependencies are usually provided by the package manager. It basically involves 3 steps: +

      +
      1. Getting the FreeCAD source code
      2. +
      3. Getting the dependencies (packages FreeCAD depends upon)
      4. +
      5. Configure with "cmake" and Compile with "make"
      +

      Below, you'll find detailed explanations of the whole process, some build scripts, and particularities you might encounter. If you find anything wrong or out-of-date in the text below (Linux distributions change often), or if you use a distribution which is not listed, please help us correcting it. +

      + + +

      Getting the source

      +

      Before you can compile FreeCAD, you need the source code. There are 3 ways to get it: +

      +

      Git

      +

      The quickest and best way to get the code is to clone the read-only git repository now hosted on GitHub (you need the git package installed): +

      +
      git clone https://github.com/FreeCAD/FreeCAD.git free-cad-code 
      +

      This will place a copy of the latest version of the FreeCAD source code in a new directory called "free-cad-code". +

      +

      Github

      +

      The official FreeCAD repository is on Github: +github.com/FreeCAD/FreeCAD +

      +

      Source package

      +

      Alternatively you can download a source package, but they could be already quite old so it's always better to get the latest sources via git or github. +

      + +

      Getting the dependencies

      +

      To compile FreeCAD under Linux you have to install all libraries mentioned in Third Party Libraries first. Please note that the names and availability of the libraries will depend on your distribution. Note that if you don't use the most recent version of your distribution, some of the packages below might be missing from your repositories. In that case, look in the Older and non-conventional distributions section below. +

      Skip to Compile FreeCAD +

      +
      +

      Debian and Ubuntu

      +
      +

      On Debian-based systems (Debian, Ubuntu, Mint, etc...) it is quite easy to get all needed dependencies installed. Most of the libraries are available via apt-get or synaptic package manager. +

      +
      • build-essential
      • +
      • cmake
      • +
      • python
      • +
      • python-matplotlib
      • +
      • libtool
      +

      either: +

      +
      • libcoin60-dev (Debian Wheezy, Wheezy-backports, Ubuntu 13.04 and before)
      +

      or: +

      +
      • libcoin80-dev (Debian unstable(Jesse), testing, Ubuntu 13.10 and forward)
      +
      • libsoqt4-dev
      • +
      • libxerces-c-dev
      • +
      • libboost-dev
      • +
      • libboost-filesystem-dev
      • +
      • libboost-regex-dev
      • +
      • libboost-program-options-dev
      • +
      • libboost-signals-dev
      • +
      • libboost-thread-dev
      • +
      • libboost-python-dev
      • +
      • libqt4-dev
      • +
      • libqt4-opengl-dev
      • +
      • qt4-dev-tools
      • +
      • python-dev
      • +
      • python-pyside
      • +
      • pyside-tools
      +

      either: +

      +
      • libopencascade-dev (official opencascade version)
      +

      or: +

      +
      • liboce*-dev (opencascade community edition)
      • +
      • oce-draw
      +
      • libeigen3-dev
      • +
      • libqtwebkit-dev
      • +
      • libshiboken-dev
      • +
      • libpyside-dev
      • +
      • libode-dev
      • +
      • swig
      • +
      • libzipios++-dev
      • +
      • libfreetype6
      • +
      • libfreetype6-dev
      +

      Additional instruction for libcoin80-dev Debian wheezy-backports, unstable, testing, Ubuntu 13.10 and forward +

      Note that liboce*-dev includes the following libraries: +

      +
      • liboce-foundation-dev
      • +
      • liboce-modeling-dev
      • +
      • liboce-ocaf-dev
      • +
      • liboce-visualization-dev
      • +
      • liboce-ocaf-lite-dev
      +

      You may have to install these packages by individual name. +

      Optionally you can also install these extra packages: +

      +
      • libsimage-dev (to make Coin to support additional image file formats)
      • +
      • checkinstall (to register your installed files into your system's package manager, so yo can easily uninstall later)
      • +
      • python-pivy (needed for the 2D Drafting module)
      • +
      • python-qt4 (needed for the 2D Drafting module)
      • +
      • doxygen and libcoin60-doc (if you intend to generate source code documentation)
      • +
      • libspnav-dev (for 3Dconnexion devices support like the Space Navigator or Space Pilot)
      +


      +

      +
      sudo apt install build-essential cmake python python-matplotlib libtool libcoin80-dev libsoqt4-dev libxerces-c-dev libboost-dev libboost-filesystem-dev libboost-regex-dev libboost-program-options-dev libboost-signals-dev libboost-thread-dev libboost-python-dev libqt4-dev libqt4-opengl-dev qt4-dev-tools python-dev python-pyside pyside-tools libeigen3-dev libqtwebkit-dev libshiboken-dev libpyside-dev libode-dev swig libzipios++-dev libfreetype6-dev liboce-foundation-dev liboce-modeling-dev liboce-ocaf-dev liboce-visualization-dev liboce-ocaf-lite-dev libsimage-dev checkinstall python-pivy python-qt4 doxygen libspnav-dev oce-draw liboce-foundation-dev liboce-modeling-dev liboce-ocaf-dev liboce-ocaf-lite-dev liboce-visualization-dev libmedc-dev libvtk6-dev libproj-dev 
      +

      Ubuntu 16.04 users please see also these Additional instructions. +

      +
      +
      +
      +

      Fedora

      +
      +

      You need the following packages : +

      +
      • gcc-c++ (or possibly another C++ compiler?)
      • +
      • cmake
      • +
      • doxygen
      • +
      • swig
      • +
      • gettext
      • +
      • dos2unix
      • +
      • desktop-file-utils
      • +
      • libXmu-devel
      • +
      • freeimage-devel
      • +
      • mesa-libGLU-devel
      • +
      • OCE-devel
      • +
      • python
      • +
      • python-devel
      • +
      • python-pyside-devel
      • +
      • pyside-tools
      • +
      • boost-devel
      • +
      • tbb-devel
      • +
      • eigen3-devel
      • +
      • qt-devel
      • +
      • qt-webkit-devel
      • +
      • ode-devel
      • +
      • xerces-c
      • +
      • xerces-c-devel
      • +
      • opencv-devel
      • +
      • smesh-devel
      • +
      • coin3-devel
      +

      (if coin2 is the latest available for your version of Fedora, use packages from http://www.zultron.com/rpm-repo/) +

      +
      • soqt-devel
      • +
      • freetype
      • +
      • freetype-devel
      +

      And optionally : +

      + +
      +
      +
      +

      Gentoo

      +
      +

      Easiest way to check which packages are needed to compile FreeCAD is to check via portage: +

      emerge -pv freecad +

      This should give a nice list of extra packages that you need installed on your system. +

      +
      +
      +
      +

      OpenSUSE

      +
      +

      You need the following packages: +

      +
      • gcc
      • +
      • cmake
      • +
      • OpenCASCADE-devel
      • +
      • libXerces-c-devel
      • +
      • python-devel
      • +
      • libqt4-devel
      • +
      • libshiboken-devel
      • +
      • python-pyside-devel
      • +
      • python-pyside-tools
      • +
      • Coin-devel
      • +
      • SoQt-devel
      • +
      • boost-devel
      • +
      • libode-devel
      • +
      • libQtWebKit-devel
      • +
      • libeigen3-devel
      • +
      • gcc-fortran
      • +
      • freetype2
      • +
      • freetype2-devel
      • +
      • Eigen3
      • +
      • swig
      +

      For FreeCAD 0.14 stable and 0.15 unstable, if Eigen3 and swig libraries are not found in standard repos, you can get them with a one-click install here: +

      + +

      Also, note that the Eigen3 Library from Factory Education was causing problems sometimes, so use the one from the KDE 4.8 Extra repo +

      Starting with 0.17pre Opensuse 13.2 is too old to build due to too old boost. +

      +
      +
      +
      +

      Arch Linux

      +
      +

      You will need the following libraries from the official repositories: +

      +
      • boost-libs
      • +
      • curl
      • +
      • hicolor-icon-theme
      • +
      • libspnav
      • +
      • opencascade
      • +
      • python2-pivy
      • +
      • python2-matplotlib
      • +
      • python2-pyside
      • +
      • python2-shiboken
      • +
      • qtwebkit
      • +
      • shared-mime-info
      • +
      • xerces-c
      • +
      • boost
      • +
      • cmake
      • +
      • coin
      • +
      • desktop-file-utils
      • +
      • eigen
      • +
      • gcc-fortran
      • +
      • swig
      +

      Also, make sure to check the AUR for any missing packages that are not on the repositories, currently: +

      +
      • python2-pyside-tools
      • +
      • med (Modelisation et Echanges de Donnees)
      +
      sudo pacman -S boost-libs curl hicolor-icon-theme libspnav opencascade python2-pivy python2-matplotlib python2-pyside python2-shiboken qtwebkit shared-mime-info xerces-c boost cmake coin desktop-file-utils eigen gcc-fortran med python2-pyside-tools 
      +
      +
      +
      +

      Older and non-conventional distributions

      +
      +

      On other distributions, we have very few feedback from users, so it might be harder to find the required packages. Try first locating the required libraries mentioned in Third Party Libraries. Beware that some of them might have a slightly different package name in your distribution (such as name, libname, name-dev, name-devel, etc...). +

      You also need the GNU gcc compiler version equal or above 3.0.0. g++ is also needed because FreeCAD is completely written in C++. During the compilation some Python scripts get executed. So the Python interpreter has to work properly. To avoid any linker problems during the build process it is also a good idea to have the library paths either in your LD_LIBRARY_PATH variable or in your ld.so.conf file. This is normally already the case in recent distributions. +

      For more details have also a look to README.Linux in your sources. +

      +
      +
      +

      Pivy

      +

      Pivy is not needed to build FreeCAD or to run it, but it is needed for the 2D Drafting module to work. If you are not going to use that module, you won't need pivy. By November 2015 the obsolete version of Pivy included with FreeCAD source code will no longer compile on many systems, due to its age. If you cannot find Pivy in your distribution's packages repository ort elsewhere, you can compile pivy yourself: +

      Pivy compilation instructions +

      +

      Compile FreeCAD

      +

      Using cMake

      +

      cMake is a newer build system which has the big advantage of being common for different target systems (Linux, Windows, MacOSX, etc). FreeCAD is now using the cMake system as its main building system. Compiling with cMake is usually very simple and happens in 2 steps. In the first step, cMake checks that every needed programs and libraries are present on your system and sets up all that's necessary for the subsequent compilation. You are given a few alternatives detailed below, but FreeCAD comes with sensible defaults. The second step is the compiling itself, which produces the FreeCAD executable. Changing any options for cmake away from their default values, is much easier with cmake-gui or other graphical cmake applications than with cmake on the command line, as the graphical applications will give you interactive feed back. +

      Since FreeCAD is a heavy application, compiling can take a bit of time (about 10 minutes on a fast machine, 30 minutes (or more) on a slow one) +

      +

      In-source building

      +

      If you are unsure then, due to its limitations, do not make an in-source build, create an out-of-source build as explained in the next section. However FreeCAD can be built in-source, which means that all the files resulting from the compilation stay in the same folder as the source code. This is fine if you are just looking at FreeCAD, and want to be able to remove it easily by just deleting that folder. But in case you are planning to compile it often, you are advised to make an out-of-source build, which offers many more advantages. The following commands will compile FreeCAD: +

      +
      $ cd freecad (the folder where you cloned the freecad source) 
      +

      If you want to use your system's copy of Pivy, which you most commonly will, then if not on Linux, set the compiler flag to use the correct pivy (via FREECAD_USE_EXTERNAL_PIVY=1). Using external Pivy became the default for Linux, during development of FreeCAD 0.16, so it does not need to be manually set when compiling this version onwards, on Linux. Also, set the build type to Debug if you want a debug build or Release if not. A Release build will run much faster than a Debug build. Sketcher becomes very slow with complex sketches if your FreeCAD is a Debug build. (NOTE: the space and "." after the cmake flags are CRITICAL!): +

      +
      For a Debug build
      +
      $ cmake -DFREECAD_USE_EXTERNAL_PIVY=1 -DCMAKE_BUILD_TYPE=Debug .
      +# Note: to speed up build use all CPU cores: make -j$(nproc)
      +$ make 
      +
      Or for a Release build
      +
      $ cmake -DFREECAD_USE_EXTERNAL_PIVY=1 -DCMAKE_BUILD_TYPE=Release .
      +# Note: to speed up build use all CPU cores: make -j$(nproc)
      +$ make 
      +

      Your FreeCAD executable will then reside in the "bin" folder, and you can launch it with: +

      +
      $ ./bin/FreeCAD 
      +

      How to repair your source code directory after accidentally running an in-source build.

      +

      This is a method, using Git, to repair your source code directory after accidentally running an in-source build. +

      +
      1) delete everything in your source base directory EXCEPT the hidden .git folder
      +2) In terminal 'git reset --hard HEAD'
      +//any remnants of an 'in source' build will be gone.
      +3) delete everything from your 'out of source' build directory and start over again with cmake and a full new clean build. 
      +

      Out-of-source build

      +

      If you intend to follow the fast evolution of FreeCAD, building in a separate folder is much more convenient. Every time you update the source code, cMake will then intelligently distinguish which files have changed, and recompile only what is needed. Out-of-source builds are specially handy when using the Git system, because you can easily try other branches without confusing the build system. To build out-of-source, simply create a build directory, distinct from your FreeCAD source folder, and, from the build folder, point cMake (or if using cmake-gui replace "cmake" in the code below with "cmake-gui") to the source folder: +

      +
      mkdir freecad-build
      +cd freecad-build
      +cmake ../freecad (or whatever the path is to your FreeCAD source folder)
      +# Note: to speed up build use all CPU cores: make -j$(nproc)
      +make 
      +

      The FreeCAD executable will then reside in the "bin" directory (within your freecad-build directory). +

      +

      Configuration options

      +

      There are a number of experimental or unfinished modules you may have to build if you want to work on them. To do so, you need to set the proper options for the configuration phase. Do it either on the command line, passing -D <var>:<type>=<value> options to cMake or using one of the availables gui-frontends (eg for Debian, packages cmake-qt-gui or cmake-curses-gui). Changing any options for cmake away from their default values, is much easier with cmake-gui or other graphical cmake applications than with cmake on the command line, as they will give you interactive feed back. +

      As an example, to configure FreeCAD with the Assembly module built just tick the box in a cmake gui application (e.g. cmake-gui) or on the command line issue: +

      +
      cmake -D FREECAD_BUILD_ASSEMBLY:BOOL=ON ''path-to-freecad-root'' 
      +

      Possible options are listed in FreeCAD's root CmakeLists.txt file. +

      +

      Qt designer plugin

      +

      If you want to develop Qt stuff for FreeCAD, you'll need the Qt Designer plugin that provides all custom widgets of FreeCAD. Go to +

      +
      freecad/src/Tools/plugins/widget 
      +

      So far we don't provide a makefile -- but calling +

      +
      qmake plugin.pro 
      +

      creates it. Once that's done, calling +

      +
      make 
      +

      will create the library libFreeCAD_widgets.so. To make this library known to Qt Designer you have to copy the file to $QTDIR/plugin/designer +

      +

      Doxygen

      +

      If you feel bold enough to dive in the code, you could take advantage to build and consult Doxygen generated FreeCAD's Source documentation +

      +

      Making a debian package

      +

      If you plan to build a Debian package out of the sources you need to install those packages first: +

      +
      dh-make
      +devscripts
      +
      +#optional, used for checking if packages are standard-compliant
      +lintian 
      +

      To build a package open a console, simply go to the FreeCAD directory and call +

      +
      debuild 
      +

      Once the package is built, you can use lintian to check if the package contains errors +

      +
      #replace by the name of the package you just created
      +lintian your-fresh-new-freecad-package.deb 
      +

      Troubleshooting

      +

      Note for 64bit systems

      +

      When building FreeCAD for 64-bit there is a known issue with the OpenCASCADE 64-bit package. To get FreeCAD running properly you might need to run the ./configure script with the additional define _OCC64 set: +

      +
      ./configure CXXFLAGS="-D_OCC64" 
      +

      For Debian based systems this workaround is not needed when using the prebuilt package because there the OpenCASCADE package is built to set internally this define. Now you just need to compile FreeCAD the same way as described above. +

      +

      Automatic build scripts

      +

      Here is all what you need for a complete build of FreeCAD. It's a one-script-approach +and works on a fresh installed distro. The commands will ask for root password +(for installation of packages) and sometime to acknowledge a fingerprint for +an external repository server or https-subversion repository. These scripts should +run on 32 and 64 bit versions. They are written for different versions, but are +also likely to run on a later version with or without major changes. +

      If you have such a script for your preferred distro, please send it! We will +incorporate it into this article. +

      +
      +

      Ubuntu

      +
      +

      These scripts provide a reliable way to install the correct set of dependencies required to build and run FreeCAD on Ubuntu. They make use of the FreeCAD Ubuntu PPA repositories, and should work on any version of Ubuntu targeted by the PPA. The 'daily' PPA targets recent versions of Ubuntu, and the 'stable' PPA targets all officially supported versions of Ubuntu. +

      This script installs dependencies for the daily development snapshot of FreeCAD. +

      +
      #!/bin/sh
      +sudo add-apt-repository --enable-source ppa:freecad-maintainers/freecad-daily && sudo apt-get update
      +# Install the dependencies needed to build FreeCAD
      +sudo apt-get build-dep freecad-daily
      +# Install the dependencies needed to run FreeCAD (and a build of FreeCAD itself)
      +sudo apt-get install freecad-daily 
      +

      This script installs dependencies for the latest stable release of FreeCAD. +(For Ubuntu 12.04, omit "--enable-source" from the add-apt-repository command.) +

      +
      #!/bin/sh
      +sudo add-apt-repository --enable-source ppa:freecad-maintainers/freecad-stable && sudo apt-get update
      +# Install the dependencies needed to build FreeCAD
      +sudo apt-get build-dep freecad
      +# Install the dependencies needed to run FreeCAD (and a build of FreeCAD itself)
      +sudo apt-get install freecad 
      +

      (These scripts also install the PPA build of FreeCAD itself, as a side effect. You could then uninstall that while leaving the dependencies in place. However, leaving it installed will enable the package manager to keep the set of dependencies up to date, which is useful if you are following the development for a long time.) +

      After installing the dependencies, please see the generic instructions for getting the source code, running CMake, and compiling. The following script is an example of one way to do this. +

      +
      #!/bin/sh
      +
      +# checkout the latest source
      +git clone https://github.com/FreeCAD/FreeCAD.git freecad
      +
      +# go to source dir
      +cd freecad
      +
      +# open cmake-gui window
      +cmake-gui .
      +
      +# build configuration
      +cmake .
      +
      +# build FreeCAD
      +# Note: to speed up build use all CPU cores: make -j$(nproc)
      +make 
      +
      +
      +
      +

      OpenSUSE 12.2

      +
      +

      No external Repositories are needed to compile FreeCAD 0.13 with this release. However, there is an imcompatability with python3-devel which needs to be removed. FreeCAD can be compiled from GIT similar to in OpenSUSE 12.2 +

      +
      # install needed packages for development
      +sudo zypper install gcc cmake OpenCASCADE-devel libXerces-c-devel \
      +python-devel libqt4-devel python-qt4 Coin-devel SoQt-devel boost-devel \
      +libode-devel libQtWebKit-devel libeigen3-devel gcc-fortran git swig
      + 
      +# create new dir, and go into it
      +mkdir FreeCAD-Compiled 
      +cd FreeCAD-Compiled
      + 
      +# get the source
      +git clone https://github.com/FreeCAD/FreeCAD.git free-cad
      + 
      +# Now you will have subfolder in this location called free-cad. It contains the source
      + 
      +# make another dir for compilation, and go into it
      +mkdir FreeCAD-Build1
      +cd FreeCAD-Build1 
      + 
      +# build configuration 
      +cmake ../free-cad
      + 
      +# build FreeCAD
      +make
      + 
      +# test FreeCAD
      +cd bin
      +./FreeCAD -t 0 
      +

      Since you are using git, next time you wish to compile you do not have to clone everything, just pull from git and compile once more +

      +
      # go into free-cad dir created earlier
      +cd free-cad
      + 
      +# pull
      +git pull
      + 
      +# get back to previous dir
      +cd ..
      + 
      +# Now repeat last few steps from before.
      + 
      +# make another dir for compilation, and go into it
      +mkdir FreeCAD-Build2
      +cd FreeCAD-Build2
      + 
      +# build configuration 
      +cmake ../free-cad
      + 
      +# build FreeCAD
      +# Note: to speed up build use all CPU cores: make -j$(nproc)
      +make
      + 
      +# test FreeCAD
      +cd bin
      +./FreeCAD -t 0 
      +
      +
      +
      +

      Debian Squeeze

      +
      +
      # get the needed tools and libs
      +sudo apt-get install build-essential python libcoin60-dev libsoqt4-dev \
      +libxerces-c2-dev libboost-dev libboost-date-time-dev libboost-filesystem-dev \
      +libboost-graph-dev libboost-iostreams-dev libboost-program-options-dev \
      +libboost-serialization-dev libboost-signals-dev libboost-regex-dev \
      +libqt4-dev qt4-dev-tools python2.5-dev \
      +libsimage-dev libopencascade-dev \
      +libsoqt4-dev libode-dev subversion cmake libeigen2-dev python-pivy \
      +libtool autotools-dev automake gfortran
      + 
      +# checkout the latest source
      +git clone https://github.com/FreeCAD/FreeCAD.git freecad
      + 
      +# go to source dir
      +cd freecad
      + 
      +# build configuration 
      +cmake .
      + 
      +# build FreeCAD
      +# Note: to speed up build use all CPU cores: make -j$(nproc)
      +make
      + 
      +# test FreeCAD
      +cd bin
      +./FreeCAD -t 0 
      +
      +
      +
      +

      Fedora 22/23/24

      +
      +

      Posted by user [PrzemoF] in the forum. +

      +
      #!/bin/bash
      +
      +#ARCH=x86_64
      +#ARCH=i686
      +ARCH=$(arch)
      +
      +MAIN_DIR=FreeCAD
      +BUILD_DIR=build
      +
      +#FEDORA_VERSION=22
      +FEDORA_VERSION=23
      +#FEDORA_VERSION=24
      +
      +echo "Installing packages required to build FreeCAD"
      +sudo dnf -y install gcc cmake gcc-c++ boost-devel zlib-devel swig eigen3 qt-devel \
      +shiboken shiboken-devel pyside-tools python-pyside python-pyside-devel xerces-c \
      +xerces-c-devel OCE-devel smesh graphviz python-pivy python-matplotlib tbb-devel \
      + freeimage-devel Coin3 Coin3-devel med-devel vtk-devel
      +
      +cd ~
      +
      +mkdir $MAIN_DIR || { echo "~/$MAIN_DIR already exist. Quitting.."; exit; }
      +
      +cd $MAIN_DIR
      +
      +git clone https://github.com/FreeCAD/FreeCAD.git
      +
      +mkdir $BUILD_DIR || { echo "~/$BUILD_DIR already exist. Quitting.."; exit; }
      +
      +cd $BUILD_DIR
      +
      +cmake ../FreeCAD 
      +
      +# Note: to speed up build use all CPU cores: make -j$(nproc)
      +make 
      +
      +
      +

      Updating the source code

      +

      FreeCAD development happens fast, everyday or so there are bug fixes or new features. The cmake systems allows you to intelligently update the source code, and only recompile what has changed, making subsequent compilations very fast. Updating the source code with git or subversion is very easy: +

      +
      #Replace with the location where you cloned the source code the first time
      +cd freecad
      +#If you are using git
      +git pull 
      +

      Move into the appropriate build directory and run cmake again (as cmake updates the version number data for the Help menu, ...about FreeCAD), however you do not need to add the path to source code after "cmake", just a space and a dot: +

      +
      #Replace with the location of the build directory
      +cd ../freecad-build
      +cmake .
      +# to use all cpu cores change to: make -j$(nproc)
      +make 
      +

      Links

      +

      See also Compiling - Speeding up How to speed up compilation +

      + +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/CompileOnWindows.html b/localwiki/CompileOnWindows.html new file mode 100644 index 0000000..6d6eb47 --- /dev/null +++ b/localwiki/CompileOnWindows.html @@ -0,0 +1,437 @@ +CompileOnWindows

      CompileOnWindows

      + +

      This article explains step by step how to compile FreeCAD on Windows. +

      See also +

      + + + +

      Prerequisites

      +

      Required programs

      +
      • Git There are a number of alternatives such as GitCola, Tortoise Git, and others.
      • +
      • CMake version 2.x.x or Cmake 3.x.x
      • +
      • Python >2.5 (This is only required if NOT using the Libpack. The Libpack comes with a minimal Python(2.7.x) suitable for compiling and running FreeCAD)
      +

      Source Code

      +

      Using Git (Preferred)

      +

      To create a local tracking branch and download the source code you need to open a terminal(command prompt) and cd to the directory you want the source, then type: +

      +
      git clone https://github.com/FreeCAD/FreeCAD.git free-cad-code
      +

      Compiler

      +

      On Windows, the default compiler is MS Visual Studio. +CI uses 2013 version. +

      For those who want to avoid installing the huge Visual Studio for the mere purpose of having a compiler, see CompileOnWindows - Reducing Disk Footprint. +

      +
      Note +

      Though it may be possible to use Cygwin or MinGW gcc it's not tested or ported so far. +

      +
      +


      +

      +

      Third Party Libraries

      +

      You will need all of the Third Party Libraries to successfully compile FreeCAD. If you use the MS compilers it is recommended to install a FreeCAD LibPack, which provides all of the required libraries to build FreeCAD in Windows. +You will need the Libpack for your architecture and compiler. FreeCAD currently supplies Libpack Version11 for x32 and x64, for VS9 2008, VS11 2012, and VS12 2013. +

      +

      Optional programs

      +
      • NSIS Windows installer (note: formerly, WiX installer was used - now under transition to NSIS) - if you want to make msi installer
      +

      System Path Configuration

      +

      Inside your system path be sure to set the correct paths to the following programs: +

      +
      • git (not tortoiseGit, but git.exe) This is necessary for Cmake to properly update the "About FreeCAD" information in the version.h file which allows FreeCAD to report the proper version in About FreeCAD from the help menu.
      • +
      • Optionally you can include the Libpack in your system path. This is useful if you plan to build multiple configurations/versions of FreeCAD, you will need to copy less files as explained later in the build process.
      +

      To add to your system path: +

      +
      • Start menu -> Right click on Computer -> Properties -> Advanced system settings
      • +
      • Advanced tab -> Environment Variables...
      • +
      • Add the PATH/TO/GIT to the PATH
      • +
      • It should be separated from the others with a semicolon `;`
      +

      Configuration with CMake

      +

      The switch to CMake

      +
      Warning +

      Since FreeCAD version 0.9 we have stopped providing .vcproj files. +

      +
      +

      Currently, FreeCAD uses the CMake build system to generate build and make files that can be used between different operating systems and compilers. +If you want build former versions of FreeCAD (0.8 and older) see +Building older versions later in this article. +

      We switched because it became more and more painful to maintain project files for 30+ +build targets and x compilers. CMake gives us the possibility to support alternative +IDEs, like Code::Blocks, Qt Creator and Eclipse CDT. +The main compiler is still MS VC9 Express, though. But we plan for the future a build process on +Windows without proprietary compiler software. +

      +

      CMake

      +

      The first step to build FreeCAD with CMake is to configure the environment. There +are two ways to do it: +

      +
      • Using the LibPack
      • +
      • Installing all the needed libraries and let CMake find them
      +


      +The following process will assume you are using the LipPack. The second option may be discussed +in Options for the Build Process. +

      +

      Configure CMake using GUI

      +
      • Open the CMake GUI
      • +
      • Specify the source folder
      • +
      • Specify the build folder
      • +
      • Click Configure
      • +
      • Specify the generator according to the IDE that you'll use.
      +


      +This will begin configuration and should fail because the location of +FREECAD_LIBPACK_DIR is unset. +

      +
      • Expand the FREECAD category and set FREECAD_LIBPACK_DIR to the correct location
      • +
      • Check FREECAD_USE_EXTERNAL_PIVY
      • +
      • Optionally Check FREECAD_USE_FREETYPE this is required to use the Draft WB's Shape String functionality
      • +
      • Click Configure again
      • +
      • There should be no errors
      • +
      • Click Generate
      • +
      • Close CMake
      • +
      • Copy libpack\bin folder into the new build folder CMake created
      +

      Options for the Build Process

      +

      The CMake build system gives us a lot more flexibility over the build process. That means +we can switch on and off some features or modules. It's in a way like the Linux kernel build. +You have a lot of switches to determine the build process. +

      Here is the description of some of these switches. They will most likely change a lot in the future +because we want to increase the build flexibility a lot more. +


      +

      + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
      Link table +
      Variable name Description Default +
      FREECAD_LIBPACK_USE Switch the usage of the FreeCAD LibPack on or off On Win32 on, otherwise off +
      FREECAD_LIBPACK_DIR Directory where the LibPack is FreeCAD SOURCE dir +
      FREECAD_BUILD_GUI Build FreeCAD with all Gui related modules ON +
      FREECAD_BUILD_CAM Build the CAM module, experimental! OFF +
      FREECAD_BUILD_INSTALLER Create the project files for the Windows installer. OFF +
      FREECAD_BUILD_DOXYGEN_DOCU Create the project files for source code documentation. OFF +
      FREECAD_MAINTAINERS_BUILD Switch on stuff needed only when you do a Release build. OFF +
      +

      If you are building with Qt Creator, jump to +Building with Qt Creator, +otherwise proceed to +Building with Visual Studio 9 2008. +

      +

      Building FreeCAD

      +

      Depending on your current setup, the process for building FreeCAD will be slightly different. This is due to the differences in available software and software versions for each operating system. +


      +The following procedure will work for compiling on Windows Vista/7/8, for XP an alternate VS tool set is required for VS 2012 and 2013, which has not been tested successfully with the current Libpacks. To target XP(both x32 and x64) it is recommended to use VS2008 and Libpack FreeCADLibs_11.0_x86_VC9.7z +

      +
      +

      Building with Visual Studio 12 2013

      +
      +

      Make sure to specify Visual Studio 12 x64(or the alternate C-Compiler you are using) as the generator in CMake before you continue. +

      +
      • Start Visual Studio 12 2013 by clicking on the desktop icon created at installation.
      +
      • Open the project by:
      +

      File -> Open -> Project/Solution +

      +
      • Open FreeCAD_Trunk.sln from the build folder CMake created
      +
      • Switch the Solutions Configuration drop down at the top to Release X64
      +

      This may take a while depending on your sytem +

      +
      • Build -> Build Solution
      +
      • This will take a long time...
      +

      If you don't get any errors you are done. Exit Visual Studio and start FreeCAD by double clicking the FreeCAD icon in the bin folder of the build directory. +

      +
      +
      +
      +

      Building with Visual Studio 9 2008

      +
      Warning +

      Since early 0.17 cycle Freecad uses c++11 features that are not supported by 2008 version +

      +
      +


      +

      +

      Building with Qt Creator

      +
      +

      Installation and configuration of Qt Creator

      +
      • Download and install Qt Creator
      • +
      • Tools -> Options -> Text Editor -> Behavior tab: +
        • File Encodings -> Default Encodings:
        • +
        • Set to: ISO-8859-1 /...csISOLatin1 (Certain characters create errors/warnings with Qt Creator if left set to UTF-8. This seems to fix it.)
      • +
      • Tools -> Options -> Build & Run: +
        • CMake tab +
          • Fill Executable box with path to cmake.exe
        • +
        • Kits tab +
          • Name: MSVC 2008
          • +
          • Compiler: Microsoft Visual C++ Compiler 9.0 (x86)
          • +
          • Debugger: Auto detected...
          • +
          • Qt version: None
        • +
        • General tab +
          • Uncheck: Always build project before deploying it
          • +
          • Uncheck: Always deploy project before running it
      +

      Import project and Build

      +
      • File -> Open File or Project
      • +
      • Open CMakeLists.txt which is in the top level of the source
      • +
      • This will start CMake
      • +
      • Choose build directory and click next
      • +
      • Set generator to NMake Generator (MSVC 2008)
      • +
      • Click Run CMake. Follow the instructions depicted above to configure CMake to your liking.
      +

      Now FreeCAD can be built +

      +
      • Build -> Build All
      • +
      • This will take a long time...
      +

      Once complete, it can be run: +There are 2 green triangles at the bottom left. One is debug. +The other is run. Pick whichever you want. +

      +
      +
      +
      +

      Command line build

      +
      +

      Here an example how to build FreeCAD from the Command line: +

      +
       rem @echo off
      + rem   Build script, uses vcbuild to completetly build FreeCAD
      + 
      + rem update trunc
      + d:
      + cd "D:\_Projekte\FreeCAD\FreeCAD_0.9"
      + "C:\Program Files (x86)\Subversion\bin\svn.exe" update 
      + 
      + rem  set the aprobiated Variables here or outside in the system
      + 
      + set PATH=C:\WINDOWS\system32;C:\WINDOWS;C:\WINDOWS\System32\Wbem
      + set INCLUDE=
      + set LIB=
      + 
      + rem Register VS Build programms
      + call "C:\Program Files (x86)\Microsoft Visual Studio 9.0\VC\vcvarsall.bat"
      + 
      + rem Set Standard include paths
      + set INCLUDE=%INCLUDE%;%FrameworkSDKDir%\include
      + set INCLUDE=%INCLUDE%;C:\Program Files\Microsoft SDKs\Windows\v6.0A\Include
      + 
      + rem Set lib Pathes
      + set LIB=%LIB%;C:\Program Files\Microsoft SDKs\Windows\v6.0A\Lib
      + set LIB=%LIB%;%PROGRAMFILES%\Microsoft Visual Studio\VC98\Lib
      + 
      + rem Start the Visuall Studio build process
      + "C:\Program Files (x86)\Microsoft Visual Studio 9.0\VC\vcpackages\vcbuild.exe" "D:\_Projekte\FreeCAD FreeCAD_0.9_build\FreeCAD_trunk.sln" /useenv
      +
      +
      +


      +

      +

      Building older versions

      +

      Using LibPack

      +

      To make it easier to get FreeCAD compiled, we provide a collection of all +needed libraries. It's called the LibPack. You can find it on the download page on +sourceforge. +

      You need to set the following environment variables: +

      +
      FREECADLIB = "D:\Wherever\LIBPACK"
      +
      QTDIR = "%FREECADLIB%"
      +

      Add "%FREECADLIB%\bin" and "%FREECADLIB%\dll" to the system PATH variable. Keep in mind that you have to replace "%FREECADLIB%" with the path name, since Windows does not recursively replace environment variables. +

      +

      Directory setup in Visual Studio

      +

      Some search path of Visual Studio need to be set. +To change them, use the menu Tools→Options→Directory +

      +
      Includes
      +

      Add the following search path to the include path search list: +

      +
      •  %FREECADLIB%\include
      • +
      •  %FREECADLIB%\include\Python
      • +
      •  %FREECADLIB%\include\boost
      • +
      •  %FREECADLIB%\include\xercesc
      • +
      •  %FREECADLIB%\include\OpenCascade
      • +
      •  %FREECADLIB%\include\OpenCV
      • +
      •  %FREECADLIB%\include\Coin
      • +
      •  %FREECADLIB%\include\SoQt
      • +
      •  %FREECADLIB%\include\QT
      • +
      •  %FREECADLIB%\include\QT\Qt3Support
      • +
      •  %FREECADLIB%\include\QT\QtCore
      • +
      •  %FREECADLIB%\include\QT\QtGui
      • +
      •  %FREECADLIB%\include\QT\QtNetwork
      • +
      •  %FREECADLIB%\include\QT\QtOpenGL
      • +
      •  %FREECADLIB%\include\QT\QtSvg
      • +
      •  %FREECADLIB%\include\QT\QtUiTools
      • +
      •  %FREECADLIB%\include\QT\QtXml
      • +
      •  %FREECADLIB%\include\Gts
      • +
      •  %FREECADLIB%\include\zlib
      +
      Libs
      +

      Add the following search path to the lib path search list: +

      +
      •  %FREECADLIB%\lib
      +
      Executables
      +

      Add the following search path to the executable path search list: +

      +
      •  %FREECADLIB%\bin
      • +
      • TortoiseSVN binary installation directory, usually "C:\Programm Files\TortoiseSVN\bin", this is needed for a distribution build when SubWVRev.exe is used to extract the version number from Subversion.
      +

      Python needed

      +

      During the compilation some Python scripts get executed. So the Python +interpreter has to function on the OS. Use a command box to check it. If +the Python library is not properly installed you will get an error message +like Cannot find python.exe. If you use the LibPack you can also use the +python.exe in the bin directory. +

      +

      Special for VC8

      +

      When building the project with VC8, you have to change the link information for the WildMagic library, since you need a different version for VC6 and VC8. Both versions are supplied in LIBPACK/dll. In the project properties for AppMesh change the library name for the wm.dll to the VC8 version. Take care to change it in Debug and Release configuration. +

      +

      Compile

      +

      After you conform to all prerequisites the compilation is - hopefully - only a mouse click in VC +

      +

      After Compiling

      +

      To get FreeCAD up and running from the compiler environment you need to copy a few files from the LibPack to the bin folder where FreeCAD.exe is installed after a successful build: +

      +
      • python.exe and python_d.exe from LIBPACK/bin
      • +
      • python25.dll and python25_d.dll from LIBPACK/bin
      • +
      • python25.zip from LIBPACK/bin
      • +
      • make a copy of Python25.zip and rename it to Python25_d.zip
      • +
      • QtCore4.dll from LIBPACK/bin
      • +
      • QtGui4.dll from LIBPACK/bin
      • +
      • boost_signals-vc80-mt-1_34_1.dll from LIBPACK/bin
      • +
      • boost_program_options-vc80-mt-1_34_1.dll from LIBPACK/bin
      • +
      • xerces-c_2_8.dll from LIBPACK/bin
      • +
      • zlib1.dll from LIBPACK/bin
      • +
      • coin2.dll from LIBPACK/bin
      • +
      • soqt1.dll from LIBPACK/bin
      • +
      • QtOpenGL4.dll from LIBPACK/bin
      • +
      • QtNetwork4.dll from LIBPACK/bin
      • +
      • QtSvg4.dll from LIBPACK/bin
      • +
      • QtXml4.dll from LIBPACK/bin
      +

      When using a LibPack with a Python version older than 2.5 you have to copy two further files: +

      +
      • zlib.pyd and zlib_d.pyd from LIBPACK/bin/lib. This is needed by python to open the zipped python library.
      • +
      • _sre.pyd and _sre_d.pyd from LIBPACK/bin/lib. This is needed by python for the built in help system.
      +

      If you don't get it running due to a Python error it is very likely that one of the zlib*.pyd files is missing. +

      Alternatively, you can copy the whole bin folder of libpack into bin folder of the build. This is easier, but takes time and disk space. This can be substited by making links instead of copying files, see CompileOnWindows - Reducing Disk Footprint. +

      +

      Additional stuff

      +

      If you whant to build the source code documentation you need DoxyGen. +

      To create an intstaller package you need WIX. +


      +During the compilation some Python scripts get executed. So the Python interpreter has to work properly. +

      For more details have also a look to README.Linux in your sources. +

      First of all you should build the Qt plugin that provides all custom widgets of FreeCAD we need for the Qt Designer. The sources are located under +

      +
      +//src/Tools/plugins/widget//.
      +
      +

      So far we don't provide a makefile -- but calling +

      +
      +qmake plugin.pro
      +
      +

      creates it. Once that's done, calling make will create the library +

      +
      +//libFreeCAD_widgets.so//.
      +
      +

      To make this library known to your Qt Designer you have to copy the file to +

      +
      +//$QTDIR/plugin/designer//.
      +
      +

      References

      + +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/CompileOnWindows_-_Reducing_Disk_Footprint.html b/localwiki/CompileOnWindows_-_Reducing_Disk_Footprint.html new file mode 100644 index 0000000..6d732dc --- /dev/null +++ b/localwiki/CompileOnWindows_-_Reducing_Disk_Footprint.html @@ -0,0 +1,154 @@ +CompileOnWindows - Reducing Disk Footprint

      CompileOnWindows - Reducing Disk Footprint

      + +

      Techniques to reduce disk space required for building FreeCAD on Windows +This may be of use to those, who are limited on disk space (for example, because of an SSD), and for those, who want to avoid installing complete Visual Studio. +

      It is recommended that you know on practice, how to CompileOnWindows with Qt Creator, before attempting this. +

      + + +

      Setting up MSVC2013 compiler without installing Visual Studio

      +

      requirements: +

      +
      • another computer where complete Visual Studio is/can be installed (in theory, this can be achieved by unpacking VS installers, but there is no instructions about this here)
      +

      getting the compiler

      +

      0. In order to get the compiler files, go to another computer and locate the actual compiler. Example of path to compiler: drive:\path\to\visual\studio\VC\bin. +

      1. Copy the compiler binaries and standard libraries to another computer. That is, copy the following folders to C:\Qt\msvc12rip: +

      +
      • drive:\path\to\visual\studio\VC\bin
      • +
      • drive:\path\to\visual\studio\VC\lib
      • +
      • drive:\path\to\visual\studio\VC\include
      +

      2. Install Windows SDK. For those who don't know, it is a set of headers, libs and tools to compile Windows programs. Note, where it is installed to. Example path: C:\Program Files (x86)\Windows Kits\8.1 +

      3. Install CMake and Qt creator (just the creator, i.e. the environment, not the actual Qt, to save space). +

      4. Set up a custom compiler in Qt Creator. Read on to see how. +

      +

      compiler in Qt Creator

      +

      32-bit

      +

      Setting the compiler for 32 bit is quite straightforward. +

      4.1. Set up the compiler under Compilers tab in settings: Add a custom compiler: +

      +
      • name = msvcrip (the name doesn't matter, it is up to you)
      • +
      • Compiler path: C:\Qt\msvc12rip\VC\bin\cl.exe
      • +
      • Make path: C:\Qt\msvc12rip\VC\bin\nmake.exe
      • +
      • ABI: x86-windows-msvc2013-pe-32bit
      • +
      • header paths - nothing
      • +
      • error parser: MSVC
      +

      Msvc-no-vs compiler-setup-32.png +

      4.2. Under kits tab, I added a kit, and set it up like this: +

      +
      • name: FreeCAD32 (again, up to you)
      • +
      • Device type: Desktop
      • +
      • Device: Local PC
      • +
      • Compiler: msvcrip (or whatever you named it in step 1)
      • +
      • Environment: (correct the paths to your setup)
      +
      INCLUDE=C:\Program Files (x86)\Windows Kits\8.1\Include\um\;C:\Qt\msvc12rip\VC\include\
      +LIB=C:\Qt\msvc12rip\VC\lib\;C:\Program Files (x86)\Windows Kits\8.1\Lib\winv6.3\um\x86\
      +LIBPATH=C:\Qt\msvc12rip\VC\lib\;C:\Program Files (x86)\Windows Kits\8.1\Lib\winv6.3\um\x86\
      +PATH=C:\Qt\msvc12rip\VC\bin\;C:\Program Files (x86)\Windows Kits\8.1\bin\x86\;C:\Qt\git\bin\ 
      +

      Note the path to git.exe in PATH. It is optional, but if not specified, the version info will be incomplete in FreeCAD's About. +

      +
      • Debugger: (optional) set to 32-bit (x86)
      • +
      • Qt version: None
      +

      Msvc-no-vs kit-setup-32.png +

      The environment part of the settings took me the most trouble to configure +

      +

      64-bit

      +

      This is a little bit more tricky than 32-bit compiler. The main problem was that there is no nmake executable in C:\Qt\msvc12rip\VC\bin\x86_amd64, and nmake keeps using the 32-bit compiler. To counter the problem, create a special folder "C:\Qt\msvc12rip\VC\bin\x86_amd64_sa", where mnake and 64-bit cl are combined. Read on for step-by-step instructions. +

      4.1. in C:\Qt\msvc12rip\VC\bin, create a folder named x86_amd64_sa (sa stands for Stand-Alone, use whatever name you like). +

      4.2. copy contents of folder C:\Qt\msvc12rip\VC\bin into x86_amd64_sa folder (now you have a 32-bit compiler there) +

      4.3. copy contents of folder x86_amd64 into x86_amd64_sa, replacing files in the process. Now you have a 64bit compiler with nmake there. +

      4.4. Set up the compiler under Compilers tab in settings: Add a custom compiler: +

      +
      • name = msvcrip64 (the name doesn't matter, it is up to you)
      • +
      • Compiler path: C:\Qt\msvc12rip\VC\bin\x86_amd64_sa\cl.exe
      • +
      • Make path: C:\Qt\msvc12rip\VC\bin\x86_amd64_sa\nmake.exe
      • +
      • ABI: x86-windows-msvc2013-pe-64bit
      • +
      • header paths - nothing
      • +
      • error parser: MSVC
      +

      4.5. Under kits tab, add a kit, and set it up like this: +

      +
      • name: FreeCAD64 (again, up to you)
      • +
      • Device type: Desktop
      • +
      • Device: Local PC
      • +
      • Compiler: msvcrip64 (or whatever you named it in step 4.4)
      • +
      • Environment: (correct the paths to your setup) (compared to 32-bit, amd64/x64 has appeared or has replaced x86 in several places)
      +
      INCLUDE=C:\Program Files (x86)\Windows Kits\8.1\include\shared\;C:\Program Files (x86)\Windows Kits\8.1\include\um\;C:\Qt\msvc12rip\VC\include
      +LIB=C:\Program Files (x86)\Windows Kits\8.1\lib\winv6.3\um\x64\;C:\Qt\msvc12rip\VC\lib\amd64\
      +LIBPATH=C:\Program Files (x86)\Windows Kits\8.1\References\CommonConfiguration\Neutral\
      +PATH=C:\Qt\msvc12rip\VC\bin\x86_amd64_sa\;C:\Program Files (x86)\Windows Kits\8.1\bin\x64\;C:\Qt\git\bin\ 
      +

      Note the path to git.exe in PATH. It is optional, but if not specified, the version info will be incomplete in FreeCAD's About. +

      +
      • Debugger: (optional) set to 64-bit (x64)
      • +
      • Qt version: None
      +

      Tip: set up another kit+compiler pair for using jom instead of nmake, to enable multicore build. The configuration is identical to 64-bit with nmake, except that Make in compiler tab should point to jom.exe. Example path to jom: C:\Qt\Qt542\Tools\QtCreator\bin\jom.exe (you should be able to find jom under where your Qt creator is installed). +

      All the rest is identical to the normal way one would compile FreeCAD. +

      +

      testing compiler and building FreeCAD

      +

      requirements: +

      +
      • FreeCAD source code (see CompileOnWindows)
      • +
      • Correct libpack, extracted. ("correct" means that it has to match the compiler and bit-ness) (see CompileOnWindows)
      +

      Open FreeCAD (CMakeLists.txt) with Qt creator, and it will invite you to run cmake. Run it. CMake will build a test program, to see if the compiler works. If the compiler doesn't work, it will show an error telling exactly that, and listing the build output. The build output should help you identify, what's going wrong. Here is a small list of typical errors: +

      +
      • Can't open Kernel32.lib - something's wrong with LIB or LIBPATH environment variables (note: they set under kits tab in Qt, not in windows!)
      • +
      • Can't resolve external symbol - something's wring with LIB or LIBPATH (they probably point to .lib-s of wrong bit-ness)
      • +
      • Manifest-related error - PATH does not point to a location where a resource compiler (rc.exe) of right bit-ness is located.
      • +
      • Can't locate include - the include location list should contain path to standard headers (C:\Qt\msvc12rip\VC\include on my machine)
      +

      To run FreeCAD built with type "Debug", debug versions of MSVC2013 redistributable libraries (msvcp120d.dll, msvcr120d.dll) must be present somewhere reacheable through PATH (system-wide, this time). +

      You can obtain these dlls from the other computer that has the Visual Studio you ripped the compiler off. Alternatively, these dlls can be extracted from visual studio installer directly, which is very easy: +

      +
      • mount the downloaded .iso image as a disk (drive D: on my system)
      • +
      • locate the files: +
        • D:\packages\vc_librarycore86\cab3.cab/F_REDIST_DLL_APPLOCAL_msvcp120d_x64 (<- or x86, if you are building 32-bit)
        • +
        • D:\packages\vc_librarycore86\cab3.cab/F_REDIST_DLL_APPLOCAL_msvcr120d_x64
      • +
      • extract the files, and name them "msvcp120d.dll", "msvcr120d.dll"
      • +
      • copy the files to libpack folder, into bin
      +

      avoiding copying any libpack files to launch FreeCAD

      +

      requirements: +

      +
      • Windows Vista and later
      • +
      • NTFS file system (? maybe not...)
      +

      The idea is very simple: instead of copying files - make links. On Windows, symbolic links are available for the purpose. A link makes the linked file appear to be where the link is, but the file is actually stored somewhere else. Links can be made using batch command mklink. +

      Since there are way too many files to make links manually, a batch script should be used. Here is an example of such a script: +

      +links_libpack.bat:
      @set libpackpath=C:\_vt\dev\PC\Qt\FreeCAD\libpack\active
      +@set builddir=%1
      +pushd %libpackpath%\bin
      +for %%i in (*) do mklink "%builddir%\bin\%%i" "%libpackpath%\bin\%%i"
      +for /D %%s in (*) do mklink /d "%builddir%\bin\%%s" "%libpackpath%\bin\%%s"
      +popd
      +pause 
      +

      First for loop creates links to files, the second loop - links to folders.
      +You'll have to modify the path to libpack to match yours. Use absolute paths. Then, feed FreeCAD build folder path (full path!) to the script as an argument. +

      This batch must be run with administrator privileges (or, you can set to allow users use mklink in local security policy settings in Windows). The batch may fail, if there are spaces in paths (it may work, but it is untested). Tip: create a shortcut to links_libpack.bat, set it up to run as admin (in shortcut properties), and drag the build folder onto the shortcut. +

      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Compile_on_Windows_with_VS2013.html b/localwiki/Compile_on_Windows_with_VS2013.html new file mode 100644 index 0000000..12d6d20 --- /dev/null +++ b/localwiki/Compile_on_Windows_with_VS2013.html @@ -0,0 +1,119 @@ +Compile on Windows with VS2013

      Compile on Windows with VS2013

      + +

      The following procedure will work for compiling on Windows Vista/7/8, for XP an alternate VS tool set is required for VS 2012 and 2013, which has not been tested successfully with the current Libpacks. To target XP(both x32 and x64) it is recommended to use VS2008 and Libpack FreeCADLibs_11.0_x86_VC9.7z +

      + + +

      Prerequisites

      +

      Windows Libpack

      +

      FreeCAD is built upon a number of third party libraries. For the users convenience FreeCAD supplies Libpacks that contain all the necessary dependencies so you don't have to compile them yourself. +

      First you'll need to download a Windows Libpack. FreeCAD Windows Libpacks are available here: +http://sourceforge.net/projects/free-cad/files/FreeCAD%20LibPack/ +

      Libpacks are available for x32 and x64 for VC12(Visual Studio 2013), VC11(Visual Studio 2012), and VC9(Visual Studio 2008) +The Libpacks will work with both the Professional and Express/Community Editions of Visual Studio. Choose the Libpack relevant to your system architecture and Compiler. +

      Assuming that your Win Vista or later, x64, and planning to use VS2013 Community Edition choose: +

      FreeCADLibs_11.0_x64_VC12.7z +

      Extract the Libpack to a directory on your hard drive. +

      You can download 7-zip if you need it here: http://www.7-zip.org/ +

      +

      Source Code

      +

      Using Git(Preferred)

      +

      Next you will need to install git to be able to download the source code. You can get Git here: +http://git-scm.com/downloads +

      Some information how to set-up a local tracking branch and a working branch can be found here: +

      http://www.freecadweb.org/wiki/index.php?title=Source_code_management +


      +To create a local tracking branch and download the source code you need to open a terminal(command prompt) and cd to the directory you want the source, then type: +

      git clone git://git.code.sf.net/p/free-cad/code free-cad-code +

      Now you have the source code and the tools you'll need to compile FreeCAD on Windows. +

      +

      Download Snapshot .zip(Alternate)This is Source Cade Snapshot not Development Snapshot pre-compiled binaries.

      +

      http://sourceforge.net/p/free-cad/code/ci/master/tarball +

      You will need to extract this to a directory using 7zip or Window's default .zip extractor. +

      NOTE: In order for Cmake to properly update your "About FreeCAD" information git must be installed and be present in your PATH environment variable, Therefore downloading with git is preferred. +

      +

      Cmake

      +

      Next you will need Cmake, you can get it here: +http://www.cmake.org/download/ +

      FreeCAD 0.15.xxxx master will configure and generate with Cmake 2.x.x or 3.x.x, you can download the latest version. Older versions of FreeCAD require Cmake 2.x.x +You should choose the non-default option to add Cmake to your system PATH environment variable. +

      +

      Visual Studio

      +

      Lastly you will need the C-compiler. MS VS 12 2013 Community Edition Update 4 is Free for personal and Open Source Projects. It can be downloaded here: +

      http://www.visualstudio.com/en-us/news/vs2013-community-vs.aspx +

      +

      Configuring and Generating with Cmake

      +

      First Pass

      +

      Start the CMake GUI by double-clicking on the desktop icon created during installation. +

      Specify source folder (This is where you cloned or extracted the source code) +

      Specify build folder (This is where you want to build the source, if it doesn't exist Cmake will prompt you to create it) +

      Click Configure +

      Specify the generator as Visual Studio 12 x64(or the alternate C-Compiler you are using) +

      This will begin configuration and should fail because the location of FREECAD_LIBPACK_DIR is unset. +

      Expand the FREECAD category and set: +

      +
      FREECAD_LIBPACK_DIR          "...\Path\to\Libpack" (Ex: C:\user\USERNAME\FreeCADLibs_11.0_x64_VC12)
      +FREECAD_USE_EXTERNAL_PIVY    (Check)
      +FREECAD_USE_FREETYPE         (Check) 
      +

      FREETYPE is optional. It is necessary to take advantage of the DRAFT Work Bench's Shape String functionality. Under normal situations it is a desirable option. +

      +

      Configure and Generate

      +

      Click Configure again (There should be no errors) +

      Click Generate (missing doxgen is OK, unless you are a developer and need the source documentation) +

      Close Cmake +

      +

      Dependencies

      +

      Copy The Libpack\bin folder into the new build folder CMake created. +


      +You could put the Libpack in your system PATH environment variable. but you still are required to copy some files? +

      +

      Building with Visual Studio

      +

      Start Visual Studio 12 2013 by clicking on the desktop icon created at installation. +

      Open the project by: +File -> Open -> Project/Solution +

      Open FreeCAD_Trunk.sln from the build folder CMake created +

      Switch the Solutions Configuration drop down at the top to Release X64 +

      Build -> Build Solution +

      This will take a long time... +

      If you don't get any errors your done. Exit Visual Studio and start FreeCAD by double clicking the FreeCAD icon in the bin folder of the build directory. +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Compiling.html b/localwiki/Compiling.html new file mode 100644 index 0000000..53ac01b --- /dev/null +++ b/localwiki/Compiling.html @@ -0,0 +1,38 @@ +Compiling

      Compiling

      + +

      Each operating system has its own page for compiling FreeCAD in the Online Help Documentation. +

      + + + + + + + + +
      'Windows' +'Linux' +'Mac' +
      Compile on Windows + Compile on Linux/Unix + Compile on Mac +
      +


      +It is also possible to compile FreeCAD on windows using Cygwin or MinGW. +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Compiling_(Speeding_up).html b/localwiki/Compiling_(Speeding_up).html new file mode 100644 index 0000000..c1bf24b --- /dev/null +++ b/localwiki/Compiling_(Speeding_up).html @@ -0,0 +1,43 @@ +Compiling (Speeding up)

      Compiling (Speeding up)

      + +

      When developing FreeCAD one needs to build from source and the compiling/build phase can start eating in to precious development time. Here are some tips to shorten that process and make build times more efficient. +

      + + +

      CCache

      +

      Install ccache to cache builds +

      +

      Disable Modules

      +

      Use cmake-curses-gui, cmake-qt-gui, or cmake flags to disable modules you aren't working on +

      +

      make -j

      +

      Use make -j # to specify the number of jobs. A suggested value is your number of computer cores, e.g. +

      +
      make -j $(nproc)
      +

      distcc

      +

      Distcc can be used for distributed compilation on a network. +

      + +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Complete.jpg b/localwiki/Complete.jpg new file mode 100644 index 0000000..68c82d0 Binary files /dev/null and b/localwiki/Complete.jpg differ diff --git a/localwiki/Complete.png b/localwiki/Complete.png new file mode 100644 index 0000000..0d6b034 Binary files /dev/null and b/localwiki/Complete.png differ diff --git a/localwiki/CompleteWorkbench.svg b/localwiki/CompleteWorkbench.svg new file mode 100644 index 0000000..7865be2 --- /dev/null +++ b/localwiki/CompleteWorkbench.svg @@ -0,0 +1,125 @@ + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + + + + + + diff --git a/localwiki/Complete_Workbench.html b/localwiki/Complete_Workbench.html new file mode 100644 index 0000000..0779166 --- /dev/null +++ b/localwiki/Complete_Workbench.html @@ -0,0 +1,34 @@ +Complete Workbench

      Complete Workbench

      + +
      +

      This documentation is not finished. Please help and contribute documentation. +

      See Draft ShapeString for good documented Command. Gui Command gives an overview over commands. And see List of Commands for other commands. +

      Go to Help FreeCAD to contribute. +

      +
      +


      +From Quality project: +

      ... Complete workbench ... is the starting workbench +for the average user (if there is one ). The complete workbench hold all +Commands and Features from all the modules and workbenches which met certain + quality criteria. That will hide away +the stormy development and half implemented features from the user which wants just model. +


      +ToDo +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Concentric_Constraint_Between_two_non_cylindrical_parts.gif b/localwiki/Concentric_Constraint_Between_two_non_cylindrical_parts.gif new file mode 100644 index 0000000..e51a590 Binary files /dev/null and b/localwiki/Concentric_Constraint_Between_two_non_cylindrical_parts.gif differ diff --git a/localwiki/Concentricity.svg b/localwiki/Concentricity.svg new file mode 100644 index 0000000..16447d7 --- /dev/null +++ b/localwiki/Concentricity.svg @@ -0,0 +1,119 @@ + + + + + Concentricity + + + + + + image/svg+xml + + Concentricity + + + bavariaSHAPE + + + + + bavariaSHAPE + + + + + bavariaSHAPE + + + 15.10.2016 + Geometric dimensioning and tolerancing symbols +All symbols in this repository are licensed under CC-BY 3.0 + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Concrete.svg b/localwiki/Concrete.svg new file mode 100644 index 0000000..b919a03 --- /dev/null +++ b/localwiki/Concrete.svg @@ -0,0 +1,191 @@ + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Console_API.html b/localwiki/Console_API.html new file mode 100644 index 0000000..e40fd87 --- /dev/null +++ b/localwiki/Console_API.html @@ -0,0 +1,83 @@ +Console API

      Console API

      + +

      This module is contained inside the FreeCAD module and contains methods to send text to FreeCAD's output console and status bar. The messages will have different color if they are message, warning or error. +

      Example: +

      +
      import FreeCAD
      +FreeCAD.Console.PrintMessage("Hello World!\n") 
      +


      +

      +
      +
      Method.png GetStatus ( "Log" or "Msg" or "Wrn" or "Err" )
      +
      +

      Description: Get the status for either Log, Msg, Wrn or Error for an observer +

      Returns: a status string. +

      +
      +
      +


      +

      +
      +
      Method.png PrintError ( string )
      +
      +

      Description: Prints an error message to the output +

      Returns: nothing +

      +
      +
      +


      +

      +
      +
      Method.png PrintLog ( string )
      +
      +

      Description: Prints a log message to the output +

      Returns: nothing +

      +
      +
      +


      +

      +
      +
      Method.png PrintMessage ( string )
      +
      +

      Description: Prints a message to the output +

      Returns: nothing +

      +
      +
      +


      +

      +
      +
      Method.png PrintWarning ( string )
      +
      +

      Description: Prints a warning to the output +

      Returns: nothing +

      +
      +
      +


      +

      +
      +
      Method.png SetStatus ( string )
      +
      +

      Description: Set the stats for either Log, Msg, Wrn or Error for an observer +

      Returns: +

      +
      +
      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Const_member.svg b/localwiki/Const_member.svg new file mode 100644 index 0000000..e32beb1 --- /dev/null +++ b/localwiki/Const_member.svg @@ -0,0 +1,282 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Constrain1.png b/localwiki/Constrain1.png new file mode 100644 index 0000000..0e22787 Binary files /dev/null and b/localwiki/Constrain1.png differ diff --git a/localwiki/Constrain2.png b/localwiki/Constrain2.png new file mode 100644 index 0000000..adc1e79 Binary files /dev/null and b/localwiki/Constrain2.png differ diff --git a/localwiki/Constrain3.png b/localwiki/Constrain3.png new file mode 100644 index 0000000..fd358ce Binary files /dev/null and b/localwiki/Constrain3.png differ diff --git a/localwiki/Constraint180_600x400.png b/localwiki/Constraint180_600x400.png new file mode 100644 index 0000000..381e229 Binary files /dev/null and b/localwiki/Constraint180_600x400.png differ diff --git a/localwiki/Constraint_Concentric.html b/localwiki/Constraint_Concentric.html new file mode 100644 index 0000000..a3b4ec2 --- /dev/null +++ b/localwiki/Constraint_Concentric.html @@ -0,0 +1,66 @@ +Constraint Concentric

      Constraint Concentric

      + +
      +

      This documentation is not finished. Please help and contribute documentation. +

      See Draft ShapeString for good documented Command. Gui Command gives an overview over commands. And see List of Commands for other commands. +

      Go to Help FreeCAD to contribute. +

      +
      +


      +

      + + + + + + + + + + + + + + + + + + + + +
      +

      Constraint Concentric.png Constraint Concentric

      +
      Menu location +
      Sketch → Sketcher constraints → Concentric +
      Workbenches +
      Sketcher, PartDesign +
      Default shortcut +
      +
      See also +
      +

      Contents

      + +
      + +
      +


      +

      Currently not used by FreeCAD +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Constraint_Concentric.svg b/localwiki/Constraint_Concentric.svg new file mode 100644 index 0000000..1dea829 --- /dev/null +++ b/localwiki/Constraint_Concentric.svg @@ -0,0 +1,135 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [wmayer] + + + Constraint_Concentric + 2011-10-10 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Sketcher/Gui/Resources/icons/Constraint_Concentric.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + diff --git a/localwiki/Constraint_Draft00.gif b/localwiki/Constraint_Draft00.gif new file mode 100644 index 0000000..8dda279 Binary files /dev/null and b/localwiki/Constraint_Draft00.gif differ diff --git a/localwiki/Constraint_Draft01.gif b/localwiki/Constraint_Draft01.gif new file mode 100644 index 0000000..796dd45 Binary files /dev/null and b/localwiki/Constraint_Draft01.gif differ diff --git a/localwiki/Constraint_Draft_Code01.gif b/localwiki/Constraint_Draft_Code01.gif new file mode 100644 index 0000000..303f779 Binary files /dev/null and b/localwiki/Constraint_Draft_Code01.gif differ diff --git a/localwiki/Constraint_Ellipse_Axis_Angle.svg b/localwiki/Constraint_Ellipse_Axis_Angle.svg new file mode 100644 index 0000000..5b39030 --- /dev/null +++ b/localwiki/Constraint_Ellipse_Axis_Angle.svg @@ -0,0 +1,98 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [Abdullah Tahiri] + + + Constraint_Ellipse_Axis_Angle + 2014-11-11 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Sketcher/Gui/Resources/icons/Constraint_Ellipse_Axis_Angle.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Constraint_Ellipse_Major_Radius.svg b/localwiki/Constraint_Ellipse_Major_Radius.svg new file mode 100644 index 0000000..a77b30b --- /dev/null +++ b/localwiki/Constraint_Ellipse_Major_Radius.svg @@ -0,0 +1,93 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [Abdullah Tahiri] + + + Constraint_Ellipse_Major_Radius + 2014-11-11 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Sketcher/Gui/Resources/icons/Constraint_Ellipse_Major_Radius.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + diff --git a/localwiki/Constraint_Ellipse_Minor_Radius.svg b/localwiki/Constraint_Ellipse_Minor_Radius.svg new file mode 100644 index 0000000..de8774b --- /dev/null +++ b/localwiki/Constraint_Ellipse_Minor_Radius.svg @@ -0,0 +1,93 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [Abdullah Tahiri] + + + Constraint_Ellipse_Minor_Radius + 2014-11-11 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Sketcher/Gui/Resources/icons/Constraint_Ellipse_Minor_Radius.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + diff --git a/localwiki/Constraint_Ellipse_Radii.svg b/localwiki/Constraint_Ellipse_Radii.svg new file mode 100644 index 0000000..1df060e --- /dev/null +++ b/localwiki/Constraint_Ellipse_Radii.svg @@ -0,0 +1,96 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [Abdullah Tahiri] + + + Constraint_Ellipse_Radii + 2014-11-11 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Sketcher/Gui/Resources/icons/Constraint_Ellipse_Radii.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + diff --git a/localwiki/Constraint_EqualLength.html b/localwiki/Constraint_EqualLength.html new file mode 100644 index 0000000..5e194d7 --- /dev/null +++ b/localwiki/Constraint_EqualLength.html @@ -0,0 +1,84 @@ +Constraint EqualLength

      Constraint EqualLength

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Constraint EqualLength.png Constraint EqualLength

      +
      Menu location +
      Sketch → Sketcher constraints → Constrain equal +
      Workbenches +
      Sketcher, PartDesign +
      Default shortcut +
      E +
      See also +
      Constraint Radius +

      + +
      +


      +

      +

      Description

      +

      The Constrain Equal constraint forces two or more line segments in a line , poly-line or rectangle to have equal length. If applied to arcs or circles the radii are constrained to be equal. It cannot be applied to geometry primitives which are not of the same type (e.g. line segments and arcs). +

      +

      Operation

      +

      The example sketch below contains a number of sketch primitives ( line,poly-line, rectangle, arc and circle).

      +EqualConstraint1.png

      +Select two or more line segments (e.g. line and one side of the rectangle).

      +EqualConstraint2.png

      +Click on the Constrain Equal icon Constraint EqualLength.png in the Sketcher toolbar (in either the Sketcher or Part Design workbenches) or select the Constrain Equal menu item from the Sketcher constraints sub menu item in either the Sketch or Part Design menu item depending upon which workbench is selected (Sketcher or Part Design) to apply the constraint to the selected items.

      +EqualConstraint3.png

      +Now select the arc and the circle in the sketch.

      +EqualConstraint4.png

      +and apply the Constrain Equal Constraint EqualLength.png constraint as before.

      +EqualConstraint5.png

      +Now select the line segment, all segments of the poly-line and one of the remaining unconstrained sides of the rectangle

      +EqualConstraint6.png

      +and apply the Constrain Equal Constraint EqualLength.png constraint as before.

      +EqualConstraint7.png

      +Select the line segment and the arc

      +EqualConstraint8.png

      +and apply the Constrain Equal Constraint EqualLength.png constraint as before. A pop-up message indicates that the constrained items have to be of the same geometrical type (lines of zero curvature or lines of non-zero curvature).

      +EqualConstraint9.png +

      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Constraint_EqualLength.svg b/localwiki/Constraint_EqualLength.svg new file mode 100644 index 0000000..2be8fae --- /dev/null +++ b/localwiki/Constraint_EqualLength.svg @@ -0,0 +1,99 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [wmayer] + + + Constraint_EqualLength + 2011-10-10 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Sketcher/Gui/Resources/icons/Constraint_EqualLength.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + diff --git a/localwiki/Constraint_ExternalAngle.html b/localwiki/Constraint_ExternalAngle.html new file mode 100644 index 0000000..feb82e4 --- /dev/null +++ b/localwiki/Constraint_ExternalAngle.html @@ -0,0 +1,66 @@ +Constraint ExternalAngle

      Constraint ExternalAngle

      + +
      +

      This documentation is not finished. Please help and contribute documentation. +

      See Draft ShapeString for good documented Command. Gui Command gives an overview over commands. And see List of Commands for other commands. +

      Go to Help FreeCAD to contribute. +

      +
      +


      +

      + + + + + + + + + + + + + + + + + + + + +
      +

      Constraint ExternalAngle.png Constraint ExternalAngle

      +
      Menu location +
      Sketch → Sketcher constraints → ExternalAngle +
      Workbenches +
      Sketcher, PartDesign +
      Default shortcut +
      +
      See also +
      +

      + +
      +


      +

      Currently not used by FreeCAD +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Constraint_ExternalAngle.svg b/localwiki/Constraint_ExternalAngle.svg new file mode 100644 index 0000000..99070bb --- /dev/null +++ b/localwiki/Constraint_ExternalAngle.svg @@ -0,0 +1,93 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [wmayer] + + + Constraint_ExternalAngle + 2011-10-10 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Sketcher/Gui/Resources/icons/Constraint_ExternalAngle.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + diff --git a/localwiki/Constraint_H_Distance.png b/localwiki/Constraint_H_Distance.png new file mode 100644 index 0000000..6c88e6e Binary files /dev/null and b/localwiki/Constraint_H_Distance.png differ diff --git a/localwiki/Constraint_Horizontal.html b/localwiki/Constraint_Horizontal.html new file mode 100644 index 0000000..b053d42 --- /dev/null +++ b/localwiki/Constraint_Horizontal.html @@ -0,0 +1,85 @@ +Constraint Horizontal

      Constraint Horizontal

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Constraint Horizontal.png Constraint Horizontal

      +
      Menu location +
      Sketch → Sketcher constraints → Constrain horizontally +
      Workbenches +
      Sketcher, PartDesign +
      Default shortcut +
      None +
      See also +
      Constraint Vertical +

      + +
      +


      +

      +

      Description

      +

      The Horizontal Constraint forces a selected line or lines in the image to be parallel to the horizontal axis of the sketch. +

      +

      Operation

      +
      HorizontalConstraint1.png
      +

      Select a line in the sketch by clicking on it. +
      +

      +
      HorizontalConstraint2.png
      +

      The line turns dark green. +
      +

      +
      HorizontalConstraint3.png
      +

      Apply the Horizontal Constraint by clicking on the Horizontal Constraint icon Constraint Horizontal.png in the Sketcher Constraints toolbar or by selecting the Constrain horizontally menu item in the Sketcher constraints sub menu of the Sketcher menu item in the Sketcher work bench (or the Part Design menu item of the Part Design work bench). The selected line is constrained to be parallel to the horizontal axis of the sketch. +
      +

      +
      HorizontalConstraint4.png
      +

      Multiple lines may be selected, +
      +

      +
      HorizontalConstraint5.png
      +

      and then applying the constraint as described above, they are constrained to be parallel to the sketch horizontal axis. +
      +

      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Constraint_Horizontal.svg b/localwiki/Constraint_Horizontal.svg new file mode 100644 index 0000000..1f72a13 --- /dev/null +++ b/localwiki/Constraint_Horizontal.svg @@ -0,0 +1,78 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [wmayer] + + + Constraint_Horizontal + 2011-10-10 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Sketcher/Gui/Resources/icons/Constraint_Horizontal.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + diff --git a/localwiki/Constraint_HorizontalDistance.html b/localwiki/Constraint_HorizontalDistance.html new file mode 100644 index 0000000..e514b04 --- /dev/null +++ b/localwiki/Constraint_HorizontalDistance.html @@ -0,0 +1,71 @@ +Constraint HorizontalDistance

      Constraint HorizontalDistance

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Constraint HorizontalDistance.png Constraint HorizontalDistance

      +
      Menu location +
      Sketch → Sketcher constraints → Constrain horizontal distance +
      Workbenches +
      Sketcher, PartDesign +
      Default shortcut +
      None +
      See also +
      Constraint Length, Constraint VerticalDistance +

      + +
      +


      +

      +

      Description

      +

      Fixes the horizontal distance between 2 points or line ends. If only one item is selected, the distance is set to the origin. +

      Constraint H Distance.png +

      +

      Usage

      +
      1. Pick one or two points
      2. +
      3. Activate the constraint
      +
      +


      +

      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Constraint_HorizontalDistance.svg b/localwiki/Constraint_HorizontalDistance.svg new file mode 100644 index 0000000..d39d877 --- /dev/null +++ b/localwiki/Constraint_HorizontalDistance.svg @@ -0,0 +1,82 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [wmayer] + + + Constraint_HorizontalDistance + 2011-10-10 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Sketcher/Gui/Resources/icons/Constraint_HorizontalDistance.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + diff --git a/localwiki/Constraint_HorizontalDistance_Driven.svg b/localwiki/Constraint_HorizontalDistance_Driven.svg new file mode 100644 index 0000000..2185a68 --- /dev/null +++ b/localwiki/Constraint_HorizontalDistance_Driven.svg @@ -0,0 +1,82 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [Abdullah Tahiri] + + + Constraint_HorizontalDistance_Driven + 2015-05-18 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Sketcher/Gui/Resources/icons/Constraint_HorizontalDistance_Driven.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + diff --git a/localwiki/Constraint_InternalAlignment.svg b/localwiki/Constraint_InternalAlignment.svg new file mode 100644 index 0000000..0cda31b --- /dev/null +++ b/localwiki/Constraint_InternalAlignment.svg @@ -0,0 +1,101 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [Abdullah Tahiri] + + + Constraint_InternalAlignment + 2014-11-11 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Sketcher/Gui/Resources/icons/Constraint_InternalAlignment.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Constraint_InternalAlignment_Ellipse_Focus1.svg b/localwiki/Constraint_InternalAlignment_Ellipse_Focus1.svg new file mode 100644 index 0000000..287bbac --- /dev/null +++ b/localwiki/Constraint_InternalAlignment_Ellipse_Focus1.svg @@ -0,0 +1,91 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [Abdullah Tahiri] + + + Constraint_InternalAlignment_Ellipse_Focus1 + 2014-11-11 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Sketcher/Gui/Resources/icons/Constraint_InternalAlignment_Ellipse_ + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + diff --git a/localwiki/Constraint_InternalAlignment_Ellipse_Focus2.svg b/localwiki/Constraint_InternalAlignment_Ellipse_Focus2.svg new file mode 100644 index 0000000..aaa5f5e --- /dev/null +++ b/localwiki/Constraint_InternalAlignment_Ellipse_Focus2.svg @@ -0,0 +1,91 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [Abdullah Tahiri] + + + Constraint_InternalAlignment_Ellipse_Focus2 + 2014-11-11 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Sketcher/Gui/Resources/icons/Constraint_InternalAlignment_Ellipse_ + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + diff --git a/localwiki/Constraint_InternalAlignment_Ellipse_MajorAxis.svg b/localwiki/Constraint_InternalAlignment_Ellipse_MajorAxis.svg new file mode 100644 index 0000000..18d63de --- /dev/null +++ b/localwiki/Constraint_InternalAlignment_Ellipse_MajorAxis.svg @@ -0,0 +1,90 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [Abdullah Tahiri] + + + Constraint_InternalAlignment_Ellipse_MajorAxis + 2014-11-11 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Sketcher/Gui/Resources/icons/Constraint_InternalAlignment_Ellipse_MajorAxis.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + diff --git a/localwiki/Constraint_InternalAlignment_Ellipse_MinorAxis.svg b/localwiki/Constraint_InternalAlignment_Ellipse_MinorAxis.svg new file mode 100644 index 0000000..972460f --- /dev/null +++ b/localwiki/Constraint_InternalAlignment_Ellipse_MinorAxis.svg @@ -0,0 +1,90 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [Abdullah Tahiri] + + + Constraint_InternalAlignment_Ellipse_MinorAxis + 2014-11-11 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Sketcher/Gui/Resources/icons/Constraint_InternalAlignment_Ellipse_MinorAxis.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + diff --git a/localwiki/Constraint_InternalAngle.html b/localwiki/Constraint_InternalAngle.html new file mode 100644 index 0000000..a979e46 --- /dev/null +++ b/localwiki/Constraint_InternalAngle.html @@ -0,0 +1,128 @@ +Constraint InternalAngle

      Constraint InternalAngle

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Constraint InternalAngle.png Constraint InternalAngle

      +
      Menu location +
      Sketch → Sketcher constraints → Constrain angle +
      Workbenches +
      Sketcher, PartDesign +
      Default shortcut +
      A +
      See also +
      Constraint Length, Constraint Perpendicular +

      + +
      +


      +

      +

      Description

      +

      Angle constraint is a datum constraint intended to fix angles in sketch. It is capable of setting slopes of individual lines, angles between lines, angles of intersections of curves, and angle spans of circular arcs. +

      +

      How to use

      +

      There are four different ways the constraint can be applied: +

      +
      1. to individual lines
      2. +
      3. between lines
      4. +
      5. to intersections of curves
      6. +
      7. to arcs of circles
      +

      To apply angle constraint, one should the follow the steps: +

      +
      • Select one, two or three entities in the sketch. The mode will be chosen depending on the selection.
      • +
      • Invoke the constraint by clicking its icon on the toolbar, or selecting the menu item, or using keyboard shortcut. A datum edit dialog box pops up.
      • +
      • Modify the angle if necessary. The angle can be entered as an expression that will be evaluated and the result will be stored. Click OK.
      +

      As with any datum constraint, it is possible to change the angle value later by double-clicking the constraint in constraint list or 3d view. Entering a negative value will cause the angle direction to flip. +

      +

      Constraint modes

      +

      line slope angle

      +

      Accepted selection: line +

      Sketcher ConsraintAngle mode1.png +

      The constraint sets the polar angle of line's direction. It is the angle between the line and X axis of the sketch. +

      +

      arc span (v0.15)

      +

      Accepted selection: arc of circle +

      Sketcher ConsraintAngle mode2.png +

      In this mode, the constraint fixes angular span of a circular arc. +

      +

      between lines

      +

      Accepted selection: line + line +

      Sketcher ConsraintAngle mode3.png +

      In this mode, the constraint sets the angle between two lines. It is not required that the lines intersect. +

      +

      between curves at intersection (angle-via-point) (v0.15)

      +

      Accepted selection: any line/curve + any line/curve + any point +

      Sketcher ConsraintAngle mode4.png +

      In this mode, angle between two curves is constrained at the point of their intersection. The intersection point can be on curves' extensions. The point should be specified explicitly, since curves typically intersect in more than one point. +

      For the constraint to work correctly, the point must be on both curves. So, as the constraint is invoked, the point will be automatically constrained onto both curves (helper constraints will be added, if necessary), and the angle between curves will be constrained at the point. These helper constraints are plain regular constraints. They can be added manually, or deleted. There are no helper constraints on the example picture above, because the point selected is already the intersection of curves. +

      +

      Scripting

      +

      Angle Constraint can be created from macros and from the python console by using the following: +

      +
      # line slope angle
      +Sketch.addConstraint(Sketcher.Constraint('Angle',iline,angle))
      +
      +# angular span of arc
      +Sketch.addConstraint(Sketcher.Constraint('Angle',iarc,angle))
      +
      +# angle between lines
      +Sketch.addConstraint(Sketcher.Constraint('Angle',iline1,pointpos1,iline2,pointpos2,angle))
      +
      +# angle-via-point (no helper constraints are added automatically when from python)
      +Sketch.addConstraint(Sketcher.Constraint('AngleViaPoint',icurve1,icurve2,geoidpoint,pointpos,angle)) 
      +

      where: +

      +
      • Sketch is a sketch object
      • +
      • iline, iline1, iline2 are integers specifying the lines by their ordinal numbers in Sketch.
      • +
      • pointpos1, pointpos2 should be 1 for start point and 2 for end point. The choice of endpoints allows to set internal angle (or external), and it affects how the constraint is drawn on the screen.
      • +
      • geoidpoint and pointpos in AngleViaPoint are the indexes specifying the point of intersection.
      • +
      • angle is the angle value in radians. The angle is counted between tangent vectors in counterclockwise direction. Tangent vectors are pointing from start to end for the lines (or vice versa if ending point is supplied in angle between lines mode), and along counterclockwise direction for circles, arcs and ellipses. Quantity is also accepted as an angle (e.g. App.Units.Quantity('45 deg'))
      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Constraint_InternalAngle.svg b/localwiki/Constraint_InternalAngle.svg new file mode 100644 index 0000000..a3de0c2 --- /dev/null +++ b/localwiki/Constraint_InternalAngle.svg @@ -0,0 +1,90 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [wmayer] + + + Constraint_InternalAngle + 2011-10-10 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Sketcher/Gui/Resources/icons/Constraint_InternalAngle.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + diff --git a/localwiki/Constraint_InternalAngle_Driven.svg b/localwiki/Constraint_InternalAngle_Driven.svg new file mode 100644 index 0000000..0a8d438 --- /dev/null +++ b/localwiki/Constraint_InternalAngle_Driven.svg @@ -0,0 +1,90 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [Abdullah Tahiri] + + + Constraint_InternalAngle_Driven + 2015-05-18 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Sketcher/Gui/Resources/icons/Constraint_InternalAngle_Driven.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + diff --git a/localwiki/Constraint_Internal_Alignment.html b/localwiki/Constraint_Internal_Alignment.html new file mode 100644 index 0000000..4fe152b --- /dev/null +++ b/localwiki/Constraint_Internal_Alignment.html @@ -0,0 +1,89 @@ +Constraint Internal Alignment

      Constraint Internal Alignment

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Constraint InternalAlignment.png Constraint InternalAlignment

      +
      Menu location +
      Sketch → Sketcher constraints → Constrain InternalAlignment +
      Workbenches +
      Sketcher, PartDesign +
      Default shortcut +
      Ctrl+A +
      See also +
      Show/Hide Internal Geometry, Ellipse +

      + +
      +


      +

      +

      Description

      +

      This constraint aligns lines and points to particular places of a complex sketcher element (there is just one "complex" element so far, the Ellipse). +

      For Ellipse and its Arc, it supports constraining lines to become major and minor diameters, and constraining points to positions of ellipse's foci. +

      The constraint requires a lot of effort to use in the way other constraints are. It is hidden in the menu, and not exposed on any toolbars by default. There is a helper tool called Show/Hide Internal Geometry which is exposed on workbenches' toolbars and aimed to completely remove the need to invoke the constraint manually. +

      +

      Operation on Ellipse

      +
      1. Select elements to be aligned and an ellipse. The ellipse must be selected last. Accepted are up to two lines and up to two points.
      2. +
      3. Invoke the constraint by picking the menu item (Sketch/Part Design → Sketcher constraints → Constrain InternalAlignment).
      +

      The first line that was selected gets aligned to become ellipse's major diameter (but if it is not occupied already by another line, otherwise it will become minor diameter). The second line is aligned to become minor radius. The lines are automatically switched to construction. +

      Likewise, the first point is constrained to become the first unoccupied focus, and the second point goes to the other focus. +

      +
      +


      +

      +

      Scripting

      +
      Sketch.addConstraint(Sketcher.Constraint('InternalAlignment:EllipseMajorDiameter', index_of_line, index_of_ellipse))
      +Sketch.addConstraint(Sketcher.Constraint('InternalAlignment:EllipseMinorDiameter', index_of_line, index_of_ellipse))
      +Sketch.addConstraint(Sketcher.Constraint('InternalAlignment:EllipseFocus1', index_of_point, 1, index_of_ellipse))
      +Sketch.addConstraint(Sketcher.Constraint('InternalAlignment:EllipseFocus2', index_of_point, 1, index_of_ellipse)) 
      +

      Remarks: +

      +
      Sketch is a sketch object.
      +
      Number 1 in the focus calls stands for starting point of a point element (it is ignored).
      +

      Version

      +

      Introduced in FreeCAD v0.15.4309 +

      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Constraint_Length.html b/localwiki/Constraint_Length.html new file mode 100644 index 0000000..9c3390b --- /dev/null +++ b/localwiki/Constraint_Length.html @@ -0,0 +1,94 @@ +Constraint Length

      Constraint Length

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Constraint Length.png Constraint Length

      +
      Menu location +
      Sketch → Sketcher constraints → Constrain distance +
      Workbenches +
      Sketcher, PartDesign +
      Default shortcut +
      None +
      See also +
      Constraint HorizontalDistance, Constraint VerticalDistance +

      + +
      +


      +

      +

      Description

      +

      Constraint Length constrains the length of a line, the perpendicular distance between a point and a line or the distance between two points to have a specified value. +

      +

      Hint

      +

      If applicable please consider using the Horizontal Distance or Vertical Distance constraints instead. These constraints are more robust and faster to calculate than the here documented length constraint. +

      +

      Operation

      +

      Select a line in the sketch,
      +LengthConstraint1.png
      +by clicking on the line (it turns dark green).
      +LengthConstraint2.png
      +Apply the Length Constraint by selecting the icon Constraint Length.png from the Sketcher Constraints toolbar or selecting the Constrain distance menu item from the Sketcher Constraints sub-menu of the Sketcher menu item in the Sketcher workbench (or Part Design in the Part Design workbench).
      +LengthConstraint3.png
      +The length of the line is constrained to its current value.Double clicking on the constraint in the 3D view or in the Tasks tab of the Combo View will bring up a dialog box to allow the constraint value to be edited.
      +LengthConstraint4.png
      +Enter the required value and click OK to set the constraint length.
      +LengthConstraint5.png
      +The Length Constraint also constrains the distance between a line and a point.
      +LengthConstraint6.png
      +Select the line and a point in the sketch,
      +LengthConstraint7.png
      +then apply the constraint as before.
      +The perpendicular distance between the point and the line is constrained to its current value. this may be edited as described above to set the constraint to a desired value.
      +LengthConstraint8.png
      +The constraint may also be applied to two points, selected here at either end of a poly-line.
      +LengthConstraint9.png
      +Applying the constraint as before, the distance between the two selected points is constrained. As described above it may be edited to set a desired value.
      +LengthConstraint10.png
      +

      +
      +


      +

      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Constraint_Length.svg b/localwiki/Constraint_Length.svg new file mode 100644 index 0000000..4a539f4 --- /dev/null +++ b/localwiki/Constraint_Length.svg @@ -0,0 +1,99 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [wmayer] + + + Constraint_Length + 2011-10-10 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Sketcher/Gui/Resources/icons/Constraint_Length.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + diff --git a/localwiki/Constraint_Length_Driven.svg b/localwiki/Constraint_Length_Driven.svg new file mode 100644 index 0000000..c13bcb6 --- /dev/null +++ b/localwiki/Constraint_Length_Driven.svg @@ -0,0 +1,102 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [Abdullah Tahiri] + + + Constraint_Length_Driven + 2015-05-18 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Sketcher/Gui/Resources/icons/Constraint_Length_Driven.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + diff --git a/localwiki/Constraint_Lock.html b/localwiki/Constraint_Lock.html new file mode 100644 index 0000000..66253a1 --- /dev/null +++ b/localwiki/Constraint_Lock.html @@ -0,0 +1,84 @@ +Constraint Lock

      Constraint Lock

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Sketcher ConstrainLock.png Sketcher ConstrainLock

      +
      Menu location +
      Sketch → Sketcher constraints → Constrain lock +
      Workbenches +
      Sketcher, PartDesign +
      Default shortcut +
      None +
      See also +
      Constraint Coincident +

      + +
      +


      +

      Create a lock constraint on the selected item +

      +

      Description

      +

      This constraint tool attempts to fully constrain any selected item. +

      NOTE: It is advised that this tool be exclusively used on points for the time-being: +

      Owing to the fact that FreeCAD is still under development - this tool exhibits strange behaviour when it attempts to 'lock' anything other than a point. For example (as of V0.12 R4802), when locking a circle by its circumferential line rather than its centre point, a horizontal constraint and a vertical constraint appear in the constraints dialogue, but they are both of value zero and do not appear in the graphics window. +

      +

      Operation

      +
        +
      1. Firstly it is necessary to highlight an item you wish to constrain. For reasons alluded-to above it is wise to only highlight a point.
        +LockConstraint1.png
      2. +
      3. +Highlighting of a drawing item is achieved by moving the mouse over the item and clicking the left-mouse-button. +A highlighted item will change colour to green.
        +LockConstraint2.png
      4. +
      5. +Once an item is highlighted, left-clicking on the lock constraint serves to lock the highlighted item in-place. This usually manifests as two constraints: a horizontal distance constraint from the drawing axis origin, and a vertical constraint from the drawing axis origin. These are set by default to the current co-ordinates of the point.
        +LockConstraint3.png
      6. +
      7. +The vertical and horizontal constraints forming the lock can be edited by double clicking on the appropriate constraint to be edited either in the drawing itself or in the Constraint tab of the Combo View pane. This will open a dialog box to edit the constraint. Clicking on the horizontal constraint component produces:
        +LockConstraint4.png.
      8. +
      9. Enter the desired value into the dialog box and click OK.
        +LockConstraint5.png
      10. +
      11. The new value of the constraint is applied to the drawing.
        +LockConstraint6.png
      12. +
      13. The vertical constraint may be similarly edited to constrain the point to the desired location.
        +LockConstraint7.png
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Constraint_Parallel.html b/localwiki/Constraint_Parallel.html new file mode 100644 index 0000000..601776e --- /dev/null +++ b/localwiki/Constraint_Parallel.html @@ -0,0 +1,73 @@ +Constraint Parallel

      Constraint Parallel

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Constraint Parallel.png Constraint Parallel

      +
      Menu location +
      Sketch → Sketcher constraints → Constrain parallel +
      Workbenches +
      Sketcher, PartDesign +
      Default shortcut +
      None +
      See also +
      Constraint Vertical, Constraint Horizontal +

      + +
      +


      +

      +

      Description

      +

      The Constrain Parallel constraint forces two selected straight lines or edges to be parallel to each other. +

      +

      Operation

      +

      The sketch contains two randomly oriented lines. +

      ConstrainParallel1.png +

      Select both lines by clicking successively on each of them. +

      ConstrainParallel2.png +

      Apply the Constrain Parallel constraint by selecting the Constrain Parallel icon Constraint Parallel.png from the Sketcher constraints toolbar or by selecting the Constraint Parallel menu item from the Sketcher constraints sub menu of the Sketcher (Sketcher workbench selected) or Part Design (Part Design workbench selected) menu item. +

      ConstrainParallel3.png +

      The selected lines are forced to be parallel to each other. Changing the orientation of one line will change the orientation of the other to be the same. +

      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Constraint_Parallel.svg b/localwiki/Constraint_Parallel.svg new file mode 100644 index 0000000..66ba5d5 --- /dev/null +++ b/localwiki/Constraint_Parallel.svg @@ -0,0 +1,134 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [wmayer] + + + Constraint_Parallel + 2011-10-10 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Sketcher/Gui/Resources/icons/Constraint_Parallel.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + diff --git a/localwiki/Constraint_Perpendicular.html b/localwiki/Constraint_Perpendicular.html new file mode 100644 index 0000000..ba55fc5 --- /dev/null +++ b/localwiki/Constraint_Perpendicular.html @@ -0,0 +1,136 @@ +Constraint Perpendicular

      Constraint Perpendicular

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Constraint Perpendicular.png Constraint Perpendicular

      +
      Menu location +
      Sketch → Sketcher constraints → Constrain perpendicular +
      Workbenches +
      Sketcher, PartDesign +
      Default shortcut +
      N +
      See also +
      Constraint Angle +

      + +
      +


      +

      +

      Description

      +

      Perpendicular Constraint makes two lines to be perpendicular to each other, or two curves to be perpendicular at their intersection. Lines are treated infinite, and arcs are treated as full circles/ellipses. The constraint is also capable of connecting two curves, forcing them perpendicular at the joint, similarly to Tangent Constraint. +

      +

      How to use

      +

      There are four different ways the constraint can be applied: +

      +
      1. between two curves (available not for all curves)
      2. +
      3. between two endpoints of a curve
      4. +
      5. between a curve and an endpoint of another curve
      6. +
      7. between two curves at user-defined point
      +

      To apply perpendicular constraint, one should the follow the steps: +

      +
      • Select two or three entities in the sketch.
      • +
      • Invoke the constraint by clicking its icon on the toolbar, or selecting the menu item, or using keyboard shortcut.
      +

      Between two curves (direct perpendicularity)

      +

      Sketcher ConsraintPerpendicular mode1.png +

      Two curves will be made perpendicular at point of their intersection (either real, or of curves' extensions), and the point of intersection will be implicit. This mode is applied if two curves were selected. +

      Accepted selection: +

      +
      • line + line, circle, arc
      • +
      • circle, arc + circle, arc
      +

      If direct perpendicularity between selected curves is not supported (e.g. between a line and an ellipse), a helper point will be added to sketch automatically, and perpendicular-via-point will be applied. +

      Unlike for tangency, it is perfectly fine to reconstruct the point of perpendicularity by creating a point and constraining it to lie on both curves (thus constraining the point to the intersection). +

      +

      Between two endpoints (point-to-point perpendicularity)

      +

      Sketcher ConsraintPerpendicular mode2.png +

      In this mode, the endpoints are made coincident, and the joint is made to be right angle. This mode is applied when two endpoints of two curves were selected. +

      Accepted selection: +

      +
      • endpoint of line/arc/arc-of-ellipse + endpoint of line/arc/arc-of-ellipse (i.e., two endpoints of any two curves)
      +

      Between curve and endpoint (point-to-curve perpendicularity)

      +

      Sketcher ConsraintPerpendicular mode3.png +

      In this mode, an endpoint of one curve is constrained to lie on the other curve, and the curves are forced perpendicular at the point. This mode is applied when a curve and an endpoint of another curve were selected. +

      Accepted selection: +

      +
      • line, circle, arc, ellipse, arc-of-ellipse + endpoint of line/arc/arc-of-ellipse (i.e., any curve + endpoint of any curve)
      +


      +

      +

      Between two curves at point (perpendicular-via-point) (v0.15)

      +

      Sketcher ConsraintPerpendicular mode4.png +

      In this mode, two curves are made perpendicular, and the point of perpendicularity is tracked. This mode is applied when two curves and a point were selected. +

      Accepted selection: +

      +
      • any line/curve + any line/curve + any point
      +

      "Any point" can be a lone point, or a point of something, e.g. a center of a circle, an endpoint of an arc, or the origin. +

      For the constraint to work correctly, the point must be on both curves. So, as the constraint is invoked, the point will be automatically constrained onto both curves (helper constraints will be added, if necessary), and the curves will be forced perpendicular at the point. These helper constraints are plain regular constraints. They can be added manually, or deleted. +

      Compared to direct perpendicular, this constraint is slower, because there are mode degrees of freedom involved, but it supports ellipses. +

      The placement of the point before the constraint is applied is a hint for the solver for where the perpendicularity should be. +

      +

      Scripting

      +

      Perpendicular Constraint can be created from macros and from the python console by using the following: +

      +
      # direct perpendicularity
      +Sketch.addConstraint(Sketcher.Constraint('Perpendicular',icurve1,icurve2))
      +
      +# point-to-point perpendicularity
      +Sketch.addConstraint(Sketcher.Constraint('Perpendicular',icurve1,pointpos1,icurve2,pointpos2))
      +
      +# point-to-curve perpendicularity
      +Sketch.addConstraint(Sketcher.Constraint('Perpendicular',icurve1,pointpos1,icurve2))
      +
      +# perpendicular-via-point (plain constraint, helpers are not added automatically)
      +Sketch.addConstraint(Sketcher.Constraint('PerpendicularViaPoint',icurve1,icurve2,geoidpoint,pointpos)) 
      +

      where: +

      +
      • Sketch is a sketch object
      • +
      • icurve1, icurve2 are two integers identifying the curves to be made perpendicular. The integers are indexes in the sketch (the value, returned by Sketch.addGeometry).
      • +
      • pointpos1, pointpos2 should be 1 for start point and 2 for end point.
      • +
      • geoidpoint and pointpos in PerpendicularViaPoint are the indexes specifying the point of perpendicularity.
      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Constraint_Perpendicular.svg b/localwiki/Constraint_Perpendicular.svg new file mode 100644 index 0000000..e07aca5 --- /dev/null +++ b/localwiki/Constraint_Perpendicular.svg @@ -0,0 +1,130 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [wmayer] + + + Constraint_Perpendicular + 2011-10-10 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Sketcher/Gui/Resources/icons/Constraint_Perpendicular.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + diff --git a/localwiki/Constraint_PointOnEnd.html b/localwiki/Constraint_PointOnEnd.html new file mode 100644 index 0000000..6eec9fd --- /dev/null +++ b/localwiki/Constraint_PointOnEnd.html @@ -0,0 +1,66 @@ +Constraint PointOnEnd

      Constraint PointOnEnd

      + +
      +

      This documentation is not finished. Please help and contribute documentation. +

      See Draft ShapeString for good documented Command. Gui Command gives an overview over commands. And see List of Commands for other commands. +

      Go to Help FreeCAD to contribute. +

      +
      +


      +

      + + + + + + + + + + + + + + + + + + + + +
      +

      Constraint PointOnEnd.png Constraint PointOnEnd

      +
      Menu location +
      Sketch → Sketcher constraints → PointOnEnd +
      Workbenches +
      Sketcher, PartDesign +
      Default shortcut +
      +
      See also +
      +

      Contents

      + +
      + +
      +


      +

      Currently not used by FreeCAD +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Constraint_PointOnEnd.svg b/localwiki/Constraint_PointOnEnd.svg new file mode 100644 index 0000000..13d4860 --- /dev/null +++ b/localwiki/Constraint_PointOnEnd.svg @@ -0,0 +1,119 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [wmayer] + + + Constraint_PointOnEnd + 2011-10-10 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Sketcher/Gui/Resources/icons/Constraint_PointOnEnd.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + diff --git a/localwiki/Constraint_PointOnMidPoint.html b/localwiki/Constraint_PointOnMidPoint.html new file mode 100644 index 0000000..74f85b5 --- /dev/null +++ b/localwiki/Constraint_PointOnMidPoint.html @@ -0,0 +1,66 @@ +Constraint PointOnMidPoint

      Constraint PointOnMidPoint

      + +
      +

      This documentation is not finished. Please help and contribute documentation. +

      See Draft ShapeString for good documented Command. Gui Command gives an overview over commands. And see List of Commands for other commands. +

      Go to Help FreeCAD to contribute. +

      +
      +


      +

      + + + + + + + + + + + + + + + + + + + + +
      +

      Constraint PointOnMidPoint.png Constraint PointOnMidPoint

      +
      Menu location +
      Sketch → Sketcher constraints → PointOnMidPoint +
      Workbenches +
      Sketcher, PartDesign +
      Default shortcut +
      +
      See also +
      +

      + +
      +


      +

      Currently not used by FreeCAD +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Constraint_PointOnMidPoint.svg b/localwiki/Constraint_PointOnMidPoint.svg new file mode 100644 index 0000000..adfd474 --- /dev/null +++ b/localwiki/Constraint_PointOnMidPoint.svg @@ -0,0 +1,93 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [wmayer] + + + Constraint_PointOnMidPoint + 2011-10-10 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Sketcher/Gui/Resources/icons/Constraint_PointOnMidPoint.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + diff --git a/localwiki/Constraint_PointOnObject.html b/localwiki/Constraint_PointOnObject.html new file mode 100644 index 0000000..bf4e5b2 --- /dev/null +++ b/localwiki/Constraint_PointOnObject.html @@ -0,0 +1,84 @@ +Constraint PointOnObject

      Constraint PointOnObject

      + +


      +

      + + + + + + + + + + + + + + + + + + + + +
      +

      Constraint PointOnObject.png Constraint PointOnObject

      +
      Menu location +
      Sketch → Sketcher constraints → Constrain point onto object +
      Workbenches +
      Sketcher, PartDesign +
      Default shortcut +
      Shift+O +
      See also +
      Constraint Coincident +

      + +
      +


      +

      +

      Description

      +

      Affixes a point onto another object such as a line, arc, or axis. +

      +

      How to Use

      +
      1. Select the point you want to affixe onto a line/arc/etc. (Once selected the point become green).
      2. +
      3. Select the line you want to be affixed onto the point you have just selected (Once selected the line become green).
      4. +
      5. Click the constraint button «point onto object » Constraint PointOnObject.png.
      +

      Note : The order you select the line and point does not matter. The point will always move to line. The line remains fixed. +

      +

      Scripting

      +

      The constraint can be created from macros and from the python console by using the following command: +

      +
      Sketch.addConstraint(Sketcher.Constraint('PointOnObject',LineMoving,PointOfLineMoving,LineFixed)) 
      +

      where : +

      +
      • Sketch is a sketch object
      • +
      • LineMoving is the number that designates the line, which contains the point that has to be moved onto the LineFixed (The line which is fixed)
      • +
      • PointOfLineMoving is the number of the vertex of line LineMoving, that has to be moved onto the LineFixed
      • +
      • LinedFixed is the number of the line to be affixed onto the point PointOfLineMoving
      +

      How to indentify the number that designates lines and points ? Please refer to the scripting part of this wiki page. +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Constraint_PointOnObject.svg b/localwiki/Constraint_PointOnObject.svg new file mode 100644 index 0000000..0342a70 --- /dev/null +++ b/localwiki/Constraint_PointOnObject.svg @@ -0,0 +1,125 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [wmayer] + + + Constraint_PointOnObject + 2011-10-10 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Sketcher/Gui/Resources/icons/Constraint_PointOnObject.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + diff --git a/localwiki/Constraint_PointOnPoint.html b/localwiki/Constraint_PointOnPoint.html new file mode 100644 index 0000000..5314bd8 --- /dev/null +++ b/localwiki/Constraint_PointOnPoint.html @@ -0,0 +1,125 @@ +Constraint PointOnPoint

      Constraint PointOnPoint

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Constraint PointOnPoint.png Constraint PointOnPoint

      +
      Menu location +
      Sketch → Sketcher constraints → Constrain coincident +
      Workbenches +
      Sketcher, PartDesign +
      Default shortcut +
      None +
      See also +
      Constraint Lock, Constraint Point onto Object +

      + +
      +


      +

      +

      Description

      +

      Create a coincident constraint on the selected item +

      This constraint tool takes two points as its argument and serves to make the two points coincident. (Meaning to make them as-one-point). +

      In practical terms this constraint tool is useful when there is a break in a profile for example - where two lines end near each other and need to be joined - a coincident constraint on their end-points will close the gap. +

      +

      How to Use

      +

      As stated above, this tool takes two arguments - both are points. +

      +
      1. Firstly it is necessary to highlight two distinct points. (Note this will not work if, for example, you attempt to select the start and end point of the same line).
      2. +
      3. Highlighting of a drawing item is achieved by moving the mouse over the item and clicking the left-mouse-button.
      4. +
      5. A highlighted item will change colour to green.
      6. +
      7. Subsequent items can be highlighted by repeating the above procedure(s) NOTE: There is no-need to hold-down any special key like Ctrl to achieve multiple item selection in a drawing.
      8. +
      9. Once you have two points highlighted, left-clicking on the 'PointOnPoint' Constraint PointOnPoint.png constraint will cause the two points to become coincident and be replaced by a single point.
      +

      NOTE: In order to make two points coincident, FreeCAD must necessarily move one, or both, of the original points. +

      +

      Scripting

      +

      General scripting

      +

      The constraint can be created from macros and from the python console by using the following command: +

      +
      Sketch.addConstraint(Sketcher.Constraint('Coincident',LineFixed,PointOfLineFixed,LineMoving,PointOfLineMoving)) 
      +

      where : +

      +
      • Sketch is a sketch object
      • +
      • LineFixed is the number of the line, that will not move by applying the constraint
      • +
      • PointOfLineFixed is the number of the vertex of the line LineFixed that has to fulfilled the constraint
      • +
      • LineMoving is the number of the line, that will move by applying the constraint
      • +
      • PointOfLineMoving is the number of the line LineMoving, that has to fulfilled the constraint
      +

      The main issue by using this function is to identify correctly the line number and the vertex number of the lines you want to process. +

      The next paragraph will explain you how to identify the numbering of a line and of a vertex of a line. +

      +

      Identifying the numbering of a line

      +

      I have drawn three lines as shown in the following figure. +

      PartDesignConstraintPointOnPointScriptingFigure1.jpg +

      By moving the cursor of the mouse above the line you can see the line number at the bottom left of the FreeCAD windows, see next figure. +

      PartDesignConstraintPointOnPointScriptingFigure2.jpg +

      Unfortunately the numbering displayed on the FreeCAD windows start from 1 whereas the numbering of the line used to script start from 0: this means that you have to retrieve one each time you want to refer to a line. +

      +

      Identifying the numbering of the vertices of a line

      +

      The vertices of one line can only have the value 1 or 2. (Don’t ask me, why the vertices numbering does not start from 0 …) The vertices are numbered according to their order of creation. To find out the order of their creation (If you have a lot of lines, you cannot remember which vertex you have created first), you just have to move the cursor of your mouse above the two vertices of one line, see following figure. +

      PartDesignConstraintPointOnPointScriptingFigure3.jpg +

      If you read e.g. 4 and 5, it means that the vertex 4 will be referenced by using the number 1 in the script command and the vertex 5 will be referenced by using the number 2 in the script command. Etc. +

      +

      Example

      +

      Let us take the previous example of the three lines. The subsequent figure indicates the numbering of each line and their vertices according to the convention for scripting. +

      PartDesignConstraintPointOnPointScriptingFigure3Bis.jpg +

      blue text = numbering of line, black text = numbering of vertices +

      The command +

      +
      Sketch.addConstraint(Sketcher.Constraint('Coincident',1,2,2,1)) 
      +

      yields following result: +

      PartDesignConstraintPointOnPointScriptingFigure4.jpg +

      The command +

      +
      Sketch.addConstraint(Sketcher.Constraint('Coincident',0,2,2,2)) 
      +

      yields following result: +

      PartDesignConstraintPointOnPointScriptingFigure5.jpg +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Constraint_PointOnPoint.svg b/localwiki/Constraint_PointOnPoint.svg new file mode 100644 index 0000000..f4f3c49 --- /dev/null +++ b/localwiki/Constraint_PointOnPoint.svg @@ -0,0 +1,92 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [wmayer] + + + Constraint_PointOnPoint + 2011-10-10 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Sketcher/Gui/Resources/icons/Constraint_PointOnPoint.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + diff --git a/localwiki/Constraint_PointOnStart.html b/localwiki/Constraint_PointOnStart.html new file mode 100644 index 0000000..3980e14 --- /dev/null +++ b/localwiki/Constraint_PointOnStart.html @@ -0,0 +1,66 @@ +Constraint PointOnStart

      Constraint PointOnStart

      + +
      +

      This documentation is not finished. Please help and contribute documentation. +

      See Draft ShapeString for good documented Command. Gui Command gives an overview over commands. And see List of Commands for other commands. +

      Go to Help FreeCAD to contribute. +

      +
      +


      +

      + + + + + + + + + + + + + + + + + + + + +
      +

      Constraint PointOnStart.png Constraint PointOnStart

      +
      Menu location +
      Sketch → Sketcher constraints → PointOnStart +
      Workbenches +
      Sketcher, PartDesign +
      Default shortcut +
      +
      See also +
      +

      + +
      +


      +

      Currently not used by FreeCAD +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Constraint_PointOnStart.svg b/localwiki/Constraint_PointOnStart.svg new file mode 100644 index 0000000..55b680a --- /dev/null +++ b/localwiki/Constraint_PointOnStart.svg @@ -0,0 +1,115 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [wmayer] + + + Constraint_PointOnStart + 2011-10-10 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Sketcher/Gui/Resources/icons/Constraint_PointOnStart.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + diff --git a/localwiki/Constraint_PointToObject.html b/localwiki/Constraint_PointToObject.html new file mode 100644 index 0000000..c25d35f --- /dev/null +++ b/localwiki/Constraint_PointToObject.html @@ -0,0 +1,66 @@ +Constraint PointToObject

      Constraint PointToObject

      + +
      +

      This documentation is not finished. Please help and contribute documentation. +

      See Draft ShapeString for good documented Command. Gui Command gives an overview over commands. And see List of Commands for other commands. +

      Go to Help FreeCAD to contribute. +

      +
      +


      +

      + + + + + + + + + + + + + + + + + + + + +
      +

      Constraint PointToObject.png Constraint PointToObject

      +
      Menu location +
      Sketch → Sketcher constraints → PointToObject +
      Workbenches +
      Sketcher, PartDesign +
      Default shortcut +
      +
      See also +
      +

      + +
      +


      +

      Currently not used by FreeCAD +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Constraint_PointToObject.svg b/localwiki/Constraint_PointToObject.svg new file mode 100644 index 0000000..c00fcd4 --- /dev/null +++ b/localwiki/Constraint_PointToObject.svg @@ -0,0 +1,103 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [wmayer] + + + Constraint_PointToObject + 2011-10-10 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Sketcher/Gui/Resources/icons/Constraint_PointToObject.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Constraint_Radius.html b/localwiki/Constraint_Radius.html new file mode 100644 index 0000000..d29573b --- /dev/null +++ b/localwiki/Constraint_Radius.html @@ -0,0 +1,81 @@ +Constraint Radius

      Constraint Radius

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Constraint Radius.png Constraint Radius

      +
      Menu location +
      Sketch → Sketcher constraints → Constrain radius +
      Workbenches +
      Sketcher, PartDesign +
      Default shortcut +
      None +
      See also +
      Constraint Distance, Constraint Horizontal, Constraint Vertical +

      + +
      +


      +

      +

      Description

      +

      This constraint constrains the value of the radius of a circle or arc to have a specific value. Only one arc or circle can be constrained at a time. +


      +

      +

      Operation

      +

      ConstrainRadius1.png
      +Select an arc or circle in the sketch by clicking on is ( turns dark green to indicate selection).
      +ConstrainRadius2.png
      +Apply the constraint by clicking on the Constrain Radius icon Constraint Radius.png in the Sketcher toolbar or selecting the Constrain radius menu item from the Sketcher constraints sub menu of the the Sketcher (or Part Design) menu item (depending upon which workbench is selected).
      +ConstrainRadius3.png
      +The radius is constrained to have its current value when the constraint is applied.
      +To change the constraint value either double click on the constraint in the 3D display (turning red indicates the constraint is currently selected) or by double clicking on the constraint in the Constraints panel of the Tasks tab of the Combo View.
      This will bring up a pop-up window.
      +ConstrainRadius4.png
      +Enter the desired value for the radius into the pop-up window and click OK to set the value of the constraint.
      +ConstrainRadius5.png
      +The constraint value is set to the value entered in the pop-up window.
      +

      +
      +


      +

      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Constraint_Radius.svg b/localwiki/Constraint_Radius.svg new file mode 100644 index 0000000..6aa6d1d --- /dev/null +++ b/localwiki/Constraint_Radius.svg @@ -0,0 +1,93 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [wmayer] + + + Constraint_Radius + 2011-10-10 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Sketcher/Gui/Resources/icons/Constraint_Radius.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + diff --git a/localwiki/Constraint_Radius_Driven.svg b/localwiki/Constraint_Radius_Driven.svg new file mode 100644 index 0000000..dabfb16 --- /dev/null +++ b/localwiki/Constraint_Radius_Driven.svg @@ -0,0 +1,93 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [Abdullah Tahiri] + + + Constraint_Radius_Driven + 2015-05-18 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Sketcher/Gui/Resources/icons/Constraint_Radius_Driven.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + diff --git a/localwiki/Constraint_SnellsLaw.html b/localwiki/Constraint_SnellsLaw.html new file mode 100644 index 0000000..84f82fd --- /dev/null +++ b/localwiki/Constraint_SnellsLaw.html @@ -0,0 +1,122 @@ +Constraint SnellsLaw

      Constraint SnellsLaw

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Constraint SnellsLaw.png Constraint SnellsLaw

      +
      Menu location +
      Sketch → Sketcher Constraints → Constrain refraction (Snell's law) +
      Workbenches +
      Sketcher, PartDesign +
      Default shortcut +
      None +
      See also +
      None +

      + +
      +


      +

      +

      Description

      +

      Constrains two lines to follow the law of refraction of light as it penetrates through an interface, where two materials of different refraction indices meet. See Snell's law on Wikipedia for more info. +

      +
      Snell's law
      +
      +


      +

      +

      How to use

      +
      The sequence of clicks is indicated by yellow arrows with numbers. n1, n2 are labeles on this picture to show where the indices of refraction are.
      +
      • You'll need two lines that are to follow a beam of light, and a curve to act as an interface. The lines should be on different sides of the interface.
      • +
      • Select the endpoint of one line, an endpoint of another line, and the interface edge. The interface can be a line, circle/arc, ellipse/arc of ellipse. Note the order you've selected the endpoints.
      • +
      • Invoke the constraint. A dialog will appear asking for a ratio of indices of refraction n2/n1. n2 corresponds to the medium where the second selected endpoint's line resides, n1 is for the first line.
      • +
      • The endpoints will be made coincident (if needed), constrained onto the interface (if needed), and the Snell's law will become constrained.
      +

      Note that there are several helper constraints smart-added (point-on-object, coincident), and they can be deleted if they cause redundancy, or added manually if they were not added automatically. For the actual Snell's law constraint, the endpoints of lines must coincide and lie on the interface, otherwise the behavior is undefined. +

      Using polyline tool, it is possible to speedup drawing of rays of light. In this case, one can select two coincident endpoints by box selection. +

      +

      Remarks

      +
      • The actual Snell's law constraint enforces the plain law equation n1*sin(theta1) = n2*sin(theta2). It needs the line ends to be made coincident and on the interface by other constraints. The necessary helper constraints are added automatically based on the current coordinates of the elements.
      • +
      • Python routine does not add the helper constraints. These must be added manually by the script (see example in Scripting section).
      • +
      • These helper constraints can be temporarily deleted and the endpoints dragged apart, which can be useful in case one wants to construct a reflected ray or birefringence rays.
      • +
      • Unlike the reality, refraction indices are associated with rays of light, but not according to the sides of the boundary. This is useful to emulate birefringence, construct paths of different wavelengths due to refraction, and easily construct angle of onset of total internal reflection.
      • +
      • Both rays can be on the same side of the interface, satisfying the constraint equation. This is physical nonsense, unless the ratio n2/n1 is 1.0, in which case the constraint emulates a reflection.
      • +
      • Arcs of circle and ellipse are also accepted as rays (physical nonsense).
      +

      Scripting

      +

      The constraints can be created from macros and from the python console by using the following function: +

      +
      Sketch.addConstraint(Sketcher.Constraint('SnellsLaw',line1,pointpos1,line2,pointpos2,interface,n2byn1)) 
      +

      where: +

      +
      • Sketch is a sketch object
      • +
      • line1 and pointpos1 are two integers identifying the endpoint of the line in medium with refractive index of n1. line1 is the line's index in the sketch (the value, returned by Sketch.addGeometry), and pointpos1 should be 1 for start point and 2 for end point.
      • +
      • line2 and pointpos2 are the indexes specifying the endpoint of the second line (in medium n2)
      • +
      • n2byn1 is a floating-point number equal to the ratio of refractive indices n2/n1
      +

      Example: +

      +
      from Sketcher import *
      +from Part import *
      +from FreeCAD import *
      +
      +StartPoint = 1
      +EndPoint = 2
      +MiddlePoint = 3
      +
      +f = App.activeDocument().addObject("Sketcher::SketchObject","Sketch")
      +
      +# add geometry to the sketch
      +icir = f.addGeometry(Part.Circle(App.Vector(-547.612366,227.479736,0),App.Vector(0,0,1),68.161979))
      +iline1 = f.addGeometry(Part.Line(App.Vector(-667.331726,244.127090,0),App.Vector(-604.284241,269.275238,0)))
      +iline2 = f.addGeometry(Part.Line(App.Vector(-604.284241,269.275238,0),App.Vector(-490.940491,256.878265,0)))
      +# add constraints
      +# helper constraints:
      +f.addConstraint(Sketcher.Constraint('Coincident',iline1,EndPoint,iline2,StartPoint)) 
      +f.addConstraint(Sketcher.Constraint('PointOnObject',iline1,EndPoint,icir)) 
      +# the Snell's law:
      +f.addConstraint(Sketcher.Constraint('SnellsLaw',iline1,EndPoint,iline2,StartPoint,icir,1.47))
      +
      +App.ActiveDocument.recompute() 
      +

      Version

      +

      The constraint was introduced in FreeCAD v0.15.4387 +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Constraint_SnellsLaw.svg b/localwiki/Constraint_SnellsLaw.svg new file mode 100644 index 0000000..32e4682 --- /dev/null +++ b/localwiki/Constraint_SnellsLaw.svg @@ -0,0 +1,154 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [DeepSOIC] + + + Constraint_SnellsLaw + 2014-12-13 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Sketcher/Gui/Resources/icons/Constraint_SnellsLaw.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Constraint_SnellsLaw_Driven.svg b/localwiki/Constraint_SnellsLaw_Driven.svg new file mode 100644 index 0000000..7483972 --- /dev/null +++ b/localwiki/Constraint_SnellsLaw_Driven.svg @@ -0,0 +1,154 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [Abdullah Tahiri] + + + Constraint_SnellsLaw_Driven + 2015-05-18 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Sketcher/Gui/Resources/icons/Constraint_SnellsLaw_Driven.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Constraint_Symmetric.html b/localwiki/Constraint_Symmetric.html new file mode 100644 index 0000000..fd61213 --- /dev/null +++ b/localwiki/Constraint_Symmetric.html @@ -0,0 +1,73 @@ +Constraint Symmetric

      Constraint Symmetric

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Constraint Symmetric.png Constraint Symmetric

      +
      Menu location +
      Sketch → Sketcher constraints → Constrain symmetrical +
      Workbenches +
      Sketcher, PartDesign +
      Default shortcut +
      None +
      See also +
      Constraint Parallel +

      + +
      +


      +

      +

      Description

      +

      The symmetrical constraint constrains two selected points to be symmetrical around a given line, i.e., both selected points are constrained to lie on a normal to the line through both points and are constrained to be equidistant from the line. Alternatively it can constrain two points to be symmetric with respect to a third one. +

      +

      Operation

      +

      SymmetricConstraint1.png

      +Select two points (vertexes) in the sketch and a line in the sketch. The selected points and the line will be dark green.

      +SymmetricConstraint2.png

      +Click on the SymmetricalConstraint icon Constraint Symmetric.png in the Sketcher toolbar or select the Constrain Symmetrical menu item from the Sketcher Constraints sub menu of the Sketcher (or Part Design) menu item. +This will apply the constraint to the selected items.

      +SymmetricConstraint3.png

      +This is a geometric constraint and has no editable parameters. +

      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Constraint_Symmetric.svg b/localwiki/Constraint_Symmetric.svg new file mode 100644 index 0000000..a0f22c6 --- /dev/null +++ b/localwiki/Constraint_Symmetric.svg @@ -0,0 +1,121 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [wmayer] + + + Constraint_Symmetric + 2011-10-10 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Sketcher/Gui/Resources/icons/Constraint_Symmetric.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Constraint_Tangent.html b/localwiki/Constraint_Tangent.html new file mode 100644 index 0000000..e0c3c1e --- /dev/null +++ b/localwiki/Constraint_Tangent.html @@ -0,0 +1,136 @@ +Constraint Tangent

      Constraint Tangent

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Constraint Tangent.png Constraint Tangent

      +
      Menu location +
      Sketch → Sketcher constraints → Constrain tangent +
      Workbenches +
      Sketcher, PartDesign +
      Default shortcut +
      None +
      See also +
      Constraint point on object +

      + +
      +


      +

      +

      Description

      +

      Tangent Constraint makes two curves to touch each other (be tangent). Lines are treated infinite, and arcs are treated as full circles/ellipses. The constraint is also capable of connecting two curves, forcing them tangent at the joint, thus making the joint smooth. +

      +

      How to use

      +

      There are four different ways the constraint can be applied: +

      +
      1. between two curves (available not for all curves)
      2. +
      3. between two endpoints of a curve, making a smooth joint
      4. +
      5. between a curve and an endpoint of another curve
      6. +
      7. between two curves at user-defined point
      +

      To apply tangent constraint, one should the follow the steps: +

      +
      • Select two or three entities in the sketch.
      • +
      • Invoke the constraint by clicking its icon on the toolbar, or selecting the menu item, or using keyboard shortcut.
      +

      Between two curves (direct tangency)

      +

      Sketcher ConsraintTangent mode1.png +

      Two curves will be made tangent, and the point of tangency will be implicit. This mode is applied if two curves were selected. +

      Accepted selection: +

      +
      • line + line, circle, arc, ellipse, arc-of-ellipse
      • +
      • circle, arc + circle, arc
      +

      If direct tangency between selected curves is not supported (e.g. between a circle and an ellipse), a helper point will be added to sketch automatically, and tangency-via-point will be applied. +

      It is not recommended to reconstruct the point of tangency by creating a point and constraining it to lie on both curves. It will work, but the convergence will be seriously slower, jumpier, and will require about twice as many iterations to converge than normal. Use other modes of this constraint if the point of tangency is needed. +

      +

      Between two endpoints (point-to-point tangency)

      +

      Sketcher ConsraintTangent mode2.png +

      In this mode, the endpoints are made coincident, and the joint is made tangent (C1-smooth, or "sharp", depending on the placement of curves before the constraint is applied). This mode is applied when two endpoints of two curves were selected. +

      Accepted selection: +

      +
      • endpoint of line/arc/arc-of-ellipse + endpoint of line/arc/arc-of-ellipse (i.e., two endpoints of any two curves)
      +

      Between curve and endpoint (point-to-curve tangency)

      +

      Sketcher ConsraintTangent mode3.png +

      In this mode, an endpoint of one curve is constrained to lie on the other curve, and the curves are forced tangent at the point. This mode is applied when a curve and an endpoint of another curve were selected. +

      Accepted selection: +

      +
      • line, circle, arc, ellipse, arc-of-ellipse + endpoint of line/arc/arc-of-ellipse (i.e., any curve + endpoint of any curve)
      +


      +

      +

      Between two curves at point (tangent-via-point) (v0.15)

      +

      Sketcher ConsraintTangent mode4.png +

      In this mode, two curves are made tangent, and the point of tangency is tracked. This mode is applied when two curves and a point were selected. +

      Accepted selection: +

      +
      • any line/curve + any line/curve + any point
      +

      "Any point" can be a lone point, or a point of something, e.g. a center of a circle, an endpoint of an arc, or the origin. +

      For the constraint to work correctly, the point must be on both curves. So, as the constraint is invoked, the point will be automatically constrained onto both curves (helper constraints will be added, if necessary), and the curves will be forced tangent at the point. These helper constraints are plain regular constraints. They can be added manually, or deleted. +

      Compared to direct tangency, this constraint is slower, because there are more degrees of freedom involved, but if the point of tangency is needed, it is the recommended mode because it offers better convergence compared to direct tangency + point on two curves. +

      The placement of the point before the constraint is applied is a hint for the solver for where the tangency should be. With this constraint, one can constrain two ellipses to touch each other in two places. +

      +

      Scripting

      +

      Tangent Constraint can be created from macros and from the python console by using the following: +

      +
      # direct tangency
      +Sketch.addConstraint(Sketcher.Constraint('Tangent',icurve1,icurve2))
      +
      +# point-to-point tangency
      +Sketch.addConstraint(Sketcher.Constraint('Tangent',icurve1,pointpos1,icurve2,pointpos2))
      +
      +# point-to-curve tangency
      +Sketch.addConstraint(Sketcher.Constraint('Tangent',icurve1,pointpos1,icurve2))
      +
      +# tangent-via-point (plain constraint, helpers are not added automatically)
      +Sketch.addConstraint(Sketcher.Constraint('TangentViaPoint',icurve1,icurve2,geoidpoint,pointpos)) 
      +

      where: +

      +
      • Sketch is a sketch object
      • +
      • icurve1, icurve2 are two integers identifying the curves to be made tangent. The integers are indexes in the sketch (the value, returned by Sketch.addGeometry).
      • +
      • pointpos1, pointpos2 should be 1 for start point and 2 for end point.
      • +
      • geoidpoint and pointpos in TangentViaPoint are the indexes specifying the point of tangency.
      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Constraint_Tangent.svg b/localwiki/Constraint_Tangent.svg new file mode 100644 index 0000000..6ad4e9c --- /dev/null +++ b/localwiki/Constraint_Tangent.svg @@ -0,0 +1,97 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [wmayer] + + + Constraint_Tangent + 2011-10-10 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Sketcher/Gui/Resources/icons/Constraint_Tangent.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + diff --git a/localwiki/Constraint_TangentToEnd.html b/localwiki/Constraint_TangentToEnd.html new file mode 100644 index 0000000..fd7b669 --- /dev/null +++ b/localwiki/Constraint_TangentToEnd.html @@ -0,0 +1,66 @@ +Constraint TangentToEnd

      Constraint TangentToEnd

      + +
      +

      This documentation is not finished. Please help and contribute documentation. +

      See Draft ShapeString for good documented Command. Gui Command gives an overview over commands. And see List of Commands for other commands. +

      Go to Help FreeCAD to contribute. +

      +
      +


      +

      + + + + + + + + + + + + + + + + + + + + +
      +

      Constraint TangentToEnd.png Constraint TangentToEnd

      +
      Menu location +
      Sketch → Sketcher constraints → TangentToEnd +
      Workbenches +
      Sketcher, PartDesign +
      Default shortcut +
      +
      See also +
      +

      + +
      +


      +

      Currently not used by FreeCAD +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Constraint_TangentToEnd.svg b/localwiki/Constraint_TangentToEnd.svg new file mode 100644 index 0000000..792b9ff --- /dev/null +++ b/localwiki/Constraint_TangentToEnd.svg @@ -0,0 +1,100 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [wmayer] + + + Constraint_TangentToEnd + 2011-10-10 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Sketcher/Gui/Resources/icons/Constraint_TangentToEnd.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + diff --git a/localwiki/Constraint_TangentToStart.html b/localwiki/Constraint_TangentToStart.html new file mode 100644 index 0000000..d3093b4 --- /dev/null +++ b/localwiki/Constraint_TangentToStart.html @@ -0,0 +1,67 @@ +Constraint TangentToStart

      Constraint TangentToStart

      + +
      +

      This documentation is not finished. Please help and contribute documentation. +

      See Draft ShapeString for good documented Command. Gui Command gives an overview over commands. And see List of Commands for other commands. +

      Go to Help FreeCAD to contribute. +

      +
      +


      +


      +

      + + + + + + + + + + + + + + + + + + + + +
      +

      Constraint TangentToStart.png Constraint TangentToStart

      +
      Menu location +
      Sketch → Sketcher constraints → TangentToStart +
      Workbenches +
      Sketcher, PartDesign +
      Default shortcut +
      +
      See also +
      +

      + +
      +


      +

      Currently not used by FreeCAD +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Constraint_TangentToStart.svg b/localwiki/Constraint_TangentToStart.svg new file mode 100644 index 0000000..af535fd --- /dev/null +++ b/localwiki/Constraint_TangentToStart.svg @@ -0,0 +1,99 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [wmayer] + + + Constraint_TangentToStart + 2011-10-10 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Sketcher/Gui/Resources/icons/Constraint_TangentToStart.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + diff --git a/localwiki/Constraint_Vertical.html b/localwiki/Constraint_Vertical.html new file mode 100644 index 0000000..281b487 --- /dev/null +++ b/localwiki/Constraint_Vertical.html @@ -0,0 +1,70 @@ +Constraint Vertical

      Constraint Vertical

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Constraint Vertical.png Constraint Vertical

      +
      Menu location +
      Sketch → Sketcher constraints → Constrain vertically +
      Workbenches +
      Sketcher, PartDesign +
      Default shortcut +
      None +
      See also +
      Constraint Horizontal +

      + +
      +


      +

      +

      Description

      +

      Creates a vertical constraint to the selected lines or polylines elements. More than one object can be selected. +

      +

      Usage

      +

      See Constraint Horizontal +

      +
      +


      +

      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Constraint_Vertical.svg b/localwiki/Constraint_Vertical.svg new file mode 100644 index 0000000..9df4293 --- /dev/null +++ b/localwiki/Constraint_Vertical.svg @@ -0,0 +1,80 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [wmayer] + + + Constraint_Vertical + 2011-10-10 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Sketcher/Gui/Resources/icons/Constraint_Vertical.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + diff --git a/localwiki/Constraint_VerticalDistance.html b/localwiki/Constraint_VerticalDistance.html new file mode 100644 index 0000000..21f8b6c --- /dev/null +++ b/localwiki/Constraint_VerticalDistance.html @@ -0,0 +1,70 @@ +Constraint VerticalDistance

      Constraint VerticalDistance

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Constraint VerticalDistance.png Constraint VerticalDistance

      +
      Menu location +
      Sketch → Sketcher constraints → Constrain vertical distance +
      Workbenches +
      Sketcher, PartDesign +
      Default shortcut +
      Shift+V +
      See also +
      Constraint HorizontalDistance, Constraint Length +

      + +
      +


      +

      +

      Description

      +

      Fixes the vertical distance between 2 points or line ends. If only one item is selected, the distance is set to the origin. +

      +

      Usage

      +
      1. Pick one or two points
      2. +
      3. Activate the constraint
      +
      +


      +

      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Constraint_VerticalDistance.svg b/localwiki/Constraint_VerticalDistance.svg new file mode 100644 index 0000000..df7e02e --- /dev/null +++ b/localwiki/Constraint_VerticalDistance.svg @@ -0,0 +1,79 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [wmayer] + + + Constraint_VerticalDistance + 2011-10-10 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Sketcher/Gui/Resources/icons/Constraint_VerticalDistance.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + diff --git a/localwiki/Constraint_VerticalDistance_Driven.svg b/localwiki/Constraint_VerticalDistance_Driven.svg new file mode 100644 index 0000000..ac0e447 --- /dev/null +++ b/localwiki/Constraint_VerticalDistance_Driven.svg @@ -0,0 +1,82 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [Abdullah Tahiri] + + + Constraint_VerticalDistance_Driven + 2015-05-18 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Sketcher/Gui/Resources/icons/Constraint_VerticalDistance_Driven.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + diff --git a/localwiki/Continuous_Integration.html b/localwiki/Continuous_Integration.html new file mode 100644 index 0000000..98dd395 --- /dev/null +++ b/localwiki/Continuous_Integration.html @@ -0,0 +1,45 @@ +Continuous Integration

      Continuous Integration

      + +
      + +

      Continuous Integration

      +

      Currently the FreeCAD repo on GitHub will trigger a build on the below two CI systems. Between these systems pretty much all the main cross-platforms OSs are coveredː Linux, MacOSX, and Windows. CIs can also be used to run unit tests. +

      +

      TravisCI

      +
      Travis-logo.png
      +

      Tests against Linux and OSX. The config file is called .travis.yml and it lives in the top directory of FreeCAD. +To view current and past buildsː https://travis-ci.org/FreeCAD/FreeCAD/builds +

      +

      Appveyor

      +
      Appveyor.svg
      Tests against Windows. The config file is called appveyor.yml and it lives in the top directory of FreeCAD. To view current and previous Appveyor buildsː https://ci.appveyor.com/project/yorikvanhavre/freecad/history +

      Tips

      +

      - If you add [skip ci] or [ci skip] to a git commit it will cancel a CI build. +


      +

      + +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Contributors.html b/localwiki/Contributors.html new file mode 100644 index 0000000..ccf3cd1 --- /dev/null +++ b/localwiki/Contributors.html @@ -0,0 +1,235 @@ +Contributors

      Contributors

      + +

      FreeCAD would not be what it is without the generous contributions of many people. Here's an overview of the people and companies who contributed to FreeCAD over time. For credits for the third party libraries see the Third Party Libraries page. +

      + + +

      Development

      +

      Project managers

      +

      Lead developers of the FreeCAD project: +

      + +

      Main developers

      +

      People who work regularly on the FreeCAD code (retrieved from https://github.com/FreeCAD/FreeCAD/graphs/contributors): +

      + +

      Other coders

      +

      Other people who contributed code to the FreeCAD project: +

      +
      • jmaustpc
      • +
      • j-dowsett
      • +
      • keithsloan52
      • +
      • Joachim Zettler
      • +
      • Graeme van der Vlugt
      • +
      • Berthold Grupp
      • +
      • Georg Wiora
      • +
      • Martin Burbaum
      • +
      • Jacques-Antoine Gaudin
      • +
      • Ken Cline
      • +
      • Dmitry Chigrin
      • +
      • Remigiusz Fiedler (DXF-parser)
      • +
      • peterl94
      • +
      • jobermayr
      • +
      • ovginkel
      • +
      • triplus
      • +
      • tomate44
      • +
      • maurerpe
      • +
      • Johan3DV
      • +
      • Mandeep Singh
      • +
      • fandaL
      • +
      • jonnor
      • +
      • usakhelo
      • +
      • plaes
      • +
      • SebKuzminsky
      • +
      • jcc242
      • +
      • ezzieyguywuf
      • +
      • marktaff
      • +
      • poutine70
      • +
      • qingfengxia
      • +
      • dbtayl
      • +
      • itain
      • +
      • Barleyman
      +


      +

      +

      Companies

      +

      Companies which donated code or developer time: +

      + +


      +

      +

      Forum moderators

      +

      People in charge of the FreeCAD forum (retrieved from http://forum.freecadweb.org/memberlist.php?mode=team): +

      + +


      +

      +

      Community

      +

      People from the community who put a lot of efforts in helping the FreeCAD project either by being active on the forum, keeping a blog about FreeCAD, making video tutorials, packaging FreeCAD for Windows/Linux/MacOS X, writing a FreeCAD book... (listed by alphabetical order) (retrieved from http://forum.freecadweb.org/memberlist.php?mode=&sk=d&sd=d#memberlist) +

      + +

      Documentation writers

      +

      People who wrote the documentation on this wiki: +

      +
      • Renato Rivoira (renatorivo)
      • +
      • Honza32
      • +
      • Hervé Blorec
      • +
      • Eduardo Magdalena
      • +
      • piffpoof
      • +
      • Wurstwasser
      • +
      • Roland Frank (r-frank)
      • +
      • bejant
      • +
      • Ediloren
      • +
      • Isaac Ayala
      +


      +

      +

      Translators

      +

      People who helped to translate the FreeCAD application (retrieved from https://crowdin.com/project/freecad): +

      +
      • Gerhard Scheepers
      • +
      • wbrwbr2011
      • +
      • hanhsuan
      • +
      • hicarl
      • +
      • fandaL
      • +
      • Peta T
      • +
      • Zdeněk Havlík
      • +
      • Jodbe
      • +
      • Peter Hageman
      • +
      • Vilfredo
      • +
      • Bruno Gonçalves Pirajá
      • +
      • Timo Seppola
      • +
      • rako
      • +
      • Pasi Kukkola
      • +
      • Ettore Atalan
      • +
      • nikoss
      • +
      • yang12
      • +
      • totyg
      • +
      • htsubota
      • +
      • asakura
      • +
      • Masaya Ootsuki
      • +
      • Jiyong Choi
      • +
      • Bartlomiej Niemiec
      • +
      • trzyha
      • +
      • bluecd
      • +
      • Miguel Morais
      • +
      • Nicu Tofan
      • +
      • Victor Radulescu
      • +
      • Angelescu Constantin
      • +
      • sema
      • +
      • Николай Матвеев
      • +
      • pinkpony
      • +
      • Alexandre Prokoudine
      • +
      • Марко Пејовић
      • +
      • Marosh
      • +
      • Peter Klofutar
      • +
      • Raulshc
      • +
      • javierMG
      • +
      • Lars
      • +
      • kunguz
      • +
      • Igor
      • +
      • Федір
      +

      Addons developers

      +

      Developers of FreeCAD addons (retrieved from https://github.com/FreeCAD/FreeCAD-addons): +

      +
      • microelly2
      • +
      • hamish2014
      • +
      • jreinhardt
      • +
      • jmwright
      • +
      • cblt2l
      • +
      • javierMG
      • +
      • looooo
      • +
      • shaise
      • +
      • marmni
      • +
      • Maaphoo
      • +
      • Rentlau
      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/CoordinateSystem.svg b/localwiki/CoordinateSystem.svg new file mode 100644 index 0000000..6445482 --- /dev/null +++ b/localwiki/CoordinateSystem.svg @@ -0,0 +1,220 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Copying_Objects.html b/localwiki/Copying_Objects.html new file mode 100644 index 0000000..c671aae --- /dev/null +++ b/localwiki/Copying_Objects.html @@ -0,0 +1,51 @@ +Copying Objects

      Copying Objects

      + +
      + +

      Overview

      +

      A facility to duplicate objects (paragraphs, spreadsheet cells, images, etc) is present in most applications. FreeCAD is no exception. Document objects may be freely copied within a document or between documents using the Copy, Paste and Duplicate Selection commands. +

      +

      Copying Linked Objects

      +

      Document objects may be linked to other objects (for example, a Pad feature is linked to it's Sketch, and a Fusion feature is linked to it's component objects). This means that some care must be exercised in selecting objects to copy. +

      If an object is selected without it's children, those children are not automatically duplicated by Copy/Paste or Duplicate Selection. In this case, the copied object may exhibit unexpected behaviour due to expected links not being present. +

      In general, recommended practice is to select all dependent objects when copying a parent object. +

      +

      Finding and Positioning Pasted Object(s)

      +

      After the Copy/Paste operation, it may not be obvious where the new object(s) are located in the Document window. That is because the new object has the same Placement property as the original. Toggle the Visibility property (spacebar) to hide the original. Then use the Placement dialog to move the copy to it's correct position. +

      +

      Other Methods

      +

      Like most things in FreeCAD, there are many ways of making a copy. For more ideas, look at: +

      + +

      Notes

      +
      • In v0.14+, if an object to be copied has links to object(s) not in the selection, FreeCAD will ask if the unselected objects should be included in the copy operation.
      +

      More

      + +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/CornerShape1.png b/localwiki/CornerShape1.png new file mode 100644 index 0000000..30f2b95 Binary files /dev/null and b/localwiki/CornerShape1.png differ diff --git a/localwiki/Countersunk_and_counterbored_holes_cross-section1.png b/localwiki/Countersunk_and_counterbored_holes_cross-section1.png new file mode 100644 index 0000000..0e176fe Binary files /dev/null and b/localwiki/Countersunk_and_counterbored_holes_cross-section1.png differ diff --git a/localwiki/Crank_00.gif b/localwiki/Crank_00.gif new file mode 100644 index 0000000..bd6027c Binary files /dev/null and b/localwiki/Crank_00.gif differ diff --git a/localwiki/Creating_a_simple_part_with_PartDesign.html b/localwiki/Creating_a_simple_part_with_PartDesign.html new file mode 100644 index 0000000..37bc89c --- /dev/null +++ b/localwiki/Creating_a_simple_part_with_PartDesign.html @@ -0,0 +1,228 @@ +Creating a simple part with PartDesign

      Creating a simple part with PartDesign

      + +
      + + + + + + + + + + + + + + + + + + + + + + + + + + + +
      +

      Base ExampleCommandModel.png Tutorial

      +
      Topic +
      Modeling +
      Level +
      Beginner +
      Time to complete +
      1 hour +
      Author +
      GlouGlou +
      FreeCAD version +
      0.17 or above +
      Example File(s) +
      Creating a simple PartDesign Body.FCStd +

      + +
      +


      +

      +
      GGTuto1 Vue.PNG
      +

      This tutorial aims to teach FreeCAD beginners a few basic features through an example. +After covering the basics in the User hub, you will be able to model a first part step by step. +

      We will cover in this tutorial in particular: +

      +
      • Using Part Design workbench v0.17, tracing the sketch.
      • +
      • Using Pad and Pocket features.
      • +
      • Changing color and transparency.
      • +
      • Moving the part manually.
      • +
      • Displaying reference dimensions in the sketch.
      • +
      • Editing one or more dimensions.
      • +
      • Using external geometry feature and using a reference plane to centre a hole.
      +

      Using Part Design workbench v0.17, tracing the sketch

      +

      Create a new document and select the Part Design workbench. Freecad will start with toolbars at the top, the combo view to the left and the 3D view at the right. +

      Create body: +

      Press PartDesign Body.png Create body. A body is a container in which Part Design features are sequentially arranged. It contains its own reference axes and planes. It will be highlighted in light blue, which means that it is active, that is to say that we can edit shapes. If it's not highlighted, double-click it. Let's take the opportunity to rename it. +

      Rename body: +

      Click on the body with the right mouse button. Select Rename and type a name, for example "Body part1" and press Enter to validate. +

      Create sketch: +

      We will now trace the sketch which defines the general shape of the part. A sketch is a diagram describing a profile to be applied to a feature in order to produce a shape. It can be either "positive" or "additive", like a pad for example; or "negative" or "subtractive", like a pocket. +

      Here, since the part's general shape is regular along the Y axis, we will create the Pad along this axis. +

      Press Sketcher NewSketch.png New sketch. FreeCAD then offers to attach this sketch to a plane of the Body; select the XZ plane and press OK. The interface now changes, the Sketcher now takes over and its toolbars appear over the 3D view. We find ourselves on the XZ plane of the body to trace the sketch. +

      To aid with sketching, set the following options in "Edit controls" in the Tasks panel to the left: +

      +
      • Show grid: checked
      • +
      • Grid size: 10 mm
      • +
      • Auto constraints: checked
      +

      We will trace the following sketch: +

      +
      GGTuto1 0.PNG
      +

      Let's start with the first segments: +

      Select the Sketcher Line.png Line tool. Click on the origin point, first making sure that a small red dot appears besides and to the right of the mouse pointer. Click next on the X axis about 10 squares to the right or at about 100 mm. If the segment is not exactly 100 mm at this point, it does not matter, we will later give it a fixed dimension that will constrain this length. +

      Do the same for the other segments, try to aim at the points that you have created which must light up in yellow. Which means that these points will be coincident. You should get pretty much this: +

      +
      GGTuto1 1.PNG
      +

      Note the small red lines above and beside the segments you have drawn: these are horizontal and vertical constraints. Your lines are forced to stay either horizontal or vertical. Note also the symbol in the form of a small arc on the left: it means that the point is fixed to the Z axis. +

      Now pick different line segments with the left mouse button and while keeping the left button pressed, drag the mouse to try to move them: some are free, others not. +

      Applying constraints: +

      At the top of the combo box, in the Tasks panel, you can read the number of degrees of freedom of the already sketched elements: it must be about 6, the objective of the constraints is to reduce the number of degrees of freedom to 0. +

      The slanted line should be free to rotate at this time: we will give it an angle constraint to fix it. +

      Click on the slanted line, then the bottom line; once selected these lines will turn dark green; then click the Constraint InternalAngle.png Constraint_InternalAngle icon. +

      +
      GGTuto1 2.PNG
      +

      Enter a value of 30°. Both lines have a fixed angle now. The constraint was created to the left of the sketch; with the mouse, move it inside the profile. +

      We will now constrain the bottom line with a dimension: select it then click Constraint HorizontalDistance.png Horizontal distance. +

      Enter a value of 100 mm. The vertical line on the right now aligns exactly with the grid's 10th square to the right of the origin. +

      Let's set the overall height to the profile by selecting the highest point on the left then the origin point. Click on Constraint VerticalDistance.png Vertical Distance, enter a value of 50 mm. +

      Do the same for the horizontal length of the sloped line with another 50 mm vertical distance contraint. +

      Move the dimensions away from the profile for better visibility. You should now have something like this: +

      +
      GGTuto1 3.PNG
      +

      Notice that the number of degrees of freedom reduced to 2. These are the ends still open. +

      Tracing the arc +

      Click on Sketcher Arc.png Arc, position the center at approximately x = 80 y = 30; then click to define the first starting point of the arc on the upper horizontal line's right end point; then click to define the end of the arc to the right vertical line's upper end point (make sure the points are highlighted in yellow before clicking). +

      Give the radius a radius constraint: select the arc, then click on Constraint Radius.png Radius then enter a value of 20 mm. +

      Now let's make the arc tangent to the lines it's connected to: select the arc, then the top line, then click on Constraint Tangent.png Tangent. A Constraint substitution message appears, click OK. Do the same for the tangent constraint on the other side of the arc. +

      We proceeded in two stages to create the sketch, but we could also have traced the profile completely before constraining it fully. +


      +Fully constrained sketch: +

      If you worked well, you should get this: +

      +
      GGTuto1 4.PNG
      +

      The sketch has become green, which means that it is fully constrained. There is no longer any ambiguity, everything is perfectly defined. This is confirmed by the solver message at the top left. Also note that the center of the arc has moved slightly, indeed giving these last three constraints, FreeCAD has calculated the true position of the center. +

      If your sketch is not yet green, one or more points are not coincident (2 points are superimposed but not coincident). Make a small window (capture window) around a point, and click Constraint PointOnPoint.png Coincident. +

      Proceed in the same way with all the points. +

      If your sketch is still not green, verify that all lines (but the slanted one) have either a Constraint Horizontal.png Horizontal or Constraint Vertical.png Vertical constraint, and add if necessary. +

      +

      Using Pad and Pocket features

      +

      Click on Close in the combo box, at the top left corner, the Part Design workbench is automatically activated again. +

      Click on View-axonometric.png Axonometric view then View-zoom-all.png Fit all, which gives a centered 3D isometric view. +

      Click on PartDesign Pad.png Pad, enter a length of 30 mm; check the Reversed box to reverse the direction of the Pad. Click OK, the shape is completed. +

      Note that the shape created forms a solid. +

      +
      GGTuto1 5.PNG
      +

      Creating the hole +

      Click on the top (square) side of the part and click the Sketcher NewSketch.png icon to create a new sketch. FreeCAD creates a new sketch attached to this face. So we are on a plane parallel to the absolute plane XY, but offset in height from the height of the piece, i.e. 50 mm. +

      You can activate a 3D view View-axonometric.png or stay in top view View-top.png. +

      Note that the origin of this new sketch is that of the body. They may be different, but here are confounded with the absolute origin. +

      With the Sketcher Circle.png Circle tool, click roughly in the center of the face and make a circle of any radius. +

      Select the circle then Constraint Radius.png Radius, enter a value of 5 mm. +

      Select the center of the circle then Sketcher ConstrainLock.png Lock, double click on the horizontal dimension and enter -65 mm (here we indicate a position relative to the origin of the sketch). Do the same for the vertical dimension (-15 mm). The circle takes its correct position and the sketch must be green, it is fully constrained: +

      +
      GGTuto1 6.PNG
      +

      Close the sketch and click on PartDesign Pocket.png Pocket. +

      Pocket is a feature called "subtractive", it removes material from our part, here in the form of a cylinder since the sketch is a circle. Set "Through all" to completely cut the part. Press OK. +

      +

      Changing color and transparency

      +

      It is possible to change the color of the part, it is often useful to distinguish a part among others. The transparency of the piece can also be modified, which is useful for visualizing its internals. +

      Select the body and go to the lower part of the left display, select the View tab, and click on the gray square of "Shape Color" and select another color then click OK. Next change the value of Transparency, for example to 50 and press Enter to complete (0 = totally opaque, 100 = totally transparent). +

      The hole is now visible inside the part. This is often useful for seeing the hidden or internal faces of the model. +

      You can also vary "Line Color" and "Line Width" to change the line thickness and the color of the part outline. +

      +

      Manually move the part

      +

      Go to the View menu and select Toggle axis cross. These are the absolute axes. You should see in the 3D view, the 3 axes X, Y, Z in different colors. This landmark will help us to orient ourselves in space. This landmark is fixed and immutable, it is either the view that rotates or the object that rotates in this space. +

      Select the Body, in the lower part of the combined view on the left, you can see this (the Data tab needs to be on the foreground, you may need to click on the Data tab to make it visible): +

      +
      GGTuto1 10.PNG
      +

      Click on the three small dots (if they don't appear, click on the Placement field), this opens a new dialog in the Tasks panel. Using the arrows you can vary the position and angles of the part. It is actually the position of the body (so its origin) that moves in space, the orientation of the 3D view does not change. +

      Another method: in the combo view, select the Body and click on the right button of the mouse, then select Transform. A view like this appears: +

      +
      GGTuto1 11.PNG
      +

      Hold and drag the cones along the axes or the spheres to move the piece (the body) in all directions. +

      Validate. Then reset angles and coordinates to 0. +

      +

      Displaying reference dimensions in the sketch

      +

      It may be useful to know the dimensions of some parts of the sketch, from the internal calculation of FreeCAD. It can be used just for reference, or use them later to set other dimensions for example. +

      Double click on the first sketch, then click on Sketcher ToggleConstraint.png Toggle Constraint. From now on, we can create reference dimensions rather than dimensional constraints: they will be blue and will have no influence on the shapes of the sketch from which they come, they are calculated automatically. +

      You can display these dimensions for example: +

      +
      GGTuto1 7.PNG
      +

      We can see for example that the arc has a length of 20 since it's tangent with the edges. +

      We can also see that FreeCAD calculates the left face (50-50xTAN 30 °), as well as the distance dimension of the axis of the arc with the origin. +

      +

      Editing one or more dimensions

      +

      During modeling, you can vary the dimensions of the model. It's very simple: for the thickness of the piece, double-click Pad, then enter a new value, 40mm for example. In the lower part of the combo view, you can change this value as well. Validate, the shape of the object has changed. +

      Do the same for the total length of the piece: double-click on Sketch, then double-click on the 100 mm dimensional constraint, change it to 110 mm then validate. +

      We can see that the piece was enlarged, but the hole is no longer centered in the middle of the top face. That's because it has been constrained to the sketch origin. Which does not necessarily correspond to what one would like, the hole should remain in the center, whatever the size of the face. +


      +

      +

      Center the hole

      +

      First method using external geometry. +

      Edit again the sketch of the hole and erase its horizontal and vertical distance constraints. +

      Then click on Sketcher External.png External Geometry. +

      We will now create two lines in the sketch, but extracted from a shape (or feature) external to this one and previously defined: that of the Pad. +

      Click on a vertical edge at the top of the part. For example, the edge slope side. +

      A new magenta line will appear above the edge. Repeat for the other edge, on the rounded side. +

      We can now use these lines (and especially their end points) to centre the circle, however we must add two construction lines: for example the diagonals. +

      Click on Sketcher ToggleConstruction.png Construction Mode, we switch to construction mode: the lines will be blue and will be discarded outside of the sketch editing mode. They will allow to fix the center of the circle. Create the diagonals in the same way that you drew the first lines. Make sure all points are coincident. +

      Then select the center of the circle, then the two blue diagonal lines and click on Constraint PointOnObject.png Point on object, the circle must be centred at the intersection of the diagonals, that is at the center of the face. The sketch must be green, completely constrained (it is essential). Note that besides the radius of the circle, it is no longer necessary to create dimensional constraints. +

      +
      GGTuto1 8.PNG
      +

      Leave the sketch, we see that the circle is well centred. (The pocket feature was not deleted, but modified). If you change the dimensions of the part again, the thickness or the length, the circle will remain centered on the face. +

      Avoid construction lines: +

      It is often possible to avoid creating construction lines. You can edit the sketch again, erase the construction lines and use a Constraint Symmetric.png Symmetric constraint between the two opposite vertices of the external geometry lines and the centre of the circle (select points in this order): +

      +
      GGTuto1 12.PNG
      +

      We get exactly the same resultat for the position of the hole. In fact, thanks to the constraints available in the Sketcher workbench, there are many possible methods. This example shows that it is often better to choose the simplest method, thus limiting the number of objects created as well as the errors that might result. +

      Second method using a datum plane. +

      Here is another, faster method that is possible since version 0.17: the use of a datum plane and its attachment. +

      Start by erasing the "Pocket" function as well as the sketch of the hole. Select the top face and click PartDesign Point.png Datum point: create a datum point in the active body. The attachment mode chosen must be "Center of mass". +

      As the face is rectangular, its center of mass corresponds to the center of its diagonals. Validate, and a datum point is created. +

      Select the top face again and while holding down the CTRL key, select the point you just created in the Model tree, release CTRL and click PartDesign Plane.png Datum plane. A reference plane is created with the origin of the point. Click OK. +

      It is now very easy to center the circle! Select from the Model tree or in the 3D view the plane you created, and click on Sketcher NewSketch.png Create a sketch, a sketch is created with as origin, the origin of the plane. Then just trace the 5 mm radius circle on this origin, then validate (the sketch must be green imperatively). +

      You get with "Pocket", as created previously, the hole and it will always be centered. +

      +
      GGTuto1 9.PNG
      +

      This tutorial is completed, save this file, you can have fun exploring various features. Change other dimensions, make other shapes, put other holes on other faces, it is when making mistakes that we progress! +

      You can also continue with this other tutorial of a slightly more complicated part: +

      Basic Part Design Tutorial 017 +

      +
      +


      +

      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Cross-section.png b/localwiki/Cross-section.png new file mode 100644 index 0000000..9380c5f Binary files /dev/null and b/localwiki/Cross-section.png differ diff --git a/localwiki/Cross.svg b/localwiki/Cross.svg new file mode 100644 index 0000000..e77cf8d --- /dev/null +++ b/localwiki/Cross.svg @@ -0,0 +1,148 @@ + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Crystal_Clear_app_terminal.png b/localwiki/Crystal_Clear_app_terminal.png new file mode 100644 index 0000000..4ef0cc3 Binary files /dev/null and b/localwiki/Crystal_Clear_app_terminal.png differ diff --git a/localwiki/Crystal_Clear_app_tutorials.png b/localwiki/Crystal_Clear_app_tutorials.png new file mode 100644 index 0000000..6d6e17b Binary files /dev/null and b/localwiki/Crystal_Clear_app_tutorials.png differ diff --git a/localwiki/Custom_Spacing.html b/localwiki/Custom_Spacing.html new file mode 100644 index 0000000..d93206e --- /dev/null +++ b/localwiki/Custom_Spacing.html @@ -0,0 +1,25 @@ +Custom Spacing

      Custom Spacing

      + +

      Description

      +

      The Custom Spacing tool allows a user to create rebar distribution in the structural element. You can define three segments for the distribution. For the first and third segments, you can give both a number of rebars and spacing between rebars. But for the second segment, you can only give either a number of rebars or spacing between rebars because one value automatically determines other. +

      For eg.: Given input values to Rebar Distribuiton dialog: +

      RebarDistributionDialog.png +

      Output produces by Rebar Distribution dialog when user click on OK button: +

      RebarDistribution.png +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Custom_extruder.jpg b/localwiki/Custom_extruder.jpg new file mode 100644 index 0000000..b89d108 Binary files /dev/null and b/localwiki/Custom_extruder.jpg differ diff --git a/localwiki/CustomizeToolBar_03.png b/localwiki/CustomizeToolBar_03.png new file mode 100644 index 0000000..74b5209 Binary files /dev/null and b/localwiki/CustomizeToolBar_03.png differ diff --git a/localwiki/CustomizeToolBar_04.png b/localwiki/CustomizeToolBar_04.png new file mode 100644 index 0000000..69f1438 Binary files /dev/null and b/localwiki/CustomizeToolBar_04.png differ diff --git a/localwiki/CustomizeToolBar_05.png b/localwiki/CustomizeToolBar_05.png new file mode 100644 index 0000000..95ecf1e Binary files /dev/null and b/localwiki/CustomizeToolBar_05.png differ diff --git a/localwiki/CustomizeToolBar_06.png b/localwiki/CustomizeToolBar_06.png new file mode 100644 index 0000000..0281a25 Binary files /dev/null and b/localwiki/CustomizeToolBar_06.png differ diff --git a/localwiki/CustomizeToolBar_07.png b/localwiki/CustomizeToolBar_07.png new file mode 100644 index 0000000..9635600 Binary files /dev/null and b/localwiki/CustomizeToolBar_07.png differ diff --git a/localwiki/CustomizeToolBar_08.png b/localwiki/CustomizeToolBar_08.png new file mode 100644 index 0000000..80c3fe1 Binary files /dev/null and b/localwiki/CustomizeToolBar_08.png differ diff --git a/localwiki/CustomizeToolBar_09.png b/localwiki/CustomizeToolBar_09.png new file mode 100644 index 0000000..0126882 Binary files /dev/null and b/localwiki/CustomizeToolBar_09.png differ diff --git a/localwiki/CustomizeToolBar_10.png b/localwiki/CustomizeToolBar_10.png new file mode 100644 index 0000000..17b7607 Binary files /dev/null and b/localwiki/CustomizeToolBar_10.png differ diff --git a/localwiki/CustomizeToolBar_11.png b/localwiki/CustomizeToolBar_11.png new file mode 100644 index 0000000..cdf7889 Binary files /dev/null and b/localwiki/CustomizeToolBar_11.png differ diff --git a/localwiki/CustomizeToolBar_12.png b/localwiki/CustomizeToolBar_12.png new file mode 100644 index 0000000..0ee0533 Binary files /dev/null and b/localwiki/CustomizeToolBar_12.png differ diff --git a/localwiki/CustomizeToolBar_13.png b/localwiki/CustomizeToolBar_13.png new file mode 100644 index 0000000..e09549c Binary files /dev/null and b/localwiki/CustomizeToolBar_13.png differ diff --git a/localwiki/CustomizeToolBar_14.png b/localwiki/CustomizeToolBar_14.png new file mode 100644 index 0000000..1a08f84 Binary files /dev/null and b/localwiki/CustomizeToolBar_14.png differ diff --git a/localwiki/CustomizeToolBar_15.png b/localwiki/CustomizeToolBar_15.png new file mode 100644 index 0000000..d56a408 Binary files /dev/null and b/localwiki/CustomizeToolBar_15.png differ diff --git a/localwiki/CustomizeToolBar_16.png b/localwiki/CustomizeToolBar_16.png new file mode 100644 index 0000000..6fee3c0 Binary files /dev/null and b/localwiki/CustomizeToolBar_16.png differ diff --git a/localwiki/CustomizeToolBar_17.png b/localwiki/CustomizeToolBar_17.png new file mode 100644 index 0000000..990a03b Binary files /dev/null and b/localwiki/CustomizeToolBar_17.png differ diff --git a/localwiki/CustomizeWorkbenches.png b/localwiki/CustomizeWorkbenches.png new file mode 100644 index 0000000..27b1451 Binary files /dev/null and b/localwiki/CustomizeWorkbenches.png differ diff --git a/localwiki/Customize_Toolbars.html b/localwiki/Customize_Toolbars.html new file mode 100644 index 0000000..dc5248f --- /dev/null +++ b/localwiki/Customize_Toolbars.html @@ -0,0 +1,181 @@ +Customize Toolbars

      Customize Toolbars

      + +
      + + + + + + + + + + + + + + + + + + + + + + + + + + + +
      +

      Base ExampleCommandModel.png Tutorial

      +
      Topic +
      SampleTopic +
      Level +
      Beginner +
      Time to complete +
      5 minutes +
      Author +
      Mario52 +
      FreeCAD version +
      All +
      Example File(s) +
      None +

      Contents

      + +
      + +
      +


      +

      +

      Synopsis

      +

      This tutorial shows you the customization of toolbars. Tools (inclusive Macro-tools) can used in different workbenches. In an example a Macro becomes a Macro-tool by creation of a Menu text, a Tool tip and an Icon. Afterwards this Macro-tool becomes part of an extra toolbar in a workbench. +

      +

      Use

      +

      1. Find the Customize Menu +

      +
      • Click Main Menu → Tools → Customize,
      +
      Customize
      +
      +


      +

      +
      • or right click on any toolbar.
      +
      Right mouse click
      +
      +


      +

      +
      • The Customize window appears.
      +
      The Customize window appears
      +
      +


      +2. Make a Macro to a Macro-Tool +

      +
      • Select the "Macro" tab.
      +
      • To add an icon for the provided macro click the Pixmap button (labelled ... ).
      +
      Select a toolbar
      +
      +


      +

      +
      • Search for an appropriate icon from amongst FreeCAD's existing icons,
      +
      +

            [or add your own icon by clicking Add icons...].                  (expand for an example) +

      +
      +
      Add icon
      +
      +


      +     [You will get a file selection window, select your custom image file (PNG format, 64x64 pixels)] +

      +
      Get a file
      +
      +


      +

      +
      +
      +
      • Select your icon and click OK.
      +
      Select your icon
      +
      +


      +

      +
      • The icon you selected is now displayed next to the Pixmap button labelled ....
      +
      Your icon is displayed
      +
      +


      +

      +
      • Select the provided macro in line Macro:' and specify a Menu text: (which will appear as the text label in the menu); also fill in the Tool Tip': (which is the text that will appear when a mouse is over the button on the toolbar); further lines are optional.
      +
      • Click the button Add.
      +
      Click the button
      +
      +


      +

      +
      • The button of the macro-tool is now created.
      +
      Your button is created
      +
      +


      +3. Create a toolbar outside the workbench Macro which contains the created Macro-tool +

      +
      • Select the Toolbars tab and choose the workbench (for which the toolbar is provided) in the drop down on the right (Part in this example).
      +

           [Since version 0.15 there is a  Freecad.svg Global  toolbar. If this is selected, the provided toolbar will be in each workbench.] +

      +
      Toolbars tab
      +
      +


      +

      +
      • In the dropdown on the left select Macros.
      +
      Macros
      +
      +


      +

      +
      • The macro-tool with its icon appears in the list.
      +
      Your icon is listed
      +
      +


      +

      +
      • Click the button New...
      +
      Click on "New"
      +
      +


      +

      +
      • In the window "New Toolbar" enter the name of the provided extra toolbar for the Part Workbench and click OK
      +
      Enter the name for your toolbar
      +
      +


      +

      +
      • The toolbar is now created.
      +
      • To add the creadet macro-tool to this toolbar, select it in the left window and then click the Button with the arrow pointing right.
      +
      Select your macro
      +
      +


      +

      +
      • You have created now a toolbar called "Camera" (with the Macro-tool Camera in it)
      +
      • Click the Close button.
      +
      Close
      +
      +


      +

      +
      • Your new toolbar is now contained in the toolbars' right-click menu. Its Icons (in our example only the camera) are visible, if the toolbar is activated (blue checkmark).
      +
      New Toolbar
      +
      +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Customize_ToolsBar.html b/localwiki/Customize_ToolsBar.html new file mode 100644 index 0000000..4a51e25 --- /dev/null +++ b/localwiki/Customize_ToolsBar.html @@ -0,0 +1,181 @@ +Customize ToolsBar

      Customize ToolsBar

      (Redirected from Customize ToolsBar)
      + +
      + + + + + + + + + + + + + + + + + + + + + + + + + + + +
      +

      Base ExampleCommandModel.png Tutorial

      +
      Topic +
      SampleTopic +
      Level +
      Beginner +
      Time to complete +
      5 minutes +
      Author +
      Mario52 +
      FreeCAD version +
      All +
      Example File(s) +
      None +

      Contents

      + +
      + +
      +


      +

      +

      Synopsis

      +

      This tutorial shows you the customization of toolbars. Tools (inclusive Macro-tools) can used in different workbenches. In an example a Macro becomes a Macro-tool by creation of a Menu text, a Tool tip and an Icon. Afterwards this Macro-tool becomes part of an extra toolbar in a workbench. +

      +

      Use

      +

      1. Find the Customize Menu +

      +
      • Click Main Menu → Tools → Customize,
      +
      Customize
      +
      +


      +

      +
      • or right click on any toolbar.
      +
      Right mouse click
      +
      +


      +

      +
      • The Customize window appears.
      +
      The Customize window appears
      +
      +


      +2. Make a Macro to a Macro-Tool +

      +
      • Select the "Macro" tab.
      +
      • To add an icon for the provided macro click the Pixmap button (labelled ... ).
      +
      Select a toolbar
      +
      +


      +

      +
      • Search for an appropriate icon from amongst FreeCAD's existing icons,
      +
      +

            [or add your own icon by clicking Add icons...].                  (expand for an example) +

      +
      +
      Add icon
      +
      +


      +     [You will get a file selection window, select your custom image file (PNG format, 64x64 pixels)] +

      +
      Get a file
      +
      +


      +

      +
      +
      +
      • Select your icon and click OK.
      +
      Select your icon
      +
      +


      +

      +
      • The icon you selected is now displayed next to the Pixmap button labelled ....
      +
      Your icon is displayed
      +
      +


      +

      +
      • Select the provided macro in line Macro:' and specify a Menu text: (which will appear as the text label in the menu); also fill in the Tool Tip': (which is the text that will appear when a mouse is over the button on the toolbar); further lines are optional.
      +
      • Click the button Add.
      +
      Click the button
      +
      +


      +

      +
      • The button of the macro-tool is now created.
      +
      Your button is created
      +
      +


      +3. Create a toolbar outside the workbench Macro which contains the created Macro-tool +

      +
      • Select the Toolbars tab and choose the workbench (for which the toolbar is provided) in the drop down on the right (Part in this example).
      +

           [Since version 0.15 there is a  Freecad.svg Global  toolbar. If this is selected, the provided toolbar will be in each workbench.] +

      +
      Toolbars tab
      +
      +


      +

      +
      • In the dropdown on the left select Macros.
      +
      Macros
      +
      +


      +

      +
      • The macro-tool with its icon appears in the list.
      +
      Your icon is listed
      +
      +


      +

      +
      • Click the button New...
      +
      Click on "New"
      +
      +


      +

      +
      • In the window "New Toolbar" enter the name of the provided extra toolbar for the Part Workbench and click OK
      +
      Enter the name for your toolbar
      +
      +


      +

      +
      • The toolbar is now created.
      +
      • To add the creadet macro-tool to this toolbar, select it in the left window and then click the Button with the arrow pointing right.
      +
      Select your macro
      +
      +


      +

      +
      • You have created now a toolbar called "Camera" (with the Macro-tool Camera in it)
      +
      • Click the Close button.
      +
      Close
      +
      +


      +

      +
      • Your new toolbar is now contained in the toolbars' right-click menu. Its Icons (in our example only the camera) are visible, if the toolbar is activated (blue checkmark).
      +
      New Toolbar
      +
      +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Cut.svg b/localwiki/Cut.svg new file mode 100644 index 0000000..90073bf --- /dev/null +++ b/localwiki/Cut.svg @@ -0,0 +1,287 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + + + + + + + + + diff --git a/localwiki/Cylindricity.svg b/localwiki/Cylindricity.svg new file mode 100644 index 0000000..aef7b55 --- /dev/null +++ b/localwiki/Cylindricity.svg @@ -0,0 +1,127 @@ + + + + + Cylindricity + + + + + + image/svg+xml + + Cylindricity + + + bavariaSHAPE + + + + + bavariaSHAPE + + + + + bavariaSHAPE + + + 15.10.2016 + Geometric dimensioning and tolerancing symbols +All symbols in this repository are licensed under CC-BY 3.0 + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/DagViewFail.svg b/localwiki/DagViewFail.svg new file mode 100644 index 0000000..e852e42 --- /dev/null +++ b/localwiki/DagViewFail.svg @@ -0,0 +1,189 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/DagViewPass.svg b/localwiki/DagViewPass.svg new file mode 100644 index 0000000..6b9479d --- /dev/null +++ b/localwiki/DagViewPass.svg @@ -0,0 +1,188 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/DagViewPending.svg b/localwiki/DagViewPending.svg new file mode 100644 index 0000000..38f98fa --- /dev/null +++ b/localwiki/DagViewPending.svg @@ -0,0 +1,401 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + diff --git a/localwiki/DagViewVisible.svg b/localwiki/DagViewVisible.svg new file mode 100644 index 0000000..a0cd967 --- /dev/null +++ b/localwiki/DagViewVisible.svg @@ -0,0 +1,226 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + + + + + + + + + + + diff --git a/localwiki/DatumPoint.png b/localwiki/DatumPoint.png new file mode 100644 index 0000000..8b13c3c Binary files /dev/null and b/localwiki/DatumPoint.png differ diff --git a/localwiki/Datum_line.png b/localwiki/Datum_line.png new file mode 100644 index 0000000..5806229 Binary files /dev/null and b/localwiki/Datum_line.png differ diff --git a/localwiki/Datum_plane.png b/localwiki/Datum_plane.png new file mode 100644 index 0000000..6052edb Binary files /dev/null and b/localwiki/Datum_plane.png differ diff --git a/localwiki/David.html b/localwiki/David.html new file mode 100644 index 0000000..77c1ee1 --- /dev/null +++ b/localwiki/David.html @@ -0,0 +1,202 @@ +David

      David

      + +

      [link removed not existent] is a very low cost sensor system introduced by Dr. Simon Winkelbach and Sven Molkenstruck. It utilizes a standard USB webcam and any sort of hand held laser line projector. This article is about my first impression of the sensor system and the discussion about how to integrate the data into FreeCAD. +


      +

      + + +

      Hardware

      +

      Sensor

      +

      I use the follwing hardware for the scan: +

      +
      • A 10€ Laser line from the hardware store
      • +
      • A 24€ Trust WebCam 640x480, 17 fps
      + +

      Test parts

      +

      I will use follwing test parts: +

      + +

      Setup

      +

      Here is my sensor setup for the first two test parts. It is a corner with a 90° angle and two sheets with the calibration pattern. +

      +
      Setup Bottle.JPG
      +

      Setup WaWue.JPG +

      +

      Software

      +

      So far I use: +

      +
      • The DAVID sensor wizard
      • +
      • FreeCAD for post processing
      +

      Scans

      +

      Here are the scans I made with the sensor. +

      +

      First tryout

      +

      This is my first tryout with the above mentioned sensor hardware: +

      + + +

      ToDos

      +

      Here some ToDos to enable FreeCAD to easily incorporate DAVID scanner data: +

      +
      • A DAVID Workbench
      • +
      • Own hole closing filter
      • +
      • ...
      +

      Done

      +

      The following DAVID related features are allready implemented: +

      +
      • OBJ file format import (Rev:358)
      +

      Scans from others

      +

      Here a list of published scans from other persons (with no warranty ;-). +

      +

      Roberto

      +

      Example

      +

      Finished model of a little dog +

      +

      Hardware

      +

      MICROSOFT Webcam LifeCam NX-6000 USB 2.0 - 2MB pixel captor works very well in 800×600 at 30 fps grey scale(no saturation), the scan is precise to 0.1 mm (180mm model)with very few noise for 82 Euros wonderful. +

      +

      Software

      +

      Only free software has been used +

      +
      • DAVID
      • +
      • MeshLab (noise remove)
      • +
      • Scanalyse (assembly)
      +

      Weblinks

      +
      • [dead link removed]
      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Debug-start.svg b/localwiki/Debug-start.svg new file mode 100644 index 0000000..277d526 --- /dev/null +++ b/localwiki/Debug-start.svg @@ -0,0 +1,407 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + Media Playback Start + + + Lapo Calamandrei + + + + + + play + media + music + video + player + + + + + Jakub Steiner + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Debug-stop.svg b/localwiki/Debug-stop.svg new file mode 100644 index 0000000..212125c --- /dev/null +++ b/localwiki/Debug-stop.svg @@ -0,0 +1,650 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + Media Playback Pause + + + Lapo Calamandrei + + + + + + media + stop + playback + video + music + + + + + Jakub Steiner + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Debug_marker.svg b/localwiki/Debug_marker.svg new file mode 100644 index 0000000..6f4c6ff --- /dev/null +++ b/localwiki/Debug_marker.svg @@ -0,0 +1,727 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Debugging.html b/localwiki/Debugging.html new file mode 100644 index 0000000..0ec9c2c --- /dev/null +++ b/localwiki/Debugging.html @@ -0,0 +1,144 @@ +Debugging

      Debugging

      + +
      + +

      Test First

      +

      Before you go through the pain of debugging use the Test framework to check if the standard tests work properly. If they do not run complete there is possibly a broken installation. +

      +

      Command Line

      +

      The debugging of FreeCAD is supported by a few internal mechanisms. The command line version of FreeCAD provides some options for debugging support. +

      These are the currently recognized options in FreeCAD 0.15: +

      Generic options: +

      +
       -v [ --version ]      Prints version string
      + -h [ --help ]         Prints help message
      + -c [ --console ]      Starts in console mode
      + --response-file arg   Can be specified with '@name', too
      +
      +

      Configuration: +

      +
       -l [ --write-log ]       Writes a log file to:
      +                          $HOME/.FreeCAD/FreeCAD.log
      + --log-file arg           Unlike to --write-log this allows to log to an 
      +                          arbitrary file
      + -u [ --user-cfg ] arg    User config file to load/save user settings
      + -s [ --system-cfg ] arg  Systen config file to load/save system settings
      + -t [ --run-test ] arg    Test level
      + -M [ --module-path ] arg Additional module paths
      + -P [ --python-path ] arg Additional python paths
      +
      +

      Generating a Backtrace

      +

      If you are running a version of FreeCAD from the bleeding edge of the development curve, it may "crash". You can help solve such problems by providing the developers with a "backtrace". To do this, you need to be running a "debug build" of the software. "Debug build" is a parameter that is set at compile time, so you'll either need to compile FreeCAD yourself, or obtain a pre-compiled "debug" version. +

      +

      For Linux

      +
      +

      Linux Debugging ----> +

      +
      +

      Prerequisites: +

      +
      • software package gdb installed
      • +
      • a debug build of FreeCAD (at this time only available by building from source)
      • +
      • a FreeCAD model that causes a crash
      +

      Steps: +Enter the following in your terminal window: +

      +
      +$ cd FreeCAD/bin
      +$ gdb FreeCAD
      +
      +

      GNUdebugger will output some initializing information. The (gdb) shows GNUDebugger is running in the terminal, now input: +

      +
      +(gdb) handle SIG33 noprint nostop
      +(gdb) run
      +
      +

      FreeCAD will now start up. Perform the steps that cause FreeCAD to crash or freeze, then enter in the terminal window: +

      +
      +(gdb) bt
      +
      +

      This will generate a lengthy listing of exactly what the program was doing when it crashed or froze. Include this with your problem report. +

      +
      +

      For MacOSX

      +
      +

      MacOSX Debugging ----> +

      +
      +

      Prerequisites: +

      +
      • software package lldb installed
      • +
      • a debug build of FreeCAD
      • +
      • a FreeCAD model that causes a crash
      +

      Steps: +Enter the following in your terminal window: +

      +
      +$ cd FreeCAD/bin
      +$ lldb FreeCAD
      +
      +

      LLDB will output some initializing information. The (lldb) shows the debugger is running in the terminal, now input: +

      +
      +(lldb) run
      +
      +

      FreeCAD will now start up. Perform the steps that cause FreeCAD to crash or freeze, then enter in the terminal window: +

      +
      +(lldb) bt
      +
      +

      This will generate a lengthy listing of exactly what the program was doing when it crashed or froze. Include this with your problem report. +

      +
      +

      Python Debugging

      +

      Here is an example of using winpdb inside FreeCAD: +

      +
      1. Run winpdb and set the password (e.g. test)
      2. +
      3. Create a Python file with this content
      +
       import rpdb2
      + rpdb2.start_embedded_debugger("test")
      + import FreeCAD
      + import Part
      + import Draft
      + print "hello"
      + print "hello"
      + import Draft
      + points=[FreeCAD.Vector(-3.0,-1.0,0.0),FreeCAD.Vector(-2.0,0.0,0.0)]
      + Draft.makeWire(points,closed=False,face=False,support=None)
      +
      1. Start FreeCAD and load the above file into FreeCAD
      2. +
      3. Press F6 to execute it
      4. +
      5. Now FreeCAD will become unresponsive because the Python debugger is waiting
      6. +
      7. Switch to the Windpdb GUI and click on "Attach". After a few seconds an item "<Input>" appears where you have to double-click
      8. +
      9. Now the currently executed script appears in Winpdb.
      10. +
      11. Set a break at the last line and press F5
      12. +
      13. Now press F7 to step into the Python code of Draft.makeWire
      + +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Delete.svg b/localwiki/Delete.svg new file mode 100644 index 0000000..dae0018 --- /dev/null +++ b/localwiki/Delete.svg @@ -0,0 +1,151 @@ + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + + + + + + + + + + diff --git a/localwiki/DeltaXYZ.png b/localwiki/DeltaXYZ.png new file mode 100644 index 0000000..dfe7299 Binary files /dev/null and b/localwiki/DeltaXYZ.png differ diff --git a/localwiki/DependencyGraph1.png b/localwiki/DependencyGraph1.png new file mode 100644 index 0000000..c25248e Binary files /dev/null and b/localwiki/DependencyGraph1.png differ diff --git a/localwiki/Developing_FreeCAD_with_GitKraken.html b/localwiki/Developing_FreeCAD_with_GitKraken.html new file mode 100644 index 0000000..bfaa776 --- /dev/null +++ b/localwiki/Developing_FreeCAD_with_GitKraken.html @@ -0,0 +1,117 @@ +Developing FreeCAD with GitKraken

      Developing FreeCAD with GitKraken

      + +
      Please Read +

      This guide is not written to teach users how to use git in it's totality, far from it. git is super handy tool with a lot of functionality that goes way beyond the scope of this intro. This is just a cursory introduction highlighting on how to work with git in a GUI environment. It also serves as a means to enourage FreeCAD users to contribute to FreeCAD. This tutorial uses GitKraken, proprietary software that is free to use for non-commercial use. +

      +
      +


      +

      + + +

      Setup git Development

      +
        +
      1. Download GitKraken (There are different ways to download GitKraken depending on your OS. I use an Arch Linux based distro called Manjaro and added it through my package manager)
      2. +
      3. In your web browser go to: https://github.com/FreeCAD/FreeCAD
      4. +
      5. Click the Fork button. This will clone the FreeCAD/FreeCAD repo to your own account. In other words the URL to access your fork of FreeCAD is: +
        https://github.com/GITUBUSERNAME/FreeCAD.git
      6. +
      7. Open GitKraken and go to File > Clone Repo
      8. +
         GitKraken-Clone-Repo-dialogue.png
        +
        +
      9. GitKraken will now git clone your repository +
          +
        • Now an important point: Please read the different between origin vs. upstream remote repos. Essentially your fork of FreeCAD is the origin repo. The official FreeCAD git repo FreeCAD/FreeCAD is your upstream. You now need to set the upstream repo as FreeCAD.
      10. +
      11. Go to File > Open Terminal
      12. +
      13. Enter the following to set up your upstream remote repo +
        git remote add upstream https://github.com/YOURGITUHUBUSERNAME/FreeCAD.git
      14. +
      15. Now check what remote branches you have set by typing: +
        git remote -v
      16. +
      17. You should see something like this in the terminal: +
        originhttps://github.com/foobar/FreeCAD (fetch)
        +originhttps://github.com/foobar/FreeCAD (push)
        +upstreamhttps://github.com/FreeCAD/FreeCAD.git (fetch)
        +upstreamhttps://github.com/FreeCAD/FreeCAD.git (push)
      18. +
      19. Switch back to GitKraken interface.
      20. +
      21. On the left side of the screen you will see a sidebar with a section labled Local double click on the master branch (this will make sure you're on the master branch AKA
        git checkout master
      22. +
      23. Click on the Push] icon on the top right side of the interface. This will push your Local master to your Remote origin master
      24. +
      +
      +

      Deciphering the GitKraken Interface

      +

      For more in-depth understanding of the GitKraken interface checkout the Getting Started Guide. +

      +
      • Orientation: +
        • Local = local machine +
          • Local master = your local copy FreeCAD <= symbolized as Blue in Screenshot)
        • +
        • Remote = Remote GitHub repos +
          • Remote Upstream = Official FreeCAD repo (AKA FreeCAD/FreeCAD) <= Symbolized as Green in Screenshot
          • +
          • Remote Origin = Fork of FreeCAD/FreeCAD (should look something like: github.com/YourGitHubUsername/FreeCAD) <= Symbolized as Red in Screenshot
      +

      GitKraken-Main-Screen-sm.jpg +

      +
      Notice +

      That both remote origin master and local master are a few commits behind upstream in the above screenshot. You can remedy this by Rebasing +

      +
      +
      +

      Rebasing

      +
      • Checkout the Local Master branch by double clicking on it (this is the equivalent of typing git branch master in the terminal)
      • +
      • Move the mouse to the where latest Upstream commit is, right click mouse and choose Rebase master on upstream/master (this will pull down the Upstream changes in to your Local master)
      • +
      • Move the mouse and press the Push button. GitKraken (This pushes from your 'Local master' to 'Remote Origin master')
      +

      Now all your repos are in sync! +

      GitKraken-Rebasing.gif +

      +
      +

      Branches

      +

      Resolving Merge Conflicts

      +
      Notice +

      GitKraken has a special merge conflict tool that is only accessible in the GitKraken Pro version. But there are workarounds to use external git merge 3rd party tools +

      +
      + +


      +

      +

      Squashing Commits

      +

      Squashing is when you have several commits you want to condense down in to one commit. From the GitKraken manual: +Squashing is available for commits that meet the following requirements: +

      +
         Selection contains more than one commit
      +   The youngest commit (by commit date) is also the current HEAD commit
      +   Genealogically consecutive
      +   Chronologically consecutive
      +   The oldest commit in the list has a parent
      +
      +

      If all these conditions are met, the Squash option appears when you right click the commit node. +See screencast at: https://support.gitkraken.com/img/documentation/working-with-files/commits/squash.gif +

      +

      Follow Other FreeCADers Branches

      +

      Remotes are forked repositories of FreeCAD/FreeCAD by fellow FreeCADers. You can use Gitkraken to follow how FreeCAD devs code and commit to their own branches before they send git Pull Requests to the main FC repo. +Here is how you can follow other users: +

      +
      1. In the left side panel there is a Remotes category. Press the +
      2. +
      3. A dialogue will come up that can give you the option to choose which remote you want to follow. Recommended remotes are: wmayer, yorikvanhavre, ickby, sliptonic, kkremitzki etc....
      4. +
      5. Choose 'Add Remote'
      +

      Whenever new commits are made or branches are rebased by said user you will see it represented in the gui. +Gitkraken-add-remote.gif +

      + + +
      + +
      +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Development_roadmap.html b/localwiki/Development_roadmap.html new file mode 100644 index 0000000..dca8724 --- /dev/null +++ b/localwiki/Development_roadmap.html @@ -0,0 +1,70 @@ +Development roadmap

      Development roadmap

      + +

      FreeCAD - though usable in many applications - is at the beginning of a long journey into CAD mainstream. There is still a lot to do to reach a state where we can compete with commercial software. +

      This section gives an overview of what is planned and gives you the opportunity to participate or give your opinion. As we are volunteers to FreeCAD we have only a certain amount of time. So if you interested in one of the topics and willing to help, just let us know! We use the Getting Things Done (GTD) style for the project document. Here is the Project template. +

      + + + +

      Projects

      +

      Current projects

      +

      These are work in progress. +

      + +

      Future projects

      +

      Projects for the near future. +

      + +

      So far finished projects

      + +

      Ideas

      +

      Release schedule

      +

      Like in the most FLOSS projects a release schedule is very rough. There will be no fixed dates and "It's done, when it's done!" +

      +
      • The Release process page gather ideas for a more efficient release workflow
      +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Diagonal1.svg b/localwiki/Diagonal1.svg new file mode 100644 index 0000000..4950ead --- /dev/null +++ b/localwiki/Diagonal1.svg @@ -0,0 +1,412 @@ + + + + + + + + + + image/svg+xml + + + + + Pablo Gil + + + + + SVG + template + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Diagonal2.svg b/localwiki/Diagonal2.svg new file mode 100644 index 0000000..1a96fd7 --- /dev/null +++ b/localwiki/Diagonal2.svg @@ -0,0 +1,412 @@ + + + + + + + + + + image/svg+xml + + + + + Pablo Gil + + + + + SVG + template + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Dialog-chamfer.png b/localwiki/Dialog-chamfer.png new file mode 100644 index 0000000..6514934 Binary files /dev/null and b/localwiki/Dialog-chamfer.png differ diff --git a/localwiki/Dialog-fillet.jpg b/localwiki/Dialog-fillet.jpg new file mode 100644 index 0000000..bd2fa64 Binary files /dev/null and b/localwiki/Dialog-fillet.jpg differ diff --git a/localwiki/Dialog-revolve.png b/localwiki/Dialog-revolve.png new file mode 100644 index 0000000..055d562 Binary files /dev/null and b/localwiki/Dialog-revolve.png differ diff --git a/localwiki/Dialog_creation.html b/localwiki/Dialog_creation.html new file mode 100644 index 0000000..75700c4 --- /dev/null +++ b/localwiki/Dialog_creation.html @@ -0,0 +1,1044 @@ +Dialog creation

      Dialog creation

      + +

      In this page we will show how to build a simple Qt Dialog with Qt Designer, Qt's official tool for designing interfaces, then convert it to python code, then use it inside FreeCAD. I'll assume in the example that you know how to edit and run python scripts already, and that you can do simple things in a terminal window such as navigate, etc. You must also have, of course, pyqt installed. +

      + + +

      Designing the dialog

      +

      In CAD applications, designing a good UI (User Interface) is very important. About everything the user will do will be through some piece of interface: reading dialog boxes, pressing buttons, choosing between icons, etc. So it is very important to think carefully to what you want to do, how you want the user to behave, and how will be the workflow of your action. +

      There are a couple of concepts to know when designing interface: +

      +
      • Modal/non-modal dialogs: A modal dialog appears in front of your screen, stopping the action of the main window, forcing the user to respond to the dialog, while a non-modal dialog doesn't stop you from working on the main window. In some case the first is better, in other cases not.
      • +
      • Identifying what is required and what is optional: Make sure the user knows what he must do. Label everything with proper description, use tooltips, etc.
      • +
      • Separating commands from parameters: This is usually done with buttons and text input fields. The user knows that clicking a button will produce an action while changing a value inside a text field will change a parameter somewhere. Nowadays, though, users usually know well what is a button, what is an input field, etc. The interface toolkit we are using, Qt, is a state-of-the-art toolkit, and we won't have to worry much about making things clear, since they will already be very clear by themselves.
      +

      So, now that we have well defined what we will do, it's time to open the qt designer. Let's design a very simple dialog, like this: +

      Qttestdialog.jpg +

      We will then use this dialog in FreeCAD to produce a nice rectangular plane. You might find it not very useful to produce nice rectangular planes, but it will be easy to change it later to do more complex things. When you open it, Qt Designer looks like this: +

      Qtdesigner-screenshot.jpg +

      It is very simple to use. On the left bar you have elements that can be dragged on your widget. On the right side you have properties panels displaying all kinds of editable properties of selected elements. So, begin with creating a new widget. Select "Dialog without buttons", since we don't want the default Ok/Cancel buttons. Then, drag on your widget 3 labels, one for the title, one for writing "Height" and one for writing "Width". Labels are simple texts that appear on your widget, just to inform the user. If you select a label, on the right side will appear several properties that you can change if you want, such as font style, height, etc. +

      Then, add 2 LineEdits, which are text fields that the user can fill in, one for the height and one for the width. Here too, we can edit properties. For example, why not set a default value? For example 1.00 for each. This way, when the user will see the dialog, both values will be filled already and if he is satisfied he can directly press the button, saving precious time. Then, add a PushButton, which is the button the user will need to press after he filled the 2 fields. +

      Note that I choosed here very simple controls, but Qt has many more options, for example you could use Spinboxes instead of LineEdits, etc... Have a look at what is available, you will surely have other ideas. +

      That's about all we need to do in Qt Designer. One last thing, though, let's rename all our elements with easier names, so it will be easier to identify them in our scripts: +

      Qtpropeditor.jpg +

      +

      Converting our dialog to python

      +

      Now, let's save our widget somewhere. It will be saved as an .ui file, that we will easily convert to python script with pyuic. On windows, the pyuic program is bundled with pyqt (to be verified), on linux you probably will need to install it separately from your package manager (on debian-based systems, it is part of the pyqt4-dev-tools package). To do the conversion, you'll need to open a terminal window (or a command prompt window on windows), navigate to where you saved your .ui file, and issue: +

      +
      pyuic mywidget.ui > mywidget.py
      +

      Into Windows pyuic.py are located in "C:\Python27\Lib\site-packages\PyQt4\uic\pyuic.py" +For create batch file "compQt4.bat: +

      +
      @"C:\Python27\python" "C:\Python27\Lib\site-packages\PyQt4\uic\pyuic.py" -x %1.ui > %1.py
      +

      In the console Dos type without extension +

      +
      compQt4 myUiFile
      +

      Into Linux : to do +

      Since FreeCAD progressively moved away from PyQt after version 0.13, in favour of PySide (Choice your PySide install building PySide), to make the file based on PySide now you have to use: +

      +
      pyside-uic mywidget.ui -o mywidget.py
      +

      Into Windows uic.py are located in "C:\Python27\Lib\site-packages\PySide\scripts\uic.py" +For create batch file "compSide.bat": +

      +
      @"C:\Python27\python" "C:\Python27\Lib\site-packages\PySide\scripts\uic.py" %1.ui > %1.py
      +

      In the console Dos type without extension +

      +
      compSide myUiFile
      +

      Into Linux : to do +


      +On some systems the program is called pyuic4 instead of pyuic. This will simply convert the .ui file into a python script. If we open the mywidget.py file, its contents are very easy to understand: +

      +
      from PySide import QtCore, QtGui
      +
      +class Ui_Dialog(object):
      +    def setupUi(self, Dialog):
      +        Dialog.setObjectName("Dialog")
      +        Dialog.resize(187, 178)
      +        self.title = QtGui.QLabel(Dialog)
      +        self.title.setGeometry(QtCore.QRect(10, 10, 271, 16))
      +        self.title.setObjectName("title")
      +        self.label_width = QtGui.QLabel(Dialog)
      +        ...
      +
      +        self.retranslateUi(Dialog)
      +        QtCore.QMetaObject.connectSlotsByName(Dialog)
      +
      +   def retranslateUi(self, Dialog):
      +        Dialog.setWindowTitle(QtGui.QApplication.translate("Dialog", "Dialog", None, QtGui.QApplication.UnicodeUTF8))
      +        self.title.setText(QtGui.QApplication.translate("Dialog", "Plane-O-Matic", None, QtGui.QApplication.UnicodeUTF8))
      +        ...
      +

      As you see it has a very simple structure: a class named Ui_Dialog is created, that stores the interface elements of our widget. That class has two methods, one for setting up the widget, and one for translating its contents, that is part of the general Qt mechanism for translating interface elements. The setup method simply creates, one by one, the widgets as we defined them in Qt Designer, and sets their options as we decided earlier. Then, the whole interface gets translated, and finally, the slots get connected (we'll talk about that later). +

      We can now create a new widget, and use this class to create its interface. We can already see our widget in action, by putting our mywidget.py file in a place where FreeCAD will find it (in the FreeCAD bin directory, or in any of the Mod subdirectories), and, in the FreeCAD python interpreter, issue: +

      +
      from PySide import QtGui
      +import mywidget
      +d = QtGui.QWidget()
      +d.ui = mywidget.Ui_Dialog()
      +d.ui.setupUi(d)
      +d.show()
      +

      And our dialog will appear! Note that our python interpreter is still working, we have a non-modal dialog. So, to close it, we can (apart from clicking its close icon, of course) issue: +

      +
      d.hide()
      +

      Making our dialog do something

      +

      Now that we can show and hide our dialog, we just need to add one last part: To make it do something! If you play a bit with Qt designer, you'll quickly discover a whole section called "signals and slots". Basically, it works like this: elements on your widgets (in Qt terminology, those elements are themselves widgets) can send signals. Those signals differ according to the widget type. For example, a button can send a signal when it is pressed and when it is released. Those signals can be connected to slots, which can be special functionality of other widgets (for example a dialog has a "close" slot to which you can connect the signal from a close button), or can be custom functions. The PyQt Reference Documentation lists all the qt widgets, what they can do, what signals they can send, etc... +

      What we will do here, is to create a new function that will create a plane based on height and width, and to connect that function to the pressed signal emitted by our "Create!" button. So, let's begin with importing our FreeCAD modules, by putting the following line at the top of the script, where we already import QtCore and QtGui: +

      +
      import FreeCAD, Part
      +

      Then, let's add a new function to our Ui_Dialog class: +

      +
      def createPlane(self):
      +    try:
      +        # first we check if valid numbers have been entered
      +        w = float(self.width.text())
      +        h = float(self.height.text())
      +    except ValueError:
      +        print "Error! Width and Height values must be valid numbers!"
      +    else:
      +        # create a face from 4 points
      +        p1 = FreeCAD.Vector(0,0,0)
      +        p2 = FreeCAD.Vector(w,0,0)
      +        p3 = FreeCAD.Vector(w,h,0)
      +        p4 = FreeCAD.Vector(0,h,0)
      +        pointslist = [p1,p2,p3,p4,p1]
      +        mywire = Part.makePolygon(pointslist)
      +        myface = Part.Face(mywire)
      +        Part.show(myface)
      +        self.hide()
      +

      Then, we need to inform Qt to connect the button to the function, by placing the following line just before QtCore.QMetaObject.connectSlotsByName(Dialog): +

      +
      QtCore.QObject.connect(self.create,QtCore.SIGNAL("pressed()"),self.createPlane)
      +

      This, as you see, connects the pressed() signal of our create object (the "Create!" button), to a slot named createPlane, which we just defined. That's it! Now, as a final touch, we can add a little function to create the dialog, it will be easier to call. Outside the Ui_Dialog class, let's add this code: +

      +
      class plane():
      +   def __init__(self):
      +       self.d = QtGui.QWidget()
      +       self.ui = Ui_Dialog()
      +       self.ui.setupUi(self.d)
      +       self.d.show()
      +

      (Python reminder: the __init__ method of a class is automatically executed whenever a new object is created!) +Then, from FreeCAD, we only need to do: +

      +
      import mywidget
      +myDialog = mywidget.plane()
      +

      That's all Folks... Now you can try all kinds of things, like for example inserting your widget in the FreeCAD interface (see the Code snippets page), or making much more advanced custom tools, by using other elements on your widget. +

      +

      The complete script

      +

      This is the complete script, for reference: +

      +
      # -*- coding: utf-8 -*-
      +
      +# Form implementation generated from reading ui file 'mywidget.ui'
      +#
      +# Created: Mon Jun  1 19:09:10 2009
      +#      by: PyQt4 UI code generator 4.4.4
      +# Modified for PySide 16:02:2015 
      +# WARNING! All changes made in this file will be lost!
      +
      +from PySide import QtCore, QtGui
      +import FreeCAD, Part 
      +
      +class Ui_Dialog(object):
      +   def setupUi(self, Dialog):
      +       Dialog.setObjectName("Dialog")
      +       Dialog.resize(187, 178)
      +       self.title = QtGui.QLabel(Dialog)
      +       self.title.setGeometry(QtCore.QRect(10, 10, 271, 16))
      +       self.title.setObjectName("title")
      +       self.label_width = QtGui.QLabel(Dialog)
      +       self.label_width.setGeometry(QtCore.QRect(10, 50, 57, 16))
      +       self.label_width.setObjectName("label_width")
      +       self.label_height = QtGui.QLabel(Dialog)
      +       self.label_height.setGeometry(QtCore.QRect(10, 90, 57, 16))
      +       self.label_height.setObjectName("label_height")
      +       self.width = QtGui.QLineEdit(Dialog)
      +       self.width.setGeometry(QtCore.QRect(60, 40, 111, 26))
      +       self.width.setObjectName("width")
      +       self.height = QtGui.QLineEdit(Dialog)
      +       self.height.setGeometry(QtCore.QRect(60, 80, 111, 26))
      +       self.height.setObjectName("height")
      +       self.create = QtGui.QPushButton(Dialog)
      +       self.create.setGeometry(QtCore.QRect(50, 140, 83, 26))
      +       self.create.setObjectName("create")
      +
      +       self.retranslateUi(Dialog)
      +       QtCore.QObject.connect(self.create,QtCore.SIGNAL("pressed()"),self.createPlane)
      +       QtCore.QMetaObject.connectSlotsByName(Dialog)
      +
      +   def retranslateUi(self, Dialog):
      +       Dialog.setWindowTitle(QtGui.QApplication.translate("Dialog", "Dialog", None, QtGui.QApplication.UnicodeUTF8))
      +       self.title.setText(QtGui.QApplication.translate("Dialog", "Plane-O-Matic", None, QtGui.QApplication.UnicodeUTF8))
      +       self.label_width.setText(QtGui.QApplication.translate("Dialog", "Width", None, QtGui.QApplication.UnicodeUTF8))
      +       self.label_height.setText(QtGui.QApplication.translate("Dialog", "Height", None, QtGui.QApplication.UnicodeUTF8))
      +       self.create.setText(QtGui.QApplication.translate("Dialog", "Create!", None, QtGui.QApplication.UnicodeUTF8))
      +
      +   def createPlane(self):
      +       try:
      +           # first we check if valid numbers have been entered
      +           w = float(self.width.text())
      +           h = float(self.height.text())
      +       except ValueError:
      +           print "Error! Width and Height values must be valid numbers!"
      +       else:
      +           # create a face from 4 points
      +           p1 = FreeCAD.Vector(0,0,0)
      +           p2 = FreeCAD.Vector(w,0,0)
      +           p3 = FreeCAD.Vector(w,h,0)
      +           p4 = FreeCAD.Vector(0,h,0)
      +           pointslist = [p1,p2,p3,p4,p1]
      +           mywire = Part.makePolygon(pointslist)
      +           myface = Part.Face(mywire)
      +           Part.show(myface)
      +
      +class plane():
      +   def __init__(self):
      +       self.d = QtGui.QWidget()
      +       self.ui = Ui_Dialog()
      +       self.ui.setupUi(self.d)
      +       self.d.show()
      +

      Creation of a dialog with buttons

      +

      Method 1

      +

      An example of a dialog box complete with its connections. +

      +
      # -*- coding: utf-8 -*-
      +# Create by flachyjoe
      +
      +from PySide import QtCore, QtGui
      +
      +try:
      +    _fromUtf8 = QtCore.QString.fromUtf8
      +except AttributeError:
      +    def _fromUtf8(s):
      +        return s
      +
      +try:
      +    _encoding = QtGui.QApplication.UnicodeUTF8
      +    def _translate(context, text, disambig):
      +        return QtGui.QApplication.translate(context, text, disambig, _encoding)
      +except AttributeError:
      +    def _translate(context, text, disambig):
      +        return QtGui.QApplication.translate(context, text, disambig)
      +
      +
      +class Ui_MainWindow(object):
      +
      +     def __init__(self, MainWindow):
      +        self.window = MainWindow
      +
      +        MainWindow.setObjectName(_fromUtf8("MainWindow"))
      +        MainWindow.resize(400, 300)
      +        self.centralWidget = QtGui.QWidget(MainWindow)
      +        self.centralWidget.setObjectName(_fromUtf8("centralWidget"))
      +
      +        self.pushButton = QtGui.QPushButton(self.centralWidget)
      +        self.pushButton.setGeometry(QtCore.QRect(30, 170, 93, 28))
      +        self.pushButton.setObjectName(_fromUtf8("pushButton"))
      +        self.pushButton.clicked.connect(self.on_pushButton_clicked) #connection pushButton
      +
      +        self.lineEdit = QtGui.QLineEdit(self.centralWidget)
      +        self.lineEdit.setGeometry(QtCore.QRect(30, 40, 211, 22))
      +        self.lineEdit.setObjectName(_fromUtf8("lineEdit"))
      +        self.lineEdit.returnPressed.connect(self.on_lineEdit_clicked) #connection lineEdit
      +
      +        self.checkBox = QtGui.QCheckBox(self.centralWidget)
      +        self.checkBox.setGeometry(QtCore.QRect(30, 90, 81, 20))
      +        self.checkBox.setChecked(True)
      +        self.checkBox.setObjectName(_fromUtf8("checkBoxON"))
      +        self.checkBox.clicked.connect(self.on_checkBox_clicked) #connection checkBox
      +
      +        self.radioButton = QtGui.QRadioButton(self.centralWidget)
      +        self.radioButton.setGeometry(QtCore.QRect(30, 130, 95, 20))
      +        self.radioButton.setObjectName(_fromUtf8("radioButton"))
      +        self.radioButton.clicked.connect(self.on_radioButton_clicked) #connection radioButton
      +
      +        MainWindow.setCentralWidget(self.centralWidget)
      +
      +        self.menuBar = QtGui.QMenuBar(MainWindow)
      +        self.menuBar.setGeometry(QtCore.QRect(0, 0, 400, 26))
      +        self.menuBar.setObjectName(_fromUtf8("menuBar"))
      +        MainWindow.setMenuBar(self.menuBar)
      +
      +        self.mainToolBar = QtGui.QToolBar(MainWindow)
      +        self.mainToolBar.setObjectName(_fromUtf8("mainToolBar"))
      +        MainWindow.addToolBar(QtCore.Qt.TopToolBarArea, self.mainToolBar)
      +
      +        self.statusBar = QtGui.QStatusBar(MainWindow)
      +        self.statusBar.setObjectName(_fromUtf8("statusBar"))
      +        MainWindow.setStatusBar(self.statusBar)
      +
      +        self.retranslateUi(MainWindow)
      +
      +     def retranslateUi(self, MainWindow):
      +        MainWindow.setWindowTitle(_translate("MainWindow", "MainWindow", None))
      +        self.pushButton.setText(_translate("MainWindow", "OK", None))
      +        self.lineEdit.setText(_translate("MainWindow", "tyty", None))
      +        self.checkBox.setText(_translate("MainWindow", "CheckBox", None))
      +        self.radioButton.setText(_translate("MainWindow", "RadioButton", None))
      +
      +     def on_checkBox_clicked(self):
      +        if self.checkBox.checkState()==0:
      +            App.Console.PrintMessage(str(self.checkBox.checkState())+"  CheckBox KO\r\n")
      +        else:     
      +            App.Console.PrintMessage(str(self.checkBox.checkState())+" CheckBox OK\r\n")
      +#        App.Console.PrintMessage(str(self.lineEdit.setText("tititi"))+" LineEdit\r\n") #write text to the lineEdit window !
      +#        str(self.lineEdit.setText("tititi")) #écrit le texte dans la fenêtre lineEdit
      +        App.Console.PrintMessage(str(self.lineEdit.displayText())+" LineEdit\r\n")
      +
      +     def on_radioButton_clicked(self):
      +        if self.radioButton.isChecked():
      +             App.Console.PrintMessage(str(self.radioButton.isChecked())+" Radio OK\r\n")
      +        else:
      +             App.Console.PrintMessage(str(self.radioButton.isChecked())+"  Radio KO\r\n")
      +
      +     def on_lineEdit_clicked(self):
      +#        if self.lineEdit.textChanged():
      +             App.Console.PrintMessage(str(self.lineEdit.displayText())+" LineEdit Display\r\n")
      +
      +     def on_pushButton_clicked(self):
      +        App.Console.PrintMessage("Terminé\r\n")
      +        self.window.hide()
      +
      +MainWindow = QtGui.QMainWindow()
      +ui = Ui_MainWindow(MainWindow)
      +MainWindow.show()
      +

      Here the same window but with an icon on each button. +

      Download associated icons (Click rigth "Copy the image below ...)" +

      Icone01.png Icone02.png Icone03.png +

      +
      # -*- coding: utf-8 -*-
      +
      +from PySide import QtCore, QtGui
      +
      +try:
      +    _fromUtf8 = QtCore.QString.fromUtf8
      +except AttributeError:
      +    def _fromUtf8(s):
      +        return s
      +
      +try:
      +    _encoding = QtGui.QApplication.UnicodeUTF8
      +    def _translate(context, text, disambig):
      +        return QtGui.QApplication.translate(context, text, disambig, _encoding)
      +except AttributeError:
      +    def _translate(context, text, disambig):
      +        return QtGui.QApplication.translate(context, text, disambig)
      +
      +
      +class Ui_MainWindow(object):
      +
      +     def __init__(self, MainWindow):
      +        self.window = MainWindow
      +        path = FreeCAD.ConfigGet("UserAppData")
      +#        path = FreeCAD.ConfigGet("AppHomePath")
      +
      +        MainWindow.setObjectName(_fromUtf8("MainWindow"))
      +        MainWindow.resize(400, 300)
      +        self.centralWidget = QtGui.QWidget(MainWindow)
      +        self.centralWidget.setObjectName(_fromUtf8("centralWidget"))
      +
      +        self.pushButton = QtGui.QPushButton(self.centralWidget)
      +        self.pushButton.setGeometry(QtCore.QRect(30, 170, 93, 28))
      +        self.pushButton.setObjectName(_fromUtf8("pushButton"))
      +        self.pushButton.clicked.connect(self.on_pushButton_clicked) #connection pushButton
      +
      +        self.lineEdit = QtGui.QLineEdit(self.centralWidget)
      +        self.lineEdit.setGeometry(QtCore.QRect(30, 40, 211, 22))
      +        self.lineEdit.setObjectName(_fromUtf8("lineEdit"))
      +        self.lineEdit.returnPressed.connect(self.on_lineEdit_clicked) #connection lineEdit
      +
      +        self.checkBox = QtGui.QCheckBox(self.centralWidget)
      +        self.checkBox.setGeometry(QtCore.QRect(30, 90, 100, 20))
      +        self.checkBox.setChecked(True)
      +        self.checkBox.setObjectName(_fromUtf8("checkBoxON"))
      +        self.checkBox.clicked.connect(self.on_checkBox_clicked) #connection checkBox
      +
      +        self.radioButton = QtGui.QRadioButton(self.centralWidget)
      +        self.radioButton.setGeometry(QtCore.QRect(30, 130, 95, 20))
      +        self.radioButton.setObjectName(_fromUtf8("radioButton"))
      +        self.radioButton.clicked.connect(self.on_radioButton_clicked) #connection radioButton
      +
      +        MainWindow.setCentralWidget(self.centralWidget)
      +
      +        self.menuBar = QtGui.QMenuBar(MainWindow)
      +        self.menuBar.setGeometry(QtCore.QRect(0, 0, 400, 26))
      +        self.menuBar.setObjectName(_fromUtf8("menuBar"))
      +        MainWindow.setMenuBar(self.menuBar)
      +
      +        self.mainToolBar = QtGui.QToolBar(MainWindow)
      +        self.mainToolBar.setObjectName(_fromUtf8("mainToolBar"))
      +        MainWindow.addToolBar(QtCore.Qt.TopToolBarArea, self.mainToolBar)
      +
      +        self.statusBar = QtGui.QStatusBar(MainWindow)
      +        self.statusBar.setObjectName(_fromUtf8("statusBar"))
      +        MainWindow.setStatusBar(self.statusBar)
      +
      +        self.retranslateUi(MainWindow)
      +
      +        # Affiche un icone sur le bouton PushButton
      +        # self.image_01 = "C:\Program Files\FreeCAD0.13\Icone01.png" # adapt the icon name
      +        self.image_01 = path+"Icone01.png" # adapt the name of the icon
      +        icon01 = QtGui.QIcon() 
      +        icon01.addPixmap(QtGui.QPixmap(self.image_01),QtGui.QIcon.Normal, QtGui.QIcon.Off)
      +        self.pushButton.setIcon(icon01) 
      +        self.pushButton.setLayoutDirection(QtCore.Qt.RightToLeft) # This command reverses the direction of the button
      +
      +        # Affiche un icone sur le bouton RadioButton 
      +        # self.image_02 = "C:\Program Files\FreeCAD0.13\Icone02.png" # adapt the name of the icon
      +        self.image_02 = path+"Icone02.png" # adapter le nom de l'icone
      +        icon02 = QtGui.QIcon() 
      +        icon02.addPixmap(QtGui.QPixmap(self.image_02),QtGui.QIcon.Normal, QtGui.QIcon.Off)
      +        self.radioButton.setIcon(icon02) 
      +        # self.radioButton.setLayoutDirection(QtCore.Qt.RightToLeft) #  This command reverses the direction of the button
      +
      +        # Affiche un icone sur le bouton CheckBox 
      +        # self.image_03 = "C:\Program Files\FreeCAD0.13\Icone03.png" # the name of the icon
      +        self.image_03 = path+"Icone03.png" # adapter le nom de l'icone
      +        icon03 = QtGui.QIcon() 
      +        icon03.addPixmap(QtGui.QPixmap(self.image_03),QtGui.QIcon.Normal, QtGui.QIcon.Off)
      +        self.checkBox.setIcon(icon03) 
      +        # self.checkBox.setLayoutDirection(QtCore.Qt.RightToLeft) # This command reverses the direction of the button
      +
      +
      +     def retranslateUi(self, MainWindow):
      +        MainWindow.setWindowTitle(_translate("MainWindow", "FreeCAD", None))
      +        self.pushButton.setText(_translate("MainWindow", "OK", None))
      +        self.lineEdit.setText(_translate("MainWindow", "tyty", None))
      +        self.checkBox.setText(_translate("MainWindow", "CheckBox", None))
      +        self.radioButton.setText(_translate("MainWindow", "RadioButton", None))
      +
      +     def on_checkBox_clicked(self):
      +        if self.checkBox.checkState()==0:
      +            App.Console.PrintMessage(str(self.checkBox.checkState())+"  CheckBox KO\r\n")
      +        else:     
      +            App.Console.PrintMessage(str(self.checkBox.checkState())+" CheckBox OK\r\n")
      +           # App.Console.PrintMessage(str(self.lineEdit.setText("tititi"))+" LineEdit\r\n") # write text to the lineEdit window !
      +           # str(self.lineEdit.setText("tititi")) #écrit le texte dans la fenêtre lineEdit
      +        App.Console.PrintMessage(str(self.lineEdit.displayText())+" LineEdit\r\n")
      +
      +     def on_radioButton_clicked(self):
      +        if self.radioButton.isChecked():
      +             App.Console.PrintMessage(str(self.radioButton.isChecked())+" Radio OK\r\n")
      +        else:
      +             App.Console.PrintMessage(str(self.radioButton.isChecked())+"  Radio KO\r\n")
      +
      +     def on_lineEdit_clicked(self):
      +          # if self.lineEdit.textChanged():
      +          App.Console.PrintMessage(str(self.lineEdit.displayText())+" LineEdit Display\r\n")
      +
      +     def on_pushButton_clicked(self):
      +        App.Console.PrintMessage("Terminé\r\n")
      +        self.window.hide()
      +
      +MainWindow = QtGui.QMainWindow()
      +ui = Ui_MainWindow(MainWindow)
      +MainWindow.show()
      +

      Here the code to display the icon on the pushButton, change the name for another button, (radioButton, checkBox) and the path to the icon. +

      +
              # Affiche un icône sur le bouton PushButton
      +        # self.image_01 = "C:\Program Files\FreeCAD0.13\icone01.png" # the name of the icon
      +        self.image_01 = path+"icone01.png" # the name of the icon
      +        icon01 = QtGui.QIcon() 
      +        icon01.addPixmap(QtGui.QPixmap(self.image_01),QtGui.QIcon.Normal, QtGui.QIcon.Off)
      +        self.pushButton.setIcon(icon01) 
      +        self.pushButton.setLayoutDirection(QtCore.Qt.RightToLeft) # This command reverses the direction of the button
      +

      The command +UserAppData gives the user path +AppHomePath gives the installation path of FreeCAD +

      +
      #        path = FreeCAD.ConfigGet("UserAppData")
      +        path = FreeCAD.ConfigGet("AppHomePath")
      +

      This command reverses the horizontal button, right to left. +

      +
      self.pushButton.setLayoutDirection(QtCore.Qt.RightToLeft) # This command reverses the direction of the button
      +

      Method 2

      +

      Another method to display a window, here by creating a file QtForm.py which contains the header program (module called with import QtForm), and a second module that contains the code window all these accessories, and your code (the calling module). +

      This method requires two separate files, but allows to shorten your program using the file ' ' QtForm.py ' ' import. Then distribute the two files together, they are inseparable. +

      The file QtForm.py +

      +
      # -*- coding: utf-8 -*-
      +# Create by flachyjoe
      +from PySide import QtCore, QtGui
      +
      +try:
      +    _fromUtf8 = QtCore.QString.fromUtf8
      +except AttributeError:
      +   def _fromUtf8(s):
      +      return s
      +
      +try:
      +    _encoding = QtGui.QApplication.UnicodeUTF8
      +    def _translate(context, text, disambig):
      +      return QtGui.QApplication.translate(context, text, disambig, _encoding)
      +except AttributeError:
      +   def _translate(context, text, disambig):
      +      return QtGui.QApplication.translate(context, text, disambig)
      +
      +class Form(object):
      +   def __init__(self, title, width, height):
      +      self.window = QtGui.QMainWindow()
      +      self.title=title
      +      self.window.setObjectName(_fromUtf8(title))
      +      self.window.setWindowTitle(_translate(self.title, self.title, None))
      +      self.window.resize(width, height)
      +
      +   def show(self):
      +      self.createUI()
      +      self.retranslateUI()
      +      self.window.show()
      +   
      +   def setText(self, control, text):
      +      control.setText(_translate(self.title, text, None))
      +

      The appellant, file that contains the window and your code. +

      The file my_file.py +

      The connections are to do, a good exercise. +

      +
      # -*- coding: utf-8 -*-
      +# Create by flachyjoe
      +from PySide import QtCore, QtGui
      +import QtForm
      +
      +class myForm(QtForm.Form):
      +   def createUI(self):
      +      self.centralWidget = QtGui.QWidget(self.window)
      +      self.window.setCentralWidget(self.centralWidget)
      +      
      +      self.pushButton = QtGui.QPushButton(self.centralWidget)
      +      self.pushButton.setGeometry(QtCore.QRect(30, 170, 93, 28))
      +      self.pushButton.clicked.connect(self.on_pushButton_clicked)
      +      
      +      self.lineEdit = QtGui.QLineEdit(self.centralWidget)
      +      self.lineEdit.setGeometry(QtCore.QRect(30, 40, 211, 22))
      +      
      +      self.checkBox = QtGui.QCheckBox(self.centralWidget)
      +      self.checkBox.setGeometry(QtCore.QRect(30, 90, 81, 20))
      +      self.checkBox.setChecked(True)
      +      
      +      self.radioButton = QtGui.QRadioButton(self.centralWidget)
      +      self.radioButton.setGeometry(QtCore.QRect(30, 130, 95, 20))
      +   
      +   def retranslateUI(self):
      +      self.setText(self.pushButton, "Fermer")
      +      self.setText(self.lineEdit, "essai de texte")
      +      self.setText(self.checkBox, "CheckBox")
      +      self.setText(self.radioButton, "RadioButton")
      +   
      +   def on_pushButton_clicked(self):
      +      self.window.hide()
      +
      +myWindow=myForm("Fenetre de test",400,300)
      +myWindow.show()
      +

      Other example +

      +
      + +
      +
      +


      +Are treated : +

      +
      1. icon for window
      2. +
      3. horizontalSlider
      4. +
      5. progressBar horizontal
      6. +
      7. verticalSlider
      8. +
      9. progressBar vertical
      10. +
      11. lineEdit
      12. +
      13. lineEdit
      14. +
      15. doubleSpinBox
      16. +
      17. doubleSpinBox
      18. +
      19. doubleSpinBox
      20. +
      21. buttom
      22. +
      23. buttom
      24. +
      25. radioButtom with icons
      26. +
      27. checkBox with icon checked and unchecked
      28. +
      29. textEdit
      30. +
      31. graphicsView with 2 graphes
      +

      The code page and the icons Qt_Example +

      +

      Icon personalized in ComboView

      +

      Here example create object with property and icon personalized in ComboView +

      Download the example icon to place in same directory of the macro icon Example for the macro +

      The icon used is one icon to file disk, one icon to resource FreeCAD and one icon include in the macro (format .XPM) +

      icon personalized +

      +
      +


      +

      +
      import PySide
      +import FreeCAD, FreeCADGui, Part
      +from pivy import coin
      +from PySide import QtGui ,QtCore
      +from PySide.QtGui import *
      +from PySide.QtCore import *
      +import Draft
      +
      +global path
      +param = FreeCAD.ParamGet("User parameter:BaseApp/Preferences/Macro")# macro path in FreeCAD preferences
      +path = param.GetString("MacroPath","") + "/"                        # macro path
      +path = path.replace("\\","/")                                       # convert the "\" to "/"
      +
      +
      +class IconViewProviderToFile:                                       # Class ViewProvider create Property view of object
      +    def __init__( self, obj, icon):
      +        self.icone = icon
      +        
      +    def getIcon(self):                                              # GetIcon
      +        return self.icone
      +        
      +    def attach(self, obj):                                          # Property view of object
      +        self.modes = []
      +        self.modes.append("Flat Lines")
      +        self.modes.append("Shaded")
      +        self.modes.append("Wireframe")
      +        self.modes.append("Points")
      +        obj.addDisplayMode( coin.SoGroup(),"Flat Lines" )           # Display Mode
      +        obj.addDisplayMode( coin.SoGroup(),"Shaded" )
      +        obj.addDisplayMode( coin.SoGroup(),"Wireframe" )
      +        obj.addDisplayMode( coin.SoGroup(),"Points" )
      +        return self.modes
      +
      +    def getDisplayModes(self,obj):
      +        return self.modes
      +
      +#####################################################
      +########## Example with icon to file # begin ########
      +#####################################################
      +
      +object1 = FreeCAD.ActiveDocument.addObject("App::FeaturePython", "Icon_In_File_Disk")                                     # create your object
      +object1.addProperty("App::PropertyString","Identity", "ExampleTitle0", "Identity of object").Identity = "FCSpring"        # Identity of object
      +object1.addProperty("App::PropertyFloat" ,"Pitch",    "ExampleTitle0", "Pitch betwen 2 heads").Pitch  = 2.0               # other Property Data
      +object1.addProperty("App::PropertyBool"  ,"View",     "ExampleTitle1", "Hello world").View            = True              # ...
      +object1.addProperty("App::PropertyColor" ,"LineColor","ExampleTitle2", "Color to choice").LineColor   = (0.13,0.15,0.37)  # ...
      +#...other Property Data
      +#...other Property Data
      +#
      +object1.ViewObject.Proxy = IconViewProviderToFile( object1, path + "FreeCADIco.png")                                      # icon download to file
      +App.ActiveDocument.recompute()
      +#
      +#__Detail__:
      +# FreeCAD.ActiveDocument.addObject( = create now object personalized
      +# "App::FeaturePython",             = object as FeaturePython
      +# "Icon_In_File_Disk")              = internal name of your object
      +#
      +#
      +# "App::PropertyString",    = type of Property , availlable : PropertyString, PropertyFloat, PropertyBool, PropertyColor
      +# "Identity",               = name of the feature
      +# "ExampleTitle0",          = title of the "section"
      +# "Identity of object")     = tooltip displayed on mouse
      +# .Identity                 = variable (same of name of the feature)
      +# object1.ViewObject.Proxy  = create the view object and gives the icon
      +#
      +########## example with icon to file end
      +
      +
      +
      +#####################################################
      +########## Example with icon in macro # begin #######
      +#####################################################
      +
      +def setIconInMacro(self):        # def contener the icon in format .xpm
      +    # File format XPM created by Gimp "https://www.gimp.org/"
      +    # Choice palette Tango
      +    # Create your masterwork ...
      +    # For export the image in XPM format
      +    #     Menu File > Export as > .xpm
      +    # (For convert image true color in Tango color palette : 
      +    #     Menu Image > Mode > Indexed ... > Use custom palette > Tango Icon Theme > Convert)
      +    return """
      +            /* XPM */
      +            static char * XPM[] = {
      +            "22 24 5 1",
      +            " c None",
      +            ".c #CE5C00",
      +            "+c #EDD400",
      +            "@c #F57900",
      +            "#c #8F5902",
      +            "                      ",
      +            "                      ",
      +            "  ....                ",
      +            "  ..@@@@..            ",
      +            "  . ...@......        ",
      +            "  .+++++++++...       ",
      +            "  .      ....++...    ",
      +            "  .@..@@@@@@.+++++..  ",
      +            "  .@@@@@..#  ++++ ..  ",
      +            "  .       ++++  .@..  ",
      +            "  .++++++++  .@@@.+.  ",
      +            " .      ..@@@@@. ++.  ",
      +            " ..@@@@@@@@@.  +++ .  ",
      +            " ....@...# +++++ @..  ",
      +            " .    ++++++++ .@. .  ",
      +            " .++++++++  .@@@@ .   ",
      +            " .   #....@@@@. ++.   ",
      +            " .@@@@@@@@@.. +++ .   ",
      +            " ........  +++++...   ",
      +            " ...  ..+++++ ..@..   ",
      +            "    ......  .@@@ +.   ",
      +            "          ......++.   ",
      +            "                ...   ",
      +            "                      "};
      +        """
      +
      +object2 = FreeCAD.ActiveDocument.addObject("App::FeaturePython", "Icon_XPM_In_Macro")                                    #
      +object2.addProperty("App::PropertyString","Identity","ExampleTitle","Identity of object").Identity = "FCSpring"
      +#...other Property Data
      +#...other Property Data
      +#
      +object2.ViewObject.Proxy = IconViewProviderToFile( object2, setIconInMacro(""))              # icon in macro (.XPM)
      +App.ActiveDocument.recompute()
      +########## example with icon in macro end
      +
      +
      +
      +####################################################################
      +########## Example with icon to FreeCAD ressource # begin ##########
      +####################################################################
      +
      +object3 = FreeCAD.ActiveDocument.addObject("App::FeaturePython", "Icon_Ressource_FreeCAD")                               #
      +object3.addProperty("App::PropertyString","Identity","ExampleTitle","Identity of object").Identity = "FCSpring"
      +#...other Property Data
      +#...other Property Data
      +#
      +object3.ViewObject.Proxy = IconViewProviderToFile( object3, ":/icons/Draft_Draft.svg")       # icon to FreeCAD ressource
      +App.ActiveDocument.recompute()
      +########## example with icon to FreeCAD ressource end
      +

      Other complete example creation cube with icon in macro +

      +
      #https://forum.freecadweb.org/viewtopic.php?t=10255#p83319
      +import FreeCAD, Part, math
      +from FreeCAD import Base
      +from PySide import QtGui
      +
      +global path
      +param = FreeCAD.ParamGet("User parameter:BaseApp/Preferences/Macro")# macro path in FreeCAD preferences
      +path = param.GetString("MacroPath","") + "/"                        # macro path
      +path = path.replace("\\","/")                                       # convert the "\" to "/"
      +
      +def setIconInMacro(self):
      +    return """
      +        /* XPM */
      +        static char * xpm[] = {
      +        "22 22 12 1",
      +        " c None",
      +        ".c #A40000",
      +        "+c #2E3436",
      +        "@c #CE5C00",
      +        "#c #F57900",
      +        "$c #FCAF3E",
      +        "%c #5C3566",
      +        "&c #204A87",
      +        "*c #555753",
      +        "=c #3465A4",
      +        "-c #4E9A06",
      +        ";c #729FCF",
      +        "                      ",
      +        "                      ",
      +        "                      ",
      +        "        ..   ..       ",
      +        "       +@#+++.$$      ",
      +        "       +.#+%..$$      ",
      +        "       &*$  &*#*      ",
      +        "      &   =&=  =      ",
      +        "   ++&  +.==   %=     ",
      +        "  ++$@ ..$ %=   &     ",
      +        "  ..-&%.#$$ &## +=$   ",
      +        "   .#  ..$ ..#%%.#$$  ",
      +        "     ;    =+=## %-$#  ",
      +        "     &=   ;&   %=     ",
      +        "      ;+ &=;  %=      ",
      +        "      ++$- +*$-       ",
      +        "      .#&&+.@$$       ",
      +        "      ..$# ..$#       ",
      +        "       ..   ..        ",
      +        "                      ",
      +        "                      ",
      +        "                      "};
      +        """
      +
      +class PartFeature:
      +    def __init__(self, obj):
      +        obj.Proxy = self
      +
      +class Box(PartFeature):
      +    def __init__(self, obj):
      +        PartFeature.__init__(self, obj)
      +        obj.addProperty("App::PropertyLength", "Length", "Box", "Length of the box").Length = 1.0
      +        obj.addProperty("App::PropertyLength", "Width",  "Box", "Width of the box" ).Width  = 1.0
      +        obj.addProperty("App::PropertyLength", "Height", "Box", "Height of the box").Height = 1.0
      +
      +    def onChanged(self, fp, prop):
      +        try:
      +            if prop == "Length" or prop == "Width" or prop == "Height":
      +                fp.Shape = Part.makeBox(fp.Length,fp.Width,fp.Height)
      +        except:
      +            pass
      +
      +    def execute(self, fp):
      +        fp.Shape = Part.makeBox(fp.Length,fp.Width,fp.Height)
      +
      +class ViewProviderBox:
      +    def __init__(self, obj, icon):
      +        obj.Proxy  = self
      +        self.icone = icon
      +        
      +    def getIcon(self):
      +        return self.icone
      +
      +    def attach(self, obj):
      +        return
      +
      +    def setupContextMenu(self, obj, menu):
      +        action = menu.addAction("Set default height")
      +        action.triggered.connect(lambda f=self.setDefaultHeight, arg=obj:f(arg))
      +
      +        action = menu.addAction("Hello World")
      +        action.triggered.connect(self.showHelloWorld)
      +
      +    def setDefaultHeight(self, view):
      +        view.Object.Height = 15.0
      +
      +    def showHelloWorld(self):
      +        QtGui.QMessageBox.information(None, "Hi there", "Hello World")
      +
      +def makeBox():
      +    FreeCAD.newDocument()
      +    a=FreeCAD.ActiveDocument.addObject("Part::FeaturePython","Box")
      +    Box(a)
      +#    ViewProviderBox(a.ViewObject, path + "FreeCADIco.png")    # icon download to file
      +#    ViewProviderBox(a.ViewObject,  ":/icons/Draft_Draft.svg") # icon to FreeCAD ressource
      +    ViewProviderBox(a.ViewObject,  setIconInMacro(""))        # icon in macro (.XPM)
      +    App.ActiveDocument.recompute()
      +
      +makeBox()
      +

      Use QFileDialog for write the file

      +

      Complete code: +

      +
      # -*- coding: utf-8 -*-
      +import PySide
      +from PySide import QtGui ,QtCore
      +from PySide.QtGui import *
      +from PySide.QtCore import *
      +path = FreeCAD.ConfigGet("UserAppData")
      +
      +try:
      +    SaveName = QFileDialog.getSaveFileName(None,QString.fromLocal8Bit("Save a file txt"),path,             "*.txt") # PyQt4
      +#                                                                     "here the text displayed on windows" "here the filter (extension)"   
      +except Exception:
      +    SaveName, Filter = PySide.QtGui.QFileDialog.getSaveFileName(None, "Save a file txt", path,             "*.txt") # PySide
      +#                                                                     "here the text displayed on windows" "here the filter (extension)"   
      +if SaveName == "":                                                            # if the name file are not selected then Abord process
      +    App.Console.PrintMessage("Process aborted"+"\n")
      +else:                                                                         # if the name file are selected or created then 
      +    App.Console.PrintMessage("Registration of "+SaveName+"\n")                # text displayed to Report view (Menu > View > Report view checked)
      +    try:                                                                      # detect error ...
      +        file = open(SaveName, 'w')                                            # open the file selected to write (w)
      +        try:                                                                  # if error detected to write ...
      +            # here your code
      +            print "here your code"
      +            file.write(str(1)+"\n")                                           # write the number convert in text with (str())
      +            file.write("FreeCAD the best")                                    # write the the text with ("  ")
      +        except Exception:                                                     # if error detected to write
      +            App.Console.PrintError("Error write file "+"\n")                  # detect error ... display the text in red (PrintError)
      +        finally:                                                              # if error detected to write ... or not the file is closed
      +            file.close()                                                      # if error detected to write ... or not the file is closed
      +    except Exception:
      +        App.Console.PrintError("Error Open file "+SaveName+"\n")      # detect error ... display the text in red (PrintError)
      +

      Use QFileDialog for read the file

      +

      Complete code: +

      +
      # -*- coding: utf-8 -*-
      +import PySide
      +from PySide import QtGui ,QtCore
      +from PySide.QtGui import *
      +from PySide.QtCore import *
      +path = FreeCAD.ConfigGet("UserAppData")
      +
      +OpenName = ""
      +try:
      +    OpenName = QFileDialog.getOpenFileName(None,QString.fromLocal8Bit("Read a file txt"),path,             "*.txt") # PyQt4
      +#                                                                     "here the text displayed on windows" "here the filter (extension)"   
      +except Exception:
      +    OpenName, Filter = PySide.QtGui.QFileDialog.getOpenFileName(None, "Read a file txt", path,             "*.txt") #PySide
      +#                                                                     "here the text displayed on windows" "here the filter (extension)"   
      +if OpenName == "":                                                            # if the name file are not selected then Abord process
      +    App.Console.PrintMessage("Process aborted"+"\n")
      +else:
      +    App.Console.PrintMessage("Read "+OpenName+"\n")                           # text displayed to Report view (Menu > View > Report view checked)
      +    try:                                                                      # detect error to read file
      +        file = open(OpenName, "r")                                            # open the file selected to read (r)  # (rb is binary)
      +        try:                                                                  # detect error ...
      +            # here your code
      +            print "here your code"
      +            op = OpenName.split("/")                                          # decode the path
      +            op2 = op[-1].split(".")                                           # decode the file name 
      +            nomF = op2[0]                                                     # the file name are isolated
      +
      +            App.Console.PrintMessage(str(nomF)+"\n")                          # the file name are displayed
      +
      +            for ligne in file:                                                # read the file
      +                X  = ligne.rstrip('\n\r') #.split()                           # decode the line
      +                print X                                                       # print the line in report view other method 
      +                                                                              # (Menu > Edit > preferences... > Output window > Redirect internal Python output (and errors) to report view checked) 
      +        except Exception:                                                     # if error detected to read
      +            App.Console.PrintError("Error read file "+"\n")                   # detect error ... display the text in red (PrintError)
      +        finally:                                                              # if error detected to read ... or not error the file is closed
      +            file.close()                                                      # if error detected to read ... or not error the file is closed
      +    except Exception:                                                         # if one error detected to read file
      +        App.Console.PrintError("Error in Open the file "+OpenName+"\n")       # if one error detected ... display the text in red (PrintError)
      +

      Use QColorDialog for get the color

      +

      Complete code: +

      +
      # -*- coding: utf-8 -*-
      +# https://deptinfo-ensip.univ-poitiers.fr/ENS/pyside-docs/PySide/QtGui/QColor.html
      +import PySide
      +from PySide import QtGui ,QtCore
      +from PySide.QtGui import *
      +from PySide.QtCore import *
      +path = FreeCAD.ConfigGet("UserAppData")
      +
      +couleur = QtGui.QColorDialog.getColor()
      +if couleur.isValid():
      +    red   = int(str(couleur.name()[1:3]),16)    # decode hexadecimal to int()
      +    green = int(str(couleur.name()[3:5]),16)    # decode hexadecimal to int()
      +    blue  = int(str(couleur.name()[5:7]),16)    # decode hexadecimal to int()
      +
      +    print couleur                               # 
      +    print "hexadecimal ",couleur.name()         # color format hexadecimal mode 16
      +    print "Red   color ",red                    # color format decimal
      +    print "Green color ",green                  # color format decimal
      +    print "Blue  color ",blue                   # color format decimal
      +

      Some useful commands

      +
      # Here the code to display the icon on the '''pushButton''', 
      +# change the name to another button, ('''radioButton, checkBox''') as well as the path to the icon,
      +
      +       # Displays an icon on the button PushButton
      +       # self.image_01 = "C:\Program Files\FreeCAD0.13\icone01.png" # he name of the icon
      +       self.image_01 = path+"icone01.png" # the name of the icon
      +       icon01 = QtGui.QIcon() 
      +       icon01.addPixmap(QtGui.QPixmap(self.image_01),QtGui.QIcon.Normal, QtGui.QIcon.Off)
      +       self.pushButton.setIcon(icon01) 
      +       self.pushButton.setLayoutDirection(QtCore.Qt.RightToLeft) # This command reverses the direction of the button
      +
      +
      +# path = FreeCAD.ConfigGet("UserAppData") # gives the user path
      +  path = FreeCAD.ConfigGet("AppHomePath") # gives the installation path of FreeCAD
      +
      +# This command reverses the horizontal button, right to left
      +self.pushButton.setLayoutDirection(QtCore.Qt.RightToLeft) # This command reverses the horizontal button
      +
      +# Displays an info button
      +self.pushButton.setToolTip(_translate("MainWindow", "Quitter la fonction", None)) # Displays an info button
      +
      +# This function gives a color button
      +self.pushButton.setStyleSheet("background-color: red") # This function gives a color button
      +
      +# This function gives a color to the text of the button
      +self.pushButton.setStyleSheet("color : #ff0000") # This function gives a color to the text of the button
      +
      +# combinaison des deux, bouton et texte
      +self.pushButton.setStyleSheet("color : #ff0000; background-color : #0000ff;" ) #  combination of the two, button, and text
      +
      +# replace the icon in the main window
      +MainWindow.setWindowIcon(QtGui.QIcon('C:\Program Files\FreeCAD0.13\View-C3P.png'))
      +
      +# connects a lineEdit on execute
      +self.lineEdit.returnPressed.connect(self.execute) # connects a lineEdit on "def execute" after validation on enter
      +# self.lineEdit.textChanged.connect(self.execute) # connects a lineEdit on "def execute" with each keystroke on the keyboard
      +
      +# display text in a lineEdit
      +self.lineEdit.setText(str(val_X)) # Displays the value in the lineEdit (convert to string)
      +
      +# extract the string contained in a lineEdit
      + val_X = self.lineEdit.text() # extract the (string) string contained in lineEdit
      + val_X = float(val_X0)        # converted the string to an floating
      + val_X = int(val_X0)          # convert the string to an integer
      +
      +# This code allows you to change the font and its attributes
      +       font = QtGui.QFont()
      +       font.setFamily("Times New Roman")
      +       font.setPointSize(10)
      +       font.setWeight(10)
      +       font.setBold(True) # same result with tags "<b>your text</b>" (in quotes)
      +       self.label_6.setFont(font)
      +       self.label_6.setObjectName("label_6")
      +       self.label_6.setStyleSheet("color : #ff0000") # This function gives a color to the text
      +       self.label_6.setText(_translate("MainWindow", "Select a view", None))
      +

      By using the characters with accents, where you get the error : +

      Several solutions are possible. +

      UnicodeDecodeError: 'utf8' codec can't decode bytes in position 0-2: invalid data +

      +
      # conversion from a lineEdit
      +App.activeDocument().CopyRight.Text = str(unicode(self.lineEdit_20.text() , 'ISO-8859-1').encode('UTF-8'))
      +DESIGNED_BY = unicode(self.lineEdit_01.text(), 'ISO-8859-1').encode('UTF-8')
      +

      or with the procedure +

      +
      def utf8(unio):
      +    return unicode(unio).encode('UTF8')
      +

      UnicodeEncodeError: 'ascii' codec can't encode character u'\xe9' in position 9: ordinal not in range(128) +

      +
      # conversion
      +a = u"Nom de l'élément : "
      +f.write('''a.encode('iso-8859-1')'''+str(element_)+"\n")
      +

      or with the procedure +

      +
      def iso8859(encoder):
      +    return unicode(encoder).encode('iso-8859-1')
      +

      or +

      +
      iso8859(unichr(176))
      +

      or +

      +
      unichr(ord(176))
      +

      or +

      +
      uniteSs = "mm"+iso8859(unichr(178))
      +print unicode(uniteSs, 'iso8859')
      +


      +

      + +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/DiameterSample.png b/localwiki/DiameterSample.png new file mode 100644 index 0000000..d7e94ac Binary files /dev/null and b/localwiki/DiameterSample.png differ diff --git a/localwiki/Dimension_partitions_flipped.png b/localwiki/Dimension_partitions_flipped.png new file mode 100644 index 0000000..984e41f Binary files /dev/null and b/localwiki/Dimension_partitions_flipped.png differ diff --git a/localwiki/Dimension_partitions_parallel.png b/localwiki/Dimension_partitions_parallel.png new file mode 100644 index 0000000..af51d06 Binary files /dev/null and b/localwiki/Dimension_partitions_parallel.png differ diff --git a/localwiki/DlgPreferences.jpg b/localwiki/DlgPreferences.jpg new file mode 100644 index 0000000..903b71e Binary files /dev/null and b/localwiki/DlgPreferences.jpg differ diff --git a/localwiki/Document-new.png b/localwiki/Document-new.png new file mode 100644 index 0000000..e3808a1 Binary files /dev/null and b/localwiki/Document-new.png differ diff --git a/localwiki/Document-new.svg b/localwiki/Document-new.svg new file mode 100644 index 0000000..d67b866 --- /dev/null +++ b/localwiki/Document-new.svg @@ -0,0 +1,117 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + New Document + + + [agryson] Alexander Gryson + + + http://agryson.net + + 2011-10-10 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Drawing/Gui/Resources/icons/actions/document-new.svg + + + FreeCAD LGPL2+ + + + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Document-open.svg b/localwiki/Document-open.svg new file mode 100644 index 0000000..f38716d --- /dev/null +++ b/localwiki/Document-open.svg @@ -0,0 +1,533 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + Folder Icon Accept + 2005-01-31 + + + Jakub Steiner + + + + http://jimmac.musichall.cz + Active state - when files are being dragged to. + + + Novell, Inc. + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Document-print.svg b/localwiki/Document-print.svg new file mode 100644 index 0000000..bb3d43d --- /dev/null +++ b/localwiki/Document-print.svg @@ -0,0 +1,530 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + Print Document + + + Jakub Steiner + + + + http://jimmac.musichall.cz + + + document + lpr + print + local + laser + bubblejet + inkjet + print + output + cups + lpd + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Document-properties.svg b/localwiki/Document-properties.svg new file mode 100644 index 0000000..e9ea32b --- /dev/null +++ b/localwiki/Document-properties.svg @@ -0,0 +1,574 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + Document Properties + + + document + settings + preferences + properties + tweak + + + + + + Jakub Steiner + + + http://jimmac.musichall.cz + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Document-save-as.svg b/localwiki/Document-save-as.svg new file mode 100644 index 0000000..09fa340 --- /dev/null +++ b/localwiki/Document-save-as.svg @@ -0,0 +1,661 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + Save As + + + Jakub Steiner + + + + + hdd + hard drive + save as + io + store + + + + + http://jimmac.musichall.cz + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Document-save.svg b/localwiki/Document-save.svg new file mode 100644 index 0000000..6be29c4 --- /dev/null +++ b/localwiki/Document-save.svg @@ -0,0 +1,617 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + Save + + + Jakub Steiner + + + + + hdd + hard drive + save + io + store + + + + + http://jimmac.musichall.cz + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Document.svg b/localwiki/Document.svg new file mode 100644 index 0000000..7fc0cf4 --- /dev/null +++ b/localwiki/Document.svg @@ -0,0 +1,1345 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + Lapo Calamandrei + + + + + + media + stop + playback + video + music + + + + + Jakub Steiner + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Document_structure.html b/localwiki/Document_structure.html new file mode 100644 index 0000000..1397c6e --- /dev/null +++ b/localwiki/Document_structure.html @@ -0,0 +1,47 @@ +Document structure

      Document structure

      + +
      Screenshot treeview.jpg
      +

      A FreeCAD document contains all the objects of your scene. It can contain groups, and objects made with any workbench. You can therefore switch between workbenches, and still work on the same document. The document is what gets saved to disk when you save your work. You can also open several documents at the same time in FreeCAD, and open several views of the same document. +

      Inside the document, the objects can be moved into groups, and have a unique name. Managing groups, objects and object names is done mainly from the Tree view. It can also be done, of course, like everything in FreeCAD, from the python interpreter. In the Tree view, you can create groups, move objects to groups, delete objects or groups, by right-clicking in the tree view or on an object, rename objects by double-clicking on their names, or possibly other operations, depending on the current workbench. +

      The objects inside a FreeCAD document can be of different types. Each workbench can create its own types of objects, for example the Mesh Workbench creates mesh objects, the Part Workbench create Part objects, the Draft Workbench also creates Part objects, etc. +

      If there is at least one document open in FreeCAD, there is always one and only one active document. That's the document that appears in the current 3D view, the document you are currently working on. +

      +

      Application and User Interface

      +

      Like almost everything else in FreeCAD, the user interface part (Gui) is separated from the base application part (App). This is also valid for documents. The documents are also made of two parts: the Application document, which contains our objects, and the View document, which contains the representation on screen of our objects. +

      Think of it as two spaces, where the objects are defined. Their constructive parameters (is it a cube? a cone? which size?) are stored in the Application document, while their graphical representation (is it drawn with black lines? with blue faces?) are stored in the View document. Why is that? Because FreeCAD can also be used WITHOUT graphical interface, for example inside other programs, and we must still be able to manipulate our objects, even if nothing is drawn on the screen. +

      Another thing that is contained inside the View document are 3D views. One document can have several views opened, so you can inspect your document from several points of view at the same time. Maybe you would want to see a top view and a front view of your work at the same time? Then, you will have two views of the same document, both stored in the View document. Creating new views or closing views can be done from the View menu or by right-clicking on a view tab. +

      +

      Scripting

      +

      Documents can be easily created, accessed and modified from the python interpreter. For example: +

      +
      FreeCAD.ActiveDocument 
      +

      Will return the current (active) document +

      +
      FreeCAD.ActiveDocument.Blob 
      +

      Would access an object called "Blob" inside your document +

      +
      FreeCADGui.ActiveDocument 
      +

      Will return the view document associated to the current document +

      +
      FreeCADGui.ActiveDocument.Blob 
      +

      Would access the graphical representation (view) part of our Blob object +

      +
      FreeCADGui.ActiveDocument.ActiveView 
      +

      Will return the current view +

      + +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Doublecad.jpg b/localwiki/Doublecad.jpg new file mode 100644 index 0000000..1085adf Binary files /dev/null and b/localwiki/Doublecad.jpg differ diff --git a/localwiki/Download.html b/localwiki/Download.html new file mode 100644 index 0000000..96b9ec1 --- /dev/null +++ b/localwiki/Download.html @@ -0,0 +1,47 @@ +Download

      Download

      + +
      +Please note that FreeCAD has still not reached a version 1.0 status in our view, and might not be ready for production use. Nevertheless multitudes of users use it. To find out if FreeCAD is appropriate for your project, please check out the FreeCAD forum.
      +

      Current Stable Version

      +

      The first 0.17 release of FreeCAD (0.17.13509) was published 2018-04-06. The bug fix release 0.17.13522 was published 2018-05-08. To find out what's new, see the release notes. +

      + + + + + + +
      Windows.png Windows 32 bits
      Windows.png Windows 64 bits
      Mac.png Mac 64-bit AppImage-logo.png AppImage (Linux) 64bit +
      +

      Notes for Windows users

      +
      • The 32-Bit installer (x86) supports the following versions of Windows: 7/8/10.
      • +
      • The 64-Bit installer (x64) supports the following versions of Windows: 7/8/10.
      +

      Notes for Mac OS X users

      +

      Mac OS X 10.11 El Capitan is the minimum supported version. +

      +

      Notes for GNU/Linux users

      +

      FreeCAD can be installed from most Linux distributions official repositories, but the version they provide might be quite dated and be missing many features. Instead you can download the linked AppImage above, mark it as executable and launch it without installation. Please see the Install on Unix page for more installation options, including how to get up-to-date packages for Ubuntu and derivatives . +

      +

      Development Versions

      +

      FreeCAD's development is always active! Do you want to check out the 0.18 development release? Get it on the FreeCAD releases page. +

      +

      Additional Modules and Macros

      +

      The FreeCAD community provides a wealth of additional modules and macros. They can now easily be installed directly from within FreeCAD using the Addon manager. +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Downloads.html b/localwiki/Downloads.html new file mode 100644 index 0000000..e683f6a --- /dev/null +++ b/localwiki/Downloads.html @@ -0,0 +1,47 @@ +Downloads

      Downloads

      (Redirected from Downloads)
      + +
      +Please note that FreeCAD has still not reached a version 1.0 status in our view, and might not be ready for production use. Nevertheless multitudes of users use it. To find out if FreeCAD is appropriate for your project, please check out the FreeCAD forum.
      +

      Current Stable Version

      +

      The first 0.17 release of FreeCAD (0.17.13509) was published 2018-04-06. The bug fix release 0.17.13522 was published 2018-05-08. To find out what's new, see the release notes. +

      + + + + + + +
      Windows.png Windows 32 bits
      Windows.png Windows 64 bits
      Mac.png Mac 64-bit AppImage-logo.png AppImage (Linux) 64bit +
      +

      Notes for Windows users

      +
      • The 32-Bit installer (x86) supports the following versions of Windows: 7/8/10.
      • +
      • The 64-Bit installer (x64) supports the following versions of Windows: 7/8/10.
      +

      Notes for Mac OS X users

      +

      Mac OS X 10.11 El Capitan is the minimum supported version. +

      +

      Notes for GNU/Linux users

      +

      FreeCAD can be installed from most Linux distributions official repositories, but the version they provide might be quite dated and be missing many features. Instead you can download the linked AppImage above, mark it as executable and launch it without installation. Please see the Install on Unix page for more installation options, including how to get up-to-date packages for Ubuntu and derivatives . +

      +

      Development Versions

      +

      FreeCAD's development is always active! Do you want to check out the 0.18 development release? Get it on the FreeCAD releases page. +

      +

      Additional Modules and Macros

      +

      The FreeCAD community provides a wealth of additional modules and macros. They can now easily be installed directly from within FreeCAD using the Addon manager. +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Draft-linestyle.jpg b/localwiki/Draft-linestyle.jpg new file mode 100644 index 0000000..7d33235 Binary files /dev/null and b/localwiki/Draft-linestyle.jpg differ diff --git a/localwiki/Draft-tutorial-01.jpg b/localwiki/Draft-tutorial-01.jpg new file mode 100644 index 0000000..7861eed Binary files /dev/null and b/localwiki/Draft-tutorial-01.jpg differ diff --git a/localwiki/Draft-tutorial-blocks.jpg b/localwiki/Draft-tutorial-blocks.jpg new file mode 100644 index 0000000..2313759 Binary files /dev/null and b/localwiki/Draft-tutorial-blocks.jpg differ diff --git a/localwiki/Draft-tutorial-dims.jpg b/localwiki/Draft-tutorial-dims.jpg new file mode 100644 index 0000000..9f77fa2 Binary files /dev/null and b/localwiki/Draft-tutorial-dims.jpg differ diff --git a/localwiki/Draft-tutorial-elevation.jpg b/localwiki/Draft-tutorial-elevation.jpg new file mode 100644 index 0000000..6cb701c Binary files /dev/null and b/localwiki/Draft-tutorial-elevation.jpg differ diff --git a/localwiki/Draft-tutorial-typical-tree.jpg b/localwiki/Draft-tutorial-typical-tree.jpg new file mode 100644 index 0000000..536a074 Binary files /dev/null and b/localwiki/Draft-tutorial-typical-tree.jpg differ diff --git a/localwiki/Draft-tutorial-walls.jpg b/localwiki/Draft-tutorial-walls.jpg new file mode 100644 index 0000000..b87c90b Binary files /dev/null and b/localwiki/Draft-tutorial-walls.jpg differ diff --git a/localwiki/DraftPatternSample.png b/localwiki/DraftPatternSample.png new file mode 100644 index 0000000..63c0e30 Binary files /dev/null and b/localwiki/DraftPatternSample.png differ diff --git a/localwiki/DraftPlaneAuto.png b/localwiki/DraftPlaneAuto.png new file mode 100644 index 0000000..fd5b7d2 Binary files /dev/null and b/localwiki/DraftPlaneAuto.png differ diff --git a/localwiki/DraftPlaneNone.png b/localwiki/DraftPlaneNone.png new file mode 100644 index 0000000..d70327f Binary files /dev/null and b/localwiki/DraftPlaneNone.png differ diff --git a/localwiki/DraftPlaneTasks.png b/localwiki/DraftPlaneTasks.png new file mode 100644 index 0000000..c0f8742 Binary files /dev/null and b/localwiki/DraftPlaneTasks.png differ diff --git a/localwiki/DraftPlaneToolbarMode.png b/localwiki/DraftPlaneToolbarMode.png new file mode 100644 index 0000000..6ba074d Binary files /dev/null and b/localwiki/DraftPlaneToolbarMode.png differ diff --git a/localwiki/DraftPlaneTop.png b/localwiki/DraftPlaneTop.png new file mode 100644 index 0000000..48055c5 Binary files /dev/null and b/localwiki/DraftPlaneTop.png differ diff --git a/localwiki/DraftPlaneView.png b/localwiki/DraftPlaneView.png new file mode 100644 index 0000000..7af2fd4 Binary files /dev/null and b/localwiki/DraftPlaneView.png differ diff --git a/localwiki/DraftViewSample.png b/localwiki/DraftViewSample.png new file mode 100644 index 0000000..6f60655 Binary files /dev/null and b/localwiki/DraftViewSample.png differ diff --git a/localwiki/DraftWorkbench.svg b/localwiki/DraftWorkbench.svg new file mode 100644 index 0000000..8ec2468 --- /dev/null +++ b/localwiki/DraftWorkbench.svg @@ -0,0 +1,364 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + DraftWorkbench + + Fri Feb 26 23:17:43 2016 +0100 + + + [triplus] + + + + + FreeCAD LGPL2+ + + + + + FreeCAD + + + FreeCAD/src/Mod/Draft/Resources/icons/DraftWorkbench.svg + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + [agryson] Alexander Gryson + + + + + ruler + drafting board + right angle ruler + + + A right angle ruler resting on a ruler on a drafting board + + + + diff --git a/localwiki/Draft_2DShapeView.svg b/localwiki/Draft_2DShapeView.svg new file mode 100644 index 0000000..77af96d --- /dev/null +++ b/localwiki/Draft_2DShapeView.svg @@ -0,0 +1,394 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + Draft_2DShapeView + + Mon Oct 10 13:44:52 2011 +0000 + + + [wmayer] + + + + + FreeCAD LGPL2+ + + + + + FreeCAD + + + FreeCAD/src/Mod/Draft/Resources/icons/Draft_2DShapeView.svg + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + [agryson] Alexander Gryson + + + + + box + plane + rectangle + + + A box floating above a projection of its lower face + + + + diff --git a/localwiki/Draft_API.html b/localwiki/Draft_API.html new file mode 100644 index 0000000..8303d5b --- /dev/null +++ b/localwiki/Draft_API.html @@ -0,0 +1,246 @@ +Draft API

      Draft API

      + +

      These functions are part of the Draft module and can be used in scripts and macros or from the python interpreter, once the Draft module has been imported. +

      Example: +

      +
      import FreeCAD
      +from Draft import *
      +myrect = makeRectangle(4,3)
      +mydistance = FreeCAD.Vector(2,2,0)
      +move(myrect,mydistance) 
      +


      +

      +
      +
      Method.png cut ( FreeCAD.Object, FreeCAD.Object )
      +
      +

      Description: Returns a cut object made from the difference of the 2 given objects. The original objects get hidden. +

      Returns: The newly created object +

      +
      +
      +


      +

      +
      +
      Method.png extrude ( FreeCAD.Object, Vector )
      +
      +

      Description: Extrudes the given object in the direction given by the vector. The original object gets hidden. +

      Returns: The newly created object +

      +
      +
      +


      +

      +
      +
      Method.png formatObject ( FreeCAD.Object, [FreeCAD.Object] )
      +
      +

      Description: This function applies to the given target object the current properties set on the Draft toolbar (line color and line width), or copies the properties of a second object if provided. It also places the object in construction group if the construction button is pressed. +

      Returns: Nothing +

      +
      +
      +


      +

      +
      +
      Method.png fuse ( FreeCAD.Object, FreeCAD.Object )
      +
      +

      Description: Returns an object made from the union of the 2 given objects. If the objects are coplanar, a special Draft Wire is used, otherwise the final object is a standard Part fuse. +

      Returns: The newly created object +

      +
      +
      +


      +

      +
      +
      Method.png getDraftPath ( [string] )
      +
      +

      Description: Returns the user or system path where the Draft module is running from. If a subpath or a filename is supplied, the full path to the subpath inside the Draft module is returned. +

      Returns: A file path +

      +
      +
      +


      +

      +
      +
      Method.png getGroupContents ( list )
      +
      +

      Description: Scans recursively the given list for groups. If groups are encountered, their contents are appended to the list. +

      Returns: A list of FreeCAD Objects +

      +
      +
      +


      +

      +
      +
      Method.png getRealName ( string )
      +
      +

      Description: Strips the trailing numbers from an object name. +

      Returns: The stripped object name +

      +
      +
      +


      +

      +
      +
      Method.png getSelection ( )
      +
      +

      Description: Returns the current FreeCAD selection. +

      Returns: The current FreeCAD selection. +

      +
      +
      +


      +

      +
      +
      Method.png makeCircle ( radius, [placement], [facemode], [startangle], [endangle] )
      +
      +

      Description: Creates a circle object with given radius. If a placement is given, it is used. If facemode is False, the circle is shown as a wireframe, otherwise as a face. If startangle AND endangle are given (in degrees), they are used and the object appears as an arc. +

      Returns: The newly created object. +

      +
      +
      +


      +

      +
      +
      Method.png makeDimension ( Vector, Vector, [Vector] or FreeCAD.Object, int, int, [Vector] )
      +
      +

      Description: Creates a Dimension object measuring distance between first and second vectors, with the dimension line passign through the third vector if provided. The current line width and color from the Draft toolbar will be used. Instead of 2 vectors, you can also pass a FreeCAD object, and two integers (and optionally a vector where the dimension line must pass). In that case, the dimension will be associated with the object, and measure two of its vertices, indicated by the two given indice numbers. +

      Returns: The newly created object. +

      +
      +
      +


      +

      +
      +
      Method.png makeLine ( Vector, Vector )
      +
      +

      Description: Creates a line between the two given vectors. The current line width and color from the Draft toolbar will be used. +

      Returns: The newly created object. +

      +
      +
      +


      +

      +
      +
      Method.png makeRectangle ( length, width, [placement], [facemode] )
      +
      +

      Description: Creates a Rectangle object with length in X direction and height in Y direction. If a placement is given, it is used. If facemode is False, the rectangle is shown as a wireframe, otherwise as a face. The current line width and color from the Draft toolbar will be used. +

      Returns: The newly created object. +

      +
      +
      +


      +

      +
      +
      Method.png makeText ( string or list, [Vector], [screenmode] )
      +
      +

      Description: Creates a Text object, at the given point if a vector is provided, containing the string or the strings given in the list, one string by line. The current color from the Draft toolbar and the text height and font specified in preferences are used. If screenmode is True, the text always faces the view direction, otherwise it lies on the XY plane. +

      Returns: The newly created object. +

      +
      +
      +


      +

      +
      +
      Method.png makeWire ( list or Part.Wire, [closed], [placement], [facemode] )
      +
      +

      Description: Creates a DWire object from the given list of vectors or from the given Wire. If closed is True or if first and last points are identical, the wire is closed. If facemode is True (and wire is closed), the wire will appear filled. The current line width and color from the Draft toolbar will be used. +

      Returns: A new Draft DWire (not a Part Wire). +

      +
      +
      +


      +

      +
      +
      Method.png move ( FreeCAD.Object or list, Vector, [copymode] )
      +
      +

      Description: Moves the given object or the objects contained in the given list in the direction and distance indicated by the given vector. If copymode is True, the actual objects are not moved, but copies are created instead. +

      Returns: The object(s) (or their copies if copymode was True). +

      +
      +
      +


      +

      +
      +
      Method.png precision ( )
      +
      +

      Description: Returns the precision value from Draft user settings. +

      Returns: An integer. +

      +
      +
      +


      +

      +
      +
      Method.png rotate ( FreeCAD.Object or list, angle, [center], [axis] ,[copymode] )
      +
      +

      Description: Rotates the given object or the objects contained in the given list with the given angle around the given center if provided, using axis as a rotation axis. If axis is omitted, the rotation will be around the vertical Z axis. If copymode is True, the actual objects are not moved, but copies are created instead. +

      Returns: The objects (or their copies). +

      +
      +
      +


      +

      +
      +
      Method.png scale ( FreeCAD.Object or list, vector, [center], [copymode] )
      +
      +

      Description: Scales the given object or the objects contained in the given list with a scale factors defined by the given vector (in X, Y and Z directions) around the given center if provided. If copymode is True, the actual objects are not moved, but copies are created instead. +

      Returns: The objects (or their copies). +

      +
      +
      +


      +

      +
      +
      Method.png select ( FreeCAD.Object )
      +
      +

      Description: Deselects everything and selects only the passed object +

      Returns: Nothing. +

      +
      +
      +


      +

      +
      +
      Method.png shapify ( FreeCAD.Object )
      +
      +

      Description: Transforms a parametric shape object into non-parametric. +

      Returns: The new object. +

      +
      +
      +


      +

      +
      +
      Method.png draftify ( FreeCAD.Object or list )
      +
      +

      Description: Turns the given object or each object of the given list into Draft parametric wires. +

      Returns: Nothing. +

      +
      +
      +


      +

      +
      +
      Method.png getSVG ( FreeCAD.Object, [linemodifier], [textmodifier], [(u,v)] )
      +
      +

      Description: Creates a SVG representation of the given object. The linemodifier attribute is a scale factor (in percents) for line width, and textmodifier for text size. You can also optionally provide a tuple of vectors to define a projection plane, otherwise the geometry will be projected on the XY plane. +

      Returns: a string containing a SVG representation of the given object. +

      +
      +
      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Draft_AddConstruction.html b/localwiki/Draft_AddConstruction.html new file mode 100644 index 0000000..f11970e --- /dev/null +++ b/localwiki/Draft_AddConstruction.html @@ -0,0 +1,65 @@ +Draft AddConstruction

      Draft AddConstruction

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Draft AddConstruction.png Draft AddConstruction

      +
      Menu location +
      Draft → Utilities → Add to construction group +
      Workbenches +
      Draft, Arch +
      Default shortcut +
      None +
      See also +
      Draft_ToggleConstructionMode +

      + +
      +


      +

      +

      Description

      +

      This command adds the selected object(s) to the Draft Construction group. +

      +

      How to use

      +
      1. Select some objects
      2. +
      3. Click menu Draft → Utilities → Draft ToggleConstructionMode.png Add to construction group
      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Draft_AddConstruction.png b/localwiki/Draft_AddConstruction.png new file mode 100644 index 0000000..ec0e446 Binary files /dev/null and b/localwiki/Draft_AddConstruction.png differ diff --git a/localwiki/Draft_AddPoint.html b/localwiki/Draft_AddPoint.html new file mode 100644 index 0000000..093e922 --- /dev/null +++ b/localwiki/Draft_AddPoint.html @@ -0,0 +1,76 @@ +Draft AddPoint

      Draft AddPoint

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Draft AddPoint.png Draft AddPoint

      +
      Menu location +
      Draft → Add Point +
      Workbenches +
      Draft, Arch +
      Default shortcut +
      None +
      See also +
      None +

      + +
      +


      +

      +

      Description

      +

      This tools allows you to add additional points to Wires and BSplines. +

      +

      How to use

      +
      1. Select a wire or a BSpline
      2. +
      3. Press the Draft AddPoint.png Draft AddPoint button
      4. +
      5. Click a point on the 3D view, or type a coordinate
      +

      Options

      +
      • This functionality is also available inside the Draft Edit.png Draft Edit tool
      +

      Scripting

      +

      Not available, but adding additional points to Wires and BSplines is easy, for example: +

      +
      import FreeCAD,Draft
      +points = FreeCAD.ActiveDocument.ActiveObject.Points
      +points.append(FreeCAD.Vector(2,2,0))
      +FreeCAD.ActiveDocument.ActiveObjects.Points = points 
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Draft_AddPoint.svg b/localwiki/Draft_AddPoint.svg new file mode 100644 index 0000000..1da4090 --- /dev/null +++ b/localwiki/Draft_AddPoint.svg @@ -0,0 +1,517 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + Draft_AddPoint + + Mon Oct 10 13:44:52 2011 +0000 + + + [wmayer] + + + + + FreeCAD LGPL2+ + + + + + FreeCAD + + + FreeCAD/src/Mod/Draft/Resources/icons/Draft_AddPoint.svg + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + [agryson] Alexander Gryson + + + + + plus + add + cross + dot + line + + + A plus sign hovering above a line with a dot at its midpoint + + + + diff --git a/localwiki/Draft_AddToGroup.html b/localwiki/Draft_AddToGroup.html new file mode 100644 index 0000000..8d27593 --- /dev/null +++ b/localwiki/Draft_AddToGroup.html @@ -0,0 +1,70 @@ +Draft AddToGroup

      Draft AddToGroup

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Draft AddToGroup.png Draft AddToGroup

      +
      Menu location +
      Draft → Utilities → Add to group +
      Workbenches +
      Draft, Arch +
      Default shortcut +
      +
      See also +
      Draft SelectGroup, Std Group +

      + +
      +


      +

      +

      Description

      +

      This tool displays a quick menu that allows you to add the selected objects to an existing group, or remove them from their current group +

      +

      How to use

      +
      1. Select object(s)
      2. +
      3. Press the Draft AddToGroup.png Add to group button
      +

      Links

      + +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Draft_AddToGroup.svg b/localwiki/Draft_AddToGroup.svg new file mode 100644 index 0000000..ffec5dd --- /dev/null +++ b/localwiki/Draft_AddToGroup.svg @@ -0,0 +1,494 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + Draft_AddToGroup + + Mon Oct 10 13:44:52 2011 +0000 + + + [wmayer] + + + + + FreeCAD LGPL2+ + + + + + FreeCAD + + + FreeCAD/src/Mod/Draft/Resources/icons/Draft_AddToGroup.svg + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + [agryson] Alexander Gryson + + + + + tree + hierarchy + list + rectangle + + + A parent rectangle with two hierarchically subordinate rectangles with a single detached rectangle between the two children + + + + diff --git a/localwiki/Draft_Angle.html b/localwiki/Draft_Angle.html new file mode 100644 index 0000000..a57fb3d --- /dev/null +++ b/localwiki/Draft_Angle.html @@ -0,0 +1,80 @@ +Draft Angle

      Draft Angle

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Draft Angle.png Draft Angle

      +
      Menu location +
      Draft → Snap → Angle +
      Workbenches +
      Draft, Arch +
      Default shortcut +
      +
      See also +
      +

      + +
      +


      +

      +

      Description

      +

      Snaps to the special cardinal points of circles and arcs, at 45° and 90°. +

      +

      Use

      +
      1. Make sure snap mode is turned on
      2. +
      3. Choose element to be inserted into the FreeCAD-document
      4. +
      5. Move cursor near one of the cardinal point you wish to attach your element to
      6. +
      7. Below on the right side of the cursor the symbol of the snap mode will appear
      8. +
      9. Click to attach your element to the selected endpoint of target element
      +

      Will also work with Draft Move and Draft Rotate. +

      +

      Notes

      +

      Snap mode can be used with +

      +
      • sketcher elements (arcs, circles)
      • +
      • draft elements (arcs, circles)
      • +
      • edge of circular face of shape
      • +
      • edge of circular face of solid
      +

      Clicking on the snap-mode icon will toggle the snap mode on/off. +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Draft_Apply.html b/localwiki/Draft_Apply.html new file mode 100644 index 0000000..ae4699c --- /dev/null +++ b/localwiki/Draft_Apply.html @@ -0,0 +1,68 @@ +Draft Apply

      Draft Apply

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Draft Apply.png Draft Apply

      +
      Menu location +
      Draft → Utilities → Apply style +
      Workbenches +
      Draft, Arch +
      Default shortcut +
      None +
      See also +
      None +

      + +
      +


      +

      +

      Description

      +

      This tool applies the current Draft color and linestyle to the selected objects. +

      +

      How to use

      +
      1. With the Draft or Arch workbench active, set the desired color and linewidth on the Tasks panel (or on the Draft toolbar if you are using the toolbar mode).
      2. +
      3. Select one or several objects
      4. +
      5. Press the Draft Apply.png Apply style button
      +

      Options

      +
      • If you just change the current Draft color or linewidth, the new setting will be applied to any selected object.
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Draft_Apply.svg b/localwiki/Draft_Apply.svg new file mode 100644 index 0000000..f51a96b --- /dev/null +++ b/localwiki/Draft_Apply.svg @@ -0,0 +1,282 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + Draft_Apply + + Mon Oct 10 13:44:52 2011 +0000 + + + [wmayer] + + + + + FreeCAD LGPL2+ + + + + + FreeCAD + + + FreeCAD/src/Mod/Draft/Resources/icons/Draft_Apply.svg + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + [agryson] Alexander Gryson + + + + + arrow + rectangle + collection + + + A collection of multicolored rectangles in a larger rectangle with an arrow pointing outwards to the left + + + + diff --git a/localwiki/Draft_Arc.html b/localwiki/Draft_Arc.html new file mode 100644 index 0000000..f548eb7 --- /dev/null +++ b/localwiki/Draft_Arc.html @@ -0,0 +1,98 @@ +Draft Arc

      Draft Arc

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Draft Arc.png Draft Arc

      +
      Menu location +
      Draft → Arc +
      Workbenches +
      Draft, Arch +
      Default shortcut +
      A R +
      See also +
      Draft Circle +

      + +
      +


      +

      +

      Description

      +

      The Arc tool creates an arc in the current work plane by entering four points, the center, the radius, the first point and the last point, or by picking tangents, or any combination of those. It takes the linewidth and color previously set on the Tasks tab. This tool works the same way as the Draft Circle tool, but adds start and end angles. +

      Draft Arc example.jpg +

      +

      How to use

      +
      1. Press the Draft Arc.png Draft Arc button, or press A then R keys
      2. +
      3. Click a first point on the 3D view, or type a coordinate
      4. +
      5. Click a second point on the 3D view, or enter a radius value
      6. +
      7. Click a third point in the 3D view, or enter a start angle
      8. +
      9. Click a fourth point in the 3D View, or enter an end ange
      +

      Options

      +
      • The primary use of the arc tool is by picking four points: the centre, a point on the circumference, defining the radius, a third point defining the start of the arc, and a fourth one defining its end.
      • +
      • By pressing ALT, you can select a tangent instead of picking point, to define the base circle of the arc. You can therefore construct several types of circles by selecting one, two or three tangents.
      • +
      • The direction of the arc depends on the movement you are doing with your mouse. If you start to move clockwise after the third point is entered, your arc will go clockwise. To go counter-clockwise, simply move your mouse back over the third point, until the arc starts drawing in the other direction.
      • +
      • To enter coordinates manually, simply enter the numbers, then press ENTER between each X, Y and Z component.
      • +
      • Press T or click the checkbox to check/uncheck the Continue button. If continue mode is on, the Arc tool will restart after you give the fourth point, allowing you to draw another arc without pressing the Arc button again.
      • +
      • Press CTRL while drawing to force snapping your point to the nearest snap location, independently of the distance.
      • +
      • Press SHIFT while drawing to constrain your point horizontally or vertically in relation to the center.
      • +
      • Press ESC or the Cancel button to abort the current Line command.
      • +
      • The arc can be turned into a circle after creation, by setting a same value to its first angle and last angle properties.
      +

      Properties

      +
      • DATARadius: The radius of the arc
      • +
      • DATAFirst Angle: The angle of the first point of the arc
      • +
      • DATALast Angle: The angle of the last point of the arc
      +

      Scripting

      +

      The Circle tool can also be used to create arcs in macros and from the python console by using the following function, giving it additional arguments: +

      +
      makeCircle (radius, [placement], [facemode], [startangle], [endangle]) 
      +
      • Creates a circle object with given radius.
      • +
      • If a placement is given, it is used. If facemode is False, the circle is shown as a wireframe, otherwise as a face.
      • +
      • If startangle AND endangle are given (in degrees), they are used and the object appears as an arc.
      • +
      • Returns the newly created object.
      +

      Example: +

      +
      import Draft
      +myArc = Draft.makeCircle(2,startangle=0,endangle=90) 
      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Draft_Arc.png b/localwiki/Draft_Arc.png new file mode 100644 index 0000000..dacb023 Binary files /dev/null and b/localwiki/Draft_Arc.png differ diff --git a/localwiki/Draft_Arc.svg b/localwiki/Draft_Arc.svg new file mode 100644 index 0000000..66b9ab2 --- /dev/null +++ b/localwiki/Draft_Arc.svg @@ -0,0 +1,286 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + Draft_Arc + + Mon Oct 10 13:44:52 2011 +0000 + + + [wmayer] + + + + + FreeCAD LGPL2+ + + + + + FreeCAD + + + FreeCAD/src/Mod/Draft/Resources/icons/Draft_Arc.svg + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + [agryson] Alexander Gryson + + + + + point + dot + arc + curve + line + + + An arc of 90° with a point at each end with a third point in the lower left where the centerpoint of the arc would be + + + + diff --git a/localwiki/Draft_Array.html b/localwiki/Draft_Array.html new file mode 100644 index 0000000..30dfb5f --- /dev/null +++ b/localwiki/Draft_Array.html @@ -0,0 +1,110 @@ +Draft Array

      Draft Array

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Draft Array.png Draft Array

      +
      Menu location +
      Draft → Array +
      Workbenches +
      Draft, Arch +
      Default shortcut +
      None +
      See also +
      PathArray +

      + +
      +


      +

      +

      Description

      +

      The Array tool creates an orthogonal (3-axes) or polar array from a selected object. If no object is selected, you will be invited to select one. +

      Draft Array example.jpg +

      +

      How to use

      +
      1. Select an object you wish to make an array with
      2. +
      3. Press the Draft Array.png Draft Array button
      4. +
      5. Select DATAArray Type: Specifies the type of the array, ortho or polar
      6. +
      7. For orthogonal arrays: +
        1. DATAInterval X: The interval between each copy on the first axis
        2. +
        3. DATAInterval Y: The interval between each copy on the second axis
        4. +
        5. DATAInterval Z: The interval between each copy on the third axis
        6. +
        7. DATANumber X: The number of copies on the first axis
        8. +
        9. DATANumber Y: The number of copies on the second axis
        10. +
        11. DATANumber Z: The number of copies on the third axis
      8. +
      9. For polar arrays: +
        1. DATAAxis: The normal direction of the array circle
        2. +
        3. DATACenter: The center point of the array
        4. +
        5. DATAAngle: The angle to cover with copies
        6. +
        7. DATANumber Polar: The number of copies
      +

      Scripting

      +

      The Array tool can by used in macros and from the python console by using one of the following functions, depending if you wish to obtain simple, standalone copies of your base object, or a parametric array object, that stays linked to the original object. +

      +

      Simple array

      +

      For rectangular array: +

      +
      array (objectslist,xvector,yvector,xnum,ynum,[zvector,znum]) 
      +

      For polar array: +

      +
      array (objectslist,center,totalangle,totalnum) 
      +
      • Creates an array of the objects contained in list (that can be an object or a list of objects) with, in case of rectangular array, xnum of iterations in the x direction at xvector distance between iterations, and same for y direction with yvector and ynum. In case of polar array, center is a vector, totalangle is the angle to cover (in degrees) and totalnum is the number of objects, including the original.
      • +
      • This function produces standalone copies of the base object(s)
      +

      Parametric array

      +

      For rectangular array: +

      +
      makeArray (object,xvector,yvector,xnum,ynum) 
      +

      For polar array: +

      +
      makeArray (object,center,totalangle,totalnum) 
      +
      • Creates an array of the given object with, in case of rectangular array, xnum of iterations in the x direction at xvector distance between iterations, and same for y direction with yvector and ynum. In case of polar array, center is a vector, totalangle is the angle to cover (in degrees) and totalnum is the number of objects, including the original.
      • +
      • The result of this function is a parametric Draft Array object.
      +

      Example: +

      +
      import FreeCAD,Draft
      +Draft.array(FreeCAD.ActiveDocument.ActiveObject,FreeCAD.Vector(2,0,0),FreeCAD.Vector(0,2,0),2,2) 
      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Draft_Array.svg b/localwiki/Draft_Array.svg new file mode 100644 index 0000000..81670f5 --- /dev/null +++ b/localwiki/Draft_Array.svg @@ -0,0 +1,549 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + Draft_Array + + Sat Dec 10 18:31:32 2011 +0000 + + + [yorikvanhavre] + + + + + FreeCAD LGPL2+ + + + + + FreeCAD + + + FreeCAD/src/Mod/Draft/Resources/icons/Draft_Array.svg + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + [agryson] Alexander Gryson + + + Six rectangles in a 2 x 3 linear array + + + rectangle + array + + + + + + diff --git a/localwiki/Draft_AutoGroup.html b/localwiki/Draft_AutoGroup.html new file mode 100644 index 0000000..d952dd2 --- /dev/null +++ b/localwiki/Draft_AutoGroup.html @@ -0,0 +1,76 @@ +Draft AutoGroup

      Draft AutoGroup

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Draft AutoGroup.png Draft AutoGroup

      +
      Menu location +
      Draft → Utilities → AutoGroup +
      Workbenches +
      Draft, Arch +
      Default shortcut +
      None +
      See also +
      +

      + +
      +


      +

      Draft AutoGroup example.jpg +

      +

      Description

      +

      This tool allows to set a Group, or derivated like Draft VisGroup, Arch Site, Arch Building or Arch Floor, as Active auto-group. When an auto-group is set, all new objects created in Draft Workbench or Arch Workbench will be placed into that group. +

      +

      How to use

      +
      1. Select menu Draft → Utilities → Draft AutoGroup.png AutoGroup, or click the autogroup button on the toolbar, or right-click a Group object in the tree view → Utilities → Draft AutoGroup.png AutoGroup
      2. +
      3. Choose the desired group in the drop-down box
      +

      Options

      +
      • When AutoGroup is set, the button turns green, it means autogrouping is activated. You can click on it to change the group or unset.
      • +
      • When autogrouping is active, any new Draft or Arch object created will be placed in that group (except when Draft construction mode is on, in which case it goes to the construction group).
      • +
      • This only works when creating Draft or Arch objects from the GUI buttons. Not when using them from python. This is so it is still possible for python scripts to do the grouping they want, regardless of what autogrouping says.
      +

      Scripting

      +

      In python scripts, using Draft autogrouping is simply done with the command below: +

      +
      import Draft
      +Draft.autogroup(object) 
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Draft_AutoGroup.svg b/localwiki/Draft_AutoGroup.svg new file mode 100644 index 0000000..987df22 --- /dev/null +++ b/localwiki/Draft_AutoGroup.svg @@ -0,0 +1,493 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + Mon Oct 10 13:44:52 2011 +0000 + + + [wmayer] + + + + + FreeCAD LGPL2+ + + + + + FreeCAD + + + FreeCAD/src/Mod/Draft/Resources/icons/Draft_Drawing.svg + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + [agryson] Alexander Gryson + + + + + arrow + page + shapes + + + An arrow pointing from left to right onto a page with shapes drawn on it + + + + diff --git a/localwiki/Draft_AutoGroup_example.jpg b/localwiki/Draft_AutoGroup_example.jpg new file mode 100644 index 0000000..897ea6f Binary files /dev/null and b/localwiki/Draft_AutoGroup_example.jpg differ diff --git a/localwiki/Draft_AutoGroup_off.svg b/localwiki/Draft_AutoGroup_off.svg new file mode 100644 index 0000000..960768c --- /dev/null +++ b/localwiki/Draft_AutoGroup_off.svg @@ -0,0 +1,489 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + Mon Oct 10 13:44:52 2011 +0000 + + + [wmayer] + + + + + FreeCAD LGPL2+ + + + + + FreeCAD + + + FreeCAD/src/Mod/Draft/Resources/icons/Draft_Drawing.svg + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + [agryson] Alexander Gryson + + + + + arrow + page + shapes + + + An arrow pointing from left to right onto a page with shapes drawn on it + + + + diff --git a/localwiki/Draft_AutoGroup_on.svg b/localwiki/Draft_AutoGroup_on.svg new file mode 100644 index 0000000..cb20fb8 --- /dev/null +++ b/localwiki/Draft_AutoGroup_on.svg @@ -0,0 +1,462 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + Mon Oct 10 13:44:52 2011 +0000 + + + [wmayer] + + + + + FreeCAD LGPL2+ + + + + + FreeCAD + + + FreeCAD/src/Mod/Draft/Resources/icons/Draft_Drawing.svg + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + [agryson] Alexander Gryson + + + + + arrow + page + shapes + + + An arrow pointing from left to right onto a page with shapes drawn on it + + + + diff --git a/localwiki/Draft_BSpline.html b/localwiki/Draft_BSpline.html new file mode 100644 index 0000000..6442739 --- /dev/null +++ b/localwiki/Draft_BSpline.html @@ -0,0 +1,107 @@ +Draft BSpline

      Draft BSpline

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Draft BSpline.png Draft BSpline

      +
      Menu location +
      Draft → BSpline +
      Workbenches +
      Draft, Arch +
      Default shortcut +
      B S +
      See also +
      Draft Wire +

      + +
      +


      +

      +

      Description

      +

      The BSpline tool creates a B-Spline curve from several points in the current work plane. It takes the linewidth and color previously set on the Tasks tab. The BSpline tool behaves exactly like the Draft Wire tool. +

      Draft bspline example.jpg +

      +

      How to use

      +
      1. Press the Draft BSpline.png Draft BSpline button, or press B then S keys
      2. +
      3. Click a first point on the 3D view, or type a coordinate
      4. +
      5. Click additional point on the 3D view, or type a coordinate
      6. +
      7. Press F or C, or double-click the last point, or click on the first point to finish or close the spline. If the spline is closed, it will also be a face, even if it appears as wireframe.
      +

      Options

      +
      • Press F or the Draft FinishLine.png Finish button to finish the spline, leaving it open
      • +
      • Press C or the Draft CloseLine.png Close button or click on the first point to finish the spline, but making it closed by adding a last segment between the last point and the first one.
      • +
      • Press X, Y or Z after a point to constrain the next point on the given axis.
      • +
      • To enter coordinates manually, simply enter the numbers, then press ENTER between each X, Y and Z component.
      • +
      • Press R or click the checkbox to check/uncheck the Relative button. If relative mode is on, the coordinates of the next point are relative to the last one. If not, they are absolute, taken from the (0,0,0) origin point.
      • +
      • Press T or click the checkbox to check/uncheck the Continue button. If continue mode is on, the BSpline tool will restart after you finish or close it, allowing you to draw another one without pressing the BSpline button again.
      • +
      • Press CTRL while drawing to force snapping your point to the nearest snap location, independently of the distance.
      • +
      • Press SHIFT while drawing to constrain your next point horizontally or vertically in relation to the last one.
      • +
      • Press W or press the Draft Wipe.png Wipe button to remove the existing segments and start the spline from the last point.
      • +
      • Press CTRL+Z or press the Draft UndoLine.png Undo button to undo the last point.
      • +
      • Press I or the Filled button to have the spline filled with a face after it has been closed.
      • +
      • Press ESC or the Cancel button to abort the current BSpline command.
      • +
      • BSplines, when in "Flat Lines" display mode, can display a hatch pattern, by setting their "Pattern" property below.
      +

      Properties

      +
      • DATAClosed: Specifies if the spline is closed or not
      • +
      • DATAMake Face: Fills the spline with a face
      • +
      • VIEWEnd Arrow: Shows an arrow symbol at the last point of the spline, so it can be used as an annotation leader line
      • +
      • VIEWPattern: Specifies a hatch pattern to fill the wire with
      • +
      • VIEWPattern Size: Specifies the size of the hatch pattern
      +

      Scripting

      +

      The BSpline tool can by used in macros and from the python console by using the following function: +

      +
      makeBSpline (pointslist,[closed],[placement]) 
      +
      • Creates a B-Spline object from the given list of vectors.
      • +
      • If closed is True or first and last points are identical, the wire is closed.
      • +
      • If face is true (and the bspline is closed), the bspline will appear filled.
      • +
      • Instead of a list of points, you can also pass a Part Wire.
      • +
      • Returns the newly created object.
      +

      Example: +

      +
      import FreeCAD,Draft
      +p1 = FreeCAD.Vector(0,0,0)
      +p2 = FreeCAD.Vector(1,1,0)
      +p3 = FreeCAD.Vector(2,0,0)
      +Draft.makeBSpline([p1,p2,p3],closed=True) 
      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Draft_BSpline.png b/localwiki/Draft_BSpline.png new file mode 100644 index 0000000..8845ae0 Binary files /dev/null and b/localwiki/Draft_BSpline.png differ diff --git a/localwiki/Draft_BSpline.svg b/localwiki/Draft_BSpline.svg new file mode 100644 index 0000000..5992ea5 --- /dev/null +++ b/localwiki/Draft_BSpline.svg @@ -0,0 +1,386 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + Draft_BSpline + + Mon Oct 10 13:44:52 2011 +0000 + + + [wmayer] + + + + + FreeCAD LGPL2+ + + + + + FreeCAD + + + FreeCAD/src/Mod/Draft/Resources/icons/Draft_BSpline.svg + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + [agryson] Alexander Gryson + + + + + dot + point + curve + line + + + A curved line in the shape of an upside-down U passing through three points + + + + diff --git a/localwiki/Draft_BezCurve.html b/localwiki/Draft_BezCurve.html new file mode 100644 index 0000000..c588988 --- /dev/null +++ b/localwiki/Draft_BezCurve.html @@ -0,0 +1,108 @@ +Draft BezCurve

      Draft BezCurve

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Draft BezCurve.png Draft BezCurve

      +
      Menu location +
      Draft → BezCurve +
      Workbenches +
      Draft, Arch +
      Default shortcut +
      B Z +
      See also +
      None +

      + +
      +


      +

      +

      Description

      +

      The BezCurve tool creates a Bezier Curve (or a piecewise Bezier Curve) from several points in the current work plane. It takes the linewidth and color previously set on the Tasks tab. +

      The object is created as a single Bezier Curve of degree (number_of_points - 1). This can be changed to a piecewise Bezier Curve of a specified degree after creation using the properties editor. Bezier Curves can be edited using Draft Edit.png Draft Edit. +

      Draft BezCurve Example.png +

      +

      How to use

      +
      1. Press the Draft BezCurve.png Draft BezCurve button, or press B then Z keys.
      2. +
      3. Click a first point on the 3D view, or type a coordinate
      4. +
      5. Click additional point on the 3D view, or type a coordinate
      6. +
      7. Press F or C, or double-click the last point, or click on the first point to finish and close the curve.
      +

      Options

      +
      • Press F or the Draft FinishLine.png Finish button to finish the spline, leaving it open
      • +
      • Press C or the Draft CloseLine.png Close button or click on the first point to finish the spline, but making it closed by adding a last segment between the last point and the first one.
      • +
      • Press X, Y or Z after a point to constrain the next point on the given axis.
      • +
      • To enter coordinates manually, simply enter the numbers, then press ENTER between each X, Y and Z component.
      • +
      • Press R or click the checkbox to check/uncheck the Relative button. If relative mode is on, the coordinates of the next point are relative to the last one. If not, they are absolute, taken from the (0,0,0) origin point.
      • +
      • Press T or click the checkbox to check/uncheck the Continue button. If continue mode is on, the BezCurve tool will restart after you finish or close it, allowing you to draw another one without pressing the BezCurve button again.
      • +
      • Press CTRL while drawing to force snapping your point to the nearest snap location, independently of the distance.
      • +
      • Press SHIFT while drawing to constrain your next point horizontally or vertically in relation to the last one.
      • +
      • Press W or press the Draft Wipe.png Wipe button to remove the existing segments and start the spline from the last point.
      • +
      • Press CTRL+Z or press the Draft UndoLine.png Undo button to undo the last point.
      • +
      • Press ESC or the Cancel button to abort the current BezCurve command.
      +

      Properties

      +
      • DATAClosed: Specifies if the Bezier Curve is closed or not
      • +
      • DATADegree: Specifies the degree of the Bezier Curve (or segments)
      +

      Scripting

      +

      The BezCurve tool can by used in macros and from the python console by using the following function: +

      +
      makeBezCurve(pointslist,[closed],[placement],[support],[degree]) 
      +
      • Create a Bezier Curve object from the given list of vectors. Instead of a pointslist, you can also pass a Part Wire.
      +

      Example: +

      +
      import FreeCAD,Draft
      +myFeature = Draft.makeBezCurve(Draft.makeBezCurve(points,False) 
      +

      Contraining Nodes

      +

      The segment endpoints in a piecewise Bezier Curve can be constrained such that adjacent control points are tangent or symmetric to the segments at the endpoint. This is done after object creation using Draft Edit.png Draft Edit. +

      +
      • Draft BezSharpNode.svg Sharp - remove constraints
      • +
      • Draft BezTanNode.svg Tangent - force adjacent control points to be tangent
      • +
      • Draft BezSymNode.svg Symmetric - force adjacent control points to be tangent and equi-distant
      +

      Limitations

      +
      • This tool is not available before FreeCAD version 0.14
      • +
      • The Points Property does not yet appear in the properties list.
      • +
      • OpenCascade does not support Bezier Curve with degree > 25. This should not be a problem in practice.
      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Draft_BezCurve.svg b/localwiki/Draft_BezCurve.svg new file mode 100644 index 0000000..f733127 --- /dev/null +++ b/localwiki/Draft_BezCurve.svg @@ -0,0 +1,456 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + Draft_BezCurve + + Fri Jan 17 12:22:46 2014 -0500 + + + [WandererFan] + + + + + FreeCAD LGPL2+ + + + + + FreeCAD + + + FreeCAD/src/Mod/Draft/Resources/icons/Draft_BezCurve.svg + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + [agryson] Alexander Gryson + + + + + curve + line + dot + point + circle + square + + + A curved line in the shape of an upside down U with a poitn at each end that has a square shaped control point + + + + diff --git a/localwiki/Draft_BezSharpNode.svg b/localwiki/Draft_BezSharpNode.svg new file mode 100644 index 0000000..c4fed96 --- /dev/null +++ b/localwiki/Draft_BezSharpNode.svg @@ -0,0 +1,529 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + Draft_BezSharpNode + + Sun Feb 2 18:22:27 2014 +0100 + + + [Sebastian Hoogen] + + + + + FreeCAD LGPL2+ + + + + + FreeCAD + + + FreeCAD/src/Mod/Draft/Resources/icons/Draft_BezSharpNode.svg + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + [agryson] Alexander Gryson + + + + + curved + line + dot + circle + control + + + An irregularly curved lin passing through a dot with unequally spaced control points at an angle to each other + + + + diff --git a/localwiki/Draft_BezSymNode.svg b/localwiki/Draft_BezSymNode.svg new file mode 100644 index 0000000..ba6a743 --- /dev/null +++ b/localwiki/Draft_BezSymNode.svg @@ -0,0 +1,511 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + Draft_BezSymNode + + Thu Jan 30 09:16:37 2014 -0500 + + + [WandererFan] + + + + + FreeCAD LGPL2+ + + + + + FreeCAD + + + FreeCAD/src/Mod/Draft/Resources/icons/Draft_BezSymNode.svg + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + [agryson] Alexander Gryson + + + + + dot + circle + line + curved + control + + + A curved line passing through a dot with equally spaced control points + + + + diff --git a/localwiki/Draft_BezTanNode.svg b/localwiki/Draft_BezTanNode.svg new file mode 100644 index 0000000..113b264 --- /dev/null +++ b/localwiki/Draft_BezTanNode.svg @@ -0,0 +1,479 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + Draft_BezTanNode + + Thu Jan 30 09:16:37 2014 -0500 + + + [WandererFan] + + + + + FreeCAD LGPL2+ + + + + + FreeCAD + + + FreeCAD/src/Mod/Draft/Resources/icons/Draft_BezTanNode.svg + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + [agryson] Alexander Gryson + + + + + curve + line + control + + + A curved line passing through a point with unequally distant control points + + + + diff --git a/localwiki/Draft_Center.html b/localwiki/Draft_Center.html new file mode 100644 index 0000000..8f7185e --- /dev/null +++ b/localwiki/Draft_Center.html @@ -0,0 +1,80 @@ +Draft Center

      Draft Center

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Draft Center.png Draft Center

      +
      Menu location +
      Draft → Snap → Center +
      Workbenches +
      Draft, Arch +
      Default shortcut +
      +
      See also +
      +

      + +
      +


      +

      +

      Description

      +

      Snaps to the the center point of arcs and circles. +

      +

      Use

      +
      1. Make sure snap mode is turned on
      2. +
      3. Choose element to be inserted into the FreeCAD-document
      4. +
      5. Move cursor near one the arc/circle/circular edge you wish to attach your element to
      6. +
      7. Below on the right side of the cursor the symbol of the snap mode will appear
      8. +
      9. Click to attach your element to the selected endpoint of target element
      +

      Will also work with Draft Move and Draft Rotate. +

      +

      Notes

      +

      Snap mode can be used with +

      +
      • sketcher elements (arcs, circles)
      • +
      • draft elements (arcs, circles)
      • +
      • edge of circular face of shape
      • +
      • edge of circular face of solid
      +

      Clicking on the snap-mode icon will toggle the snap mode on/off. +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Draft_Circle.html b/localwiki/Draft_Circle.html new file mode 100644 index 0000000..251f045 --- /dev/null +++ b/localwiki/Draft_Circle.html @@ -0,0 +1,101 @@ +Draft Circle

      Draft Circle

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Draft Circle.png Draft Circle

      +
      Menu location +
      Draft → Circle +
      Workbenches +
      Draft, Arch +
      Default shortcut +
      C I +
      See also +
      Draft Arc +

      + +
      +


      +

      +

      Description

      +

      The Circle tool creates a circle in the current work plane by entering two points, the center and the radius, or by picking tangents, or any combination of those. It takes the linewidth and color previously set on the Tasks tab. This tool works the same way as the Draft Arc tool, except that it stops after entering the radius. +

      Draft Circle example.jpg +

      +

      How to use

      +
      1. Press the Draft Circle.png Draft Circle button, or press C then I keys
      2. +
      3. Click a first point on the 3D view, or type a coordinate
      4. +
      5. Click a second point on the 3D view, or enter a radius value.
      +

      Options

      +
      • The primary use of the circle tool is by picking two points, the centre and a point on the circumference, defining the radius.
      • +
      • By pressing ALT, you can select a tangent instead of picking a point. You can therefore construct several types of circles by selecting one, two or three tangents.
      • +
      • To enter coordinates manually, simply enter the numbers, then press ENTER between each X, Y and Z component.
      • +
      • Press T or click the checkbox to check/uncheck the Continue button. If continue mode is on, the Circle tool will restart after you give the second point, allowing you to draw another circle without pressing the Circle button again.
      • +
      • Press CTRL while drawing to force snapping your point to the nearest snap location, independently of the distance.
      • +
      • Press SHIFT while drawing to constrain your second point horizontally or vertically in relation to the first one.
      • +
      • Press I or the Filled button to have the circle filled with a face.
      • +
      • Press ESC or the Cancel button to abort the current Line command.
      • +
      • The circle can be turned into an arc after creation, by setting its first angle and last angle properties to different values.
      • +
      • Circles, when in "Flat Lines" display mode, can display a hatch pattern, by setting their "Pattern" property below.
      +

      Properties

      +
      • DATARadius: The radius of the circle
      • +
      • DATAMake Face: Fills the circle with a face
      • +
      • VIEWPattern: Specifies a hatch pattern to fill the wire with
      • +
      • VIEWPattern Size: Specifies the size of the hatch pattern
      +

      See also Draft Pattern page. +

      +

      Scripting

      +

      The Circle tool can by used in macros and from the python console by using the following function: +

      +
      makeCircle (radius, [placement], [facemode], [startangle], [endangle]) 
      +
      • Creates a circle object with given radius.
      • +
      • If a placement is given, it is used.
      • +
      • If facemode is False, the circle is shown as a wireframe, otherwise as a face.
      • +
      • If startangle AND endangle are given (in degrees), they are used and the object appears as an arc.
      • +
      • Returns the newly created object.
      +

      Example: +

      +
      import Draft
      +myCircle = Draft.makeCircle(2) 
      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Draft_Circle.png b/localwiki/Draft_Circle.png new file mode 100644 index 0000000..858bff6 Binary files /dev/null and b/localwiki/Draft_Circle.png differ diff --git a/localwiki/Draft_Circle.svg b/localwiki/Draft_Circle.svg new file mode 100644 index 0000000..7a7132a --- /dev/null +++ b/localwiki/Draft_Circle.svg @@ -0,0 +1,311 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + Draft_Circle + + Mon Oct 10 13:44:52 2011 +0000 + + + [wmayer] + + + + + FreeCAD LGPL2+ + + + + + FreeCAD + + + FreeCAD/src/Mod/Draft/Resources/icons/Draft_Circle.svg + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + [agryson] Alexander Gryson + + + + + dot + circle + + + A circle with a dot at its centerpoint and another on the rightermost point of its circumference + + + + diff --git a/localwiki/Draft_Clone.html b/localwiki/Draft_Clone.html new file mode 100644 index 0000000..80cf08a --- /dev/null +++ b/localwiki/Draft_Clone.html @@ -0,0 +1,88 @@ +Draft Clone

      Draft Clone

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Draft Clone.png Draft Clone

      +
      Menu location +
      Draft → Clone +
      Workbenches +
      Draft, Arch +
      Default shortcut +
      None +
      See also +
      Draft Scale +

      + +
      +


      +

      +

      Description

      +

      This tool produces a clone (a copy that is parametrically bound to the original object) of a selected object. If the original object changes, the clone changes too, but keeps its position, rotation and scale. +

      Draft Clone example.jpg +

      +

      How to use

      +
      1. Select objects you wish to clone
      2. +
      3. Press the Draft Clone.png Draft Clone button
      +

      Options

      +
      • Clones of 2D objects (Draft or Sketch) will also be 2D objects, and therefore can be used as such for Part Design.
      • +
      • All Arch objects have the possibility to behave as a clone (using their CloneOf property). If you use the Draft Clone tool on a selected Arch object, you will produce such an Arch cloned object instead of a regular Draft clone.
      +

      Properties

      +
      • DATAScale: Specifies an optional scale factor for the clone
      • +
      • DATAFuse: If this clone is using several objects, this specifies if the result is a fusion or a compound available in version 0.17
      +
      • The result of the Draft Scale tool is also a clone
      • +
      • No sketches can be mapped to faces of a clone. That is at the moment a known limitation.
      +

      Scripting

      +

      The Clone tool can by used in macros and from the python console by using the following function: +

      +
      clone (obj,[delta]) 
      +
      • Makes a clone of the given object(s).
      • +
      • The clone is an exact, linked copy of the given object.
      • +
      • If the original object changes, the final object changes too. Optionally, you can give a delta Vector to move the clone away from the original position.
      +

      Example: +

      +
      import Draft
      +Draft.clone(FreeCAD.ActiveDocument.ActiveObject) 
      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Draft_Clone.png b/localwiki/Draft_Clone.png new file mode 100644 index 0000000..04199fa Binary files /dev/null and b/localwiki/Draft_Clone.png differ diff --git a/localwiki/Draft_Clone.svg b/localwiki/Draft_Clone.svg new file mode 100644 index 0000000..5e09edd --- /dev/null +++ b/localwiki/Draft_Clone.svg @@ -0,0 +1,492 @@ + + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Draft_CloseLine.html b/localwiki/Draft_CloseLine.html new file mode 100644 index 0000000..49eb204 --- /dev/null +++ b/localwiki/Draft_CloseLine.html @@ -0,0 +1,65 @@ +Draft CloseLine

      Draft CloseLine

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Draft CloseLine.png Draft CloseLine

      +
      Menu location +
      Draft → Utilities → Close Line +
      Workbenches +
      Draft, Arch +
      Default shortcut +
      C +
      See also +
      FinishLine, UndoLine +

      + +
      +


      +

      +

      Description

      +

      This command finishes the drawing of a current wire, and closes it by drawing a closing segment between the last point and the first one. Closed wires are always also filled faces internally, even if they appear as wireframe. +

      +

      How to use

      +
      1. Start drawing a Draft Wire
      2. +
      3. Press the Draft CloseLine.png Close button or press the C key
      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Draft_Constrain.html b/localwiki/Draft_Constrain.html new file mode 100644 index 0000000..3e621b0 --- /dev/null +++ b/localwiki/Draft_Constrain.html @@ -0,0 +1,23 @@ +Draft Constrain

      Draft Constrain

      + +

      To use constraining, press SHIFT while drawing. +

      Draft Constrain example.jpg +

      In all tools that support constraining, you can force the next point to be constrained horizontally or vertically in relation to the last point entered. The vertical or horizontal constraining depends on where your mouse lies when you press SHIFT. If you are more north or south from the last point, it will be vertical. If you are more east or west, it will be horizontal. To change, just release SHIFT and press again at another location. +

      Some tools, like offset and trimex use constraining differently. They do not constrain vertically or horizontally but use a different way more adapted to the particular tool, like for example constraining the operation to a certain polyline segment. +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Draft_Constrain_example.jpg b/localwiki/Draft_Constrain_example.jpg new file mode 100644 index 0000000..31b8fc5 Binary files /dev/null and b/localwiki/Draft_Constrain_example.jpg differ diff --git a/localwiki/Draft_Construction.svg b/localwiki/Draft_Construction.svg new file mode 100644 index 0000000..2241290 --- /dev/null +++ b/localwiki/Draft_Construction.svg @@ -0,0 +1,272 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + Draft_Construction + + Mon Oct 10 13:44:52 2011 +0000 + + + [wmayer] + + + + + FreeCAD LGPL2+ + + + + + FreeCAD + + + FreeCAD/src/Mod/Draft/Resources/icons/Draft_Construction.svg + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + [agryson] Alexander Gryson + + + + + trowel + tool + + + A trowel + + + + diff --git a/localwiki/Draft_Coordinates.html b/localwiki/Draft_Coordinates.html new file mode 100644 index 0000000..b227465 --- /dev/null +++ b/localwiki/Draft_Coordinates.html @@ -0,0 +1,40 @@ +Draft Coordinates

      Draft Coordinates

      + +

      In all Draft tools, when you are asked for 3d point locations, distances, radiuses, angles or any other numeric data, you can always choose to enter those values graphically, by picking on the screen with your mouse, or directly by entering numbers with the keyboard. The first method is usually more intuitive, but when you work with absolute precision, you often need to enter a precise number and be sure the coordinate you entered is exact. Therefore, the command bar of the Draft module can always accept number input: +

      Draft Coordinates.jpg +

      The Draft command bar is an "intelligent" toolbar, which means its contents change according to the tool being used and the input required from the user. When you draw a circle, for example, the command bar will successively ask you for the circle center, then the radius. Those two values can both be indicated by picking a point on the screen or by entering numbers. +

      Whenever you see the number input fields appearing on the command bar, you can enter numbers in them You will see that those numbers also reflect the movements of your mouse cursor. You can TAB through the X,Y and Z fields to set the coordinates. Pressing ENTER in the Z field will record the point. Repeating the entry of new X, Y and Z coordinates will set the second point for a line and/or subsequent points for a wire. +

      The following shortcuts can also be used: +

      +
      • SPACE BAR to swap between absolute and relative coordinates
      • +
      • C to swap between original mode and copy mode
      • +
      • L to lock/unlock the Z coordinate
      • +
      • TAB or ENTER switches to the next field (for ex. from X to Y or from Y to Z)
      +

      Sometimes, it can be hard to align objects when working in 3D space. You can lock the Z coordinate, so you'll be certain that everything you draw will lie in the same horizontal plane. When you open FreeCAD, the Z coordinate is locked by default at 0.00, but you can easily change it, just unlock, change the Z value, and lock again. If Z coordinate is locked, you won't be able to draw in non-horizontal planes. +

      Most of the Draft commands now work in 3D, just unlock the Z coordinate and switch the view to the appropriate angle, and what you'll draw next will be aligned to that view. +

      Impose a decimal +

      By default, FreeCAD works with two decimal places, to change the number of decimal places, you must: +

      +
      • add a new integer element Decimals in the menu Tools → Edit parameters... → BaseApp → Preferences → Units
      • +
      • make right click in the window and select New integer item → create name Decimals and enter the number of decimal places you want.
      • +
      • then click Save to disk, to validate your change.
      • +
      • close and return to FreeCAD to activate your changes.
      +


      +

      +
      PreferencesDecimals 01 en.png
      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Draft_Coordinates.jpg b/localwiki/Draft_Coordinates.jpg new file mode 100644 index 0000000..cc21db2 Binary files /dev/null and b/localwiki/Draft_Coordinates.jpg differ diff --git a/localwiki/Draft_Cursor.svg b/localwiki/Draft_Cursor.svg new file mode 100644 index 0000000..aa1a79a --- /dev/null +++ b/localwiki/Draft_Cursor.svg @@ -0,0 +1,105 @@ + + + + + + + + + + + + + + + image/svg+xml + + Draft_Cursor + + Sat Dec 17 15:36:02 2011 +0000 + + + [yorikvanhavre] + + + + + FreeCAD LGPL2+ + + + + + FreeCAD + + + FreeCAD/src/Mod/Draft/Resources/icons/Draft_Cursor.svg + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + [agryson] Alexander Gryson + + + + + crosshair + cross + plus + + + A white crosshair + + + + diff --git a/localwiki/Draft_DAT.html b/localwiki/Draft_DAT.html new file mode 100644 index 0000000..75c9360 --- /dev/null +++ b/localwiki/Draft_DAT.html @@ -0,0 +1,21 @@ +Draft DAT

      Draft DAT

      + +

      The common airfoil data format is a simple file containing the optional metadata about the airfoil in the first 1-2 lines and the coordinates of the upper and lower surface. +

      There are many different dialects to this format so this import module tries to be as smart as possible to understand almost anyone. +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Draft_DXF.html b/localwiki/Draft_DXF.html new file mode 100644 index 0000000..74a9672 --- /dev/null +++ b/localwiki/Draft_DXF.html @@ -0,0 +1,85 @@ +Draft DXF

      Draft DXF

      + +

      Screenshot qcad.jpg +

      + + +

      Opening

      +

      This function opens a DXF file (any version from 12 to 2007) in a new drawing. +The following DXF object types are currently supported: +

      +
      • lines
      • +
      • polylines and lwpolylines
      • +
      • circles
      • +
      • arcs
      • +
      • layers (layers containing objects are conveted to FreeCAD Groups)
      • +
      • texts and mtexts
      • +
      • dimensions
      • +
      • blocks (only geometry. texts, dims and attributes inside blocks will be skipped)
      • +
      • points available in version 0.13
      + +

      Other DXF entities are currently not imported because there is no corresponding FreeCAD object. As new functionality gets implemented, it will be possible to import more entity types. +

      +

      Installing

      +

      Warning: For license reasons, the dxf import/export libraries are not part of the FreeCAD source code anymore. For that reason, they must be installed by you, the user, after you install FreeCAD. There is a way to allow FreeCAD to do that automatically, or you can do it manually. +

      +

      Automatically

      +

      Starting from version 0.15, you only need to mark the Edit-> Preferences -> Import/Export -> DXF/DWG -> "Allow FreeCAD to automatically download the DXF libraries" option to have FreeCAD take automatically care of doenloading and installing these libraries. For older versions, you will need to do it manually. +

      +

      Manually

      +

      Libraries must be downloaded from https://github.com/yorikvanhavre/Draft-dxf-importer +There is a very complete step-by-step tutorial that will explain you the necessary steps. +

      +

      Importing

      +

      This works the same way as opening, but it will add the contents of the dxf file in the active documento instead of creating a new document. +

      Tutorial: Dxf Importer Install +

      +

      Exporting

      +

      The exported DXF is compatible with Autocad version 12 and up, so it should open in about any application that supports dxf format. +Currently the following FreeCAD objects get exported: +

      +
      • lines and wires (polylines)
      • +
      • arcs and circles
      • +
      • texts
      • +
      • colors are mapped from objects RGB colors to autocad color index (ACI). Black will always be "by layer"
      • +
      • layers are mapped from group names. When groups are nested, the deepest group gives the layer name.
      • +
      • dimensions, which are exported with "Standard" dimstyle
      +

      Preferences

      +

      The following parameters can be specified in the Draft Preferences tab (menu Edit -> Preferences -> Draft): +

      +
      • Import style: This lets you choose the way objects from the dxf file will be drawn in FreeCAD. You can choose between: +
        • None: this is the faster way, there is no conversion, all objects will be black with 2px width (FreeCAD default)
        • +
        • Use default color and linewidth: All imported dxf objects will take current linewidth/color from the draft command bar
        • +
        • Original color and linewidth: Objects will keep the color and linewidth (if specified) they have in the dxf file
        • +
        • Colors mapped to linewidth: If this option is selected, the mapping file option below is used.
      • +
      • Color mapping file: This allows you to specify a mapping file to be used for translating dxf colors to color and linewidth, the same way as a plot style works in Autocad. The mapping file must be a tab-separated text file. There is a nice free utility called Plot style viewer that can convert Autocad CTB or STB (plot styles) files to tab-separated mapping files ready to use in FreeCAD. Alternatively, we have a couple of home-made mapping files availables here.
      • +
      • Import texts: This allows you to specify if you want to import dxf texts and dimensions or not. Many texts might make your work in FreeCAD very heavy, so you might want to use this option some time.
      • +
      • Import layout objects: Turn this on if you want to import paper space object. They will be merged in the same document than model space objects.
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Draft_DelPoint.html b/localwiki/Draft_DelPoint.html new file mode 100644 index 0000000..1b549d8 --- /dev/null +++ b/localwiki/Draft_DelPoint.html @@ -0,0 +1,76 @@ +Draft DelPoint

      Draft DelPoint

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Draft DelPoint.png Draft DelPoint

      +
      Menu location +
      Draft → Remove Point +
      Workbenches +
      Draft, Arch +
      Default shortcut +
      +
      See also +
      Draft AddPoint +

      + +
      +


      +

      +

      Description

      +

      This tools allows you to remove points from Wires and BSplines. +

      +

      How to use

      +
      1. Select a wire or a BSpline
      2. +
      3. Press the Draft DelPoint.png Draft DelPoint button
      4. +
      5. Click a point on the wire or BSpline
      +

      Options

      +
      • This functionality is also available inside the Draft Edit.png Draft Edit tool
      +

      Scripting

      +

      Not available, but removing points from Wires and BSplines is easy, for example: +

      +
      import FreeCAD,Draft
      +points = FreeCAD.ActiveDocument.ActiveObject.Points
      +points.pop(0)
      +FreeCAD.ActiveDocument.ActiveObjects.Points = points 
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Draft_DelPoint.svg b/localwiki/Draft_DelPoint.svg new file mode 100644 index 0000000..607dff2 --- /dev/null +++ b/localwiki/Draft_DelPoint.svg @@ -0,0 +1,516 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + Draft_DelPoint + + Mon Oct 10 13:44:52 2011 +0000 + + + [wmayer] + + + + + FreeCAD LGPL2+ + + + + + FreeCAD + + + FreeCAD/src/Mod/Draft/Resources/icons/Draft_DelPoint.svg + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + [agryson] Alexander Gryson + + + + + minus + line + dot + + + A minus sign floating above a line with a dot at its midpoint + + + + diff --git a/localwiki/Draft_Dimension.html b/localwiki/Draft_Dimension.html new file mode 100644 index 0000000..1799c36 --- /dev/null +++ b/localwiki/Draft_Dimension.html @@ -0,0 +1,135 @@ +Draft Dimension

      Draft Dimension

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Draft Dimension.png Draft Dimension

      +
      Menu location +
      Draft → Dimension +
      Workbenches +
      Draft, Arch +
      Default shortcut +
      D I +
      See also +
      FlipDimension +

      + +
      +


      +

      +

      Description

      +

      The dimension tool creates a dimension in the current document with two points defining the distance to measure, and a third point specifying where the dimension line passes. +

      Screenshot Draft Dimension.jpg +

      +

      How to use

      +
      1. Press the Draft Dimension.png Draft Dimension button, or press D then I keys
      2. +
      3. Click a point on the 3D view, or type a coordinate
      4. +
      5. Click a second point on the 3D view, or type a coordinate
      6. +
      7. Click a third on the 3D view, or type a coordinate
      +

      Available dimension types

      +
      • Linear dimensions: by picking any 2 points or any straight edge with ALT pressed.
      • +
      • Horizontal/vertical dimensions: by pressing SHIFT while the second point is selected.
      • +
      • Diameter dimensions: by picking a curved edge with ALT pressed.
      • +
      • Radius dimensions: by picking a curved edge with ALT pressed, then pressing SHIFT.
      • +
      • Angular dimensions: by picking 2 straight edges with ALT pressed.
      +

      Options

      +
      • Press X, Y or Z after a point to constrain the next point on the given axis.
      • +
      • To enter coordinates manually, simply enter the numbers, then press ENTER between each X, Y and Z component.
      • +
      • Press CTRL while drawing to force snapping your point to the nearest snap location, independently of the distance.
      • +
      • Pressing SHIFT will constrain the dimension horizontally or vertically, or, when working on a circular edge, switches between diameter and radius modes.
      • +
      • Press R or click the checkbox to check/uncheck the Relative button. If relative mode is on, the coordinates of the next point are relative to the last one. If not, they are absolute, taken from the (0,0,0) origin point.
      • +
      • Press T or click the checkbox to check/uncheck the Continue button. If continue mode is on, you will be able to draw continued dimensions, one after the other, that share the same baseline.
      • +
      • Press ESC or the Cancel button to abort the current Line command.
      • +
      • By picking an existing edge with ALT, instead of entering measurement points, the dimension will become parametric and remember which edge it is bound to. If the endpoints of that edge move later on, the dimension will follow them.
      • +
      • If an edge is selected before starting the Dimension command, the created dimension will also be parametric.
      • +
      • The direction of the dimension can be changed afterwards, by modifying its "Direction" property
      +

      Properties

      +
      • DATAStart: The start point of the distance to measure
      • +
      • DATAEnd: The end point of the distance to measure
      • +
      • DATADimline: A point through which the dimension line must pass
      • +
      • VIEWDisplay Mode: Specifies if the text is aligned to the dimension lines or always faces the camera
      • +
      • VIEWFont Size: The size of the letters
      • +
      • VIEWExt Lines: The size of the extension lines (between the measurement points and the dimension line)
      • +
      • VIEWText Position: Can be used to force the text to be displayed at a certain position
      • +
      • VIEWText Spacing: Specifies the space between the text and the dimension line
      • +
      • VIEWOverride: Specifies a text to display instead of the measurement. Insert "$dim", inside that text, to display the measurement value
      • +
      • VIEWFont Name: The font to use to draw the text. It can be a font name, such as "Arial", a default style such as "sans", "serif" or "mono", or a family such as "Arial,Helvetica,sans" or a name with a style such as "Arial:Bold". If the given font is not found on the system, a generic one is used instead.
      • +
      • VIEWArrow Type: The type of arrow to use
      • +
      • VIEWArrow Size: The size of the arrows
      • +
      • VIEWDecimals: The number of decimal places to display on the dimension
      • +
      • VIEWFlip Arrows: Reverse the orientation of arrows
      • +
      • VIEWUnit Override: Expresses the distance in the given unit (leave blank to use the system unit) available in version 0.17
      +


      +

      +

      Scripting

      +

      The Dimension tool can by used in macros and from the python console by using the following functions: +

      +
      makeDimension (p1,p2,[p3]) 
      +

      or +

      +
      makeDimension (object,i1,i2,p3) 
      +

      or +

      +
      makeDimension (objlist,indices,p3) 
      +
      • Creates a Dimension object with the dimension line passign through p3.
      • +
      • The Dimension object takes the Draft linewidth and color set in the command bar.
      • +
      • There are multiple ways to create a dimension, depending on the arguments you pass to it:
      +
      1. (p1,p2,p3): creates a standard dimension from p1 to p2.
      2. +
      3. (object,i1,i2,p3): creates a linked dimension to the given object, measuring the distance between its vertices indexed i1 and i2.
      4. +
      5. (object,i1,mode,p3): creates a linked dimension to the given object, i1 is the index of the (curved) edge to measure, and mode is either "radius" or "diameter". Returns the newly created object.
      +
      makeAngularDimension (center,[angle1,angle2],p3) 
      +
      • creates an angular Dimension from the given center, with the given list of angles, passing through p3.
      • +
      • Returns the newly created object.
      +

      Example: +

      +
      import FreeCAD,Draft
      +p1 = FreeCAD.Vector(0,0,0)
      +p2 = FreeCAD.Vector(1,1,0)
      +p3 = FreeCAD.Vector(2,0,0)
      +Draft.makeDimension(p1,p2,p3) 
      +

      Links

      + +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Draft_Dimension.png b/localwiki/Draft_Dimension.png new file mode 100644 index 0000000..261ec72 Binary files /dev/null and b/localwiki/Draft_Dimension.png differ diff --git a/localwiki/Draft_Dimension.svg b/localwiki/Draft_Dimension.svg new file mode 100644 index 0000000..2aa55c5 --- /dev/null +++ b/localwiki/Draft_Dimension.svg @@ -0,0 +1,482 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + Draft_Dimension + + Mon Oct 10 13:44:52 2011 +0000 + + + [wmayer] + + + + + FreeCAD LGPL2+ + + + + + FreeCAD + + + FreeCAD/src/Mod/Draft/Resources/icons/Draft_Dimension.svg + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + [agryson] Alexander Gryson + + + + + line + dot + number + + + A number floating above a line corresponding to the upper three sides of a rectangle with a dot at eacf endpoint and corner + + + + diff --git a/localwiki/Draft_Dimensions.html b/localwiki/Draft_Dimensions.html new file mode 100644 index 0000000..e3780de --- /dev/null +++ b/localwiki/Draft_Dimensions.html @@ -0,0 +1,77 @@ +Draft Dimensions

      Draft Dimensions

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Draft Dimensions.png Draft Dimensions

      +
      Menu location +
      Draft → Snap → Dimensions +
      Workbenches +
      Draft, Arch +
      Default shortcut +
      +
      See also +
      +

      + +
      +


      +

      +

      Description

      +

      Lets you snap to one of the three lines making up the draft dimension +


      +

      +

      Use

      +
      1. Make sure snap mode is turned on
      2. +
      3. Choose element (for example draft line) to be inserted into the FreeCAD-document
      4. +
      5. Move cursor near draft dimension of the element you wish to attach your element to
      6. +
      7. below on the right side of the cursor the symbol of the snap mode will appear
      8. +
      9. click to attach your element to the selected line of the draft dimension of the target element
      +


      +

      +

      Notes

      +


      +
      +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Draft_Dot.svg b/localwiki/Draft_Dot.svg new file mode 100644 index 0000000..d958d5f --- /dev/null +++ b/localwiki/Draft_Dot.svg @@ -0,0 +1,289 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + Draft_Dot + + Sat Dec 17 15:36:02 2011 +0000 + + + [yorikvanhavre] + + + + + FreeCAD LGPL2+ + + + + + FreeCAD + + + FreeCAD/src/Mod/Draft/Resources/icons/Draft_Dot.svg + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + [agryson] Alexander Gryson + + + + + dot; circle + + + A dot or circle + + + + diff --git a/localwiki/Draft_Downgrade.html b/localwiki/Draft_Downgrade.html new file mode 100644 index 0000000..7707f6b --- /dev/null +++ b/localwiki/Draft_Downgrade.html @@ -0,0 +1,105 @@ +Draft Downgrade

      Draft Downgrade

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Draft Downgrade.png Draft Downgrade

      +
      Menu location +
      Draft → Downgrade +
      Workbenches +
      Draft, Arch +
      Default shortcut +
      D N +
      See also +
      Draft Upgrade +

      + +
      +


      +

      +

      Description

      +

      This tool downgrades selected objects in different ways. If no object is selected, you will be invited to select one. +

      Draft Downgrade example.jpg +

      +

      How to use

      +
      1. Select one or more objects you want to downgrade
      2. +
      3. Press the Draft Downgrade.png Draft Downgrade button or press D then N keys
      +

      Options

      +

      The selected objects are modified/downgraded, according to the following conditions (in order): +

      +
      • if only one object is selected and it contains more than one face, each face becomes a separate object
      • +
      • if there are more than one face in the selection, the subsequent objects are subtracted from the first one
      • +
      • if there is only one face in the selection, it gets converted into a wire
      • +
      • otherwise all wires found in the selection are exploded into single edges
      +

      Example

      + +

      Scripting

      +

      The Downgrade tool can be used in python scripts and macros by using the following function: +

      +
      downgrade (objects, [delete], [force]) 
      +
      • Downgrades the given object(s) (can be an object or a list of objects).
      • +
      • If delete is True, old objects are deleted.
      • +
      • The force attribute can be used to force a certain way of downgrading. It can be: explode, shapify, subtr, splitFaces, cut2, getWire, splitWires.
      • +
      • Returns a dictionary containing two lists, a list of new objects and a list of objects to be deleted
      +

      Example: +

      +
      import FreeCADGui,Draft
      +selection = FreeCADGui.Selection.getSelection()
      +Draft.downgrade(selection) 
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Draft_Downgrade.png b/localwiki/Draft_Downgrade.png new file mode 100644 index 0000000..44422f5 Binary files /dev/null and b/localwiki/Draft_Downgrade.png differ diff --git a/localwiki/Draft_Downgrade.svg b/localwiki/Draft_Downgrade.svg new file mode 100644 index 0000000..04fee6f --- /dev/null +++ b/localwiki/Draft_Downgrade.svg @@ -0,0 +1,192 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + Draft_Downgrade + + Mon Oct 10 13:44:52 2011 +0000 + + + [wmayer] + + + + + FreeCAD LGPL2+ + + + + + FreeCAD + + + FreeCAD/src/Mod/Draft/Resources/icons/Draft_Downgrade.svg + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + [agryson] Alexander Gryson + + + + + arrow + down + + + An arrow pointing downwards + + + + diff --git a/localwiki/Draft_Draft.svg b/localwiki/Draft_Draft.svg new file mode 100644 index 0000000..44307ef --- /dev/null +++ b/localwiki/Draft_Draft.svg @@ -0,0 +1,201 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + Draft_Draft + + Mon Oct 10 13:44:52 2011 +0000 + + + [wmayer] + + + + + FreeCAD LGPL2+ + + + + + FreeCAD + + + FreeCAD/src/Mod/Draft/Resources/icons/Draft_Draft.svg + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + [agryson] Alexander Gryson + + + + + square + rectangle + circle + + + The intersecting outlines of a circle and a square or rectangle + + + + diff --git a/localwiki/Draft_Draft2Sketch.html b/localwiki/Draft_Draft2Sketch.html new file mode 100644 index 0000000..6b48b44 --- /dev/null +++ b/localwiki/Draft_Draft2Sketch.html @@ -0,0 +1,77 @@ +Draft Draft2Sketch

      Draft Draft2Sketch

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Draft Draft2Sketch.png Draft Draft2Sketch

      +
      Menu location +
      Drafting → Draft to Sketch +
      Workbenches +
      Draft, Arch +
      Default shortcut +
      None +
      See also +
      None +

      + +
      +


      +

      +

      Description

      +

      This tool converts Draft objects to Sketcher objects, and vice-versa. +

      Draft Draft2Sketch example.jpg +

      +

      How to use

      +
      1. Select a Draft object or a Sketch
      2. +
      3. Press the Draft Draft2Sketch.png Draft Draft2Sketch button
      +

      Options

      +
      • If you convert a Draft Wire, point constraints will be applied to the nodes
      • +
      • If you convert a Draft Rectangle, point constraints will be applied to the corners, and horizontal and vertical constraints to the edges
      • +
      • Non-Draft objects that are totally planar will also get converted to sketches
      +

      The sketcher does support straight lines and circular arcs. The conversion of any element that can not be represented with those will fail. +

      The conversion of any element that can not be represented with either a straight line or circular curve will just fail, i.e. the item will not appear in the sketch. See also the BSpline conversion in the forum https://forum.freecadweb.org/viewtopic.php?f=9&t=25082 +

      +

      Scripting

      +

      Not available, see the Sketcher Module documentation for how to create sketches by scripting +

      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Draft_Draft2Sketch.svg b/localwiki/Draft_Draft2Sketch.svg new file mode 100644 index 0000000..0f797f6 --- /dev/null +++ b/localwiki/Draft_Draft2Sketch.svg @@ -0,0 +1,348 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + Draft_Draft2Sketch + + Tue Dec 6 17:18:18 2011 +0000 + + + [yorikvanhavre] + + + + + FreeCAD LGPL2+ + + + + + FreeCAD + + + FreeCAD/src/Mod/Draft/Resources/icons/Draft_Draft2Sketch.svg + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + [agryson] Alexander Gryson + + + + + circe + square + rectangle + arrow + + + The intersecting outlines of a pair of circles and pair of squares behind a pair of arrows pointing in opposing directions up and down + + + + diff --git a/localwiki/Draft_Drawing.html b/localwiki/Draft_Drawing.html new file mode 100644 index 0000000..5e48dab --- /dev/null +++ b/localwiki/Draft_Drawing.html @@ -0,0 +1,89 @@ +Draft Drawing

      Draft Drawing

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Draft Drawing.png Draft Drawing

      +
      Menu location +
      Drafting → Drawing +
      Workbenches +
      Draft, Arch +
      Default shortcut +
      None +
      See also +
      None +

      + +
      +


      +

      +

      Description

      +

      This tool allows you to put selected objects on a svg Drawing sheet. If no sheet exists in the document, a default one will be created. This tool works similarly to the Drawing View tool, but is optimized for Draft objects, and can render flat 2D objects with a face filling. It can also handle a couple of specific Draft objects, such as dimensions and texts, that the Drawing View tool cannot handle. +

      Draft drawing example.jpg +

      +

      How to use

      +
      1. Select the objects you wish to put on a drawing sheet
      2. +
      3. Press the Draft Drawing.png Draft Drawing button
      +

      Options

      +
      • Select objects you want to put on the drawing sheet. The tool will work best with flat 2D objects from the Draft or Sketcher modules.
      • +
      • If the selected object is an Arch SectionPlane, this tool will create an additional view of that section plane.
      • +
      • In the same selection, add the page object you want to draw your objects to. If there is no existing page, a new one will be created. If you didn't select a page but there is at least one in the document, the first found one will be used to draw to.
      • +
      • If you selected an existing sheet, and the objects in the selection that are already on that sheet (for ex. for a "Rectangle" object there is already a "ViewRectangle" object on the sheet), they will be substitued. This allows you to simply select all the objects and send them to an existing page, which will simply be updated.
      +

      Properties

      +
      • DATAFill Style: For closed shapes, allows to specify one of the Default Draft fill styles, or use the shape color.
      • +
      • DATAFont Size: Allows you to specify the font size of texts and dimensions.
      • +
      • DATALine Width: Allows you to specify the line width of viewed objects.
      +

      Scripting

      +

      The Draft Drawing tool can by used in macros and from the python console by using the following function: +

      +
      Draft.makeDrawingView (object,page) 
      +
      • Adds a view of the given object to the given page.
      • +
      • Returns the created view object.
      +

      Example: +

      +
      import FreeCAD,Draft
      +obj = FreeCAD.ActiveDocument.ActiveObject
      +page = FreeCAD.ActiveDocument.Page
      +Draft.makeDrawingView(obj,page) 
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Draft_Drawing.png b/localwiki/Draft_Drawing.png new file mode 100644 index 0000000..ede0a17 Binary files /dev/null and b/localwiki/Draft_Drawing.png differ diff --git a/localwiki/Draft_Drawing.svg b/localwiki/Draft_Drawing.svg new file mode 100644 index 0000000..65af18b --- /dev/null +++ b/localwiki/Draft_Drawing.svg @@ -0,0 +1,638 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + Draft_Drawing + + Mon Oct 10 13:44:52 2011 +0000 + + + [wmayer] + + + + + FreeCAD LGPL2+ + + + + + FreeCAD + + + FreeCAD/src/Mod/Draft/Resources/icons/Draft_Drawing.svg + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + [agryson] Alexander Gryson + + + + + arrow + page + shapes + + + An arrow pointing from left to right onto a page with shapes drawn on it + + + + diff --git a/localwiki/Draft_Edit.html b/localwiki/Draft_Edit.html new file mode 100644 index 0000000..a8907d3 --- /dev/null +++ b/localwiki/Draft_Edit.html @@ -0,0 +1,84 @@ +Draft Edit

      Draft Edit

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Draft Edit.png Draft Edit

      +
      Menu location +
      Draft → Edit +
      Workbenches +
      Draft, Arch +
      Default shortcut +
      None +
      See also +
      None +

      + +
      +


      +

      +

      Description

      +

      This tool allows you to edit graphically certain properties of the selected object, such as the vertices of a Wire, or the length and width of a Rectangle, or the radius of a Circle. It does nothing more than enter the object's edit mode, so other ways to enter edit mode (such as double-clicking the object in the Tree view) give the same result. +

      Draft edit example.jpg +

      +

      How to use

      +
      1. Select a wire, line, rectangle, bspline or circle
      2. +
      3. Press the Draft Edit.png Draft Edit button, or double-click the object in the Tree panel, or use the Std Edit.png Std Edit tool.
      4. +
      5. Click on a point you wish to move
      6. +
      7. Click another point on the 3D view, or type a coordinate
      8. +
      9. Press ESC or the Finish button
      +

      Options

      +
      • The Edit tool only works on one selected object at a time.
      • +
      • The Edit tool only works on Draft Wires, Rectangles, Circles and Arcs. Other object types must first be converted to Draft objects.
      • +
      • Click on an edit vertex to move it, click again to release it.
      • +
      • Press X, Y or Z after a point to constrain the next point on the given axis.
      • +
      • To enter coordinates manually, simply enter the numbers, then press ENTER between each X, Y and Z component.
      • +
      • Press CTRL while drawing to force snapping your point to the nearest snap location, independently of the distance.
      • +
      • Press SHIFT while drawing to constrain your next point horizontally or vertically in relation to the last one.
      • +
      • Press ESC or the Cancel button or the Draft Edit.png Draft Edit button again to finish editing.
      • +
      • Pressing the Draft AddPoint.png Add point button allows you to add points to Wires and BSplines by clicking on the segments
      • +
      • Pressing the Draft DelPoint.png Del point button allows you to remove points from Wires and BSplines by clicking on the points to remove
      +

      Scripting

      +

      Not available. Each of the above object can be modified by changing its properties directly. +

      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Draft_Edit.svg b/localwiki/Draft_Edit.svg new file mode 100644 index 0000000..9b40509 --- /dev/null +++ b/localwiki/Draft_Edit.svg @@ -0,0 +1,543 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + Draft_Edit + + Mon Oct 10 13:44:52 2011 +0000 + + + [wmayer] + + + + + FreeCAD LGPL2+ + + + + + FreeCAD + + + FreeCAD/src/Mod/Draft/Resources/icons/Draft_Edit.svg + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + [agryson] Alexander Gryson + + + + + polygon + pencil + edit + + + Irregular polygon behind a pencil + + + + diff --git a/localwiki/Draft_Ellipse.html b/localwiki/Draft_Ellipse.html new file mode 100644 index 0000000..0b8a339 --- /dev/null +++ b/localwiki/Draft_Ellipse.html @@ -0,0 +1,98 @@ +Draft Ellipse

      Draft Ellipse

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Draft Ellipse.png Draft Ellipse

      +
      Menu location +
      Draft → Ellipse +
      Workbenches +
      Draft, Arch +
      Default shortcut +
      E L +
      See also +
      Draft Circle +

      + +
      +


      +

      +

      Description

      +

      The Ellipse tool creates an ellipse in the current work plane by entering two points, defining the corner of a rectangular box in which the ellipse will fit. It takes the linewidth and color previously set on the Tasks tab. +

      Draft ellipse example.jpg +

      +

      How to use

      +
      1. Press the Draft Ellipse.png Draft Ellipse button, or press E then L keys
      2. +
      3. Click a first point on the 3D view, or type a coordinate
      4. +
      5. Click a second point on the 3D view, or type a coordinate
      +

      Options

      +
      • To enter coordinates manually, simply enter the numbers, then press ENTER between each X, Y and Z component.
      • +
      • Press T or click the checkbox to check/uncheck the Continue button. If continue mode is on, the Ellipse tool will restart after you give the second point, allowing you to draw another ellipse without pressing the Ellipse button again.
      • +
      • Press CTRL while drawing to force snapping your point to the nearest snap location, independently of the distance.
      • +
      • Press SHIFT while drawing to constrain your second point horizontally or vertically in relation to the first one.
      • +
      • Press I or the Filled button to have the ellipse filled with a face after it has been closed
      • +
      • Press ESC or the Cancel button to abort the command.
      • +
      • Ellipses, when in "Flat Lines" display mode, can display a hatch pattern, by setting their "Pattern" property below.
      +

      Properties

      +
      • DATAMajor Radius: The major radius of the ellipse
      • +
      • DATAMinor Radius: The minor radius of the ellipse
      • +
      • DATAMake Face: Fills the ellipse with a face
      • +
      • VIEWPattern: Specifies a hatch pattern to fill the ellipse with
      • +
      • VIEWPattern Size: Specifies the size of the hatch pattern
      +

      See also Draft Pattern page. +

      +

      Scripting

      +

      The Ellipse tool can by used in macros and from the python console by using the following function: +

      +
      makeEllipse (majorradius, minorradius, [placement], [facemode]) 
      +
      • Creates an ellipse object with given major and minor radius.
      • +
      • If a placement is given, it is used.
      • +
      • If facemode is False, the ellipse is shown as a wireframe, otherwise as a face.
      • +
      • Returns the newly created object.
      +

      Example: +

      +
      import Draft
      +myEllipse = Draft.makeEllipse(4,2) 
      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Draft_Ellipse.png b/localwiki/Draft_Ellipse.png new file mode 100644 index 0000000..3a6bbcf Binary files /dev/null and b/localwiki/Draft_Ellipse.png differ diff --git a/localwiki/Draft_Ellipse.svg b/localwiki/Draft_Ellipse.svg new file mode 100644 index 0000000..06b473a --- /dev/null +++ b/localwiki/Draft_Ellipse.svg @@ -0,0 +1,552 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + Draft_Ellipse + + Mon Apr 1 17:46:32 2013 -0300 + + + [Yorik van Havre] + + + + + FreeCAD LGPL2+ + + + + + FreeCAD + + + FreeCAD/src/Mod/Draft/Resources/icons/Draft_Ellipse.svg + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + [agryson] Alexander Gryson + + + + + ellipse + dot + + + An ellipse with a dot below and to the left and another dot above and to the right + + + + diff --git a/localwiki/Draft_Endpoint.html b/localwiki/Draft_Endpoint.html new file mode 100644 index 0000000..d76d849 --- /dev/null +++ b/localwiki/Draft_Endpoint.html @@ -0,0 +1,82 @@ +Draft Endpoint

      Draft Endpoint

      + +


      +

      + + + + + + + + + + + + + + + + + + + + +
      +

      Draft Endpoint.png Draft Endpoint

      +
      Menu location +
      Draft → Snap → Endpoint +
      Workbenches +
      Draft, Arch +
      Default shortcut +
      +
      See also +
      +

      + +
      +


      +

      +

      Description

      +

      This snap mode lets you select the endpoints of elements. +


      +

      +

      Use

      +
      1. Make sure snap mode is turned on
      2. +
      3. Choose element to be inserted into the FreeCAD-document
      4. +
      5. Move cursor near one of the endpoints you wish to attach your element to
      6. +
      7. Below on the right side of the cursor the symbol of the snap mode will appear
      8. +
      9. Click to attach your element to the selected endpoint of target element
      +

      Notes

      +

      Snap mode can be used with +

      +
      • sketcher elements (lines, arcs)
      • +
      • draft elements (DWires, Lines, Arcs, Bezier Curves)
      • +
      • edges of shapes
      • +
      • edges of solids
      +

      Clicking on the snap-mode icon will toggle the snap mode on/off. +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Draft_Extension.html b/localwiki/Draft_Extension.html new file mode 100644 index 0000000..42485fe --- /dev/null +++ b/localwiki/Draft_Extension.html @@ -0,0 +1,67 @@ +Draft Extension

      Draft Extension

      + +
      +

      This documentation is not finished. Please help and contribute documentation. +

      See Draft ShapeString for good documented Command. Gui Command gives an overview over commands. And see List of Commands for other commands. +

      Go to Help FreeCAD to contribute. +

      +
      +


      +

      + + + + + + + + + + + + + + + + + + + + +
      +

      Draft Extension.png Draft Extension

      +
      Menu location +
      Draft → Snap → Extension +
      Workbenches +
      Draft, Arch +
      Default shortcut +
      +
      See also +
      +

      + +
      +


      +

      +

      Description

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Draft_Facebinder.html b/localwiki/Draft_Facebinder.html new file mode 100644 index 0000000..8310451 --- /dev/null +++ b/localwiki/Draft_Facebinder.html @@ -0,0 +1,82 @@ +Draft Facebinder

      Draft Facebinder

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Draft Facebinder.png Draft Facebinder

      +
      Menu location +
      Draft → Facebinder +
      Workbenches +
      Draft, Arch +
      Default shortcut +
      F F +
      See also +
      None +

      + +
      +


      +

      +

      Description

      +

      The facebinder a very simple object constructed from selected faces of other objects. It is of parametric, you can modify the original object and the facebinder object updates accordingly. It can then be used for example for making an extrusion out of a collection of faces from other objects. A typical use is in architectural design, to build an object that covers several pieces of walls. You can move and rotate the facebinder around after its creation, everything will stay linked to the original faces. +

      Draft facebinder example.jpg +

      +

      How to use

      +
      1. Select faces on objects (use CTRL to select several faces)
      2. +
      3. Press the Draft Facebinder.png Facebinder, button, or press F, F keys
      +

      Scripting

      +

      The facebinder tool can be usedin scripts and macros by using the following function: +

      +
      makeFacebinder ( selectionset ) 
      +
      • Creates a facebinder object from the given selection set, which is a list of selection objects such as returned by the FreeCADGui.Selection.getSelectionEx() method.
      • +
      • Only selected faces are taken into account
      • +
      • Returns the newly created object
      +

      Example: +

      +
      import Draft, FreeCADGui
      +mySelection = FreeCADGui.Selection.getSelectionEx()
      +Draft.makeFacebinder(mySelection) 
      +

      Limitations

      +
      • Not available before version 0.14
      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Draft_Facebinder.svg b/localwiki/Draft_Facebinder.svg new file mode 100644 index 0000000..d70ed1a --- /dev/null +++ b/localwiki/Draft_Facebinder.svg @@ -0,0 +1,581 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + Draft_Facebinder + + Thu Oct 10 19:25:33 2013 -0300 + + + [Yorik van Havre] + + + + + FreeCAD LGPL2+ + + + + + FreeCAD + + + FreeCAD/src/Mod/Draft/Resources/icons/Draft_ + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + [agryson] Alexander Gryson + + + + + polygon + + + A large polygon to the left with two smaller adjacent polygond to the right. + + + + diff --git a/localwiki/Draft_Finish.svg b/localwiki/Draft_Finish.svg new file mode 100644 index 0000000..6a4c4c0 --- /dev/null +++ b/localwiki/Draft_Finish.svg @@ -0,0 +1,492 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + Draft_Finish + + Mon Oct 10 13:44:52 2011 +0000 + + + [wmayer] + + + + + FreeCAD LGPL2+ + + + + + FreeCAD + + + FreeCAD/src/Mod/Draft/Resources/icons/Draft_ + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + [agryson] Alexander Gryson + + + + + line + dot + checkmark + check + correct + + + Three sides of a square or diamond with a dot on the three leftmost corners and a large circle on the rightmost corner with a checkmark + + + + diff --git a/localwiki/Draft_FinishLine.html b/localwiki/Draft_FinishLine.html new file mode 100644 index 0000000..ec062a0 --- /dev/null +++ b/localwiki/Draft_FinishLine.html @@ -0,0 +1,67 @@ +Draft FinishLine

      Draft FinishLine

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Draft FinishLine.png Draft FinishLine

      +
      Menu location +
      Draft → Utilities → Finish Line +
      Workbenches +
      Draft, Arch +
      Default shortcut +
      F +
      See also +
      CloseLine, UndoLine +

      + +
      +


      +

      +

      Description

      +

      This command finishes the drawing of a current wire, leaving it open. +

      +

      How to use

      +
      1. Start drawing a Draft Wire
      2. +
      3. Press the Draft FinishLine.png Finish button or press the F key
      +
      +


      +

      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Draft_FlipDimension.html b/localwiki/Draft_FlipDimension.html new file mode 100644 index 0000000..a1a37fe --- /dev/null +++ b/localwiki/Draft_FlipDimension.html @@ -0,0 +1,66 @@ +Draft FlipDimension

      Draft FlipDimension

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Draft FlipDimension.png Draft FlipDimension

      +
      Menu location +
      Draft → Utilities → Flip Dimension +
      Workbenches +
      Draft, Arch +
      Default shortcut +
      None +
      See also +
      Dimension +

      + +
      +


      +

      +

      Description

      +

      When in 2D mode, the text of the Draft dimensions is displayed aligned to the dimension line. The Dimension tool always tries to show you the dimension text on the correct side of the dimension line, depending on where you are viewing it from. In some cases, though, the viewing direction might not reflect the intent of the viewer, and the orientation of the dimension text might be inverted. This tool inverts that orientation on selected dimension objects. +

      What this tool does, internally, is to invert the Normal direction of the dimension, which is the direction used to draw the text with the correct orientation. Dimensions also have a Flip Text property, which rotates the text by 180 degrees around the normal direction. By combining these two features, normal direction and Flip Text, you are able to make the text appear correctly in all possible situations. +

      +

      How to use

      +
      1. Select one or more dimension objects
      2. +
      3. Press the Draft FlipDimension.png Flip Dimension button
      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Draft_FlipDimension.svg b/localwiki/Draft_FlipDimension.svg new file mode 100644 index 0000000..554f86c --- /dev/null +++ b/localwiki/Draft_FlipDimension.svg @@ -0,0 +1,230 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + Draft_FlipDimension + + Wed Nov 13 19:25:01 2013 -0200 + + + [Yorik van Havre] + + + + + FreeCAD LGPL2+ + + + + + FreeCAD + + + FreeCAD/src/Mod/Draft/Resources/icons/Draft_ + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + [agryson] Alexander Gryson + + + + + triangle + arrow + curved + + + Two triangles, one pointing left, the other right, with a curved arrow below them pointing from the left to the right and slightly upwards + + + + diff --git a/localwiki/Draft_Grid.svg b/localwiki/Draft_Grid.svg new file mode 100644 index 0000000..8de0095 --- /dev/null +++ b/localwiki/Draft_Grid.svg @@ -0,0 +1,353 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + Draft_Grid + + Tue Dec 29 12:10:22 2015 -0200 + + + [Yorik van Havre] + + + + + FreeCAD LGPL2+ + + + + + FreeCAD + + + FreeCAD/src/Mod/Draft/Resources/icons/Draft_Grid.svg + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + [agryson] Alexander Gryson + + + + + grid + lines + intersecting + + + Six mutually intersecting lines forming a grid + + + + diff --git a/localwiki/Draft_Heal.html b/localwiki/Draft_Heal.html new file mode 100644 index 0000000..80a86de --- /dev/null +++ b/localwiki/Draft_Heal.html @@ -0,0 +1,66 @@ +Draft Heal

      Draft Heal

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Draft Heal.png Draft Heal

      +
      Menu location +
      Draft → Utilities → Heal +
      Workbenches +
      Draft, Arch +
      Default shortcut +
      None +
      See also +
      None +

      + +
      +


      +

      +

      Description

      +

      Because of the fast evolution of FreeCAD, some object definitions might change over time and between versions, causing some Draft objects found in older files to not load properly or contain errors when opened with a more recent version of FreeCAD. This command tries to fix those bad objects by recreating a new one from scratch, then copying the contents of the properties from the old one to the new one. It can be run with objects selected, in which case it will only look at the selected objects, or with no object selected. All the objects of the current document will then be scanned for errors. If no error is found, this command will do nothing. +

      This command can only heal Draft objects. +

      +

      How to use

      +
      1. Select one or more problematic objects to heal, or nothing to scan the whole document
      2. +
      3. Press the Draft Heal.png Heal button
      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Draft_Heal.svg b/localwiki/Draft_Heal.svg new file mode 100644 index 0000000..af36528 --- /dev/null +++ b/localwiki/Draft_Heal.svg @@ -0,0 +1,302 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + Draft_Heal + + Wed Mar 6 12:14:14 2013 -0300 + + + [Yorik van Havre] + + + + + FreeCAD LGPL2+ + + + + + FreeCAD + + + FreeCAD/src/Mod/Draft/Resources/icons/Draft_Heal.svg + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + [agryson] Alexander Gryson + + + + + red cross + cross + circle + + + A red cross similar to a medical red cross on a white circle + + + + diff --git a/localwiki/Draft_Intersection.html b/localwiki/Draft_Intersection.html new file mode 100644 index 0000000..46b29b7 --- /dev/null +++ b/localwiki/Draft_Intersection.html @@ -0,0 +1,88 @@ +Draft Intersection

      Draft Intersection

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Draft Intersection.png Draft Intersection

      +
      Menu location +
      Draft → Snap → Intersection +
      Workbenches +
      Draft, Arch +
      Default shortcut +
      +
      See also +
      +

      + +
      +


      +

      +

      Description

      +

      This snap mode lets you select the the intersection of 2 line or arc segments. +


      +

      +

      Use

      +
      1. Make sure snap mode is turned on
      2. +
      3. Choose element to be inserted into the FreeCAD-document
      +

      On Linux +

      +
      1. Move cursor near the Intersection of the elements you wish to attach your element to
      2. +
      3. Below on the right side of the cursor the symbol of the snap mode will appear
      4. +
      5. Click to attach your element to the selected intersection point of target elements
      +

      On Windows +

      +
      1. Press CTRL and move mouse near to intersection
      2. +
      3. Below on the right side of the cursor the symbol of the snap mode will appear
      4. +
      5. Click to attach your element to the selected intersection point of target elements
      +

      Works also with Draft Move and Draft Rotate +


      +

      +

      Notes

      +

      Snap mode can be used with +

      +
      • sketcher elements (lines)
      • +
      • draft elements (DWires, Lines)
      +

      Clicking on the snap-mode icon will toggle the snap mode on/off. +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Draft_Label.html b/localwiki/Draft_Label.html new file mode 100644 index 0000000..e1cbccd --- /dev/null +++ b/localwiki/Draft_Label.html @@ -0,0 +1,114 @@ +Draft Label

      Draft Label

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Draft Label.png Draft Label

      +
      Menu location +
      Draft → Label +
      Workbenches +
      Draft, Arch +
      Default shortcut +
      D L +
      See also +
      None +

      + +
      +


      +

      +

      Description

      +

      This tool inserts a label, which is a piece of text with a 2-segment line and an arrow, in the active document. If an object or a sub-element (face, edge or vertex) is selected when starting the command, the Label can be made to automatically display a certain attribute of the selected element. +

      Draft Label example.jpg +

      +

      How to use

      +
      1. Optionally, select an object or a subelement of an object (Vertex, edge or face)
      2. +
      3. Press the Draft Label.png Draft Label button, or press D then L keys
      4. +
      5. Click a first point on the 3D view, or type a coordinate, to indicate the target point (arrow position). This can be anywhere, it doesn't need to be exactly on the selected element
      6. +
      7. Click a second point on the 3D view, or type a coordinate, to indicate the middle point that is the start of the straight segment.
      8. +
      9. Click a third point on the 3D view, or type a coordinate, to indicate the position of the text.
      +

      Options

      +
      • Pressing CTRL will snap your point to available snap locations.
      • +
      • To enter coordinates manually, simply enter the numbers, then press ENTER between each X, Y and Z component.
      • +
      • Pressing ESC will cancel the operation.
      • +
      • The direction of the straight segment (right or left) will automatically justify the text left or right.
      +

      Properties

      +
      • DATALabel Type: The type of information shown by this label (see below)
      • +
      • DATACustom Text: The text to display when Label Type is set to custom
      • +
      • DATAPlacement: Indicates the rotation and the position of the text
      • +
      • DATAStraight Distance: The length of the straight segment
      • +
      • DATAStraight Direction: The direction of the straight segment Horizontal or vertical
      • +
      • DATATarget Point: The point indicated by this label
      • +
      • VIEWText Size: The size of the text
      • +
      • VIEWText Font: The font used for the text
      • +
      • VIEWText Alignment: The vertical alignment of the text: Top, middle or bottom
      • +
      • VIEWText Color: The color of the text
      • +
      • VIEWLine Width: The width of the line
      • +
      • VIEWLine Color: The color of the line
      • +
      • VIEWArrow Type: The type of the arrow: Dot, circle, arrow or tick.
      • +
      • VIEWArrow Size: The size of the arrow
      • +
      • VIEWFrame: Draws a frame around the text
      +

      Label types

      +
      • Custom: Shows the contents of the Custom Text property
      • +
      • Name: Shows the name of the target object
      • +
      • Label: Shows the label of the target object
      • +
      • Position: Shows the coordinates of the target object (Placement base point), or the coordinates of the target vertex, if applicable, or the coordinates of the center of the target subelement (center of mass)
      • +
      • Length: Shows the length of the target subelement, if possible
      • +
      • Area: Shows the area of the target subelement, if possible
      • +
      • Volume: Shows the volume of the target object, if possible
      • +
      • Tag: Shows the tag value of the target object, if the target object has such property (which is the case of all Arch objects)
      • +
      • Material: Shows the label of the material of the target object, if the target object has such property
      +

      Scripting

      +

      The Text tool can by used in macros and from the python console by using the following function: +

      +
      makeLabel(targetpoint=None,target=None,direction=None,distance=None,labeltype=None,placement=None) 
      +
      • Returns the newly created object.
      +

      Example: +

      +
      import FreeCAD,Draft
      +selection = FreeCADGui.Selection.getSelectionEx()[0]
      +Draft.makeLabel(FreeCAD.Vector(10,-10,0),selection,"Horizontal",20,"Label") 
      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Draft_Label.svg b/localwiki/Draft_Label.svg new file mode 100644 index 0000000..e5c88df --- /dev/null +++ b/localwiki/Draft_Label.svg @@ -0,0 +1,179 @@ + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + + + + + + + + + + + diff --git a/localwiki/Draft_Line.html b/localwiki/Draft_Line.html new file mode 100644 index 0000000..b2086b4 --- /dev/null +++ b/localwiki/Draft_Line.html @@ -0,0 +1,96 @@ +Draft Line

      Draft Line

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Draft Line.png Draft Line

      +
      Menu location +
      Draft → Line +
      Workbenches +
      Draft, Arch +
      Default shortcut +
      L I +
      See also +
      Draft Wire +

      + +
      +


      +

      +

      Description

      +

      The Line tool creates a straight, two-points line in the current work plane. It takes the linewidth and color previously set on the Tasks tab. The Line tool behaves exactly like the Draft Wire tool, except that it stops after two points. +

      Draft Line example.jpg +

      +

      How to use

      +
      1. Press the Draft Line.png Draft Line button, or press L then I keys
      2. +
      3. Click a first point on the 3D view, or type a coordinate
      4. +
      5. Click a second point on the 3D view, or type a coordinate
      +

      Options

      +
      • Press X, Y or Z after the first point to constrain the second point on the given axis.
      • +
      • To enter coordinates manually, simply enter the numbers, then press ENTER between each X, Y and Z component.
      • +
      • Press R or click the checkbox to check/uncheck the Relative button. If relative mode is on, the coordinates of the second point are relative to the first one. If not, they are absolute, taken from the (0,0,0) origin point.
      • +
      • Press T or click the checkbox to check/uncheck the Continue button. If continue mode is on, the Line tool will restart after you give the second point, allowing you to draw another line segment without pressing the Line button again.
      • +
      • Press CTRL while drawing to force snapping your point to the nearest snap location, independently of the distance.
      • +
      • Press SHIFT while drawing to constrain your second point horizontally or vertically in relation to the first one.
      • +
      • Press CTRL+Z or press the Draft UndoLine.png Undo button to undo the last point.
      • +
      • Press ESC or the Cancel button to abort the current Line command.
      • +
      • If several connected Draft Lines are selected they can be transformed into a wire by pressing the Draft Upgrade Button.
      +

      Properties

      +
      • DATAStart: The start point
      • +
      • DATAEnd: The end point
      • +
      • DATASubdivisions: Divides the line with the given number of subdivisions available in version 0.16
      +


      +

      +

      Scripting

      +

      The Line tool can by used in macros and from the python console by using the following function: +

      +
      makeLine (Vector, Vector) 
      +
      • Creates a line between the two given vectors. The current draft linewidth and color will be used.
      • +
      • Returns the newly created object.
      +

      Example: +

      +
      import FreeCAD, Draft
      +Draft.makeLine(FreeCAD.Vector(0,0,0),FreeCAD.Vector(2,0,0)) 
      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Draft_Line.png b/localwiki/Draft_Line.png new file mode 100644 index 0000000..fc425ba Binary files /dev/null and b/localwiki/Draft_Line.png differ diff --git a/localwiki/Draft_Line.svg b/localwiki/Draft_Line.svg new file mode 100644 index 0000000..19e473d --- /dev/null +++ b/localwiki/Draft_Line.svg @@ -0,0 +1,198 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + Draft_Line + + Mon Oct 10 13:44:52 2011 +0000 + + + [wmayer] + + + + + FreeCAD LGPL2+ + + + + + FreeCAD + + + FreeCAD/src/Mod/Draft/Resources/icons/Draft_Line.svg + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + [agryson] Alexander Gryson + + + + + dot + line + + + A line at an angle from lower left to upper right with a dot at each end + + + + diff --git a/localwiki/Draft_Linestyle.html b/localwiki/Draft_Linestyle.html new file mode 100644 index 0000000..c7ceac9 --- /dev/null +++ b/localwiki/Draft_Linestyle.html @@ -0,0 +1,31 @@ +Draft Linestyle

      Draft Linestyle

      + +

      The line color and line width of Draft objects (and any other FreeCAD object) can easily be changed in the Draft module. +

      Draft-linestyle.jpg +

      On the Command bar , a series of buttons displayed, including three for lines : Draft Style 01.png +
      +Draft Style Couleur Ligne.png Gives color to the line (edge).
      +Draft Style Couleur Face.png Gives background color (face) to the form.
      +Draft Style Epaisseur Ligne.png Gives the thickness line (edge).
      +Draft Style Style.png Gives all the parameters of style bjects selected. +


      +On the Draft command bar, you will see three buttons: a linewidth setting, a linecolor button, and an "apply" button. If objects are selected when you change those values, they will receive automatically the new values. If no object is selected, the changes you make will apply to objects you will create later. At any moment, you can hit the "apply" button to apply current settings to selected objects. You can also do that from the tree's context menu. If a group is selected, the settings will be applied to all objects in the group. +

      If you would like to change the face color of filled objects, you can do it via the properties window. +

      See also Draft Apply Draft Apply.png. +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Draft_Lock.svg b/localwiki/Draft_Lock.svg new file mode 100644 index 0000000..1b4ba5c --- /dev/null +++ b/localwiki/Draft_Lock.svg @@ -0,0 +1,600 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + Draft_Lock + + Mon Oct 10 13:44:52 2011 +0000 + + + [wmayer] + + + + + FreeCAD LGPL2+ + + + + + FreeCAD + + + FreeCAD/src/Mod/Draft/Resources/icons/Draft_Lock.svg + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + [agryson] Alexander Gryson + + + + + dot + line + lock + circle + square + + + An square or diamond shape with a dot at each of its three leftmost corners and a largerdot or circle on the rightmost corner containing a lock symbol + + + + diff --git a/localwiki/Draft_Macro.svg b/localwiki/Draft_Macro.svg new file mode 100644 index 0000000..2e8eba0 --- /dev/null +++ b/localwiki/Draft_Macro.svg @@ -0,0 +1,437 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + Draft_Macro + + Mon Oct 10 13:44:52 2011 +0000 + + + [wmayer] + + + + + FreeCAD LGPL2+ + + + + + FreeCAD + + + FreeCAD/src/Mod/Draft/Resources/icons/Draft_Macro.svg + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + [agryson] Alexander Gryson + + + + + flower + macro + + + A two leaved flower, similar in form to a tulip + + + + diff --git a/localwiki/Draft_Midpoint.html b/localwiki/Draft_Midpoint.html new file mode 100644 index 0000000..8ae34c7 --- /dev/null +++ b/localwiki/Draft_Midpoint.html @@ -0,0 +1,85 @@ +Draft Midpoint

      Draft Midpoint

      + +


      +

      + + + + + + + + + + + + + + + + + + + + +
      +

      Draft Midpoint.png Draft Midpoint

      +
      Menu location +
      Draft → Snap → Midpoint +
      Workbenches +
      Draft, Arch +
      Default shortcut +
      +
      See also +
      +

      + +
      +


      +


      +

      +

      Description

      +

      This snap mode lets you select the midpoint of elements. +


      +

      +

      Use

      +
      1. Make sure snap mode is turned on
      2. +
      3. Choose element to be inserted into the FreeCAD-document
      4. +
      5. Move cursor near the midpoint of the element you wish to attach your element to
      6. +
      7. below on the right side of the cursor the symbol of the snap mode will appear
      8. +
      9. click to attach your element to the selected endpoint of target element
      +


      +

      +

      Notes

      +

      Snap mode can be used with +

      +
      • sketcher elements (lines, arcs)
      • +
      • draft elements (DWires, Lines, Arcs)
      • +
      • edges of shapes
      • +
      • edges of solids
      +

      Clicking on the snap-mode icon will toggle the snap mode on/off. +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Draft_Mirror.html b/localwiki/Draft_Mirror.html new file mode 100644 index 0000000..6dacdc1 --- /dev/null +++ b/localwiki/Draft_Mirror.html @@ -0,0 +1,90 @@ +Draft Mirror

      Draft Mirror

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Draft Mirror.png Draft Mirror

      +
      Menu location +
      Draft → Mirror +
      Workbenches +
      Draft, Arch +
      Default shortcut +
      None +
      See also +
      Draft Scale +

      + +
      +


      +

      +

      Description

      +

      This tool produces a mirrored copy of a selected object, using a Part Mirror object. The copy is parametrically bound to the original object: If the original object changes, the mirrored copy changes too, but keeps mirrored. +

      Draft Mirror example.jpg +

      +

      How to use

      +
      1. Select objects you wish to mirror
      2. +
      3. Press the Draft Mirror.png Draft Mirror button
      4. +
      5. Click the first point of the mirror line on the 3D view, or type a coordinate
      6. +
      7. Click the other point of the mirror line on the 3D view, or type a coordinate
      +

      Properties

      +
      • DATABase: The base point of the mirror plane
      • +
      • DATANormal: The normal direction of the mirror plane
      +

      Options

      + +

      Scripting

      +

      The Clone tool can by used in macros and from the python console by using the following function: +

      +
      mirror (objectslist,p1,p2) 
      +
      • Makes mirror(s) of the given object(s) across a plane defined by a line from p1 to p2, and parallel to the current view
      • +
      • The result is a Part Mirror object
      • +
      • If the original object changes, the final object changes too but keeps mirrored
      +

      Example: +

      +
      import Draft,FeeCAD
      +p1 = FreeCAD.Vector(0,0,0)
      +p2 = FreeCAD.Vector(2,2,0)
      +Draft.mirror(FreeCAD.ActiveDocument.ActiveObject,p1,p2) 
      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Draft_Mirror.svg b/localwiki/Draft_Mirror.svg new file mode 100644 index 0000000..7d35df5 --- /dev/null +++ b/localwiki/Draft_Mirror.svg @@ -0,0 +1,446 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + Draft_Mirror + + Sat Dec 5 14:19:35 2015 -0200 + + + [Yorik van Havre] + + + + + FreeCAD LGPL2+ + + + + + FreeCAD + + + FreeCAD/src/Mod/Draft/Resources/icons/Draft_Mirror.svg + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + [agryson] Alexander Gryson + + + + + mirror + triangle + dotted + + + A right angled triangle on the left, with a line in the middle and the mirrored form of the triangle on the right + + + + diff --git a/localwiki/Draft_Module.html b/localwiki/Draft_Module.html new file mode 100644 index 0000000..14d25e1 --- /dev/null +++ b/localwiki/Draft_Module.html @@ -0,0 +1,121 @@ +Draft Module

      Draft Module

      + +

      The Draft workbench allows to quickly draw simple 2D objects in the current document, and offers several tools to modify them afterwards. Some of these tools also work on all other FreeCAD objects, not only those created with the Draft workbench. It also provides a complete snapping system, and several utilities to manage objects and settings. +

      + + +

      Drawing objects

      +

      These are tools for creating objects. +

      +
      • Draft Line.png Line: Draws a line segment between 2 points
      • +
      • Draft Wire.png Wire: Draws a line made of multiple line segments (polyline)
      • +
      • Draft Circle.png Circle: Draws a circle from center and radius
      • +
      • Draft Arc.png Arc: Draws an arc segment from center, radius, start angle and end angle
      • +
      • Draft Ellipse.png Ellipse: Draws an ellipse from two corner points
      • +
      • Draft Polygon.png Polygon: Draws a regular polygon from a center and a radius
      • +
      • Draft Rectangle.png Rectangle: Draws a rectangle from 2 opposite points
      • +
      • Draft Text.png Text: Draws a multi-line text annotation
      • +
      • Draft Dimension.png Dimension: Draws a dimension annotation
      • +
      • Draft BSpline.png BSpline: Draws a B-Spline from a series of points
      • +
      • Draft Point.png Point: Inserts a point object
      • +
      • Draft ShapeString.png ShapeString: The ShapeString tool inserts a compound shape representing a text string at a given point in the current document
      • +
      • Draft Facebinder.png Facebinder: Creates a new object from selected faces on existing objects
      • +
      • Draft BezCurve.png Bezier Curve: Draws a Bezier curve from a series of points
      • +
      • Draft Label.png Label: Places a label with an arrow pointing to a selected element available in version 0.17
      +

      Modifying objects

      +

      These are tools for modifying existing objects. They work on selected objects, but if no object is selected, you will be invited to select one. +

      +
      • Draft Move.png Move: Moves object(s) from one location to another
      • +
      • Draft Rotate.png Rotate: Rotates object(s) from a start angle to an end angle
      • +
      • Draft Offset.png Offset: Moves segments of an object about a certain distance
      • +
      • Draft Trimex.png Trim/Extend (Trimex): Trims or extends an object
      • +
      • Draft Upgrade.png Upgrade: Joins objects into a higher-level object
      • +
      • Draft Downgrade.png Downgrade: Explodes objects into lower-level objects
      • +
      • Draft Scale.png Scale: Scales selected object(s) around a base point
      • +
      • Draft PutOnSheet.png Drawing: Writes selected objects to a Drawing sheet
      • +
      • Draft Edit.png Edit: Edits a selected object
      • +
      • Draft WireToBSpline.png Wire to BSpline: Converts a wire to a BSpline and vice-versa
      • +
      • Draft AddPoint.png Add point: Adds a point to a wire or BSpline
      • +
      • Draft DelPoint.png Delete point: Deletes a point from a wire or BSpline
      • +
      • Draft Shape2DView.png Shape 2D View: Creates a 2D object which is a flattened 2D view of another 3D object
      • +
      • Draft Draft2Sketch.png Draft to Sketch: Converts a Draft object to Sketch and vice-versa
      • +
      • Draft Array.png Array: Creates a polar or rectangular array from selected objects
      • +
      • Draft PathArray.png Path Array: Creates an array of objects by placing the copies along a path
      • +
      • Draft Clone.png Clone: Clones the selected objects
      • +
      • Draft Mirror.png Mirror: Mirrors the selected objects
      • +
      • Draft Stretch.png Stretch: Stretches the selected objects available in version 0.17
      +

      Utility tools

      +

      Additional tools available via right-click context menu, depending on the selected objects. +

      + + + + +

      Preferences

      + +

      File formats

      +

      The Draft module provides FreeCAD with importers and exporters for the following file formats: +

      + + +

      Additional features

      +
      • Snapping: Allows to place new points on special places on existing objects
      • +
      • Constraining: Allows to place new points horizontally or vertically in relation to previous points
      • +
      • Working with manual coordinates: Allows to enter manual coordinates instead of clicking on screen
      • +
      • Working plane: Allows you to define a plane in the 3D space, where next operations will take place
      +

      Scripting

      +

      The Draft module features a complete Draft API so you can use its functions in scripts and macros +

      +

      Tutorials

      + + +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Draft_Move.html b/localwiki/Draft_Move.html new file mode 100644 index 0000000..c49fb08 --- /dev/null +++ b/localwiki/Draft_Move.html @@ -0,0 +1,124 @@ +Draft Move

      Draft Move

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Draft Move.png Draft Move

      +
      Menu location +
      Draft → Move +
      Workbenches +
      Draft, Arch +
      Default shortcut +
      M V +
      See also +
      None +

      + +
      +


      +

      +

      Description

      +

      The Move tool moves or copies the selected objects from one point to another on the current work plane. If no object is selected, you will be invited to select one. +

      Draft Move example.jpg +

      +

      How to use

      +
      1. Select objects you wish to move or copy
      2. +
      3. Press the Draft Move.png Draft Move button, or press M then V keys
      4. +
      5. Click a first point on the 3D view, or type a coordinate
      6. +
      7. Click another point on the 3D view, or type a coordinate
      +

      Snapping, Constraining, and more

      +

      Preferences

      +

      Moving object around in 3D can be dreadful, and is most likely not what you want. FreeCAD comes with a lot more power to move object around, but first you must check your preferences to see how to activate those commands. +

      Go to Edit -> Preferences -> DRAFT, then open the Grid and snapping tab. +

      You will see there several options: +

      Pref Draft Snapping.png +

      By default the option "Always snap (disable snap mod)" is activated, which means that the snapping tools will always be active (you don't need to press a key to activate them), note here what keys are assigned to activate the different modes, by default: +

      +
      • SHIFT activate the Constrain mode (move along an axis vector only)
      • +
      • Ctl activate the SNAP mode (cursor will snap on specific points)
      • +
      • Alt activate the ALT
      +

      Moving along a specific axis

      +

      In order to move along a specific axis, you must first select a working plane containing this axis (see the selecting working plane page for more information). +

      After selecting the first point to move, start to move roughly in the axis direction and hold the SHIFT key. FreeCAD will automatically find which axis you are trying to follow and stick to this axis. +

      (This tool is especially powerful if you want to align a point to another one, regarding to an axis only). +

      More on constrain move here +

      +

      Snapping

      +

      If you have a point that you want to directly match on a solid, you can use snapping see the snapping page on how to activate the snap. Select the first point (using snap or not), and then hover to the second point until you see it highlighted. +

      By default the snapping mode is activated, but you may have it deactivated in the preferences (see preceding section), in that case, you will have to hold the Snapping key Ctrl by default. +

      +

      Alt Mode

      +

      Alt mode allows you to copy and object instead of moving it only. +

      +

      Options

      +
      • Press X, Y or Z after a point to constrain the next point on the given axis.
      • +
      • To enter coordinates manually, simply enter the numbers, then press ENTER between each X, Y and Z component.
      • +
      • Press R or click the checkbox to check/uncheck the Relative button. If relative mode is on, the coordinates of the next point are relative to the last one. If not, they are absolute, taken from the (0,0,0) origin point.
      • +
      • Press T or click the checkbox to check/uncheck the Continue button. If continue mode is on, the Move tool will restart after you finish or close it, allowing you to move or copy the objects another time without pressing the Move button again.
      • +
      • Pressing ALT or C or clicking the Copy button will make a copy of the objects, instead of moving them. If you keep ALT pressed after clicking the second point, you will be able to place more copies, until you release the ALT key.
      • +
      • Press CTRL while drawing to force snapping your point to the nearest snap location, independently of the distance.
      • +
      • Press SHIFT while drawing to constrain your next point horizontally or vertically in relation to the last one.
      • +
      • Press ESC or the Cancel button to abort the current command.
      +

      Scripting

      +

      The Move tool can by used in macros and from the python console by using the following function: +

      +
      move (FreeCAD.Object or list, Vector, [copymode]) 
      +
      • Moves the given object or the objects contained in the given list in the direction and distance indicated by the given vector.
      • +
      • If copymode is True, the actual objects are not moved, but copies are created instead. Returns the object(s) (or their copies if copymode was True)
      • +
      • A list of the moved object (or the copies) is returned
      +

      Example: +

      +
      import FreeCAD,Draft
      +Draft.move(FreeCAD.ActiveDocument.ActiveObject,FreeCAD.Vector(2,2,0)) 
      +

      Limitations

      +
      • When moving (or changing Placement of) a document object (eg: Pad, Revolution, etc) which is based on a Sketch (from Sketcher/Part Design), you must move the original sketch. If you move the derived object, it will just go back to the position defined by the sketch.
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Draft_Move.png b/localwiki/Draft_Move.png new file mode 100644 index 0000000..cbda031 Binary files /dev/null and b/localwiki/Draft_Move.png differ diff --git a/localwiki/Draft_Move.svg b/localwiki/Draft_Move.svg new file mode 100644 index 0000000..aad4d79 --- /dev/null +++ b/localwiki/Draft_Move.svg @@ -0,0 +1,369 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + Draft_Move + + Mon Oct 10 13:44:52 2011 +0000 + + + [wmayer] + + + + + FreeCAD LGPL2+ + + + + + FreeCAD + + + FreeCAD/src/Mod/Draft/Resources/icons/Draft_Move.svg + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + [agryson] Alexander Gryson + + + + + arrow + move + arrows + compass + cross + + + Four equally sized arrow heads at 90° to eachother, all joined at the tail + + + + diff --git a/localwiki/Draft_Near.html b/localwiki/Draft_Near.html new file mode 100644 index 0000000..8c06a63 --- /dev/null +++ b/localwiki/Draft_Near.html @@ -0,0 +1,74 @@ +Draft Near

      Draft Near

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Draft Near.png Draft Near

      +
      Menu location +
      Draft → Snap → Near +
      Workbenches +
      Draft, Arch +
      Default shortcut +
      +
      See also +
      +

      + +
      +


      +

      +

      Description

      +

      Snaps to the closest point on the nearest object. +

      +

      Use

      +
      1. Make sure snap mode is turned on
      2. +
      3. Choose element to be inserted into the FreeCAD-document
      4. +
      5. Move cursor near the object you wish to attach your element to
      6. +
      7. A small yellow circle will indicate where you element will be attached to the target element
      8. +
      9. Click to attach your element to the target element
      +

      Will also work with Draft Move and Draft Rotate. +

      +

      Notes

      +

      Snap mode will detect any snap possibilities of the other basic snap modes or just attach to the nearest point on the target. +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Draft_OCA.html b/localwiki/Draft_OCA.html new file mode 100644 index 0000000..5e75977 --- /dev/null +++ b/localwiki/Draft_OCA.html @@ -0,0 +1,47 @@ +Draft OCA

      Draft OCA

      + +
      + +

      Opening

      +

      This function imports OCA/GCAD files. The OCA file format is community effort to create a free, simple and open CAD file format. OCA is largely based on the GCAD file format generated from gCAD3D. Both formats can be imported in FreeCAD, and the OCA files exported by FreeCAD can be opened in gCAD3D. +

      The following OCA objects get imported at the moment: +

      +
      • Lines
      • +
      • Arcs and Circles
      • +
      • Closed areas
      +

      Importing

      +

      Works the same way as opening but creates the objects in the active document instead of creating a new one. +

      +

      Exporting

      +

      Objects that can be exported at the moment: +

      +
      • Lines and wires (polylines)
      • +
      • Arcs and circles
      • +
      • Faces
      +

      Preferences

      +

      The following parameters can be specified in the Draft Preferences tab (menu Edit -> Preferences -> Draft): +

      +
      • Import closed areas or not
      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Draft_Offset.html b/localwiki/Draft_Offset.html new file mode 100644 index 0000000..458cbdb --- /dev/null +++ b/localwiki/Draft_Offset.html @@ -0,0 +1,87 @@ +Draft Offset

      Draft Offset

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Draft Offset.png Draft Offset

      +
      Menu location +
      Draft → Offset +
      Workbenches +
      Draft, Arch +
      Default shortcut +
      O S +
      See also +
      Part 2D Offset +

      + +
      +


      +

      +

      Description

      +

      The Offset tool offsets the selected object by a given distance on the current work plane. If no object is selected, you will be invited to select one. +

      Draft Offset example.jpg +

      +

      How to use

      +
      1. Select objects you wish to offset
      2. +
      3. Press the Draft Offset.png Draft Offset button, or press O then S keys
      4. +
      5. Click a point on the 3D view, or type a distance.
      +

      Options

      +
      • Press T or click the checkbox to check/uncheck the Continue button. If continue mode is on, the Offset tool will restart after you finish or close it, allowing you to offset or copy the objects another time without pressing the Offset button again.
      • +
      • Pressing ALT or C or clicking the Copy button will make a copy of the objects, instead of moving them. If you keep ALT pressed after clicking the second point, you will be able to place more copies, until you release the ALT key.
      • +
      • Press CTRL while drawing to force snapping your point to the nearest snap location, independently of the distance.
      • +
      • Pressing SHIFT will constrain you to the current segment, instead of picking the closest one.
      • +
      • Press ESC or the Cancel button to abort the current command.
      +

      Scripting

      +

      The Offset tool can by used in macros and from the python console by using the following function: +

      +
      offset (object,Vector,[copymode],[bind],[sym]) 
      +
      • Offsets the given wire by applying the given Vector to its first vertex.
      • +
      • If copymode is True, another object is created, otherwise the same object gets offsetted.
      • +
      • If bind is True, and provided the wire is open, the original and the offsetted wires will be bound by their endpoints, forming a face.
      • +
      • If sym is True, the offset is made on both sides, the total width being the length of the given vector.
      • +
      • Returns the offsetted object (or its copy if copymode as True).
      +

      Example: +

      +
      import FreeCAD,Draft
      +Draft.offset(FreeCAD.ActiveDocument.ActiveObject,FreeCAD.Vector(2,2,0)) 
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Draft_Offset.svg b/localwiki/Draft_Offset.svg new file mode 100644 index 0000000..a70eb33 --- /dev/null +++ b/localwiki/Draft_Offset.svg @@ -0,0 +1,225 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + Draft_Offset + + Mon Oct 10 13:44:52 2011 +0000 + + + [wmayer] + + + + + FreeCAD LGPL2+ + + + + + FreeCAD + + + FreeCAD/src/Mod/Draft/Resources/icons/Draft_Offset.svg + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + [agryson] Alexander Gryson + + + + + offset + + + An angled and curved shape nested within a similar, but larger version of itself + + + + diff --git a/localwiki/Draft_Ortho.html b/localwiki/Draft_Ortho.html new file mode 100644 index 0000000..b60d2d7 --- /dev/null +++ b/localwiki/Draft_Ortho.html @@ -0,0 +1,67 @@ +Draft Ortho

      Draft Ortho

      + +
      +

      This documentation is not finished. Please help and contribute documentation. +

      See Draft ShapeString for good documented Command. Gui Command gives an overview over commands. And see List of Commands for other commands. +

      Go to Help FreeCAD to contribute. +

      +
      +


      +

      + + + + + + + + + + + + + + + + + + + + +
      +

      Draft Ortho.png Draft Ortho

      +
      Menu location +
      Draft → Snap → Ortho +
      Workbenches +
      Draft, Arch +
      Default shortcut +
      +
      See also +
      +

      Contents

      + +
      + +
      +


      +

      +

      Description

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Draft_Parallel.html b/localwiki/Draft_Parallel.html new file mode 100644 index 0000000..f31a5ce --- /dev/null +++ b/localwiki/Draft_Parallel.html @@ -0,0 +1,85 @@ +Draft Parallel

      Draft Parallel

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Draft Parallel.png Draft Parallel

      +
      Menu location +
      Draft → Snap → Parallel +
      Workbenches +
      Draft, Arch +
      Default shortcut +
      +
      See also +
      +

      + +
      +


      +

      +

      Description

      +

      This snap mode lets you select a point on an imaginary line parallel to a line segment. +

      +

      Use

      +
      1. Make sure snap mode is turned on
      2. +
      3. Choose element to be inserted into the FreeCAD-document
      +

      On Linux +

      +
      1. Move cursor over the desired object to activate its parallel snap
      2. +
      3. Move cursor until below on the right side of the cursor the symbol of the snap mode will appear
      4. +
      5. Click to place your element parallel to selected object
      +

      On WIndows +

      +
      1. Press CTRL and move cursor over the desired object to activate its parallel snap
      2. +
      3. Move cursor until below on the right side of the cursor the symbol of the snap mode will appear
      4. +
      5. Click to place your element parallel to selected object
      +

      Works also with Draft Move and Draft Rotate +

      +

      Notes

      +

      Snap mode can be used with +

      +
      • sketcher elements (lines, arcs)
      • +
      • draft elements (DWires, Lines, Arcs)
      +

      Clicking on the snap-mode icon will toggle the snap mode on/off. +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Draft_PathArray.html b/localwiki/Draft_PathArray.html new file mode 100644 index 0000000..9f1da8f --- /dev/null +++ b/localwiki/Draft_PathArray.html @@ -0,0 +1,131 @@ +Draft PathArray

      Draft PathArray

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Draft PathArray.png Draft PathArray

      +
      Menu location +
      Draft → PathArray +
      Workbenches +
      Draft, Arch +
      Default shortcut +
      None +
      See also +
      Draft Array +

      + +
      +


      +

      +

      Description

      +

      The PathArray tool places copies of a selected shape along a selected path. The path can be a Wire or one or more Edges. The shapes can optionally be aligned with the tangent of the path. If required, a translation Vector can be specified to shift the shapes so the centroid is on the path. If no objects are selected, you will be invited to select them. +

      Draft PathArray Example.png +

      +

      How to use

      +
      1. Select a shape object you wish to distribute.
      2. +
      3. Select a path object along which the shapes will be distributed. -or-
      4. +
      5. Select some edges of a path object.
      6. +
      7. Press the Draft PathArray.png Draft PathArray button.
      +

      Options

      +
      • The array starts with shape copies which are not aligned to the path, nor translated to a new position by default. You can then change the count, alignment and/or translation vector in the properties.
      +

      Properties

      +
      • DATABase: The shape object
      • +
      • DATAPathObj: The path object
      • +
      • DATAPathSubs: The subelements(edges) of path object to be used as the path
      • +
      • DATACount: The number of time to copy the shape
      • +
      • DATAXlate: The translation vector
      • +
      • DATAAlign: True to align the shapes to the path, False to leave shapes in their default orientation.
      +

      Scripting

      +

      The PathArray tool can by used in macros and from the python console by using the following function: +

      +
      makePathArray(shapeobject,pathobject,count,[translationvector],[alignment],[listofpathsubelements]) 
      +
      • Distribute count copies of a document shapeobject along a pathobject or subobjects of a pathobject. Optionally translates each copy by FreeCAD.Vector xlate direction and distance to adjust for difference in shape centre vs shape reference point. Optionally aligns baseobject to tangent/normal/binormal of path.
      +

      Example: +

      +
      import FreeCAD,Draft
      +Draft.makePathArray(base,path,items,centretrans,orient,pathsubs) 
      +

      Usage Notes

      +
      • Align + Xlate: When Align is True, the Xlate vector is relative to the local (tangent/normal/binormal) coordinates. When Align is False, the Xlate vector is relative to the global (XYZ) coordinates.
      +

      Limitations

      +
      • This tool is not available before version 0.14
      • +
      • The PathSubs Property does not yet appear in the properties list.
      +

      Technical Explanation

      +

      When "Align = false", PathArray's logic is quite easy to understand. +

      +
      Align false
      +
      +


      +When "Align = true" the logic is a bit harder to grasp: +

      +
      1. Construct Frenet coordinate systems on the path (X is tangent, Z is normal, Y is binormal).
      2. +
      3. Copy the original object to every on-path coordinate system, so that the global origin is matched with the on-path coordinate system origin.
      +
      Patharray alignment annotated.png
      +
      +


      +It is much easier to understand with pictures. The following images show how the array is produced, depending on which plane is the path. +

      +
      XY Plane
      +
      +

      Path on XY Plane +
      +

      +
      XZ Plane
      +
      +

      Path on XZ Plane +
      +

      +
      YZ Plane
      +
      +

      Path on YZ Plane +
      +

      +
      +


      +The clear advantage of this logic is that as you reorient the path but not the object, the result is consistent - object remains aligned to the path the way it was before reorienting the path. +

      (Thanks to @DeepSOIC for this explanation) +

      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Draft_PathArray.svg b/localwiki/Draft_PathArray.svg new file mode 100644 index 0000000..620d05b --- /dev/null +++ b/localwiki/Draft_PathArray.svg @@ -0,0 +1,1105 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + Draft_PathArray + + Wed Nov 27 18:41:35 2013 -0500 + + + [WandererFan] + + + + + FreeCAD LGPL2+ + + + + + FreeCAD + + + FreeCAD/src/Mod/Draft/Resources/icons/Draft_PathArray.svg + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + [agryson] Alexander Gryson + + + + + rectangle + line + path + sequence + repetition + + + Three rectangles joined by a path, one in the lower left aligned top-bottom, another in the center aligned left-right and a third aligned top-bottom in the top right corner + + + + diff --git a/localwiki/Draft_PathArray_Example.png b/localwiki/Draft_PathArray_Example.png new file mode 100644 index 0000000..fdd3dca Binary files /dev/null and b/localwiki/Draft_PathArray_Example.png differ diff --git a/localwiki/Draft_Pattern.html b/localwiki/Draft_Pattern.html new file mode 100644 index 0000000..8e26690 --- /dev/null +++ b/localwiki/Draft_Pattern.html @@ -0,0 +1,32 @@ +Draft Pattern

      Draft Pattern

      + +

      Description

      +

      All closable Draft objects, such as rectangle, circle, ellipse, wire or polygon, when closed and set to "Flat Lines" display mode, can display a hatch pattern, instead of the face color, by setting their "Pattern" property. +

      DraftPatternSample.png +

      +

      How to use

      +
      1. Select the object
      2. +
      3. In Combo View -> Data: set Make Face to true to make sure the object will have a face to set the pattern
      4. +
      5. In Combo View -> View -> Pattern: specify a hatch pattern to fill the wire with
      6. +
      7. In Combo View -> View -> Pattern Size: specify the size of the hatch pattern
      +

      Note: +

      +
      • The pattern is not visible when the item is either selected or pre-selected.
      • +
      • If you create a face with upgrade, the resulting object is not a Draft object anymore, and so patterns are not available
      • +
      • The Draft Wire can be closed and turned into a face directly when created, by checking the "Filled" checkbox.
      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Draft_Perpendicular.html b/localwiki/Draft_Perpendicular.html new file mode 100644 index 0000000..e42e2bc --- /dev/null +++ b/localwiki/Draft_Perpendicular.html @@ -0,0 +1,59 @@ +Draft Perpendicular

      Draft Perpendicular

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Draft Perpendicular.png Draft Perpendicular

      +
      Menu location +
      Draft → Snap → Perpendicular +
      Workbenches +
      Draft, Arch +
      Default shortcut +
      +
      See also +
      +

      + +
      +


      +

      +

      Description

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Draft_Point.html b/localwiki/Draft_Point.html new file mode 100644 index 0000000..2a46383 --- /dev/null +++ b/localwiki/Draft_Point.html @@ -0,0 +1,85 @@ +Draft Point

      Draft Point

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Draft Point.png Draft Point

      +
      Menu location +
      Draft → Point +
      Workbenches +
      Draft, Arch +
      Default shortcut +
      P T +
      See also +
      None +

      + +
      +


      +

      +

      Description

      +

      The Point tool creates a simple point in the current work plane, handy to serve as reference for placing other objects later. It takes the color previously set on the Tasks tab. +

      Draft point example.jpg +

      +

      How to use

      +
      1. Press the Draft Point.png Draft Point button, or press P then T keys
      2. +
      3. Click a point on the 3D view, or type a coordinate
      +

      Options

      +
      • To enter coordinates manually, simply enter the numbers, then press ENTER between each X, Y and Z component.
      • +
      • Press ESC or the Cancel button to abort the current Line command.
      +

      Properties

      +
      • DATAX: The X coordinate of the point
      • +
      • DATAY: The Y coordinate of the point
      • +
      • DATAZ: The Z coordinate of the point
      +

      Scripting

      +

      The Point tool can by used in macros and from the python console by using the following function: +

      +
      makePoint([x],[y],[z]) 
      +
      • makes a point at the given coordinates. If no X, Y and Z coordinates are given, the point is created at (0,0,0). Returns the newly created object.
      +

      Example: +

      +
      import Draft
      +Draft.makePoint(6,4,2) 
      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Draft_Point.png b/localwiki/Draft_Point.png new file mode 100644 index 0000000..51216ca Binary files /dev/null and b/localwiki/Draft_Point.png differ diff --git a/localwiki/Draft_Point.svg b/localwiki/Draft_Point.svg new file mode 100644 index 0000000..fc69d90 --- /dev/null +++ b/localwiki/Draft_Point.svg @@ -0,0 +1,279 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + Draft_Point + + Sat Dec 17 15:36:02 2011 +0000 + + + [yorikvanhavre] + + + + + FreeCAD LGPL2+ + + + + + FreeCAD + + + FreeCAD/src/Mod/Draft/Resources/icons/Draft_Point.svg + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + [agryson] Alexander Gryson + + + + + dot circle + + + A dot or circle + + + + diff --git a/localwiki/Draft_Polygon.html b/localwiki/Draft_Polygon.html new file mode 100644 index 0000000..2a1dadf --- /dev/null +++ b/localwiki/Draft_Polygon.html @@ -0,0 +1,102 @@ +Draft Polygon

      Draft Polygon

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Draft Polygon.png Draft Polygon

      +
      Menu location +
      Draft → Polygon +
      Workbenches +
      Draft, Arch +
      Default shortcut +
      P G +
      See also +
      None +

      + +
      +


      +

      +

      Description

      +

      The polygon tool creates a regular polygon by picking two points, the center and a second point defining a radius. It takes the linewidth and color previously set on the Tasks tab. +

      Draft polygon example.jpg +

      +

      How to use

      +
      1. Press the Draft Polygon.png Draft Polygon button, or press P then G keys
      2. +
      3. Click a first point on the 3D view, or type a coordinate to indicate the center
      4. +
      5. Adjust the desired number of sides in the options dialog,
      6. +
      7. Click another point on the 3D view, or type a radius value to define the polygon radius. The polygon will also be a face, even if it appears as wireframe.
      +

      Options

      +
      • To enter coordinates manually, simply enter the numbers, then press ENTER between each X, Y and Z component.
      • +
      • Press T or click the checkbox to check/uncheck the Continue button. If continue mode is on, the Polygon tool will restart after you finish or close it, allowing you to draw another one without pressing the Polygon button again.
      • +
      • Press CTRL while drawing to force snapping your point to the nearest snap location, independently of the distance.
      • +
      • Press SHIFT while drawing to constrain your next point horizontally or vertically in relation to the last one.
      • +
      • Press I or the Filled button to have the polygon filled with a face after it has been closed
      • +
      • Press ESC or the Cancel button to abort the current command.
      • +
      • Polygons, when in "Flat Lines" display mode, can display a hatch pattern, by setting their "Pattern" property below.
      +

      Properties

      +
      • DATARadius: The radius of the defining circle
      • +
      • DATADraw Mode: Specifies if the polygon is inscribed or circumscribed around the defining circle
      • +
      • DATAFaces Number: The number of sides of the polygon
      • +
      • DATAChamfer Size: Specifies the size of chamfered corners
      • +
      • DATAFillet Radius: Specifies a curvature radius to give to the corners of the rectangle
      • +
      • DATAMake Face: Fills the polygon with a face
      • +
      • VIEWPattern: Specifies a hatch pattern to fill the wire with
      • +
      • VIEWPattern Size: Specifies the size of the hatch pattern
      +

      See also Draft Pattern page. +

      +

      Scripting

      +

      The Polygon tool can by used in macros and from the python console by using the following function: +

      +
      makePolygon(nfaces,[radius],[inscribed],[placement],[face]) 
      +
      • Creates a polygon object with the given number of faces and the radius.
      • +
      • If inscribed is False, the polygon is circumscribed around a circle with the given radius, otherwise it is inscribed.
      • +
      • If face is True, the resulting shape is displayed as a face, otherwise as a wireframe.
      • +
      • Returns the newly created object.
      +

      Example: +

      +
      import Draft
      +Draft.makePolygon(5,radius=3) 
      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Draft_Polygon.png b/localwiki/Draft_Polygon.png new file mode 100644 index 0000000..ae77b66 Binary files /dev/null and b/localwiki/Draft_Polygon.png differ diff --git a/localwiki/Draft_Polygon.svg b/localwiki/Draft_Polygon.svg new file mode 100644 index 0000000..02361d3 --- /dev/null +++ b/localwiki/Draft_Polygon.svg @@ -0,0 +1,245 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + Draft_Polygon + + Mon Oct 10 13:44:52 2011 +0000 + + + [wmayer] + + + + + FreeCAD LGPL2+ + + + + + FreeCAD + + + FreeCAD/src/Mod/Draft/Resources/icons/Draft_Polygon.svg + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + [agryson] Alexander Gryson + + + + + pentagon + polygon + dot + circle + + + A pentagon with a dot in the center and another on the rightmost corner + + + + diff --git a/localwiki/Draft_Preferences.html b/localwiki/Draft_Preferences.html new file mode 100644 index 0000000..bc13400 --- /dev/null +++ b/localwiki/Draft_Preferences.html @@ -0,0 +1,42 @@ +Draft Preferences

      Draft Preferences

      + +

      The preferences screen of the Draft module are found in the Preferences window (Menu Edit → Preferences). +

      It has General settings, where you can specify the color of the snap symbols, the default width and color for new objects. By checking the "Save current color and linewidth across sessions" checkbox, any change you make on the draft command bar will be saved here, so you will start your next FreeCAD session with the color and width you were using on quit. +

      + + +

      General settings

      +
      Preference Draft Tab 01.png
      +
      +

      Grid and snapping

      +
      Preference Draft Tab 02.png
      +
      +

      Visuals settings

      +
      Preference Draft Tab 03.png
      +
      +

      Texts and dimensions

      +
      Preference Draft Tab 04.png
      +
      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Draft_PutOnSheet.png b/localwiki/Draft_PutOnSheet.png new file mode 100644 index 0000000..c8549a9 Binary files /dev/null and b/localwiki/Draft_PutOnSheet.png differ diff --git a/localwiki/Draft_Rectangle.html b/localwiki/Draft_Rectangle.html new file mode 100644 index 0000000..f87d975 --- /dev/null +++ b/localwiki/Draft_Rectangle.html @@ -0,0 +1,106 @@ +Draft Rectangle

      Draft Rectangle

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Draft Rectangle.png Draft Rectangle

      +
      Menu location +
      Draft → Rectangle +
      Workbenches +
      Draft, Arch +
      Default shortcut +
      R E +
      See also +
      Part Box +

      + +
      +


      +

      +

      Description

      +

      The rectangle tool creates a rectangle by picking two opposite points. It takes the linewidth and color previously set on the Tasks tab. +

      Draft Rectangle example.jpg +

      +

      How to use

      +
      1. Press the Draft Rectangle.png Draft Rectangle button, or press R then E keys
      2. +
      3. Click a first corner point on the 3D view, or type a coordinate
      4. +
      5. Click another opposite point on the 3D view, or type a coordinate. The rectangle will also be a face, even if it appears as wireframe.
      +

      Options

      +
      • Press X, Y or Z after a point to constrain the next point on the given axis.
      • +
      • To enter coordinates manually, simply enter the numbers, then press ENTER between each X, Y and Z component.
      • +
      • Press R or click the checkbox to check/uncheck the Relative button. If relative mode is on, the coordinates of the next point are relative to the last one. If not, they are absolute, taken from the (0,0,0) origin point.
      • +
      • Press T or click the checkbox to check/uncheck the Continue button. If continue mode is on, the Rectangle tool will restart after you finish or close it, allowing you to draw another one without pressing the Rectangle button again.
      • +
      • Press CTRL while drawing to force snapping your point to the nearest snap location, independently of the distance.
      • +
      • Press SHIFT while drawing to constrain your next point horizontally or vertically in relation to the last one.
      • +
      • Press I or the Filled button to have the rectangle filled with a face after it has been closed.
      • +
      • Press ESC or the Cancel button to abort the current Line command.
      • +
      • Rectangles, when in "Flat Lines" display mode, can display a hatch pattern, by setting their "Pattern" property.
      +

      Properties

      +
      • DATALength: Specifies the length of the rectangle
      • +
      • DATAWidth: Specifies the width of the rectangle
      • +
      • DATAChamfer Size: Specifies the size of chamfered corners
      • +
      • DATAFillet Radius: Specifies a curvature radius to give to the corners of the rectangle
      • +
      • DATARows: Allows to give horizontal subdivisions to this rectangle
      • +
      • DATAColumns: Allows to give vertical subdivisions to this rectangle
      • +
      • DATAMake Face: Fills the rectangle with a face
      • +
      • VIEWTexture Image: Allows to give the path to an image file to be mapped on the rectangle. It is up to you to give the rectangle the same proportion as the image if you want to avoid distortions. Blanking this property will remove the image.
      • +
      • VIEWPattern: Specifies a hatch pattern to fill the wire with.
      • +
      • VIEWPattern Size: Specifies the size of the hatch pattern
      +

      See also Draft Pattern page. +

      +

      Scripting

      +

      The Rectangle tool can by used in macros and from the python console by using the following function: +

      +
      makeRectangle (length, width, [placement], [facemode]) 
      +
      • Creates a Rectangle object with length in X direction and height in Y direction.
      • +
      • If a placement is given, it is used.
      • +
      • If facemode is False, the rectangle is shown as a wireframe, otherwise as a face.
      • +
      • The current Draft linewidth and color will be used.
      • +
      • Returns the newly created object.
      +

      Example: +

      +
      import FreeCAD,Draft
      +Draft.makeRectangle(10,4) 
      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Draft_Rectangle.png b/localwiki/Draft_Rectangle.png new file mode 100644 index 0000000..6cedaa7 Binary files /dev/null and b/localwiki/Draft_Rectangle.png differ diff --git a/localwiki/Draft_Rectangle.svg b/localwiki/Draft_Rectangle.svg new file mode 100644 index 0000000..ff448fd --- /dev/null +++ b/localwiki/Draft_Rectangle.svg @@ -0,0 +1,212 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + Draft_Rectangle + + Mon Oct 10 13:44:52 2011 +0000 + + + [wmayer] + + + + + FreeCAD LGPL2+ + + + + + FreeCAD + + + FreeCAD/src/Mod/Draft/Resources/icons/Draft_Rectangle.svg + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + [agryson] Alexander Gryson + + + A square or rectangle with a dot or circle on the lower left and upper right corners + + + square + rectangle + dot + + + + + + diff --git a/localwiki/Draft_Rotate.html b/localwiki/Draft_Rotate.html new file mode 100644 index 0000000..4408649 --- /dev/null +++ b/localwiki/Draft_Rotate.html @@ -0,0 +1,90 @@ +Draft Rotate

      Draft Rotate

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Draft Rotate.png Draft Rotate

      +
      Menu location +
      Draft → Rotate +
      Workbenches +
      Draft, Arch +
      Default shortcut +
      R O +
      See also +
      None +

      + +
      +


      +

      +

      Description

      +

      This tool rotates or copies the selected objects by a given angle around a point on the current work plane. If no object is selected, you will be invited to select one. +

      Draft Rotate example.jpg +

      +

      How to use

      +
      1. Select objects you wish to rotate or copy
      2. +
      3. Press the Draft Rotate.png Draft Rotate button, or press R then O keys
      4. +
      5. Click a center point on the 3D view, or type a coordinate
      6. +
      7. Click a second point on the 3D view, or give a reference angle
      8. +
      9. Click a third point on the 3D view, or give a rotation angle
      +

      Options

      +
      • Press X, Y or Z after a point to constrain the next point on the given axis.
      • +
      • To enter coordinates manually, simply enter the numbers, then press ENTER between each X, Y and Z component.
      • +
      • Press T or click the checkbox to check/uncheck the Continue button. If continue mode is on, the Rotate tool will restart after you finish or close it, allowing you to rotate or copy the objects another time without pressing the Rotate button again.
      • +
      • Pressing ALT or C or clicking the Copy button will make a copy of the objects, instead of rotating them. If you keep ALT pressed after clicking the third point, you will be able to place more copies, until you release the ALT key.
      • +
      • Press CTRL while drawing to force snapping your point to the nearest snap location, independently of the distance.
      • +
      • Press SHIFT while drawing to constrain your next point horizontally or vertically in relation to the rotation center.
      • +
      • Press ESC or the Cancel button to abort the current command.
      +

      Scripting

      +

      The Rotate tool can by used in macros and from the python console by using the following function: +

      +
      rotate (FreeCAD.Object or list, angle, [center], [axis] ,[copymode]) 
      +
      • Rotates the given object or the objects contained in the given list with the given angle around the given center if provided, using axis as a rotation axis.
      • +
      • If axis is omitted, the rotation will be around the vertical Z axis.
      • +
      • If copymode is True, the actual objects are not moved, but copies are created instead.
      • +
      • Returns the objects (or their copies is copymode was True).
      +

      Example: +

      +
      import FreeCAD,Draft
      +Draft.rotate(FreeCAD.ActiveDocument.ActiveObject,45) 
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Draft_Rotate.svg b/localwiki/Draft_Rotate.svg new file mode 100644 index 0000000..5b46589 --- /dev/null +++ b/localwiki/Draft_Rotate.svg @@ -0,0 +1,170 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + Draft_Rotate + + Mon Oct 10 13:44:52 2011 +0000 + + + [wmayer] + + + + + FreeCAD LGPL2+ + + + + + FreeCAD + + + FreeCAD/src/Mod/Draft/Resources/icons/Draft_Rotate.svg + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + [agryson] Alexander Gryson + + + An arrow in a circular shape with the head curving towards the tail + + + arrow + curved + refresh + rotate + + + + + + diff --git a/localwiki/Draft_SVG.html b/localwiki/Draft_SVG.html new file mode 100644 index 0000000..e331728 --- /dev/null +++ b/localwiki/Draft_SVG.html @@ -0,0 +1,72 @@ +Draft SVG

      Draft SVG

      + +

      Screenshot inkscape.jpg +

      + + +

      Opening

      +

      This function imports SVG files as workable 2D objects, as opposed to the built-in drawing module which imports svg files as sheet drawings. +The following SVG objects get imported at the moment: +

      +
      • PATH objects
      • +
      • LINE objects
      • +
      • RECT objects
      • +
      • CIRCLE objects
      • +
      • ELLIPSE objects
      • +
      • POLYGON objects
      • +
      • POLYLINE objects
      +

      Importing

      +

      Works the same way as opening but creates the objects in the active document instead of creating a new one. +

      +

      Exporting

      +

      The following objects can be exported in an SVG file: +

      +
      • Lines and wires (polylines)
      • +
      • Arcs and circles
      • +
      • Faces
      • +
      • Texts
      • +
      • Dimensions
      +

      Keep in mind that SVG is a 2D format, so all Z information will be disregarded (all objects will be flattened). +

      +

      Preferences

      +

      The following parameters can be specified in the Draft Preferences tab (menu Edit -> Preferences -> Draft): +

      +
      • Import/Export -> Import style: This lets you choose the way objects from the svg file will be drawn in FreeCAD. You can choose between: +
        • None: this is the faster way, there is no conversion, all objects will be black with 2px width (FreeCAD default)
        • +
        • Use default color and linewidth: All imported objects will take current linewidth/color from the draft command bar
        • +
        • Original color and linewidth: Objects will keep the color and linewidth (if specified) they have in the svg file
      • +
      • Import/Export -> Export Style: +
        • Translated: All elements are translated that their coordinates are positive. This should aid display and printing. The output coordinate system is NOT cosistent between individualy exported elements.
        • +
        • Raw: The position of all elements preserved. This intended for CAM usage for example in PyCAM. Layers or Slices exported individualy will match.
      • +
      • General settings -> Internal precision level: +
        • This value is used to check if a bezier curve segment has to be considered a straight line. If you import detailed paths, like rendered text, you may want to increase this setting up to 6. If you are working with Inkscape please consider to raise the precision in the SVG file, well. (Inkscape Menu -> File -> Inkscape Preferences -> SVG Output -> Numeric Precision)
      +

      Unit Handling

      +

      When exporting, a User Unit (px) equals one millimeter. +

      When importing, the width, height and viewBox attributes are respected. All elements are scaled to their size in millimeter, which is FreeCAD internal unit. If the SVG does not contain information on its physical size, it is assumed to have 90 DPI resolution. +Using absoulte units in attributes inside the SVG should be avoided. Relative units like em,ex and % are currently not supported. +

      The SVG Editor Inkscape currently works only with 90 DPI documents. No matter which unit is selected in Inkscape. All the output has to be considered converted to 90 DPI and rounded to 6 decimal places. As FreeCAD (and the SVG standard) is agnostic to the precision of rounding done in Inkscape these values will not be rounded on input. And odd values in millimeter will remain. +If you need the SVG import not to be rounded, work on User Units (px) in Inkscape. Scaling can be done after the import to FreeCAD or by changing the width, height and viewbox attributes. +

      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Draft_Scale.html b/localwiki/Draft_Scale.html new file mode 100644 index 0000000..3f81519 --- /dev/null +++ b/localwiki/Draft_Scale.html @@ -0,0 +1,90 @@ +Draft Scale

      Draft Scale

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Draft Scale.png Draft Scale

      +
      Menu location +
      Draft → Scale +
      Workbenches +
      Draft, Arch +
      Default shortcut +
      S C +
      See also +
      Draft Clone +

      + +
      +


      +

      +

      Description

      +

      This tool scales selected object(s) around a base point. If no object is selected, you will be invited to select one. +

      Draft Scale example.jpg +

      +

      How to use

      +
      1. Select objects you wish to scale
      2. +
      3. Press the Draft Scale.png Draft Scale button, or press S then C keys
      4. +
      5. Click a first point on the 3D view, or type a coordinate to define the base point of the scaling
      6. +
      7. Another task dialog with scaling options opens. Fill in the different options, and press OK to accept
      +

      Options

      +
      • To enter base point coordinates manually, simply enter the numbers, then press ENTER between each X, Y and Z component.
      • +
      • Fill in the X, Y and Z scaling value to define the scaling.
      • +
      • Checking the "Uniform scaling" option will lock the X, Y and Z to the same value
      • +
      • The "Relative to Working Plane" option will consider X, Y and Z scaling values to be taken along he current Working Plane. Otherwise, global X, Y and Z directions are used.
      • +
      • The result of the scaling operation can be: +
        • A Draft Clone of the original objects, which doesn't modify the original objects, but allow you to change the scaling factor manually later on (works for all object types)
        • +
        • The original objects have their size modified (will only work with Draft objects or non-parametric Part shapes)
        • +
        • A scaled copy of the base objects is produced (will work for all object types, but only the copies of Draft objects will be parametric)
      +

      Scripting

      +

      The Scale tool can by used in macros and from the python console by using the following function: +

      +
      scale (objects,vector,[center,copy,legacy]) 
      +
      • Scales the objects contained in objects (that can be a list of objects or an object) of the given scale factors defined by the given vector (in X, Y and Z directions) around the given center.
      • +
      • If legacy is True, direct (old) mode is used, otherwise a parametric copy is made.
      • +
      • If copy is True, the actual objects are not moved, but copies are created instead.
      • +
      • The objects (or their copies) are returned.
      +

      Example: +

      +
      import FreeCAD,Draft
      +Draft.scale(FreeCAD.ActiveDocument.ActiveObject,FreeCAD.Vector(2,2,2)) 
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Draft_Scale.svg b/localwiki/Draft_Scale.svg new file mode 100644 index 0000000..8a0b6f8 --- /dev/null +++ b/localwiki/Draft_Scale.svg @@ -0,0 +1,323 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + Draft_Scale + + Mon Oct 10 13:44:52 2011 +0000 + + + [wmayer] + + + + + FreeCAD LGPL2+ + + + + + FreeCAD + + + FreeCAD/src/Mod/Draft/Resources/icons/Draft_Scale.svg + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + [agryson] Alexander Gryson + + + + + square + arrow + dotted line + + + + A small square in the bottom left corner of a large dotted box ith an arrow pointing from the top left corner of the inner box to the top left corner of the outer box + + + + diff --git a/localwiki/Draft_Select.html b/localwiki/Draft_Select.html new file mode 100644 index 0000000..be55e27 --- /dev/null +++ b/localwiki/Draft_Select.html @@ -0,0 +1,84 @@ +Draft Select

      Draft Select

      + +

      Select any component in FreeCAD is easy, simply click on it. +

      +
      + + + +
      +

      Options

      +

      To change the color preset (overflight of the mouse) and the selection of an object, go to: Edit → Preferences → Display → Colors. +

      +
      + +
      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Draft_SelectGroup.html b/localwiki/Draft_SelectGroup.html new file mode 100644 index 0000000..c0fe730 --- /dev/null +++ b/localwiki/Draft_SelectGroup.html @@ -0,0 +1,70 @@ +Draft SelectGroup

      Draft SelectGroup

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Draft SelectGroup.png Draft SelectGroup

      +
      Menu location +
      Draft → Utilities → Select group +
      Workbenches +
      Draft, Arch +
      Default shortcut +
      +
      See also +
      Draft AddToGroup, Std Group +

      + +
      +


      +

      +

      Description

      +

      This tool allows you to select the contents of one or more selected groups. +

      +

      How to use

      +
      1. Select one or more groups in the Tree view
      2. +
      3. Press the Draft SelectGroup.png Add to group button
      +

      Links

      + +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Draft_SelectGroup.svg b/localwiki/Draft_SelectGroup.svg new file mode 100644 index 0000000..2fea233 --- /dev/null +++ b/localwiki/Draft_SelectGroup.svg @@ -0,0 +1,582 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + Draft_SelectGroup + + Mon Oct 10 13:44:52 2011 +0000 + + + [wmayer] + + + + + FreeCAD LGPL2+ + + + + + FreeCAD + + + FreeCAD/src/Mod/Draft/Resources/icons/Draft_SelectGroup.svg + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + [agryson] Alexander Gryson + + + + + hierarchy + group + selection + tree + + + A hierarchical tree structure with two blue child elements of a white parent element, both of which are surrounded by the same dotted box + + + + diff --git a/localwiki/Draft_SelectPlane.html b/localwiki/Draft_SelectPlane.html new file mode 100644 index 0000000..d769448 --- /dev/null +++ b/localwiki/Draft_SelectPlane.html @@ -0,0 +1,99 @@ +Draft SelectPlane

      Draft SelectPlane

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Draft SelectPlane.png Draft SelectPlane

      +
      Menu location +
      Draft → Utilities → Select Plane +
      Workbenches +
      Draft, Arch +
      Default shortcut +
      W P +
      See also +
      Draft SetWorkingPlaneProxy +

      + +
      +


      +

      +

      Description

      +

      The Draft module features a working plane system, that allows you to specify a custom plane in the 3D space on which next Draft command will occur. There are several methods to define the working plane: +

      +
      • From a selected face
      • +
      • From 3 selected vertices
      • +
      • From the current view
      • +
      • From a preset: top, frontal or lateral
      • +
      • None, in which case the working plane is adapted automatically to the current view when you start a command, or to a face if you start drawing on an existing face.
      +

      Workingplane example.jpg +

      +

      How to use

      +
      1. Press the Draft SelectPlane.png SelectPlane button. If your button doesn't look like this, see this note.
      +

      Options

      +
      • To set the workplane to existing geometry: select a face of an existing object in the 3D view, or, available in version 0.17
      +

      , with CTRL pressed, 3 vertices on any object(s). Then press the Draft SelectPlane.png SelectPlane button +

      +
      • Pressing the VIEW button will set the working plane as the view plane, perpendicular to the camera axis and passing through the (0,0,0) origin point.
      • +
      • Pressing the AUTO will unset any current working plane. The next 2D operations will be view-dependent.
      • +
      • You can also specify an offset value, which will set your working plane at a certain distance from the plane you select.
      • +
      • You can hide and show the grid with the shortcut GR
      +

      Scripting

      +

      Working plane objects can easily be created and manipulated in scripts and macros. You can create your own, and use them independently of the current Draft working plane. +

      Example: +

      +
      import WorkingPlane
      +myPlane = WorkingPlane.plane() 
      +

      You can also access the current Draft working plane: +

      +
      import FreeCAD
      +draftPlane = FreeCAD.DraftWorkingPlane 
      +

      To move or rotate the Draft working plane (see the WorkingPlane API page for available methods): +

      +
      import FreeCAD
      +from FreeCAD import Vector
      +FreeCAD.DraftWorkingPlane.alignToPointAndAxis(Vector(0,0,0), Vector(1,1,1).normalize(), 17) 
      +

      (note: a Draft command must have been issued to make grid adopt changes) +

      The working plane has a complete scripting API on its own, with convenience functions to position it and convert to/from placements. +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Draft_SelectPlane.svg b/localwiki/Draft_SelectPlane.svg new file mode 100644 index 0000000..bf28b17 --- /dev/null +++ b/localwiki/Draft_SelectPlane.svg @@ -0,0 +1,357 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + Draft_SelectPlane + + Mon Oct 10 13:44:52 2011 +0000 + + + [wmayer] + + + + + FreeCAD LGPL2+ + + + + + FreeCAD + + + FreeCAD/src/Mod/Draft/Resources/icons/Draft_SelectPlane.svg + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + [agryson] Alexander Gryson + + + + + rectangle + grid + plane + + + A rectangle sitting on a plane aligned to a grid that is going into the page from the left to the right + + + + diff --git a/localwiki/Draft_SetWorkingPlaneProxy.html b/localwiki/Draft_SetWorkingPlaneProxy.html new file mode 100644 index 0000000..8c26104 --- /dev/null +++ b/localwiki/Draft_SetWorkingPlaneProxy.html @@ -0,0 +1,89 @@ +Draft SetWorkingPlaneProxy

      Draft SetWorkingPlaneProxy

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Draft SetWorkingPlaneProxy.png Draft SetWorkingPlaneProxy

      +
      Menu location +
      Draft → Utilities → Create WP Proxy +
      Workbenches +
      Draft, Arch +
      Default shortcut +
      None +
      See also +
      Draft SelectPlane +

      + +
      +


      +

      +

      Description

      +

      This command will place a Proxy object in the document, placed and aligned to the current Working Plane. When using the Draft SelectPlane command with such a Proxy object selected, or by double-clicking it in the tree view, the working plane will be positioned and aligned back with the proxy object. The camera position and hidden/shown state of objects are also stored in the Proxy object, and can be restored if the corresponding properties are enabled (see below). +

      +

      How to use

      +
      1. Make sure the Working Plane is set as you want.
      2. +
      3. Press Draft -> Utilities -> Draft SetWorkingPlaneProxy.png Create WP Proxy
      +

      Options

      +
      • WP proxies can be manipulated (moved and rotated) like any other FreeCAD object
      • +
      • The size and appearance of the proxy object can be set in the View properties
      • +
      • The position of the camera is stored in the Proxy object upon creation. That position can be changed anytime by right-clicking the Proxy object, then select the "Write camera position" option to store the current camera position.
      • +
      • The hidden/shown state of all the objects currently in the document is also stored in the Proxy object upon creation. That state can be updated anytime by right-clicking the Proxy object, then select the "Write objects state" option.
      • +
      • The Working Plane stored in the Proxy object can be restored by double-clicking the Proxy object in the tree view, or by using the Draft SelectPlane tool with the Proxy object selected.
      • +
      • If the RestoreView property is set to True, the camera position will also be restored to the saved position on double-clicking the Proxy object or using Draft SelectPlane
      • +
      • If the RestoreState property is set to True, the objects hidden/shown state will also be restored to the saved position on double-clicking the Proxy object or using Draft SelectPlane. If new objects have been added to the document after the state was stored in the Proxy object, the visibility of these new objects will be unchanged
      +

      Properties

      +
      • DATAPlacement: Stores the position of this Proxy and the corresponding Working Plane
      • +
      • VIEWDisplay Size: The size of the Proxy object in the 3D view
      • +
      • VIEWArrow Size: The size of the arrows on the 3 axes
      • +
      • VIEWRestore View: If true, the camera position will be restored on activating (by double-click or Draft SelectPlane) this object
      • +
      • VIEWRestore State: If true, the visibility state of all objects in the current document will be restored on activating (by double-click or Draft SelectPlane) this object
      +

      Scripting

      +

      Working plane proxy objects can easily be created in scripts and macros: +

      Example: +

      +
      import FreeCAD,Draft
      +currentWP = FreeCAD.DraftWorkingPlane
      +Draft.makeWorkingPlaneProxy(currentWP.getPlacement()) 
      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Draft_Shape2DView.html b/localwiki/Draft_Shape2DView.html new file mode 100644 index 0000000..69ce5a8 --- /dev/null +++ b/localwiki/Draft_Shape2DView.html @@ -0,0 +1,93 @@ +Draft Shape2DView

      Draft Shape2DView

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Draft Shape2DView.png Draft Shape2DView

      +
      Menu location +
      Draft → Shape 2D View +
      Workbenches +
      Draft, Arch +
      Default shortcut +
      None +
      See also +
      None +

      + +
      +


      +

      +

      Description

      +

      This tool places in the document a 2D object which is a flattened view of a selected Shape-based object, projected along the current view direction. +

      Draft Shape2DView example.jpg +

      +

      How to use

      +
      1. Select the object you want to extract a 2D view from
      2. +
      3. Rotate the view (or use the view presets shortcuts) so it reflects the direction you want to project the object to. For example, using a Top view will project the object on the XY plane, vertically along the Z axis like on the image above.
      4. +
      5. Press the Draft Shape2DView.png Draft Shape2DView button
      +

      Options

      +
      • If the selected object is an Arch SectionPlane, the 2D projection will be of the contents of the Section plane, and the projection vector will be taken from the section plane instead of the Projection property below.
      • +
      • The normal operating mode is Solid, which projects the whole shape, but, if you selected some faces of the base object when creating the 2D view, you can also set the Individual Faces mode, which will project only the faces that were selected.
      • +
      • If the selected object is an Arch SectionPlane, Cutlines and Cutfaces projection mode are also available, which project only the edges being cut by the section plane. Cutfaces mode displays the cut areas of solids as faces.
      +

      Properties

      +
      • DATAProjection: The direction of the projection.
      • +
      • DATAProjection Mode: The mode of the projection: solid, individual faces, or cutlines.
      • +
      • DATAIn Place: If this is True, when using Cutlines or Cutfaces mode (Arch SectionPlane only), the result will appear at the cut plane location instead of the ground plane available in version 0.17
      +
      • DATAHiddenLines: Shows hidden lines or not
      • +
      • DATATessellation: Tessellate Ellipses and BSplines into line segments
      • +
      • DATASegment Length: The size of segments if Tessellation is turned on
      • +
      • DATAVisible Only: If True, this view will be recomputed only if it is visible
      +

      Scripting

      +

      The Draft Shape2DView tool can by used in macros and from the python console by using the following function: +

      +
      makeShape2DView (object,[projection],[facenumbers]) 
      +
      • Adds a 2D shape to the document, which is a 2D projection of the given object.
      • +
      • A specific projection vector can also be given.
      • +
      • Returns the generated object.
      • +
      • You can also provide a list of face numbers to be considered.
      +

      Example: +

      +
      import FreeCAD,Draft
      +Draft.makeShape2DView(FreeCAD.ActiveDocument.ActiveObject) 
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Draft_Shape2DView_example.jpg b/localwiki/Draft_Shape2DView_example.jpg new file mode 100644 index 0000000..f3f5f36 Binary files /dev/null and b/localwiki/Draft_Shape2DView_example.jpg differ diff --git a/localwiki/Draft_ShapeString.html b/localwiki/Draft_ShapeString.html new file mode 100644 index 0000000..c6d1197 --- /dev/null +++ b/localwiki/Draft_ShapeString.html @@ -0,0 +1,111 @@ +Draft ShapeString

      Draft ShapeString

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Draft ShapeString.png Draft ShapeString

      +
      Menu location +
      Draft → Shape from text ... +
      Workbenches +
      Draft, Arch +
      Default shortcut +
      S S +
      See also +
      None +

      + +
      +


      +

      +

      Description

      +

      The ShapeString tool inserts a compound shape representing a text string at a given point in the current document. Text height, tracking and font can be specified. +

      Draft ShapeString Example400.png +

      +

      How to use

      +
      1. Press the Draft ShapeString16.png Draft Shape from text ... button, or press S then S keys
      2. +
      3. Click a point on the 3D view, or type a coordinate
      4. +
      5. Enter the desired text, press ENTER
      6. +
      7. Enter the desired size, press ENTER
      8. +
      9. Enter the desired tracking, press ENTER
      10. +
      11. Press ENTER to accept the displayed font file, or,
      12. +
      13. Press ... to select a font file.
      +

      Options

      +
      • To enter coordinates manually, simply enter the numbers, then press ENTER between each X, Y and Z component.
      • +
      • Pressing ESC will cancel the operation.
      • +
      • You can set a default font file in Draft/Prefences.
      +

      Properties

      +
      • DATAPosition: The base point of the compound shape
      • +
      • DATAString: The contents of the text string
      • +
      • DATASize: The height of the letters in FC units
      • +
      • DATATracking: The inter-character spacing in FC units
      • +
      • DATAFont File: The font definition file used to draw the string
      +

      Scripting

      +

      The ShapeString tool can by used in macros and from the python console by using the following function: +

      +
      makeShapeString(String,FontFile,[Size],[Tracking]) 
      +
      • Turns a text string into a Compound Shape using a specified font.
      +

      Example: +

      +
      import FreeCAD,Draft
      +Draft.makeShapeString("This is a sample text",
      +                       "/usr/share/fonts/truetype/msttcorefonts/Arial.ttf",
      +                       200.0,10) 
      +

      Selecting A Font

      +

      SSFontSelect.png +

      ShapeString uses the internal geometry of a font to make FreeCAD shapes. To do this it must read the actual font file (*.tff, etc). If the Font Selection box is empty, you must type the full path to the font file or use ... to select a font file. +

      +

      Limitations

      +
      • This tool is not available in FreeCAD versions anterior to 0.14
      • +
      • TrueType(*.ttf), OpenType(*.otf) and Type1(*.pfb) font files are supported.
      • +
      • Very small text heights may result in deformed character glyphs due to loss of detail in scaling.
      • +
      • The current version is limited to left-to-right layouts on a horizontal baseline.
      • +
      • For creating curved text you can use the macro FCCircularTextButtom.pngCircular Text
      +

      Tutorials

      + +


      +

      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Draft_ShapeString.png b/localwiki/Draft_ShapeString.png new file mode 100644 index 0000000..82b7e12 Binary files /dev/null and b/localwiki/Draft_ShapeString.png differ diff --git a/localwiki/Draft_ShapeString.svg b/localwiki/Draft_ShapeString.svg new file mode 100644 index 0000000..c79f261 --- /dev/null +++ b/localwiki/Draft_ShapeString.svg @@ -0,0 +1,185 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + Draft_ShapeString + + Mon Apr 15 13:25:25 2013 -0400 + + + [WandererFan] + + + + + FreeCAD LGPL2+ + + + + + FreeCAD + + + FreeCAD/src/Mod/Draft/Resources/icons/Draft_ShapeString.svg + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + [agryson] Alexander Gryson + + + + + S + letter + + + A capital letter S, slightly italicized + + + + diff --git a/localwiki/Draft_ShapeString16.png b/localwiki/Draft_ShapeString16.png new file mode 100644 index 0000000..5cde37a Binary files /dev/null and b/localwiki/Draft_ShapeString16.png differ diff --git a/localwiki/Draft_ShapeString_Example400.png b/localwiki/Draft_ShapeString_Example400.png new file mode 100644 index 0000000..12641c1 Binary files /dev/null and b/localwiki/Draft_ShapeString_Example400.png differ diff --git a/localwiki/Draft_ShapeString_tutorial.html b/localwiki/Draft_ShapeString_tutorial.html new file mode 100644 index 0000000..f4618bb --- /dev/null +++ b/localwiki/Draft_ShapeString_tutorial.html @@ -0,0 +1,166 @@ +Draft ShapeString tutorial

      Draft ShapeString tutorial

      + +
      + + + + + + + + + + + + + + + + + + + + + + + + + + + +
      +

      Base ExampleCommandModel.png Tutorial

      +
      Topic +
      ShapeString (Draft workbench) +
      Level +
      Beginner +
      Time to complete +
      30 minutes +
      Author +
      r-frank +
      FreeCAD version +
      0.16.6704 +
      Example File(s) +
      Draft_Shapestring_Text +

      + +
      +


      +

      +

      Introduction

      +

      In this tutorial we will discuss how to +

      +
      • insert a text with the Draft ShapeString.png ShapeString tool
      • +
      • extrude it to be a solid
      • +
      • position it in 3D space using placement and Draft Move with sketches as helper elements
      • +
      • doing an engraving by applying a boolean cut
      +

      It is recommended to have completed the sketcher tutorial first. +

      +

      Creating the basic shape

      +
      • Start FreeCAD and create a new document
      • +
      • Switch to part workbench
      • +
      • Insert a cube by clicking on Part Box.png
      • +
      • Make sure the cube is selected in the tree view
      • +
      • Change width to be 31 mm by using the data-tab in the property view
      • +
      • Click on View-axometric.png to change to axometric view
      • +
      • Click on View-zoom-all.png to zoom to fit all
      • +
      • Select upper edge on the front face of the cube in 3D view
      • +
      • Apply a chamfer (to Edge6) of 5 mm by clicking on Part Chamfer.png
      • +
      • Make sure object "chamfer" is selected in the tree view and press <Space> to toggle visibility
      +

      TutorialDraftShapeString BasicShape.jpg +

      +

      Inserting text with the Draft ShapeString tool

      +
      • Switch to Draft workbench
      • +
      • make sure nothing is selected in the tree view
      • +
      • Toggle working plane to XY (Top) by clicking on Draft SelectPlane.png Auto and choosing XY
      • +
      • Insert text "FreeCAD" by +
        • Click on Draft ShapeString.png
        • +
        • Highlight the text in the "Global X"-field and type "0" on the keyboard and press Return
        • +
        • Highlight the text in the "Global Y" field
        • +
        • Type "0" on the keyboard and press Return
        • +
        • Highlight the text in the "Global Z" field
        • +
        • Type "0" on the keyboard and press Return
        • +
        • Enter "FreeCAD" in the string field (without brackets) and press Return
        • +
        • Choose a height of 5mm
        • +
        • Choose a tracking of 0 mm
        • +
        • now point FreeCAD to a "TTF"-Text-Font to use (for example the ARIAL-TTF)
        • +
        • After pressing Return one last time, the Draft-Shapestring object is created in the tree view
      +

      Create 3D text

      +
      • Switch to part workbench
      • +
      • Make sure the object "Shapestring" is selected in the tree view
      • +
      • Use Part Extrude-Tool Part Extrude.png with the parameters: +
        • extrude Z=1 mm
        • +
        • make sure to tick "create solid"
        • +
        • use "OK" to finish part extrude operation
      • +
      • Make sure object "Extrude" is selected in the tree view and press <Space> to toggle its visibility to be visible
      +

      TutorialDraftShapeString DraftShapestring.jpg +

      +

      Insert sketch for positioning

      +
      • Switch to sketcher workbench
      • +
      • Make sure object "chamfer" is selected in the tree view and press <Space> to toggle its visibility to visible
      • +
      • Choose sloped face created by chamfer operation
      • +
      • Click on Sketcher NewSketch.png to insert new sketch
      • +
      • Draw a line (may be horizontal or vertical, length is not of importance ...)
      • +
      • Constrain one of the endpoints to be +2,5 mm vertical distance and +2,5 mm horizontal distance away from the origin
      • +
      • Close the sketch
      +

      TutorialDraftShapeString Sketch.jpg +

      +

      Positioning 3D text in 3D space

      +
      • Make sure object "Extrude" is selected in the tree view and press <Space> to toggle visibility to visible
      • +
      • Make sure, object "Extrude" is selected in the tree view
      • +
      • Open Placement task Edit->Placement...
      • +
      • Apply incremental placement, axis of rotation Z=90°
      • +
      • Apply incremental placement, axis of rotation Y=45°
      • +
      • Switch to draft workbench
      • +
      • Switch to wireframe mode
      • +
      • Make sure, only "snap to endpoint" is activated Draft->Snapping->Snap to endpoint
      • +
      • Select "extrude"-object
      • +
      • Click on Draft Move.png
      • +
      • In 3D view click on the most upper left corner point of "extrude"-object (1) and then click on the constrained point in the sketch (2)
      +

      TutorialDraftShapeString Position.jpg +

      +

      Creating engraved text

      +
      • Switch to part workbench
      • +
      • Switch to "As is"-view mode
      • +
      • Select the 3D text ("extrude") and then the base object ("chamfer") in the tree view
      • +
      • Apply a boolean cut by clicking on Part Cut.png
      • +
      • Make sure object "Sketch" is selected in the tree view
      • +
      • Press <Space> to toggle visibilty
      • +
      • Click on View-axometric.png to change to axometric view
      • +
      • Click on View-zoom-all.png to zoom to fit all
      • +
      • Finished
      +

      TutorialDraftShapeString Complete.jpg +

      +

      Notes

      +
      • for creating curved text you can use the macro Circular Text FCCircularTextButtom.png
      • +
      • for importing text from inkscape look at the Importing text from inkscape tutorial
      • +
      • Extrusion of the Shapestring-Text can also be done with the PartDesign-Pad-Tool
      • +
      • Remember that the DraftShapestring-Object cannot be attached to a face (so no pocket-command possible)
      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Draft_ShowSnapBar.html b/localwiki/Draft_ShowSnapBar.html new file mode 100644 index 0000000..a33cacc --- /dev/null +++ b/localwiki/Draft_ShowSnapBar.html @@ -0,0 +1,61 @@ +Draft ShowSnapBar

      Draft ShowSnapBar

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Draft ShowSnapBar.png Draft ShowSnapBar

      +
      Menu location +
      Draft → Utilities → Show Snap Bar +
      Workbenches +
      Draft, Arch +
      Default shortcut +
      None +
      See also +
      None +

      + +
      +


      +

      +

      Description

      +

      This command shows and hides the snapping toolbar. +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Draft_Slope.html b/localwiki/Draft_Slope.html new file mode 100644 index 0000000..7a39712 --- /dev/null +++ b/localwiki/Draft_Slope.html @@ -0,0 +1,67 @@ +Draft Slope

      Draft Slope

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Draft Slope.png Draft Slope

      +
      Menu location +
      Draft → Utilities → Set Slope +
      Workbenches +
      Draft, Arch +
      Default shortcut +
      None +
      See also +
      +

      + +
      +


      +

      +

      Description

      +

      This tool allows to set the slope (vertical horizontal) of selected wires or lines. By setting a slope value, all vertices after the first one will have their Z value changed so the different segments of the wires or lines will have the given inclination. +

      The slope value is a tangential value: 0 means horizontal, 1 means 45 degrees upwards, -1 means 45 degrees downwards, 0.577 means 30 degrees up, etc. +

      +

      How to use

      +
      1. Select one or more Wire or Line objects
      2. +
      3. Select menu Draft → Utilities → Draft Slope.png Set Slope
      4. +
      5. Set the desired value in the Slope task panel box
      6. +
      7. Press the OK button
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Draft_Slope.svg b/localwiki/Draft_Slope.svg new file mode 100644 index 0000000..0aea1c6 --- /dev/null +++ b/localwiki/Draft_Slope.svg @@ -0,0 +1,527 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + Draft_Slope + + Mon Aug 22 17:34:38 2016 -0300 + + + [Yorik van Havre] + + + + + FreeCAD LGPL2+ + + + + + FreeCAD + + + FreeCAD/src/Mod/Draft/Resources/icons/Draft_Slope.svg + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + [agryson] Alexander Gryson + + + + + arrow + line + + + An arrow pointing down and to the right parallel to a downwardly sloping line + + + + diff --git a/localwiki/Draft_Snap.html b/localwiki/Draft_Snap.html new file mode 100644 index 0000000..7e84f9e --- /dev/null +++ b/localwiki/Draft_Snap.html @@ -0,0 +1,43 @@ +Draft Snap

      Draft Snap

      + +

      Snapping means "gluing" your next 3d point onto an existing point. Snapping is available with most Draft and Arch tools, and can be enabled and disabled globally with the Snap Lock.png Draft ToggleSnap command. Each snap location below can also be enabled or disabled individually by clicking the corresponding button on the snap toolbar. View → Tool Bars → Draft Snap +

      Draft Snap example.jpg +

      +

      Available snap locations

      +
      • Snap Midpoint.png Midpoint: the middle point of line and arc segments
      • +
      • Snap Perpendicular.png Perpendicular: on line and arc segments, perpendicularly to the latest point
      • +
      • Snap Grid.png Grid: the nodes of the Draft grid, if visible.
      • +
      • Snap Intersection.png Intersection: the intersection of 2 line or arc segments. Hover the mouse over the two desired objects to activate their intersection snaps
      • +
      • Snap Parallel.png Parallel: on an imaginary line parallel to a line segment. Hover the mouse over the desired object to activate its parallel snap
      • +
      • Snap Endpoint.png Endpoint: the endpoints of line, arc and spline segments
      • +
      • Snap Angle.png Angle: the special cardinal points of circles and arcs, at 45° and 90°
      • +
      • Snap Center.png Center: the center point of arcs and circles
      • +
      • Snap Extension.png Extension: on an imaginary line that extends beyond the endpoints of line segments. Hover the mouse over the desired object to activate its extension snap
      • +
      • Snap Near.png Near: the closest point on the nearest object
      • +
      • Snap Ortho.png Ortho: on imaginary lines that cross the last point, and extend at 0°, 45° and 90°
      • +
      • Snap Special.png Special: on special points defined by object available in version 0.17
      + +

      Options

      +
      • Snap Lock.png Lock: turns snapping on/off globally
      • +
      • Certain additional snap locations can be obtained by combining 2 snap locations, such as ortho + extension, that will give you a snap point at the intersection of their imaginary lines.
      • +
      • Other, more complex snap locations can also be obtained by using constraining (by pressing SHIFT or X or Y or Z while drawing).
      • +
      • Pressing L while drawing locks the current angle of the line segment being drawn.
      • +
      • The maximum distance at which a point is snapped a snap location is specified in the preferences, and can also be changed on-the-fly by pressing [ or ] keys.
      • +
      • Pressing Q while drawing inserts a hold point at the current location of the mouse cursor. You will then be able to snap orthogonally to those hold points, and at the intersections of their orthogonal axes. If midpoint snapping is enabled, you will also be able to snap at the mid distance between any two hold points. available in version 0.17
      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Draft_Snap.svg b/localwiki/Draft_Snap.svg new file mode 100644 index 0000000..eda2917 --- /dev/null +++ b/localwiki/Draft_Snap.svg @@ -0,0 +1,272 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + Draft_Snap + + Thu Feb 23 14:44:03 2012 -0200 + + + [Yorik van Havre] + + + + + FreeCAD LGPL2+ + + + + + FreeCAD + + + FreeCAD/src/Mod/Draft/Resources/icons/Draft_Snap.svg + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + [agryson] Alexander Gryson + + + + + perpindicular + point + line + dot + circle + + + The perpindicular symbol above and to the left of a dot at the midpoint of a line + + + + diff --git a/localwiki/Draft_Snap_example.jpg b/localwiki/Draft_Snap_example.jpg new file mode 100644 index 0000000..af9865b Binary files /dev/null and b/localwiki/Draft_Snap_example.jpg differ diff --git a/localwiki/Draft_Special.html b/localwiki/Draft_Special.html new file mode 100644 index 0000000..0fa8fd0 --- /dev/null +++ b/localwiki/Draft_Special.html @@ -0,0 +1,64 @@ +Draft Special

      Draft Special

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Draft Special.png Draft Special

      +
      Menu location +
      Draft → Snap → Special +
      Workbenches +
      Draft, Arch +
      Default shortcut +
      +
      See also +
      +

      + +
      +


      +

      +

      Description

      +

      When this snap location is activated, special snap locations defined by object are available. These include: +

      +
      • Vertices of base lines of Arch Walls
      • +
      • Base points of Arch Structures
      • +
      • Any point defined in the Snap Points property of objects, if existing (Currently only Arch Equipments have such property). The 3D vectors defined in the SnapPoints property (a VectorList property) are transformed together with the object placement before snapping.
      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Draft_Stretch.html b/localwiki/Draft_Stretch.html new file mode 100644 index 0000000..22a996c --- /dev/null +++ b/localwiki/Draft_Stretch.html @@ -0,0 +1,78 @@ +Draft Stretch

      Draft Stretch

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Draft Stretch.png Draft Stretch

      +
      Menu location +
      Draft → Stretch +
      Workbenches +
      Draft, Arch +
      Default shortcut +
      None +
      See also +
      Draft Offset +

      + +
      +


      +

      +

      Description

      +

      This tool allows to stretch an object by moving some of its vertices. +

      Draft Stretch Example.jpg +

      +

      How to use

      +
      1. Select objects you wish to stretch
      2. +
      3. Press the Draft Stretch.png Draft Stretch button
      4. +
      5. Pick the first corner of a selection rectangle
      6. +
      7. Pick the opposite corner of the selection rectangle. The selected vertices get highlighted
      8. +
      9. Pick the first point of the displacement you wish to give to these vertices
      10. +
      11. Pick the end point of the displacement
      +

      Options

      +
      • If no object is selected when starting the command, you will be invited to pick one. But to work on more than one object, you need to have them selected before starting the command.
      • +
      • So far, only Draft Wire, Draft Line, Draft BSpline, Draft BezCurve and Draft Rectangle objects will have their individual vertices stretched. All other objects will have their origin point moved if it is inside the selection rectangle.
      +

      Scripting

      +

      The Stretch tool has no direct python function because all it does is modify properties of the selected objects, such as the Placement or Points properties of Draft objects. By looking at the python output when using the stretch tool, it is easy to reproduce its working manually. +


      +

      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Draft_Stretch.svg b/localwiki/Draft_Stretch.svg new file mode 100644 index 0000000..34706be --- /dev/null +++ b/localwiki/Draft_Stretch.svg @@ -0,0 +1,279 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + Mon Oct 10 13:44:52 2011 +0000 + + + [wmayer] + + + + + FreeCAD LGPL2+ + + + + + FreeCAD + + + FreeCAD/src/Mod/Draft/Resources/icons/Draft_Scale.svg + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + [agryson] Alexander Gryson + + + + + square + arrow + dotted line + + + + A small square in the bottom left corner of a large dotted box ith an arrow pointing from the top left corner of the inner box to the top left corner of the outer box + + + + diff --git a/localwiki/Draft_Stretch_Example.jpg b/localwiki/Draft_Stretch_Example.jpg new file mode 100644 index 0000000..b69a778 Binary files /dev/null and b/localwiki/Draft_Stretch_Example.jpg differ diff --git a/localwiki/Draft_Style_01.png b/localwiki/Draft_Style_01.png new file mode 100644 index 0000000..7b5d057 Binary files /dev/null and b/localwiki/Draft_Style_01.png differ diff --git a/localwiki/Draft_Style_Couleur_Face.png b/localwiki/Draft_Style_Couleur_Face.png new file mode 100644 index 0000000..30592b8 Binary files /dev/null and b/localwiki/Draft_Style_Couleur_Face.png differ diff --git a/localwiki/Draft_Style_Couleur_Ligne.png b/localwiki/Draft_Style_Couleur_Ligne.png new file mode 100644 index 0000000..75654e1 Binary files /dev/null and b/localwiki/Draft_Style_Couleur_Ligne.png differ diff --git a/localwiki/Draft_Style_Epaisseur_Ligne.png b/localwiki/Draft_Style_Epaisseur_Ligne.png new file mode 100644 index 0000000..ada3fb0 Binary files /dev/null and b/localwiki/Draft_Style_Epaisseur_Ligne.png differ diff --git a/localwiki/Draft_Style_Style.png b/localwiki/Draft_Style_Style.png new file mode 100644 index 0000000..6e2e4ef Binary files /dev/null and b/localwiki/Draft_Style_Style.png differ diff --git a/localwiki/Draft_SwitchMode.svg b/localwiki/Draft_SwitchMode.svg new file mode 100644 index 0000000..5a4cc2b --- /dev/null +++ b/localwiki/Draft_SwitchMode.svg @@ -0,0 +1,409 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + Draft_SwitchMode + + Mon Oct 10 13:44:52 2011 +0000 + + + [wmayer] + + + + + FreeCAD LGPL2+ + + + + + FreeCAD + + + FreeCAD/src/Mod/Draft/Resources/icons/Draft_SwitchMode.svg + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + [agryson] Alexander Gryson + + + + + square + squares + empty + full + filled + wireframe + + + An empty square in front of and slightly to the top left of a filled square + + + + diff --git a/localwiki/Draft_Text.html b/localwiki/Draft_Text.html new file mode 100644 index 0000000..0059e86 --- /dev/null +++ b/localwiki/Draft_Text.html @@ -0,0 +1,100 @@ +Draft Text

      Draft Text

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Draft Text.png Draft Text

      +
      Menu location +
      Draft → Text +
      Workbenches +
      Draft, Arch +
      Default shortcut +
      T E +
      See also +
      None +

      + +
      +


      +

      +

      Description

      +

      The Text tool inserts a piece of text at a given point in the current document. It takes the text size and color previously set on the Tasks tab. +

      Draft Text example.jpg +

      +

      How to use

      +
      1. Press the Draft Text.png Draft Text button, or press T then E keys
      2. +
      3. Click a point on the 3D view, or type a coordinate
      4. +
      5. Enter the desired text, pressing ENTER between each line
      6. +
      7. Press ENTER twice to finish the operation.
      +

      Options

      +
      • Pressing CTRL will snap your point to available snap locations.
      • +
      • To enter coordinates manually, simply enter the numbers, then press ENTER between each X, Y and Z component.
      • +
      • Pressing ESC will cancel the operation.
      • +
      • When editing the text, pressing ENTER or DOWN ARROW allow you to enter or edit a next line of text.
      • +
      • Pressing UP ARROW allows you to edit a previous line of text.
      • +
      • Pressing ENTER twice (thus leaving the last line empty) adds the text to the document and closes the editor.
      +

      Properties

      +
      • DATAPosition: The base point of the text block
      • +
      • DATALabel Text: The contents of the text block
      • +
      • VIEWDisplay Mode: Specifies if the text is aligned to the scene axes or always faces the camera
      • +
      • VIEWFont Size: The size of the letters
      • +
      • VIEWJustification: Specifies if the text is aligned to the left, right or center of the base point.
      • +
      • VIEWLine Spacing: Specifies the space between lines of text
      • +
      • VIEWRotation: Specifies a rotation to be applied to the text
      • +
      • VIEWRotation Axis: Specifies the axis to use for the rotation
      • +
      • VIEWFont Name: The font to use to draw the text. It can be a font name, such as "Arial", a default style such as "sans", "serif" or "mono", or a family such as "Arial,Helvetica,sans" or a name with a style such as "Arial:Bold". If the given font is not found on the system, a generic one is used instead.
      +

      Scripting

      +

      The Text tool can by used in macros and from the python console by using the following function: +

      +
      makeText (string or list, [Vector], [screenmode]) 
      +
      • Creates a Text object, at the given point if a vector is provided, containing the string or the strings given in the list, one string by line.
      • +
      • The current Draft color and text height and font specified in preferences are used.
      • +
      • If screenmode is True, the text always faces the view direction, otherwise it lies on the XY plane.
      • +
      • Returns the newly created object.
      +

      Example: +

      +
      import FreeCAD,Draft
      +Draft.makeText("This is a sample text",FreeCAD.Vector(1,1,0)) 
      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Draft_Text.png b/localwiki/Draft_Text.png new file mode 100644 index 0000000..3da931f Binary files /dev/null and b/localwiki/Draft_Text.png differ diff --git a/localwiki/Draft_Text.svg b/localwiki/Draft_Text.svg new file mode 100644 index 0000000..5bc1919 --- /dev/null +++ b/localwiki/Draft_Text.svg @@ -0,0 +1,153 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + Draft_Text + + Mon Oct 10 13:44:52 2011 +0000 + + + [wmayer] + + + + + FreeCAD LGPL2+ + + + + + FreeCAD + + + FreeCAD/src/Mod/Draft/Resources/icons/Draft_Text.svg + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + [agryson] Alexander Gryson + + + The capital letter A, slightly italicized + + + A + letter + + + + + + diff --git a/localwiki/Draft_ToggleConstructionMode.html b/localwiki/Draft_ToggleConstructionMode.html new file mode 100644 index 0000000..7d2a1e6 --- /dev/null +++ b/localwiki/Draft_ToggleConstructionMode.html @@ -0,0 +1,73 @@ +Draft ToggleConstructionMode

      Draft ToggleConstructionMode

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Draft ToggleConstructionMode.png Draft ToggleConstructionMode

      +
      Menu location +
      Draft → Utilities → Toggle construction mode +
      Workbenches +
      Draft, Arch +
      Default shortcut +
      None +
      See also +
      Draft_AddConstruction +

      + +
      +


      +

      +

      Description

      +

      The Draft module features a construction mode, which allows to draw certain objects in a special group, with a defined color, so it is easy to separate them from the other objects and switch it off when you don't need it, or delete them after you don't need them anymore. +

      Draft construction mode example.jpg +

      +

      How to use

      +
      1. Press the Draft ToggleConstructionMode.png Toggle construction mode button
      2. +
      3. Draw some objects
      4. +
      5. Press the Draft ToggleConstructionMode.png Toggle construction mode button again to go back to normal mode
      +

      Options

      +
      • The Construction Mode button is also present on the Task panel or Draft toolbar when the Draft workbench is active
      • +
      • The color and the group name can be changed in the preferences screen.
      +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Draft_ToggleContinueMode.html b/localwiki/Draft_ToggleContinueMode.html new file mode 100644 index 0000000..28ce32e --- /dev/null +++ b/localwiki/Draft_ToggleContinueMode.html @@ -0,0 +1,66 @@ +Draft ToggleContinueMode

      Draft ToggleContinueMode

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Draft ToggleContinueMode.png Draft ToggleContinueMode

      +
      Menu location +
      Draft → Utilities → Toggle continue mode +
      Workbenches +
      Draft, Arch +
      Default shortcut +
      None +
      See also +
      None +

      + +
      +


      +

      +

      Description

      +

      Some tools of the Draft and Arch modules feature a Continue checkbox, which, when checked, restarts the command after you finish it, so you don't need to press the command button again, and you can quickly create several objects in a row, one after the other. This command switches on/off this checkbox for the next commands. +

      +

      How to use

      +
      1. Press the Draft ToggleContinueMode.png Toggle continue mode button
      2. +
      3. Start a command that has a Continue checkbox, such as Draft Line or Arch Wall
      4. +
      5. Cancel the command or press ESC to leave both the command and the continue mode.
      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Draft_ToggleContinueMode.png b/localwiki/Draft_ToggleContinueMode.png new file mode 100644 index 0000000..1f82bda Binary files /dev/null and b/localwiki/Draft_ToggleContinueMode.png differ diff --git a/localwiki/Draft_ToggleDisplayMode.html b/localwiki/Draft_ToggleDisplayMode.html new file mode 100644 index 0000000..593fdc5 --- /dev/null +++ b/localwiki/Draft_ToggleDisplayMode.html @@ -0,0 +1,68 @@ +Draft ToggleDisplayMode

      Draft ToggleDisplayMode

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Draft ToggleDisplayMode.png Draft ToggleDisplayMode

      +
      Menu location +
      Draft → Utilities → Toggle display mode +
      Workbenches +
      Draft, Arch +
      Default shortcut +
      Shift + Space +
      See also +
      None +

      + +
      +


      +

      +

      Description

      +

      This tool switches the display of selected object(s) between Wireframe and Flat Lines +

      +

      How to use

      +
      1. Select object(s)
      2. +
      3. Press the Draft ToggleDisplayMode.png Toggle display mode button or press the SHIFT and SPACEBAR keys
      +

      Options

      +
      • This as the same effect as changing the Display Mode property of objects between "Wireframe" and "Flat Lines"
      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Draft_ToggleGrid.html b/localwiki/Draft_ToggleGrid.html new file mode 100644 index 0000000..7f5397d --- /dev/null +++ b/localwiki/Draft_ToggleGrid.html @@ -0,0 +1,65 @@ +Draft ToggleGrid

      Draft ToggleGrid

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Draft ToggleGrid.png Draft ToggleGrid

      +
      Menu location +
      Draft → Utilities → Toggle grid +
      Workbenches +
      Draft, Arch +
      Default shortcut +
      G R +
      See also +
      None +

      + +
      +


      +

      +

      Description

      +

      This commands toggles the snapping to the nodes of the Draft grid (if visible) on/off. +

      +

      Options

      +

      The aspect and spacing of the Draft grid can be adjusted in the Draft preferences from menu Edit → Preferences → Draft → Grid and snapping +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Draft_ToggleSnap.html b/localwiki/Draft_ToggleSnap.html new file mode 100644 index 0000000..cadbfd9 --- /dev/null +++ b/localwiki/Draft_ToggleSnap.html @@ -0,0 +1,61 @@ +Draft ToggleSnap

      Draft ToggleSnap

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Draft ToggleSnap.png Draft ToggleSnap

      +
      Menu location +
      Draft → Utilities → Toggle snap +
      Workbenches +
      Draft, Arch +
      Default shortcut +
      None +
      See also +
      None +

      + +
      +


      +

      +

      Description

      +

      This command toggles snapping on/off. +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Draft_Trimex.html b/localwiki/Draft_Trimex.html new file mode 100644 index 0000000..71cc9b0 --- /dev/null +++ b/localwiki/Draft_Trimex.html @@ -0,0 +1,77 @@ +Draft Trimex

      Draft Trimex

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Draft Trimex.png Draft Trimex

      +
      Menu location +
      Draft → Trim/Extend +
      Workbenches +
      Draft, Arch +
      Default shortcut +
      T R +
      See also +
      Part Extrude +

      + +
      +


      +

      +

      Description

      +

      This tool trims/cuts and extends lines and polylines, and extrudes faces. +

      Draft trimex example.jpg +

      +

      How to use

      +
      1. Select a wire you wish to trim or extend, or select a face you wish to extrude
      2. +
      3. Press the Draft Trimex.png Draft Trimex button, or press T then R keys
      4. +
      5. Click a point in the 3D view
      +

      Options

      +
      • trimming or extending is decided automatically from the position of your mouse
      • +
      • if you move the mouse cursor over another object, the trim/extend operation will snap to that object or segment
      • +
      • pressing SHIFT will constrain you to the segment currently being trimmed or extended
      • +
      • pressing ALT will invert the direction of the trimming
      • +
      • When the selected object is a face, or a face is selected from an existing object, the trimex tool switches to extrude mode. In extrude mode, pressing SHIFT frees the extrusion from the face normal and allows to snap elsewhere.
      +

      Scripting

      +

      Not available. See the Part Extrude tool. +

      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Draft_Trimex.svg b/localwiki/Draft_Trimex.svg new file mode 100644 index 0000000..21769ab --- /dev/null +++ b/localwiki/Draft_Trimex.svg @@ -0,0 +1,263 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + Draft_Trimex + + Mon Oct 10 13:44:52 2011 +0000 + + + [wmayer] + + + + + FreeCAD LGPL2+ + + + + + FreeCAD + + + FreeCAD/src/Mod/Draft/Resources/icons/Draft_Trimex.svg + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + [agryson] Alexander Gryson + + + + + arrow + arrows + line + + + A vertical line with an arrow pointing away from it on each side + + + + diff --git a/localwiki/Draft_UndoLine.html b/localwiki/Draft_UndoLine.html new file mode 100644 index 0000000..4253bfc --- /dev/null +++ b/localwiki/Draft_UndoLine.html @@ -0,0 +1,65 @@ +Draft UndoLine

      Draft UndoLine

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Draft UndoLine.png Draft UndoLine

      +
      Menu location +
      Draft → Utilities → Undo Line +
      Workbenches +
      Draft, Arch +
      Default shortcut +
      Ctrl + Z +
      See also +
      FinishLine, CloseLine +

      + +
      +


      +

      +

      Description

      +

      This command undoes the last segment of a Draft Wire being drawn. +

      +

      How to use

      +
      1. Start drawing a Draft Wire
      2. +
      3. Press the Draft UndoLine.png Undo button or press the CTRL + Z keys
      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Draft_Upgrade.html b/localwiki/Draft_Upgrade.html new file mode 100644 index 0000000..4d3c612 --- /dev/null +++ b/localwiki/Draft_Upgrade.html @@ -0,0 +1,89 @@ +Draft Upgrade

      Draft Upgrade

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Draft Upgrade.png Draft Upgrade

      +
      Menu location +
      Draft → Upgrade +
      Workbenches +
      Draft, Arch +
      Default shortcut +
      U P +
      See also +
      Draft Downgrade +

      + +
      +


      +

      +

      Description

      +

      This tool upgrades selected objects in different ways. If no object is selected, you will be invited to select one. +

      Draft Upgrade example.jpg +

      +

      How to use

      +
      1. Select one or more objects you wish to upgrade
      2. +
      3. Press the Draft Upgrade.png Draft Upgrade button or press U then P keys
      +

      Options

      +

      The selected objects are modified/upgraded according to the following conditions (in order): +

      +
      • if there are more than one face in the selection, the faces are merged (union)
      • +
      • if there is only one face in the selection, nothing is done
      • +
      • if there is only one open wire in the selection, it gets closed
      • +
      • if there are only edges in the selection, all edges are joined into a wire (closed if possible)
      • +
      • if none of the above is possible, a compound object is created
      +

      Scripting

      +

      The upgrade tool can be used from python scripts and macros like this: +

      +
      Draft.upgrade(objects, delete=False, force=None) 
      +
      • Upgrades the given object(s) (can be an object or a list of objects).
      • +
      • If delete is True, old objects are deleted.
      • +
      • The force attribute can be used to force a certain way of upgrading. It can be: makeCompound, closeGroupWires, makeSolid, closeWire, turnToParts, makeFusion, makeShell, makeFaces, draftify, joinFaces, makeSketchFace, makeWires
      • +
      • Returns a dictionnary containing two lists, a list of new objects and a list of objects to be deleted
      +

      Some of the operations of the Upgrade tool can also be made with the Part Union or Draft Wire tools. +

      Example: +

      +
      import Draft
      +mycircle = Draft.makeCircle(2)
      +face1 = Draft.upgrade([mycircle],True) 
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Draft_Upgrade.png b/localwiki/Draft_Upgrade.png new file mode 100644 index 0000000..74f9f3a Binary files /dev/null and b/localwiki/Draft_Upgrade.png differ diff --git a/localwiki/Draft_Upgrade.svg b/localwiki/Draft_Upgrade.svg new file mode 100644 index 0000000..98a65b6 --- /dev/null +++ b/localwiki/Draft_Upgrade.svg @@ -0,0 +1,192 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + Draft_Upgrade + + Mon Oct 10 13:44:52 2011 +0000 + + + [wmayer] + + + + + FreeCAD LGPL2+ + + + + + FreeCAD + + + FreeCAD/src/Mod/Draft/Resources/icons/Draft_Upgrade.svg + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + [agryson] Alexander Gryson + + + + + arrow + up + + + A large blue arrow pointing upwards + + + + diff --git a/localwiki/Draft_VisGroup.html b/localwiki/Draft_VisGroup.html new file mode 100644 index 0000000..1aae06a --- /dev/null +++ b/localwiki/Draft_VisGroup.html @@ -0,0 +1,67 @@ +Draft VisGroup

      Draft VisGroup

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Draft VisGroup.png Draft VisGroup

      +
      Menu location +
      Draft → Utilities → VisGroup +
      Workbenches +
      Draft, Arch +
      Default shortcut +
      None +
      See also +
      None +

      + +
      +


      +

      +

      Description

      +

      This command creates a special kind of FreeCAD group, with additional features: It allows to control visual features of the objects placed inside the group, such as line width, line color, shape color and transparency. By changing these properties on the VisGroup, the changes are propagated to the objects contained in the group. +

      The VisGroup can also be used on Drawing pages. You can then use it to control the color and linewidth of some Drawing Views. In that case, though, not all options are available, since, at the moment, Drawing Views don't support shape color or transparency. +

      +

      How to use

      +
      1. Press the Draft VisGroup.png VisGroup button
      2. +
      3. Drag and drop objects inside the VisGroup
      4. +
      5. Change some visual properties of the VisGroup, such as Line Color, Line Width, Shape Color or Transparency.
      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Draft_VisGroup.svg b/localwiki/Draft_VisGroup.svg new file mode 100644 index 0000000..b110c0e --- /dev/null +++ b/localwiki/Draft_VisGroup.svg @@ -0,0 +1,214 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + Draft_VisGroup + + Tue Jun 10 10:21:01 2014 -0300 + + + [Yorik van Havre] + + + + + FreeCAD LGPL2+ + + + + + FreeCAD + + + FreeCAD/src/Mod/Draft/Resources/icons/Draft_VisGroup.svg + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + [agryson] Alexander Gryson + + + + + page + pages + rectangles + stack + + + Three pages or rectangles stacked on top of each other + + + + diff --git a/localwiki/Draft_Wipe.svg b/localwiki/Draft_Wipe.svg new file mode 100644 index 0000000..5c3d12c --- /dev/null +++ b/localwiki/Draft_Wipe.svg @@ -0,0 +1,162 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + Draft_Wipe + + Fri Oct 14 18:47:29 2011 +0000 + + + [yorikvanhavre] + + + + + FreeCAD LGPL2+ + + + + + FreeCAD + + + FreeCAD/src/Mod/Draft/Resources/icons/Draft_Wipe.svg + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + [agryson] Alexander Gryson + + + + + cross + line + + + A large red cross over a line which is white left of the cross, blue right of the cross + + + + diff --git a/localwiki/Draft_Wire.html b/localwiki/Draft_Wire.html new file mode 100644 index 0000000..4bbce71 --- /dev/null +++ b/localwiki/Draft_Wire.html @@ -0,0 +1,113 @@ +Draft Wire

      Draft Wire

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Draft Wire.png Draft Wire

      +
      Menu location +
      Draft → Wire +
      Workbenches +
      Draft, Arch +
      Default shortcut +
      W I +
      See also +
      Draft Line, Draft BSpline +

      + +
      +


      +

      +

      Description

      +

      The Wire tool creates a polyline (sequence of lines made of several segments) in the current work plane. It takes the linewidth and color previously set on the Tasks tab. The Wire tool behaves like the Draft Line tool, except that it doesn't stop after two points. +

      Draft Polyline example.jpg +

      +

      How to use

      +
      1. Press the Draft Wire.png Draft Wire button, or press W then I keys
      2. +
      3. Click a first point on the 3D view, or type a coordinate
      4. +
      5. Click additional point on the 3D view, or type a coordinate
      6. +
      7. Press F or C, or double-click the last point, or click on the first point to finish or close the wire. If the wire is closed, it will also be a face, even if it appears as wireframe.
      +

      Options

      + +
      • Press F or the Draft FinishLine.png Finish button to finish the wire, leaving it open
      • +
      • Press C or the Draft CloseLine.png Close button or click on the first point to finish the wire, but making it closed by adding a last segment between the last point and the first one.
      • +
      • Press X, Y or Z after a point to constrain the next point on the given axis.
      • +
      • To enter coordinates manually, simply enter the numbers, then press ENTER between each X, Y and Z component.
      • +
      • Press R or click the checkbox to check/uncheck the Relative button. If relative mode is on, the coordinates of the next point are relative to the last one. If not, they are absolute, taken from the (0,0,0) origin point.
      • +
      • Press T or click the checkbox to check/uncheck the Continue button. If continue mode is on, the Wire tool will restart after you finish or close it, allowing you to draw another one without pressing the Wire button again.
      • +
      • Press CTRL while drawing to force snapping your point to the nearest snap location, independently of the distance.
      • +
      • Press SHIFT while drawing to constrain your next point horizontally or vertically in relation to the last one.
      • +
      • Press W or press the Draft Wipe.png Wipe button to remove the existing segments and start the wire from the last point.
      • +
      • Press CTRL+Z or press the Draft UndoLine.png Undo button to undo the last point.
      • +
      • Press I or the Filled button to have the wire filled with a face if it is closed.
      • +
      • Press ESC or the Cancel button to abort the current Line command.
      • +
      • Closed wires, when in "Flat Lines" display mode, can display a hatch pattern, by setting their "Pattern" property below.
      +

      Properties

      +
      • DATAClosed: Specifies if the wire is closed or not
      • +
      • DATAChamfer Size: Specifies the size of chamfered corners
      • +
      • DATAFillet Radius: Specifies a curvature radius to give to the nodes of the wire
      • +
      • DATASubdivisions: Divides the segments of the wire with the given number of subdivisions available in version 0.16
      +
      • DATAMake Face: Fills the wire with a face if it is closed
      • +
      • VIEWEnd Arrow: Shows an arrow symbol at the last point of the wire, so it can be used as an annotation leader line
      • +
      • VIEWPattern: Specifies a hatch pattern to fill the wire with (Closed Wire)
      • +
      • VIEWPattern Size: Specifies the size of the hatch pattern
      +

      See also Draft Pattern page. +

      +

      Scripting

      +

      The Wire tool can by used in macros and from the python console by using the following function: +

      +
      makeWire (list or Part.Wire, [closed], [placement], [facemode]) 
      +
      • Creates a Wire object from the given list of vectors or from the given wire. +
        • If closed is True or if first and last points are identical, the wire is closed.
        • +
        • If facemode is True (and the wire is closed), the wire will appear filled.
      • +
      • The current Draft linewidth and color will be used.
      • +
      • Returns the newly created object.
      +

      Example: +

      +
      import FreeCAD,Draft
      +p1 = FreeCAD.Vector(0,0,0)
      +p2 = FreeCAD.Vector(1,1,0)
      +p3 = FreeCAD.Vector(2,0,0)
      +Draft.makeWire([p1,p2,p3],closed=True) 
      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Draft_Wire.svg b/localwiki/Draft_Wire.svg new file mode 100644 index 0000000..edd1807 --- /dev/null +++ b/localwiki/Draft_Wire.svg @@ -0,0 +1,400 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + Draft_Wire + + Mon Oct 10 13:44:52 2011 +0000 + + + [wmayer] + + + + + FreeCAD LGPL2+ + + + + + FreeCAD + + + FreeCAD/src/Mod/Draft/Resources/icons/Draft_Wire.svg + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + [agryson] Alexander Gryson + + + + + dots + dot + circle + circles + line + lines + + + Four scattered dots or circles joined by a line + + + + diff --git a/localwiki/Draft_WireToBSpline.html b/localwiki/Draft_WireToBSpline.html new file mode 100644 index 0000000..b79d849 --- /dev/null +++ b/localwiki/Draft_WireToBSpline.html @@ -0,0 +1,80 @@ +Draft WireToBSpline

      Draft WireToBSpline

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Draft WireToBSpline.png Draft WireToBSpline

      +
      Menu location +
      Drafting → Wire to BSpline +
      Workbenches +
      Draft, Arch +
      Default shortcut +
      None +
      See also +
      None +

      + +
      +


      +

      +

      Description

      +

      This tool converts Wires to BSplines, and vice-versa. +

      Draft Wire2BSpline example.jpg +

      +

      How to use

      +
      1. Select a wire or a BSpline
      2. +
      3. Press the Draft WireToBSpline.png Draft WireToBSpline button
      +

      Options

      +
      • The original object will not be deleted after the operation, you must delete it manually if you wish so.
      +

      Scripting

      +

      Not available, but creating a new object with the points from another one is easy, for example: +

      +
      • If the active object is a wire:
      +
      import FreeCAD,Draft
      +points = FreeCAD.ActiveDocument.ActiveObject.Points
      +Draft.makeBSpline(points) 
      +
      • if the active object is a bspline
      +
      import FreeCAD,Draft
      +points = FreeCAD.ActiveDocument.ActiveObject.Points
      +Draft.makeWire(points) 
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Draft_WireToBSpline.svg b/localwiki/Draft_WireToBSpline.svg new file mode 100644 index 0000000..18fcc37 --- /dev/null +++ b/localwiki/Draft_WireToBSpline.svg @@ -0,0 +1,574 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + Draft_WireToBSpline + + Mon Oct 10 13:44:52 2011 +0000 + + + [wmayer] + + + + + FreeCAD LGPL2+ + + + + + FreeCAD + + + FreeCAD/src/Mod/Draft/Resources/icons/Draft_WireToBSpline.svg + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + [agryson] Alexander Gryson + + + + + wire + zig-zag + jagged + smooth + spline + curve + arrow + triangle + + + A jagged zig-zagging line above a downwards pointing triangle above a smoothly meandering line + + + + diff --git a/localwiki/Draft_Workbench.html b/localwiki/Draft_Workbench.html new file mode 100644 index 0000000..b79bf89 --- /dev/null +++ b/localwiki/Draft_Workbench.html @@ -0,0 +1,121 @@ +Draft Workbench

      Draft Workbench

      (Redirected from Draft Workbench)
      + +

      The Draft workbench allows to quickly draw simple 2D objects in the current document, and offers several tools to modify them afterwards. Some of these tools also work on all other FreeCAD objects, not only those created with the Draft workbench. It also provides a complete snapping system, and several utilities to manage objects and settings. +

      + + +

      Drawing objects

      +

      These are tools for creating objects. +

      +
      • Draft Line.png Line: Draws a line segment between 2 points
      • +
      • Draft Wire.png Wire: Draws a line made of multiple line segments (polyline)
      • +
      • Draft Circle.png Circle: Draws a circle from center and radius
      • +
      • Draft Arc.png Arc: Draws an arc segment from center, radius, start angle and end angle
      • +
      • Draft Ellipse.png Ellipse: Draws an ellipse from two corner points
      • +
      • Draft Polygon.png Polygon: Draws a regular polygon from a center and a radius
      • +
      • Draft Rectangle.png Rectangle: Draws a rectangle from 2 opposite points
      • +
      • Draft Text.png Text: Draws a multi-line text annotation
      • +
      • Draft Dimension.png Dimension: Draws a dimension annotation
      • +
      • Draft BSpline.png BSpline: Draws a B-Spline from a series of points
      • +
      • Draft Point.png Point: Inserts a point object
      • +
      • Draft ShapeString.png ShapeString: The ShapeString tool inserts a compound shape representing a text string at a given point in the current document
      • +
      • Draft Facebinder.png Facebinder: Creates a new object from selected faces on existing objects
      • +
      • Draft BezCurve.png Bezier Curve: Draws a Bezier curve from a series of points
      • +
      • Draft Label.png Label: Places a label with an arrow pointing to a selected element available in version 0.17
      +

      Modifying objects

      +

      These are tools for modifying existing objects. They work on selected objects, but if no object is selected, you will be invited to select one. +

      +
      • Draft Move.png Move: Moves object(s) from one location to another
      • +
      • Draft Rotate.png Rotate: Rotates object(s) from a start angle to an end angle
      • +
      • Draft Offset.png Offset: Moves segments of an object about a certain distance
      • +
      • Draft Trimex.png Trim/Extend (Trimex): Trims or extends an object
      • +
      • Draft Upgrade.png Upgrade: Joins objects into a higher-level object
      • +
      • Draft Downgrade.png Downgrade: Explodes objects into lower-level objects
      • +
      • Draft Scale.png Scale: Scales selected object(s) around a base point
      • +
      • Draft PutOnSheet.png Drawing: Writes selected objects to a Drawing sheet
      • +
      • Draft Edit.png Edit: Edits a selected object
      • +
      • Draft WireToBSpline.png Wire to BSpline: Converts a wire to a BSpline and vice-versa
      • +
      • Draft AddPoint.png Add point: Adds a point to a wire or BSpline
      • +
      • Draft DelPoint.png Delete point: Deletes a point from a wire or BSpline
      • +
      • Draft Shape2DView.png Shape 2D View: Creates a 2D object which is a flattened 2D view of another 3D object
      • +
      • Draft Draft2Sketch.png Draft to Sketch: Converts a Draft object to Sketch and vice-versa
      • +
      • Draft Array.png Array: Creates a polar or rectangular array from selected objects
      • +
      • Draft PathArray.png Path Array: Creates an array of objects by placing the copies along a path
      • +
      • Draft Clone.png Clone: Clones the selected objects
      • +
      • Draft Mirror.png Mirror: Mirrors the selected objects
      • +
      • Draft Stretch.png Stretch: Stretches the selected objects available in version 0.17
      +

      Utility tools

      +

      Additional tools available via right-click context menu, depending on the selected objects. +

      + + + + +

      Preferences

      + +

      File formats

      +

      The Draft module provides FreeCAD with importers and exporters for the following file formats: +

      + + +

      Additional features

      +
      • Snapping: Allows to place new points on special places on existing objects
      • +
      • Constraining: Allows to place new points horizontally or vertically in relation to previous points
      • +
      • Working with manual coordinates: Allows to enter manual coordinates instead of clicking on screen
      • +
      • Working plane: Allows you to define a plane in the 3D space, where next operations will take place
      +

      Scripting

      +

      The Draft module features a complete Draft API so you can use its functions in scripts and macros +

      +

      Tutorials

      + + +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Draft_WorkingPlane.html b/localwiki/Draft_WorkingPlane.html new file mode 100644 index 0000000..6635b6f --- /dev/null +++ b/localwiki/Draft_WorkingPlane.html @@ -0,0 +1,75 @@ +Draft WorkingPlane

      Draft WorkingPlane

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Draft WorkingPlane.png Draft WorkingPlane

      +
      Menu location +
      Draft → Snap → WorkingPlane +
      Workbenches +
      Draft, Arch +
      Default shortcut +
      +
      See also +
      +

      + +
      +


      +


      +

      +

      Description

      +

      Always places the snapped point on the current working plane, even if you snap to a point outside that working plane. +


      +

      +

      Use

      +


      +
      +


      +

      +

      Notes

      +


      +
      +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Draft_mapping_files.html b/localwiki/Draft_mapping_files.html new file mode 100644 index 0000000..396ef9f --- /dev/null +++ b/localwiki/Draft_mapping_files.html @@ -0,0 +1,111 @@ +Draft mapping files

      Draft mapping files

      + +

      The Draft module is able to import files created form any program capable of exporting DXF files. But since FreeCAD is very different from AutoCAD and other usual 2D CAD programs, you might want to translate automatically the way DXF entities appear in FreeCAD. +

      For example 2D CAD programs often use a black background, so you make your drawing using bright colors, like yellow, green, etc. Then, when you want to print your drawing, those ugly colors will be mapped to nice black colors with different linewidths. +

      Since FreeCAD is not an AutoCAD clone, we don't need to stick to those ugly colors. The concepts of colors, linewidth, or layers are actually very different in FreeCAD. So, we can take advantage of this new environment and work, for example, with black lines on white background. We can also use different linewidths, so our drawing will look on the screen pretty much the same way as it will be printed (note that printing your drawing from FreeCAD is still not supported at the moment, a little bit more patience!). +

      To use a mapping file, simply navigate to Edit -> Preferences -> Draft -> dxf settings and select those two options: +

      +
      • Import style: Map colors to linewidths
      • +
      • Mapping file: navigate to a .csv file (see below)
      +

      These settings will then be your defaults next time you import a DXF file. +

      The Draft module accepts two types of .csv (comma- or tab-separated file) as mapping file: +

      +

      converting from autocad plot styles

      +

      AutoCAD saves its plot styles as .CTB files. If you open your plot style manager from AutoCAD, you will actually open an explorer window showing the location where those files are saved. The DXF importer cannot use these files directly because, you will have guessed, they are encoded. Fortunately, there is a nice free CTB viewer & converter that can convert CTB files to TAB-separated CSV files. +The .csv files generated by this program can be used immediately, they can also be edited with any spreadsheet application. +

      +

      making your own .csv files

      +

      Making your own mapping files is very easy too. It can be made in a spreadsheet application or in any text editor. The rule is simple: you need 3 columns separated by a tabulation (hit the TAB key). First column is the AutoCAD color, second column is the FreeCAD linecolor RGB value formatted like this: 255,255,255 and the third column is the FreeCAD linewidth in pixels. The first line won't be read. So, you can make one like this, for example: +

      + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
      dxf color + freecad color + freecad linewidth +
      1 + 0,0,0 + 1 +
      2 + 0,0,0 + 2 +
      3 + 0,0,0 + 3 +
      4 + 0,0,0 + 4 +
      5 + 0,0,0 + 5 +
      6 + 0,0,0 + 6 +
      7 + 0,0,0 + 1 +
      8 + 80,80,80 + 1 +
      9 + 160,160,160 + 1 +
      +

      The above table would convert color 1 (red) to black (0,0,0)/1 pixel, color 2 (yellow) to black/2 pixels, color 8 (darkgrey) to some dark shade of grey(80,80,80) and 1 pixel wide, etc, etc. You can specify only the colors that you need. What you didn't specify will receive default color/linewidth. +

      Don't forget that the first line won't be used, so you can use it for writing column titles for example. +If you write a .csv file in a spreadsheet application (such as OpenOffice), be careful that sometimes your spreadsheet will think that something written 100,100,100 is one number (hundred million one hundred thousand hundred) and will want to remove the commas. Also, when you save the file as .csv, be sure to specify that it must be TAB-separated and not COMMA-separated. +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Draft_taskview.jpg b/localwiki/Draft_taskview.jpg new file mode 100644 index 0000000..2022252 Binary files /dev/null and b/localwiki/Draft_taskview.jpg differ diff --git a/localwiki/Draft_tutorial.html b/localwiki/Draft_tutorial.html new file mode 100644 index 0000000..db2b794 --- /dev/null +++ b/localwiki/Draft_tutorial.html @@ -0,0 +1,199 @@ +Draft tutorial

      Draft tutorial

      + +

      + + + + + + + + + + + + + + + + + + + + + + + + + + + +
      +

      Base ExampleCommandModel.png Tutorial

      +
      Topic +
      Drafting +
      Level +
      Beginner +
      Time to complete +
      20 minutes +
      Author +
      Drei +
      FreeCAD version +
      0.16 or above +
      Example File(s) +
      +

      + +
      +


      +

      +

      Introduction

      +

      This tutorial is meant to introduce the reader to the basic workflow of the Draft Workbench, which includes the creation of profiles, the use of working planes, and the creation of dimensions, text and annotations. This tutorial uses the notation (X, Y, Z) to denote the coordinates required to define points in an object. +

      Draft tutorial result.png +

      +

      Requirements

      +
      • FreeCAD version 0.16 or above
      • +
      • The reader know how to use the Data and View tabs to change an element's properties if desired
      +

      Procedure

      +

      It is compulsory to make sure the Draft Snap toolbar will be available to use in this tutorial. +

      +
      1. Start FreeCAD
      2. +
      3. If you haven't opened a new FreeCAD document (most of the FreeCAD window looks greyed-out), from the pull-down menu click File > New or click the Create A New Document tool Document-new.svg.
      4. +
      5. Activate the Draft Workbench
      6. +
      7. Select the Edit menu
      8. +
      9. Click on Preferences
      10. +
      11. Go to Draft and select the Grid and snapping tab
      12. +
      13. Verify that the Show Draft Snap toolbar is active
      +

      Note that you can change the visibility of the Grid in this menu, in case you wish to disable it. +

      +

      Using Planes

      +

      Planes are used to restrict the behaviour of the Draft tools to a specific plane, avoiding problems with the location of points and curves in complex workpieces. +Planes can reference the axes of the coordinate system (XY, YZ, ...) or they can use a planar surface in the document as its reference. +

      +
      1. Select Draft SelectPlane.png Set working plane. It ca be located within the Draft workbench toolbar or inside the Draft menu in the Utilities division.
      2. +
      3. Selec the XY plane
      +

      Creating Profiles

      +

      The creation of profiles can be done in several ways. Though it is possible to use simple arcs and lines to do most of the work, FreeCAD includes several tools to speed up the process. +

      +
      Lines and Arcs
      +
      1. Select Draft Arc.png Arc.
      2. +
      3. Set the center at (0, 0, 0)
      4. +
      5. Set the radius to 30 mm
      6. +
      7. The starting angle is 60.0°
      8. +
      9. The aperture is 60.0°
      +

      Repeat the same procedure for a second arc with a radius of 25 mm, the other properties remain unchanged. +

      We will now close the profile with a couple of lines. +

      +
      1. Select Draft Line.png Line.
      2. +
      3. Approach the Endpoint of either arc. A white point should appear, alongside this icon Snap Endpoint.png when your cursor approaches the endpoint.
      4. +
      5. Select the endpoint of the other arc.
      6. +
      7. Repeat for the other side of the arcs.
      +

      We now have several curves that detail a profile, however it is still not recognized as a single entity. It is possible to continue working with the elements intact, though in this case we will fuse them into a single object. +

      The following actions will alter the way the objects behave, making it hard to edit their properties, so it is best to do any necessary modifications before proceding. +

      +
      1. Select an arc and a line while pressing the CTRL key
      2. +
      3. Click on Draft Upgrade.png Upgrade
      +

      This will fuse both objects into a Wire. Repeat until the four elements are fused into a single Wire. +


      +

      +
      Planes, Rectangles and Circles
      +
      1. Click Draft Rectangle.png Rectangle
      2. +
      3. Set the first point on (-100, -60, 0)
      4. +
      5. Set the second point on (140, 90, 0)
      +

      The result is a Plane. Its properties can be modified to remove the filling, by changing its Display Mode to Wireframe. +

      +
      1. Select Draft Circle.png
      2. +
      3. Set the center to (0, 0, 0)
      4. +
      5. Set the radius to 15 mm
      +
      Polygons
      +
      1. Select Draft Polygon.png Polygon
      2. +
      3. The center point is located at (0, 0, 0)
      4. +
      5. Set the radius to 50 mm
      6. +
      7. Set the number of sides to 6
      +
      Arrays
      +

      Arrays are used to replicate an object several times in a direction, a revolution axis or along a path. +

      +
      1. Select the Wire that was previously created
      2. +
      3. Click Draft Array.png Array
      4. +
      5. In the Data tab of the object, change the Array type from ortho to polar
      6. +
      7. Change Number Polar from 1 to 3
      +


      +

      +

      Adding Dimensions

      +

      Dimensions require a constant use of Snapping Constraints to properly select the points that one wishes to dimension. The Snapping toolbar is used to change the possible points that can be selected. +

      +
      1. Select Draft Dimension.png Dimension
      2. +
      3. Select the first point. This can be either an existing element or specified by coordintes. For this tutorial, the first point will always be (0, 0, 0)
      4. +
      5. Select the second point. Approach the midpoint of the top line of the polygon. A white point should appear alongside this icon Snap Midpoint.png
      6. +
      7. Move the cursor to the desired location of the dimension and click on it.
      8. +
      9. Change the font size on the View tab to 6 mm
      +

      Repeat the process for the arcs and circles. +

      +

      Annotations and Text

      +

      There is a slight difference between the two: it is only possible to use the second one as a profile to perform 3D operations. +

      +
      Annotations
      +
      1. Select Draft Text.png Text
      2. +
      3. Select the reference point in the 3D View. In this case, the midoint of the top arc.
      4. +
      5. Enter your text and press Enter. Repeat for as many lines of text as you wish to input.
      6. +
      7. Press Enter
      +
      Text
      +
      1. Select Draft ShapeString.png ShapeString
      2. +
      3. Select the reference point in the 3D View. This can be an existing point or the current cursor location.
      4. +
      5. Enter your text and press Enter
      6. +
      7. Set the desired font size
      8. +
      9. Leave tracking at 0 mm
      10. +
      11. Select the path to the font file that you wish to use
      +

      Creating Blueprints

      +

      To create blueprints, it is necessary to create a Drawing with the elements that you wish to use. Please read the Drawing tutorial for a detailed description. +

      We are now finished with the basic workflow for the Draft Module. +

      +

      Recommended Lectures

      +
      • For a detailed description of the workbench, please see Draft Module
      • +
      • To know more about the Snapping controls, see Draft Snap
      +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Draft_tutorial_Outdated.html b/localwiki/Draft_tutorial_Outdated.html new file mode 100644 index 0000000..cde1cb2 --- /dev/null +++ b/localwiki/Draft_tutorial_Outdated.html @@ -0,0 +1,204 @@ +Draft tutorial Outdated

      Draft tutorial Outdated

      + +
      + + + + + + + + + + + + + + + + + + + + + + + + + + + +
      +

      Base ExampleCommandModel.png Tutorial

      +
      Topic +
      Drafting +
      Level +
      Beginner +
      Time to complete +
      +
      Author +
      +
      FreeCAD version +
      +
      Example File(s) +
      +

      + +
      +


      +

      +
      The Draft module has changed a lot since this tutorial was written. Several concepts are now different and might not work the way they are described below.
      +


      +This tutorial will teach you how to use FreeCAD's 2D drafting module (also called Draft module) to create a simple architecture drawing. For this purpose, we will be drawing a simple masonry cabin. Let's assume that we received a CAD drawing showing the location of the cabin, and we'll use it to draw our project on top of it. We'll draw a plan, a section and two elevations. +

      +

      Before you begin

      +

      Keep in mind that FreeCAD is still in an early stage of development, so you might not be as productive as with another CAD application, and you will certainly encounter bugs, or experience crashes. FreeCAD now has the ability to save backup files. The number of those backup files can be specified in the preferences dialog. Don't hesitate to allow 2 or 3 backup files until you know well how to deal with FreeCAD. +

      Save your work often, from time to time save your work under a different name, so you have a "safe" copy to fall back to, and be prepared to the possibilty that some commands might not give you the expected results. +

      +

      Setting up your FreeCAD workspace

      +

      FreeCAD is a 3D modeler, but in this tutorial we will use it only for working in 2D. So, we will be drawing on the ground plane, and everything we do will have a Z coordinate of zero. So first, let's put ourselves in top view by pressing the 2 and be sure we are in orthographic projection (key O) otherwise we might get fooled by some perspective effects. +

      Another very important thing to do, is to give custom hotkeys to your Draft commands. So you can do all the commands from the keyboard, which will drastically improve your speed. Basically you can do about everything from the keyboard, and will need the mouse only to draw points and select objects. Go to menu Customize -> Keyboard -> Category Python and select shortcuts as you like, a good idea is to make them easy to remember. For example, I use L for Line, W for Polyline (also called Wire in FreeCAD), A for Arc, C for Circle, M for Move, R for Rotate, F for Offset (O is already taken by Orthographic), D for Dimension, T for Text, etc... +

      Now we are set up, we can begin to draw. +

      +

      Importing CAD drawings

      +

      If you are going to import a 2D cad drawing, chances are high that they will be in a proprietary format such as .dwg (from AutoCAD) or .mcd (from VectorWorks). The specification of those file formats are being kept secret by their vendors, so it is extremely difficult or totally impossible for FreeCAD to support them. However, One file format that is fairly well documented is the DXF format, and the Draft module supports it partially. +

      Almost all CAD applications can export to the DXF format, and you also have several free converters such as openDWG's "Teigha file Converter" utility, that will allow you to convert your file to the DXF format. For example, Doublecad is a free, fully functional CAD program that allows you to export DXF files: +

      Doublecad.jpg +

      Open your DXF file simply with the File -> Open dialog. Several import settings can be configured in the Draft Preferences screen. For example, you can configure if you want the DXF file to be imported with original colors and linewidths, or converted to current Draft color, that you see at the right side of the Draft command bar. But in FreeCAD you won't need to attribute ugly colors to your objects to determine their linewidth. Objects all have independent color and linewidth attributes. So, you can very well forget about DXF colors, or convert everything to the colors of your choice. +

      After importing your drawing in FreeCAD, it will look like this: +

      Situation.jpg +

      Let's begin with doing some cleaning. +

      +
      Tutorial-treeview.jpg
      In FreeCAD, there are no layers like in AutoCAD. We work with groups instead. Groups are another more flexible way to organize your drawing. You can create new groups with a right-click on the tree view, rearrange them, move them into other groups, or move objects to/from groups simply by dragging and dropping things in the tree view. You can also assign current line width and colors to all objects in a group, or turn them on or off by pressing SPACE. +

      Let's put all our objects into one new group, and turn off everything we won't use, like vegetation and dimensions, to speed up our work. +

      +

      Drawing the plan view

      +

      Using the drawing tools

      +

      The only thing we'll need at the moment is the area that is assigned to our cabin. It lies in a separate group named "projection". So we can basically turn off everything else with the SPACE key, and start drawing on top of it. We will draw a small cabin with a guard room and a WC, in very simple structural masonry, so there won't be any need for special concretework in the plan itself. But we'll put a layer of plaster inside, and a layer of ceramics outside. +

      So, let's begin with doing the general shape of our walls: +

      Draft-tutorial-01.jpg +

      Our DXF drawing was drawn in meters, so unless we have any reason to change that, we'll continue with the same units. FreeCAD currently does not have a friendly system to work with real-world units, so we simply assume that "one" means "one meter". +

      Another good thing to remember is to construct temporary geometry whenever you need. You want a point that lies 2 meters away horizontally? Draw a vertical line, move it 2m away, pass a horizontal line through it, there is your point. +

      +
      • Create a rectangle: Snap its cornerpoints with CTRL to the corners of the assigned area
      • +
      • Offset the rectangle: With the rectangle selected, press Offset, press C to turn on copy mode, move your mouse inside the first rectangle so offset knows in which direction to go, and type 0.20, Enter
      • +
      • Turn them into a face: Upgrade the first rectangle, upgrade the second rectangle, then select the outer rectangle, CTRL-select the inner rectangle and press Downgrade
      • +
      • Create the door opening: Make a 1.00 x 0.50 rectangle, move it to the upper corner of our main wall (press C to turn copy mode off).
      • +
      • Move the door opening to the right position: Move it 0.10 to the left. We won't put our opening directly on the corner, because it would make the door difficult to open.
      • +
      • Subtract the door opening: Select the wall, CTRL-select the door opening, and press downgrade.
      +

      A note about upgrade & downgrade

      +

      Now, you must be aware that the openCasCade kernel that FreeCAD is built upon, is a 3D kernel. It is made primarily for 3D operations. When it has to cut or unite planar faces, like we are doing now with upgrade/downgrade operations, it sometimes does strange things, and subsequent operations (like other upgrades/downgrades) sometimes don't give the expected results. Of course with time those behaviours will end up being corrected by the FreeCAD developers, but it is wise to know alternative ways to solve immediate problems. +

      The best way to solve a face that isn't upgrading/downgrading/offsetting correctly, is simply to downgrade it until it is all exploded to single edges, then upgrade those edges together again up to a new face. In case that doesn't work either, simply redraw a new wire (polyline) on top of the problematic face, snapping to its endpoints, then delete the old face and upgrade the new wire. Usually a face that you draw yourself is in much better shape than a face that you obtained by upgrade/downgrade. +

      Another thing to keep in mind is that when you subtract a shape from another, you can find yourself with one object containing several faces. This might difficult your further work (they don't offset correctly, etc), so a good thing in that case is always to separate them with the downgrade tool. +

      +

      Another note about snapping

      +

      There are two forms of snapping in the Draft module: passive snap, which occurs when you simply pass your mouse cursor over an object (an open circle symbol appears), and active snap, which is when you press CTRL. Active snapping allows you to snap to specific points on an object, like its endpoints, midpoints, centers, or intersections with other objects. If you press SHIFT, which is the key for constraining horizontally and vertically, you gain even more snapping points. But this has a cost, because FreeCAD must do many calculations in real time. If you have many objects, you'll begin to feel the difference. So a good trick to speedup your work is to take the habit of working as much as possible with SHIFT and passive snapping only. You will see quickly that you'll obtain accurate results and work much faster. +

      So let's go back to work: +

      +
      • Create a 10cm-wide wall between the main room and the WC. Upgrade it, then upgrade it together with the main wall to unite them
      • +
      • Create other rectangles for your other openings. I put a 60cm-wide window in what will become the WC, a 80cm door between the main room and the WC, and for the big window in the main room I simply left 40cm wall at the left and right side.
      • +
      • Offset all the walls of 1cm, to make a cement/plaster layer, then downgrade the offsetted copies to turn them into simple wires
      • +
      • Create a layer of ceramics on the exterior side, by offsetting our plaster line 2cm, then drawing a 2cm-thick shape between the two lines
      • +
      • Delete the 2cm offset. that we don't need anymore, as well as all construction geometry. If you feel you might need them later, simply put them in a separate group and turn that group off with SPACE.
      +

      This is where we are now (I kept construction geometry there, in blue, for you to see): +

      Draft-tutorial-walls.jpg +

      +

      Importing and building compound objects

      +

      In FreeCAD, compound objects are objects made with the geometry of several other objects. In other softwares, it is called blocks, symbols or components. It is a very handy way to group geometry under one single object. Any of the objects created with the draft module can be grouped into a compound. The command to create a compound is the Upgrade command. The use is simple, select everything you want to turn into a compound, and press Upgrade. If no other more intelligent shape can be created, they will be turned into a compound. +

      Using compound geometry is specially useful to build a symbol library on your disk, so you can reuse them later. One cool use of this, coupled to the DXF import function, is that you can very easily use symbol libraries in DXF format (if your symbols are in dwg format, the free "Teigha file Converter" application can batch-convert all your library at once). +

      Once you have a library of DXF symbols, just drag one of them and drop it on top of your open FreeCAD window and it will be imported in the current document. It won't be imported as a compound, but all of the symbol geometry will be placed in a separate group, so it is easy to select it all and simply press "Upgrade". Beware that AutoCAD users have the bad habit of drawing things very far from the origin point (0,0,0), your inserted symbol can then lie very far from your drawing zone. +

      So, back to our drawing: +

      +
      • Import a sanitary block if you have one, or pick one on the Cad Exchange site, and convert it to DXF with the "Teigha file Converter"
      • +
      • Create the geometry for a door, upgrade it to a compound, copy it to the other door location, downgrade it, adjust the elements to the new size, and upgrade it again
      • +
      • Do the same for the windows
      +

      Draft-tutorial-blocks.jpg +

      +

      Dimensions and annotations

      +

      Now that our plan is more or less ready, we can add dimensions and texts. This is usually pretty straightforward, so there is probably no need to explain much. Just try to dimension everything, and as a convention, always start the dimension lines from the main wall line, not the finishing layer. One thing is good to know, sometimes you draw a text or a dimension over a filled area, and the filled area will cover your dimension. There is a simple way to fix that, it is by downgrading and upgrading again the filled area. It will then be displayed under the other elements. +

      The dimension and text will by default have the same text height, which can be changed in the Draft Preferences page. You can then edit individually each text height. +

      Unfortunately certain non-geometry objects like texts and dimension are still not selectable in the FreeCAD 3D view, you must therefore select them in the tree, and you won't be able to snap to them, but this will probably be solved in a near future. It is also not possible at the moment to choose a font style. To align dimensions, at the moment, you need to draw a line first, then snap your dimensions to that line. +

      Draft-tutorial-dims.jpg +

      +

      Organizing

      +
      Draft-tutorial-typical-tree.jpg
      +

      Finally, we can add a few things to finish our plan, like putting vegetation around the cabin. We can simply copy a few trees from our imported DXF drawing and scale them down with the scale tool, to for example (0.5,0.5). We can also change the line thickness of a couple of objects, for example make the walls thicker, and change the color of some things. And we can organize all our elements in groups. +

      The ability to organize your work in nested groups is surely one of the big advantages of groups over traditional work with layers. In this tutorial, I grouped my objects by type, inside the Plan group. For example, instead of having one big layer with all dimensions of your drawing, each part of the drawing will contain their own dimensions group, making it extremely easy to organize your drawing. +

      You might feel a loss at first if you come from a traditional drawing program like AutoCAD, but you'll quickly see the power that this method brings. +

      For example, all our construction geometry can go in a separate group, that we'll turn off. Maybe later we'll need to make some changes, and it will be handy to have that geometry available. +

      So, now we are ready to draw other parts... +


      +

      +

      Drawing the elevations

      +
      Draft-tutorial-elevation.jpg
      +

      Since in this exercise we are going to stay in pure 2D, we will draw our elevations and sections directly. In more advanced architecture environments (what FreeCAD will hopefully become in some future), we wouldn't need to draw the elevations. We would model the building in 3D and then generate the different views automatically. But for the sake of this exercise (and also because all the needed tools are still not implemented in FreeCAD), we'll do it by hand, like in the old times. +

      We'll begin with the rear wall elevation, because the way our plan is oriented, it can be drawn directly below it, without the need to rotate the view. We will simply draw construction lines from the plan, set horizontal lines to the desired heights, I set the 0.00 level, the +0.15 level of the slab, then heights for the windows, and the roof slab at +2.50. We can then draw our geometry very quickly on top of it. +

      We can then place a couple of annotations, dimensions, and upgrade some of the objects so they appear filled with a color. Finally, we can make a bit of cleaning by creating a "South Elevation" group, then subgroups for our construction geometry and annotations, and place all of our new objects in them. +

      +
      +


      +

      +

      Rotating the view, and creating macros

      +

      Now, we need to draw other elevations of our little building. The simplest way would be to draw them directly under the plan view, as we did with the south elevation. For this, it would be handy to be able to rotate the view by 90°, so we can continue drawing our elevations "on foot". Unfortunately, FreeCAD has at the moment no "Rotate View" tool. But, fortunately, it has tools for us to easily create our own tools, called Macros. So, this is a good opportunity for us to try something easy. +

      Macros, as well as all scripting in FreeCAD, is done in a very simple programming language called python. You can write very complex programs in FreeCAD in python, but you can also use it to perform very simple operations where there still isn't a proper FreeCAD toolbar icon, such as our Rotate The View tool. So, first thing to do, open the Report view, if you closed it, and select the python tab. In there, type (or copy/paste) the following code: +

      +
      import math
      + from pivy import coin
      + cam = Gui.ActiveDocument.ActiveView.getCameraNode()
      + rot = coin.SbRotation()
      + rot.setValue(coin.SbVec3f(0,0,1),math.pi/2)
      + cam.orientation = rot 
      +

      This small script will simply rotate the view by 90° (left). For rotating by -90° (right), you would simply change math.pi/2 by -math.pi/2. If you would like to learn more about python scripting in FreeCAD, there is an extensive Scripting section on this wiki. +

      Now, we need to do one more step, which is save our piece of code in a macro, so we can reuse it later. So, instead of pasting our code in the python interpreter, let's open the macro manager (Tools -> Macros), create a new macro, press the "Edit" button and paste our code in it. Close the macro editor tab, and the macro will be saved. +

      The macros can behave like any other FreeCAD tool. With the Tools -> Customize menu, we can add an icon to our macro, a keyboard shortcut, and add it to a toolbar. +

      +

      Drawing the rotated views

      +
      Draft-tutorial05.jpg
      +

      Now that we can rotate the view at will, we can draw our other elevations. The easiest way is to draw your elevation at the right place under the plan view, and use a "mirror" (a 45°-oriented line) to push the height lines from another elevation. This way, drawing goes pretty fast. +

      +
      +

      Finally, we draw 2 others elevations, and since the fourth one is the same as the second one (but mirrored), we will skip it. We can then draw a cross section, and our drawing is complete: +

      Fctutorial-complete.jpg +

      To be continued... +


      +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/DrawStyleAsIs.svg b/localwiki/DrawStyleAsIs.svg new file mode 100644 index 0000000..c3183b1 --- /dev/null +++ b/localwiki/DrawStyleAsIs.svg @@ -0,0 +1,400 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/DrawStyleFlatLines.svg b/localwiki/DrawStyleFlatLines.svg new file mode 100644 index 0000000..05d1bca --- /dev/null +++ b/localwiki/DrawStyleFlatLines.svg @@ -0,0 +1,273 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/DrawStylePoints.svg b/localwiki/DrawStylePoints.svg new file mode 100644 index 0000000..7f231b5 --- /dev/null +++ b/localwiki/DrawStylePoints.svg @@ -0,0 +1,335 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/DrawStyleShaded.svg b/localwiki/DrawStyleShaded.svg new file mode 100644 index 0000000..12899e7 --- /dev/null +++ b/localwiki/DrawStyleShaded.svg @@ -0,0 +1,250 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/DrawStyleWireFrame.svg b/localwiki/DrawStyleWireFrame.svg new file mode 100644 index 0000000..3a4e751 --- /dev/null +++ b/localwiki/DrawStyleWireFrame.svg @@ -0,0 +1,212 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Drawing-annotation.svg b/localwiki/Drawing-annotation.svg new file mode 100644 index 0000000..e4edf31 --- /dev/null +++ b/localwiki/Drawing-annotation.svg @@ -0,0 +1,163 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [Yorik van Havre] + + + drawing-annotation + 2012-05-02 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Drawing/Gui/Resources/icons/actions/drawing-annotation.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Drawing-clip.svg b/localwiki/Drawing-clip.svg new file mode 100644 index 0000000..26dab6d --- /dev/null +++ b/localwiki/Drawing-clip.svg @@ -0,0 +1,168 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [Yorik van Havre] + + + drawing-clip + 2012-05-16 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Drawing/Gui/Resources/icons/actions/drawing-clip.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Drawing-draft-view.svg b/localwiki/Drawing-draft-view.svg new file mode 100644 index 0000000..3be67a2 --- /dev/null +++ b/localwiki/Drawing-draft-view.svg @@ -0,0 +1,611 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + Jakub Steiner + + + http://jimmac.musichall.cz + + techdraw-draft-view + 2016-01-14 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/TechDraw/Gui/Resources/icons/actions/techdraw-draft-view.svg + + + FreeCAD LGPL2+ + + + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Drawing-dxf-export.jpg b/localwiki/Drawing-dxf-export.jpg new file mode 100644 index 0000000..680a32a Binary files /dev/null and b/localwiki/Drawing-dxf-export.jpg differ diff --git a/localwiki/Drawing-landscape-A0.svg b/localwiki/Drawing-landscape-A0.svg new file mode 100644 index 0000000..8f95ef1 --- /dev/null +++ b/localwiki/Drawing-landscape-A0.svg @@ -0,0 +1,334 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [agryson] Alexander Gryson + + + http://agryson.net + + drawing-landscape-A0 + 2011-10-10 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Drawing/Gui/Resources/icons/actions/drawing-landscape-A0.svg + + + FreeCAD LGPL2+ + + + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Drawing-landscape-A1.svg b/localwiki/Drawing-landscape-A1.svg new file mode 100644 index 0000000..4099526 --- /dev/null +++ b/localwiki/Drawing-landscape-A1.svg @@ -0,0 +1,339 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [agryson] Alexander Gryson + + + http://agryson.net + + drawing-landscape-A1 + 2011-10-10 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Drawing/Gui/Resources/icons/actions/drawing-landscape-A1.svg + + + FreeCAD LGPL2+ + + + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Drawing-landscape-A2.svg b/localwiki/Drawing-landscape-A2.svg new file mode 100644 index 0000000..a8a5d1a --- /dev/null +++ b/localwiki/Drawing-landscape-A2.svg @@ -0,0 +1,339 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [agryson] Alexander Gryson + + + http://agryson.net + + drawing-landscape-A2 + 2011-10-10 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Drawing/Gui/Resources/icons/actions/drawing-landscape-A2.svg + + + FreeCAD LGPL2+ + + + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Drawing-landscape-A3.svg b/localwiki/Drawing-landscape-A3.svg new file mode 100644 index 0000000..f83a4de --- /dev/null +++ b/localwiki/Drawing-landscape-A3.svg @@ -0,0 +1,339 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [agryson] Alexander Gryson + + + http://agryson.net + + drawing-landscape-A3 + 2011-10-10 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Drawing/Gui/Resources/icons/actions/drawing-landscape-A3.svg + + + FreeCAD LGPL2+ + + + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Drawing-landscape-A4.svg b/localwiki/Drawing-landscape-A4.svg new file mode 100644 index 0000000..d97310d --- /dev/null +++ b/localwiki/Drawing-landscape-A4.svg @@ -0,0 +1,339 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [agryson] Alexander Gryson + + + http://agryson.net + + drawing-landscape-A4 + 2011-10-10 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Drawing/Gui/Resources/icons/actions/drawing-landscape-A4.svg + + + FreeCAD LGPL2+ + + + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Drawing-landscape-new.svg b/localwiki/Drawing-landscape-new.svg new file mode 100644 index 0000000..d46042a --- /dev/null +++ b/localwiki/Drawing-landscape-new.svg @@ -0,0 +1,105 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [agryson] Alexander Gryson + + + http://agryson.net + + drawing-landscape-new + 2011-10-10 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Drawing/Gui/Resources/icons/actions/drawing-landscape-new.svg + + + FreeCAD LGPL2+ + + + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Drawing-landscape.svg b/localwiki/Drawing-landscape.svg new file mode 100644 index 0000000..edb12d8 --- /dev/null +++ b/localwiki/Drawing-landscape.svg @@ -0,0 +1,104 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [agryson] Alexander Gryson + + + http://agryson.net + + drawing-landscape + 2011-10-10 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Drawing/Gui/Resources/icons/actions/drawing-landscape.svg + + + FreeCAD LGPL2+ + + + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Drawing-openbrowser.svg b/localwiki/Drawing-openbrowser.svg new file mode 100644 index 0000000..15b2c91 --- /dev/null +++ b/localwiki/Drawing-openbrowser.svg @@ -0,0 +1,541 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [Yorik van Havre] + + + drawing-openbrowser + 2012-01-19 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Drawing/Gui/Resources/icons/actions/drawing-openbrowser.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Drawing-orthoviews.svg b/localwiki/Drawing-orthoviews.svg new file mode 100644 index 0000000..be940d5 --- /dev/null +++ b/localwiki/Drawing-orthoviews.svg @@ -0,0 +1,86 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [wmayer] + + + drawing-orthoviews + 2011-12-11 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Drawing/Gui/Resources/icons/actions/drawing-orthoviews.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Drawing-portrait-A0.svg b/localwiki/Drawing-portrait-A0.svg new file mode 100644 index 0000000..cb3b262 --- /dev/null +++ b/localwiki/Drawing-portrait-A0.svg @@ -0,0 +1,332 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [agryson] Alexander Gryson + + + http://agryson.net + + drawing-landscape-A0 + 2011-10-10 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Drawing/Gui/Resources/icons/actions/drawing-landscape-A0.svg + + + FreeCAD LGPL2+ + + + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Drawing-portrait-A1.svg b/localwiki/Drawing-portrait-A1.svg new file mode 100644 index 0000000..43c0ecd --- /dev/null +++ b/localwiki/Drawing-portrait-A1.svg @@ -0,0 +1,337 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [agryson] Alexander Gryson + + + http://agryson.net + + drawing-landscape-A1 + 2011-10-10 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Drawing/Gui/Resources/icons/actions/drawing-landscape-A1.svg + + + FreeCAD LGPL2+ + + + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Drawing-portrait-A2.svg b/localwiki/Drawing-portrait-A2.svg new file mode 100644 index 0000000..3e0768e --- /dev/null +++ b/localwiki/Drawing-portrait-A2.svg @@ -0,0 +1,337 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [agryson] Alexander Gryson + + + http://agryson.net + + drawing-landscape-A2 + 2011-10-10 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Drawing/Gui/Resources/icons/actions/drawing-landscape-A2.svg + + + FreeCAD LGPL2+ + + + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Drawing-portrait-A3.svg b/localwiki/Drawing-portrait-A3.svg new file mode 100644 index 0000000..deb3175 --- /dev/null +++ b/localwiki/Drawing-portrait-A3.svg @@ -0,0 +1,337 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [agryson] Alexander Gryson + + + http://agryson.net + + drawing-landscape-A3 + 2011-10-10 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Drawing/Gui/Resources/icons/actions/drawing-landscape-A3.svg + + + FreeCAD LGPL2+ + + + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Drawing-portrait-A4.svg b/localwiki/Drawing-portrait-A4.svg new file mode 100644 index 0000000..f0a5d98 --- /dev/null +++ b/localwiki/Drawing-portrait-A4.svg @@ -0,0 +1,337 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [agryson] Alexander Gryson + + + http://agryson.net + + drawing-landscape-A4 + 2011-10-10 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Drawing/Gui/Resources/icons/actions/drawing-landscape-A4.svg + + + FreeCAD LGPL2+ + + + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Drawing-spreadsheet.svg b/localwiki/Drawing-spreadsheet.svg new file mode 100644 index 0000000..a33ebb3 --- /dev/null +++ b/localwiki/Drawing-spreadsheet.svg @@ -0,0 +1,183 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [Yorik van Havre] + + + drawing-spreadsheet + 2016-01-03 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Drawing/Gui/Resources/icons/actions/drawing-spreadsheet.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Drawing-symbol.svg b/localwiki/Drawing-symbol.svg new file mode 100644 index 0000000..7d19cd4 --- /dev/null +++ b/localwiki/Drawing-symbol.svg @@ -0,0 +1,108 @@ + + + + + + + image/svg+xml + + + + + [WandererFan] + + + techdraw-symbol + 2016-01-14 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/TechDraw/Gui/Resources/icons/actions/techdraw-symbol.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson, [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Drawing-view.svg b/localwiki/Drawing-view.svg new file mode 100644 index 0000000..c9e8474 --- /dev/null +++ b/localwiki/Drawing-view.svg @@ -0,0 +1,141 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + New Document + + + [agryson] Alexander Gryson + + + http://agryson.net + + 2011-10-10 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Drawing/Gui/Resources/icons/actions/drawing-view.svg + + + FreeCAD LGPL2+ + + + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/DrawingWorkbench.svg b/localwiki/DrawingWorkbench.svg new file mode 100644 index 0000000..2cc6b67 --- /dev/null +++ b/localwiki/DrawingWorkbench.svg @@ -0,0 +1,436 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + New Document + + + Jakub Steiner + + + http://jimmac.musichall.cz + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Drawing_Annotation.html b/localwiki/Drawing_Annotation.html new file mode 100644 index 0000000..3852e24 --- /dev/null +++ b/localwiki/Drawing_Annotation.html @@ -0,0 +1,70 @@ +Drawing Annotation

      Drawing Annotation

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Drawing Annotation.png Drawing Annotation

      +
      Menu location +
      Drawing → Annotation +
      Workbenches +
      Drawing, Complete +
      Default shortcut +
      none +
      See also +
      None +

      + +
      +


      +

      +

      Description

      +

      This command allows you to place a block of text on a Drawing page. +

      +

      How to use

      +
      1. Create a Drawing page
      2. +
      3. Refresh the view if a Drawing view wasn't opened
      4. +
      5. Press the Drawing Annotation.png Drawing Annotation button
      6. +
      7. Adjust the desired properties, such as text contents, font, size and position.
      +

      Limitations

      +
      • Texts spanned on multiple lines are not supported by the internal Qt-based Svg viewer, but the Open Browser command shows these texts correctly.
      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Drawing_Clip.html b/localwiki/Drawing_Clip.html new file mode 100644 index 0000000..802c05f --- /dev/null +++ b/localwiki/Drawing_Clip.html @@ -0,0 +1,73 @@ +Drawing Clip

      Drawing Clip

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Drawing Clip.png Drawing Clip

      +
      Menu location +
      Drawing → Clip +
      Workbenches +
      Drawing, Complete +
      Default shortcut +
      none +
      See also +
      None +

      + +
      +


      +

      +

      Description

      +

      This command allows you to place a clipping rectangle on a Drawing page. Drawing View objects can then be added to that clipping rectangle, and their display will be truncated by the borders of the rectangle. +

      +

      How to use

      +
      1. Create a Drawing page
      2. +
      3. Refresh the view if a Drawing view wasn't opened
      4. +
      5. Press the Drawing Clip.png Drawing Clip button
      6. +
      7. Adjust the desired properties, such as size and position.
      8. +
      9. Drag and Drop Drawing View objects on the Clip object in the Tree View
      +

      Options

      +
      • A property allows you to show or hide the clipping rectangle itself.
      +

      Limitations

      +
      • Clipping objects are not displayed properly by the internal Qt-based Svg viewer, but the Open Browser command shows them correctly.
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Drawing_Dimensioning_example.jpg b/localwiki/Drawing_Dimensioning_example.jpg new file mode 100644 index 0000000..4c41d4a Binary files /dev/null and b/localwiki/Drawing_Dimensioning_example.jpg differ diff --git a/localwiki/Drawing_Documentation.html b/localwiki/Drawing_Documentation.html new file mode 100644 index 0000000..a6def10 --- /dev/null +++ b/localwiki/Drawing_Documentation.html @@ -0,0 +1,169 @@ +Drawing Documentation

      Drawing Documentation

      + +

      This page documents jcc242's understanding of the Drawing module. It includes files and features that he is currently working on and may not yet be in the master branch. The source for those files is on his Github, but be careful as that is very unstable! +

      + + +

      Base (Mod/Drawing)

      +

      gdtsvg.py

      +

      Python script that generates svg snippets for things such as gd&t symbols, dimension symbols, and basic svg elements such as lines, circles, and paths. +

      It has several support files that don't really do much. Run DrawingTest.py to create a bunch of svg icons in the icon directory that previews various icons in the gdtsvg.py file. settingslist.py and dimesettings, and convert.py are all deprecated from older settings methods and should probably be removed as the Drawing branch approaches merging into master. +

      +

      DrawingAlgos.py

      +

      Creates svg lines from a list of vertices, supports both hidden and visible edges. Should probably be merged with gdtsvg.py as that file matures. +

      +

      createSVG

      +

      Accepts part as an argument, projects the part into lines from the Drawing.project object and then draws creates the svg for each line. +

      +

      App

      +

      Contains the backend side of the drawing module. +

      +

      AppDrawing.cpp

      +

      Initializes the various namespaces and modules and stuff used in the drawing module. Will throw an error if it cannot load the Part module. +

      +

      DrawingExport.cpp

      +

      Two classes: SVGOutput and DXFOutput. They both contain methods to put out the code in their respective language. Typically require an object of the appropriate typedef, and sometimes some additional identifier information. +

      +

      FeatureClip.cpp

      +

      Callback (?) methods for the feature clipping gui, so it would seem. Called alone it will create the clip path, if ShowFrame.getValue is TRUE set it will show the frame border as well. +

      +

      FeaturePage.cpp

      +

      Manages the views. +

      onChanged() for doing stuff when properties get changed. +

      execute() for recalculating a feature view, or so it claims. It seems to have stuff for checking for editable texts and saving drawings. Need to investigate further. +

      getEditableTextsFromTemplate() for retrieving text that can be edited by FreeCAD from an SVG file. +

      +

      FeatureProjection.cpp

      +

      Flattens object to a 2D image? +

      +

      FeatureView.cpp

      +

      Defines the properties for views. +

      +

      FeatureViewAnnotation.cpp

      +

      Defines properties for annotations (right now just text), has an execute method to update the text if changed/moved. +

      +

      FeatureViewPart.cpp

      +

      Constructor to add properties. Gets appearance stuff for projected parts. +

      +

      PageGroup.cpp

      +

      Just adds a property for a list of pages, does not much else. +

      +

      Precompiled.cppp

      +

      Just #include "PreCompiled.h" +

      +

      ProjectionAlgos.cpp

      +

      The constructor just runs the execute() method to update it's stuff +

      invertY: since SVG does its y-axis backwards to every other coordinate system in the world, we must invert it when converting from a FreeCAD part to an SVG projection for the Drawing view. +

      getSVG: fetches the SVG code from the DrawingExport stuff. Formats depending on type of line (hidden or not and some other stuff I need to figure out). +

      getDXF: same as getSVG except for DXF format. +


      +

      +

      Gui

      +

      AppDrawingGui.cpp

      +

      Initializes the drawing gui. +

      +

      AppDrawingGuiPy.cpp

      +

      Provides opening, importing, and exporting interfaces? Looks like it is python accessible. +

      +

      Command.cpp

      +

      Handles commands (from the toolbar?) such as creating new drawings and stuff. It looks like this handles QT calls from clicking the button to whatever command it needs to go to e.g. clicking the CmdDrawingOrthoViews button will show the Ortho views gui in the task dialog spot. +

      +

      DrawingView.cpp

      +

      Does a bunch of qt gui stuff, need to read more on it. +

      +

      TaskDialog.cpp

      +

      Creates the task dialog thing on the side and probably switches to it from the tree view, as appropriate. +

      +

      TaskOrthoViews.cpp

      +

      Creates the task dialog for placing the orthographic views! +

      Does a lot of the calculations for where to position stuff (automatic calculations as well, it seems). +

      Takes the input from the TaskOrthoViews gui and does stuff with it. Uses the single inheritance method talked about on the qt website. +

      +

      ViewProviderPage.cpp

      +

      Constructor adds some properties for the view stuff. +Destructor does nothing. +Attaches something (attaches what? attaches the view to the page?) sets and gets display modes (what are display modes? what do they do and what are possible options?) +Does something about updating some kind of data has a context menu that says "Show drawing", figure out what this means +Has a thing for double clicking to select the view (I think?) +

      showDrawingView seems to do some work on settings things up: gets the current document, sets the window icon and title, adds it to the main window (of FreeCAD?) +

      +

      ViewProviderView.cpp

      +

      Doesn't seem to do much, though I am sure it is important. +

      +

      Workbench.cpp

      +

      Adds the icons to the toolbars and stuff. +

      +

      Workflow

      +

      Program Flow

      +

      CanvasView is the actual QGraphicsScene object and DrawingView processes a list of FeatureView that are linked by reference in /App/FeatureViewPage. DrawingView then chooses the appropriate QGraphicsItem class (QGraphicsItemViewPart or QGraphicsItemViewDimension) and then calls a function in CanvasView to create this and add it to the scene. +

      +

      Adding commands to the Drawing Workbench

      +

      4 simple steps: +

      +
      1. Add a class to Command.cpp. Follow the others for an example of the formatting.
      2. +
      3. Add a title, icon, tooltip, etc., again, follow the existing classes in command.cpp
      4. +
      5. Add your class to the bottom of Command.cpp
      6. +
      7. Add your information to Workbench.cpp, this will tell FreeCAD/Drawing module where to place the icons defined in command.cpp in the actual freecad interface (the toolbars, dropdowns, etc.)
      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Drawing_Landscape_A3.html b/localwiki/Drawing_Landscape_A3.html new file mode 100644 index 0000000..ce63b29 --- /dev/null +++ b/localwiki/Drawing_Landscape_A3.html @@ -0,0 +1,65 @@ +Drawing Landscape A3

      Drawing Landscape A3

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Drawing Landscape A3.png Drawing Landscape A3

      +
      Menu location +
      Drawing → Insert new drawing → A3 Landscape +
      Workbenches +
      Drawing, Complete +
      Default shortcut +
      none +
      See also +
      None +

      + +
      +


      +

      This tool creates a new drawing sheet from already installed templates. Currently, even though the menu and the toolbar allow for A0 to A4 landscape formats, only an A3 Landscape template is available. +

      A Page object will be added to the Project tree, taking the form of a folder icon. Views that will be created afterward will be placed underneath this folder. +

      To open the Drawing viewer to display the page, simply double-click on the Page object, or right-click → Show drawing. The page will be opened in a new tab. You can close the tab and open it again at any time the same way. +

      If the page does not display, click on the View-refresh.png refresh icon in the main toolbar, or go to Edit → Refresh menu, or shortcut CTRL+R. +


      +Drawing Page.png +

      +

      Options

      +
      • The template used by a Page can be changed through its Template property in Data view. Click on the value field, then on the "..." button and navigate to a suitable template. Then refresh the view.
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Drawing_Module.html b/localwiki/Drawing_Module.html new file mode 100644 index 0000000..e26c959 --- /dev/null +++ b/localwiki/Drawing_Module.html @@ -0,0 +1,263 @@ +Drawing Module

      Drawing Module

      + +

      The Drawing module allows you to put your 3D work on paper. That is, to put views of your models in a 2D window and to insert that window in a drawing, for example a sheet with a border, a title and your logo and finally print that sheet. +

      +
      Development of the Drawing Module has stopped, and a new TechDraw Module aiming to replace it will be introduced in version 0.17. Both modules will be provided in v0.17, but the Drawing module may be removed in future releases.
      +


      +

      + + +

      GUI Tools

      +

      These are tools for creating, configuring and exporting 2D drawing sheets +

      + + +
      • Drawing View.png Insert a view: Inserts a view of the selected object in the active drawing sheet
      +
      • Drawing Annotation.png Annotation: Adds an annotation to the current drawing sheet
      +
      • Drawing Clip.png Clip: Adds a clip group to the current drawing sheet
      +
      • Drawing Openbrowser.png Open Browser: Opens a preview of the current sheet in the browser
      +
      • Drawing Orthoviews.png Ortho Views: Automatically creates orthographic views of an object on the current drawing sheet
      +
      • Drawing Symbol.png Symbol: Adds the contents of a SVG file as a symbol on the current drawing sheet
      +
      • Drawing DraftView.png Draft View: Inserts a special Draft view of the selected object in the current drawing sheet
      +
      • Drawing SpreadsheetView.png Spreadsheet View: Inserts a view of a selected spreadsheet in the current drawing sheet
      +
      • Drawing Save.png Save sheet: Saves the current sheet as a SVG file
      +
      • Project Shape: Creates a projection of the selected object (Source) in the 3D view.
      +

      Note +The Draft View tool is used mainly to place Draft objects on paper. It has a couple of extra capabilities over the standard Drawing tools, and supports specific objects like Draft dimensions. +


      +Drawing extraction.png +

      In the picture you see the main concepts of the Drawing module. The document contains a shape object (Schenkel) which we want to extract to a drawing. Therefore a "Page" is created. A page gets instantiated through a template, in this case the "A3_Landscape" template. The template is an SVG document which can hold your usual page frame, your logo or comply to your presentation standards. +

      In this page we can insert one or more views. Each view has a position on the page (Properties X,Y), a scale factor (Property scale) and additional properties. Every time the page or the view or the referenced object changes the page gets regenerated and the page display updated. +

      +

      Scripting

      +

      At the moment the end user(GUI) workflow is very limited, so the scripting API is more interesting. Here follow examples on how to use the scripting API of the drawing module. +

      Here a script that can easily fill the Macro_CartoucheFC leaf FreeCAD A3_Landscape. +

      +

      Simple example

      +

      First of all you need the Part and the Drawing module: +

      +
      import FreeCAD, Part, Drawing 
      +

      Create a small sample part +

      +
      Part.show(Part.makeBox(100,100,100).cut(Part.makeCylinder(80,100)).cut(Part.makeBox(90,40,100)).cut(Part.makeBox(20,85,100))) 
      +

      Direct projection. The G0 means hard edge, the G1 is tangent continuous. +

      +
      Shape = App.ActiveDocument.Shape.Shape
      +[visibleG0,visibleG1,hiddenG0,hiddenG1] = Drawing.project(Shape)
      +print "visible edges:", len(visibleG0.Edges)
      +print "hidden edges:", len(hiddenG0.Edges) 
      +

      Everything was projected on the Z-plane: +

      +
      print "Bnd Box shape: X=",Shape.BoundBox.XLength," Y=",Shape.BoundBox.YLength," Z=",Shape.BoundBox.ZLength
      +print "Bnd Box project: X=",visibleG0.BoundBox.XLength," Y=",visibleG0.BoundBox.YLength," Z=",visibleG0.BoundBox.ZLength 
      +

      Different projection vector +

      +
      [visibleG0,visibleG1,hiddenG0,hiddenG1] = Drawing.project(Shape,App.Vector(1,1,1)) 
      +

      Project to SVG +

      +
      resultSVG = Drawing.projectToSVG(Shape,App.Vector(1,1,1))
      +print resultSVG 
      +

      The parametric way

      +

      Create the body +

      +
      import FreeCAD
      +import Part
      +import Drawing
      +
      +# Create three boxes and a cylinder
      +App.ActiveDocument.addObject("Part::Box","Box")
      +App.ActiveDocument.Box.Length=100.00
      +App.ActiveDocument.Box.Width=100.00
      +App.ActiveDocument.Box.Height=100.00
      +
      +App.ActiveDocument.addObject("Part::Box","Box1")
      +App.ActiveDocument.Box1.Length=90.00
      +App.ActiveDocument.Box1.Width=40.00
      +App.ActiveDocument.Box1.Height=100.00
      +
      +App.ActiveDocument.addObject("Part::Box","Box2")
      +App.ActiveDocument.Box2.Length=20.00
      +App.ActiveDocument.Box2.Width=85.00
      +App.ActiveDocument.Box2.Height=100.00
      +
      +App.ActiveDocument.addObject("Part::Cylinder","Cylinder")
      +App.ActiveDocument.Cylinder.Radius=80.00
      +App.ActiveDocument.Cylinder.Height=100.00
      +App.ActiveDocument.Cylinder.Angle=360.00
      +# Fuse two boxes and the cylinder
      +App.ActiveDocument.addObject("Part::Fuse","Fusion")
      +App.ActiveDocument.Fusion.Base = App.ActiveDocument.Cylinder
      +App.ActiveDocument.Fusion.Tool = App.ActiveDocument.Box1
      +
      +App.ActiveDocument.addObject("Part::Fuse","Fusion1")
      +App.ActiveDocument.Fusion1.Base = App.ActiveDocument.Box2
      +App.ActiveDocument.Fusion1.Tool = App.ActiveDocument.Fusion
      +# Cut the fused shapes from the first box
      +App.ActiveDocument.addObject("Part::Cut","Shape")
      +App.ActiveDocument.Shape.Base = App.ActiveDocument.Box 
      +App.ActiveDocument.Shape.Tool = App.ActiveDocument.Fusion1
      +# Hide all the intermediate shapes 
      +Gui.ActiveDocument.Box.Visibility=False
      +Gui.ActiveDocument.Box1.Visibility=False
      +Gui.ActiveDocument.Box2.Visibility=False
      +Gui.ActiveDocument.Cylinder.Visibility=False
      +Gui.ActiveDocument.Fusion.Visibility=False
      +Gui.ActiveDocument.Fusion1.Visibility=False 
      +

      Insert a Page object and assign a template +

      +
      App.ActiveDocument.addObject('Drawing::FeaturePage','Page')
      +App.ActiveDocument.Page.Template = App.getResourceDir()+'Mod/Drawing/Templates/A3_Landscape.svg' 
      +

      Create a view on the "Shape" object, define the position and scale and assign it to a Page +

      +
      App.ActiveDocument.addObject('Drawing::FeatureViewPart','View')
      +App.ActiveDocument.View.Source = App.ActiveDocument.Shape
      +App.ActiveDocument.View.Direction = (0.0,0.0,1.0)
      +App.ActiveDocument.View.X = 10.0
      +App.ActiveDocument.View.Y = 10.0
      +App.ActiveDocument.Page.addObject(App.ActiveDocument.View) 
      +

      Create a second view on the same object but this time the view will be rotated by 90 degrees. +

      +
      App.ActiveDocument.addObject('Drawing::FeatureViewPart','ViewRot')
      +App.ActiveDocument.ViewRot.Source = App.ActiveDocument.Shape
      +App.ActiveDocument.ViewRot.Direction = (0.0,0.0,1.0)
      +App.ActiveDocument.ViewRot.X = 290.0
      +App.ActiveDocument.ViewRot.Y = 30.0
      +App.ActiveDocument.ViewRot.Scale = 1.0
      +App.ActiveDocument.ViewRot.Rotation = 90.0
      +App.ActiveDocument.Page.addObject(App.ActiveDocument.ViewRot) 
      +

      Create a third view on the same object but with an isometric view direction. The hidden lines are activated too. +

      +
      App.ActiveDocument.addObject('Drawing::FeatureViewPart','ViewIso')
      +App.ActiveDocument.ViewIso.Source = App.ActiveDocument.Shape
      +App.ActiveDocument.ViewIso.Direction = (1.0,1.0,1.0)
      +App.ActiveDocument.ViewIso.X = 335.0
      +App.ActiveDocument.ViewIso.Y = 140.0
      +App.ActiveDocument.ViewIso.ShowHiddenLines = True
      +App.ActiveDocument.Page.addObject(App.ActiveDocument.ViewIso) 
      +

      Change something and update. The update process changes the view and the page. +

      +
      App.ActiveDocument.View.X = 30.0
      +App.ActiveDocument.View.Y = 30.0
      +App.ActiveDocument.View.Scale = 1.5
      +App.ActiveDocument.recompute() 
      +

      Accessing the bits and pieces

      +

      Get the SVG fragment of a single view +

      +
      ViewSVG = App.ActiveDocument.View.ViewResult
      +print ViewSVG 
      +

      Get the whole result page (it's a file in the document's temporary directory, only read permission) +

      +
      print "Resulting SVG document: ",App.ActiveDocument.Page.PageResult
      +file = open(App.ActiveDocument.Page.PageResult,"r")
      +print "Result page is ",len(file.readlines())," lines long" 
      +

      Important: free the file! +

      +
      del file 
      +

      Insert a view with your own content: +

      +
      App.ActiveDocument.addObject('Drawing::FeatureView','ViewSelf')
      +App.ActiveDocument.ViewSelf.ViewResult = """<g id="ViewSelf"
      +  stroke="rgb(0, 0, 0)"
      +  stroke-width="0.35"
      +  stroke-linecap="butt"
      +  stroke-linejoin="miter"
      +  transform="translate(30,30)"
      +  fill="#00cc00"
      +  >
      +
      +  <ellipse cx="40" cy="40" rx="30" ry="15"/>
      +  </g>"""
      +App.ActiveDocument.Page.addObject(App.ActiveDocument.ViewSelf)
      +App.ActiveDocument.recompute()
      +
      +del ViewSVG 
      +

      That leads to the following result: +

      DrawingScriptResult.jpg +

      +

      General Dimensioning and Tolerancing

      +

      Drawing dimensions an tolerances are still under development but you can get some basic functionality with a bit of work. +

      First you need to get the gdtsvg python module from here (WARNING: This could be broken at any time!): +

      https://github.com/jcc242/FreeCAD +

      To get a feature control frame, try out the following: +

      +
      import gdtsvg as g # Import the module, I like to give it an easy handle
      +ourFrame = g.ControlFrame("0","0", g.Perpendicularity(), ".5", g.Diameter(), g.ModifyingSymbols("M"), "A",  
      +           g.ModifyingSymbols("F"), "B", g.ModifyingSymbols("L"), "C", g.ModifyingSymbols("I")) 
      +

      Here is a good breakdown of the contents of a feature control frame: http://www.cadblog.net/adding-geometric-tolerances.htm +

      The parameters to pass to control frame are: +

      +
      1. X-coordinate in SVG-coordinate system (type string)
      2. +
      3. Y-coordinate in SVG-coordinate system (type string)
      4. +
      5. The desired geometric characteristic symbol (tuple, svg string as first, width of symbol as second, height of symbol as third)
      6. +
      7. The tolerance (type string)
      8. +
      9. (optional) The diameter symbol (tuple, svg string as first, width of symbol as second, height of symbol as third)
      10. +
      11. (optional) The condition modifying material (tuple, svg string as first, width of symbol as second, height of symbol as third)
      12. +
      13. (optional) The first datum (type string)
      14. +
      15. (optional) The first datum's modifying condition (tuple, svg string as first, width of symbol as second, height of symbol as third)
      16. +
      17. (optional) The second datum (type string)
      18. +
      19. (optional) The second datum's modifying condition (tuple, svg string as first, width of symbol as second, height of symbol as third)
      20. +
      21. (optional) The third datum (type string)
      22. +
      23. (optional) The third datum's material condition (tuple, svg string as first, width of symbol as second, height of symbol as third)
      +

      The ControlFrame function returns a type containing (svg string, overall width of control frame, overall height of control frame) +

      To get a dimension, try out the following: +

      +
      import gdtsvg
      +ourDimension = linearDimension(point1, point2, textpoint, dimensiontext, linestyle=getStyle("visible"), 
      +               arrowstyle=getStyle("filled"), textstyle=getStyle("text") 
      +

      Inputs for linear dimension are: +

      +
      1. point1, an (x,y) tuple with svg-coordinates, this is one of the points you would like to dimension between
      2. +
      3. point2, an (x,y) tuple with svg-coordinates, this is the second point you would like to dimension between
      4. +
      5. textpoint, an (x,y) tuple of svg-coordinates, this is where the text of your dimension will be
      6. +
      7. dimensiontext, a string containing the text you want the dimension to say
      8. +
      9. linestyle, a string containing svg (i.e. css) styles, using the getStyle function to retrieve a preset string, for styling the how the lines look
      10. +
      11. arrowstyle, a string containing svg (i.e. css) styles, using the getStyle function to retrieve a preset string, for styling how the arrows look
      12. +
      13. textstyle, a string containing svg (i.e. css) styles, using the getStyle function to retrieve a preset string, for styling how the text looks
      +

      With those two, you can proceed as above for displaying them on the drawing page. This module is very buggy and can be broken at any given moment, bug reports are welcome on the github page for now, or contact jcc242 on the forums if you post a bug somewhere else. +

      +

      Templates

      +

      FreeCAD comes bundled with a set of default templates, but you can find more on the Drawing templates page. +

      +

      Extending the Drawing Module

      +

      Some notes on the programming side of the drawing module will be added to the Drawing Documentation page. This is to help quickly understand how the drawing module works, enabling programmers to rapidly start programming for it. +

      +

      Tutorials

      + +


      +

      +

      External links

      + +


      +

      + +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Drawing_Open_SVG.html b/localwiki/Drawing_Open_SVG.html new file mode 100644 index 0000000..8870cc7 --- /dev/null +++ b/localwiki/Drawing_Open_SVG.html @@ -0,0 +1,58 @@ +Drawing Open SVG

      Drawing Open SVG

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Drawing Open SVG.png Drawing Open SVG

      +
      Menu location +
      Drawing → Open SVG... +
      Workbenches +
      Drawing, Complete +
      Default shortcut +
      none +
      See also +
      Drawing Save +

      Contents

      + +
      + +
      +


      +

      This tool opens a drawing sheet previously saved as an SVG (scalable vector graphics) file. It can also be used to display any SVG. +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Drawing_Openbrowser.html b/localwiki/Drawing_Openbrowser.html new file mode 100644 index 0000000..cb1fd77 --- /dev/null +++ b/localwiki/Drawing_Openbrowser.html @@ -0,0 +1,69 @@ +Drawing Openbrowser

      Drawing Openbrowser

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Drawing Openbrowser.png Drawing Openbrowser

      +
      Menu location +
      Drawing → Open Browser +
      Workbenches +
      Drawing, Complete +
      Default shortcut +
      none +
      See also +
      None +

      + +
      +


      +

      +

      Description

      +

      This command allows you to display a selected Drawing page using FreeCAD's internal web browser. The normal Drawing page viewer of FreeCAD is based on Qt's built-in SVG rendering module, which only supports a tiny subset of the full SVG specification. As a result, some more advanced SVG features, such as pattern fills or multiline texts are not supported by this viewer. The FreeCAD internal web browser, however, is built on webkit, which is one of the best SVG renderers available, and will correctly render your page with all its features. +

      +

      How to use

      +
      1. Create a Drawing page
      2. +
      3. Add some views or other content to your page
      4. +
      5. Refresh the view if a Drawing view wasn't opened
      6. +
      7. Press the Drawing Openbrowser.png Drawing Openbrowser button
      +

      Limitations

      +
      • A page opened in the web browser will not refresh automatically on changes. You must use right-click -> reload manually.
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Drawing_Orthoviews.html b/localwiki/Drawing_Orthoviews.html new file mode 100644 index 0000000..49fa263 --- /dev/null +++ b/localwiki/Drawing_Orthoviews.html @@ -0,0 +1,116 @@ +Drawing Orthoviews

      Drawing Orthoviews

      + +
      +

      This documentation is not finished. Please help and contribute documentation. +

      See Draft ShapeString for good documented Command. Gui Command gives an overview over commands. And see List of Commands for other commands. +

      Go to Help FreeCAD to contribute. +

      +
      +


      +

      +

      Description

      + + + + + + + + + + + + + + + + + + + + +
      +

      Drawing Orthoviews.png Drawing Orthoviews

      +
      Menu location +
      Drawing → Insert orthographic views +
      Workbenches +
      Drawing, Complete +
      Default shortcut +
      none +
      See also +
      Drawing Landscape A3 +

      + +
      +


      +


      +The Orthoviews tool inserts a set of orthographic projections of the selected object in the active drawing sheet. Note that it does not create a single view object on the page. Instead, a separate orthographic projection will be created for each of the views selected in the options. +

      The Orthoviews tool creates all of the orthographic projections is the proper location for the given main view. +

      +

      How to use

      +
      1. Select a feature in the model tree.
      2. +
      3. If there is more than one page, multi-select the desired page (while keeping the feature selected).
      4. +
      5. Press the Drawing Orthoviews.png Insert orthographic views button.
      6. +
      7. Define your desired view creation options. See Options.
      8. +
      9. Click OK to create the views of the selected feature on the selected page.
      +

      Options

      +

      Depending on the selections made, some options may not be available. +

      +
      Drawing Orthoviews Options.png
      +
      • Projection: Select whether you want a third angle (default) or first angle projection
      • +
      • View from: Choose the axis that will face out of the drawing sheet toward the user.
      • +
      • Axis aligned right: Choose the axis that will point to the right on the drawing sheet. The remaining axis will be vertical on the page.
      • +
      • Secondary views: Choose the views that you wish to have created. The main view lies in the center of the checkboxes, and is oriented by the View from and Axis aligned right options. Secondary views will be created for each box that is checked.
      +

      General

      +
      • Auto scale / position: If this box is checked, the view scale, location, and spacing will be chosen to best use the available space on the page. If this box is unchecked, the user specifies scale, location, and spacing.
      • +
      • Scale: The scale for the view, expressed as the denominator of a scale fraction. Thus, 2 will create a set of views scaled at 1:2.
      • +
      • Top left x / y: The location of the set of views from the top left of the page. Incresing the x value (first column) moves the views to the right. Increasing the y value (second column) moves the views down on the page.
      • +
      • Spacing dx / dy: The x (first column) and y (second column) spacings between adjacent views. The spacings are the spacing of the Part coordinate system; in most cases there will be less blank space between the views that the spacing value (as the views have x and y dimensions).
      • +
      • Show hidden lines: If selected, hidden lines will be visible in the created views.
      • +
      • Show smooth lines: If selected, show lines where curvature is discontinuous (for example, where a fillet connects to a flat part).
      +

      Properties

      +

      There are no properties for this command; the command creates properties for each of the individual views. +

      +

      Scripting

      +

      Drawing Orthoviews is not called in scripting. The individual views created by the Drawing Orthoviews command can be created in scripts. +

      +

      Limitations

      +

      To be added +

      +

      Tutorials

      +

      To be added +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Drawing_Orthoviews_Options.png b/localwiki/Drawing_Orthoviews_Options.png new file mode 100644 index 0000000..ed2a243 Binary files /dev/null and b/localwiki/Drawing_Orthoviews_Options.png differ diff --git a/localwiki/Drawing_ProjectShape.html b/localwiki/Drawing_ProjectShape.html new file mode 100644 index 0000000..4d95a41 --- /dev/null +++ b/localwiki/Drawing_ProjectShape.html @@ -0,0 +1,112 @@ +Drawing ProjectShape

      Drawing ProjectShape

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Drawing ProjectShape.png Drawing ProjectShape

      +
      Menu location +
      Drawing → Project shape +
      Workbenches +
      Drawing, Complete +
      Default shortcut +
      +
      See also +
      +

      + +
      +


      +

      +

      Description

      +

      This tool creates a projection of the selected object (Source) in the 3D view. +

      ProjectShape1 it.png +


      +

      +

      Usage

      + + + +
      ProjectShapeSet it.png + +
      1. Select an object in the 3D view or in the project tree
      2. +
      3. from the Drawing menu, click Project shape
      4. +
      5. set the desired options in the Task Dialog
      6. +
      7. click OK
      +


      +A projection object (objectname_proj) will be added to the project. For subsequent projections of the same Source object, the projection object will be named objectname_projXXX, where XXX is a three digit number. +

      +
      +

      Edit an existing projection

      + + + +
      ProjectShapeOptions it.png
      +
      +

      The projection parameters can be edited in the Property editor. +

      +Base +

      +
      • DATALabel :
      • +
      • DATAPlacement :
      +


      +Projection +

      +
      • DATADirection : defines the direction of the projection. This is the normal vector of the projection plane. For example, to project the object onto the xy plane, use (0,0,1). To reverse the projection, use negative values.
      • +
      • DATAHCompound :
      • +
      • DATAIso Line HCompound :
      • +
      • DATAIso Line VCompound :
      • +
      • DATAOut Line HCompound :
      • +
      • DATAOut Line VCompound :
      • +
      • DATARg1 Line HCompound :
      • +
      • DATARg1 Line VCompound :
      • +
      • DATARg NLine HCompound :
      • +
      • DATARg NLine VCompound :
      • +
      • DATASource : the object being projected
      • +
      • DATAVCompound :
      +
      +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Drawing_ProjectShape.png b/localwiki/Drawing_ProjectShape.png new file mode 100644 index 0000000..782eb4d Binary files /dev/null and b/localwiki/Drawing_ProjectShape.png differ diff --git a/localwiki/Drawing_Save.html b/localwiki/Drawing_Save.html new file mode 100644 index 0000000..cefad31 --- /dev/null +++ b/localwiki/Drawing_Save.html @@ -0,0 +1,59 @@ +Drawing Save

      Drawing Save

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Drawing Save.png Drawing Save

      +
      Menu location +
      Drawing → Export page... +
      Workbenches +
      Drawing, Complete +
      Default shortcut +
      none +
      See also +
      Drawing Open SVG +

      Contents

      + +
      + +
      +


      +

      This tool saves the current Drawing sheet as an SVG (scalable vector graphics) file. Such a file can then be edited in a scalable vector graphics program such as Inkscape. +

      SVG files are common and can be viewed in most modern browsers and image viewers. It can be a useful way to share a design with people who don't have FreeCAD installed on their PC. +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Drawing_SpreadsheetView.html b/localwiki/Drawing_SpreadsheetView.html new file mode 100644 index 0000000..af6be0a --- /dev/null +++ b/localwiki/Drawing_SpreadsheetView.html @@ -0,0 +1,73 @@ +Drawing SpreadsheetView

      Drawing SpreadsheetView

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Drawing SpreadsheetView.png Drawing SpreadsheetView

      +
      Menu location +
      Drawing → Spreadsheet View +
      Workbenches +
      Drawing +
      Default shortcut +
      None +
      See also +
      None +

      + +
      +


      +

      +

      Description

      +

      This tool allows you to place a view of a selected spreadsheet on a drawing sheet. +

      Drawing spreadsheetview.jpg +

      +

      How to use

      +
      1. Select a spreadsheet you wish to put on a drawing sheet
      2. +
      3. Press the Drawing SpreadsheetView.png Drawing SpreadsheetView button
      +

      Properties

      +
      • DATACell Start: The top left cell of the cells range to be included in this view
      • +
      • DATACell End: The bottom right cell of the cells range to be included in this view
      • +
      • DATAFont: The name of the font used for texts
      • +
      • DATAColor: The color of lines and texts that have no color specified in the spreadsheet
      • +
      • DATAFont Size: The font size of texts
      • +
      • DATALine Width: The width of the cell borders
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Drawing_Symbol.html b/localwiki/Drawing_Symbol.html new file mode 100644 index 0000000..9ce6a6a --- /dev/null +++ b/localwiki/Drawing_Symbol.html @@ -0,0 +1,68 @@ +Drawing Symbol

      Drawing Symbol

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Drawing Symbol.png Drawing Symbol

      +
      Menu location +
      Drawing → Symbol +
      Workbenches +
      Drawing, Complete +
      Default shortcut +
      none +
      See also +
      None +

      + +
      +


      +

      +

      Description

      +

      This command allows you to add the contents of a SVG image on a selected Drawing page. These contents can then be moved and rescaled on the page. The contents of the SVG image are copied into the FreeCAD document, so it is independent from the original file, and will display the same way on another computer that doesn't have the original SVG file. +

      +

      How to use

      +
      1. Create a Drawing page
      2. +
      3. Refresh the view if a Drawing viewer wasn't opened
      4. +
      5. Press the Drawing Symbol.png Drawing Symbol button
      6. +
      7. Select a SVG file
      8. +
      9. Adjust the needed properties, like position and scale.
      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Drawing_Template_HowTo.html b/localwiki/Drawing_Template_HowTo.html new file mode 100644 index 0000000..126bacd --- /dev/null +++ b/localwiki/Drawing_Template_HowTo.html @@ -0,0 +1,229 @@ +Drawing Template HowTo

      Drawing Template HowTo

      + +
      + + + + + + + + + + + + + + + + + + + + + + + + + + + +
      +

      Base ExampleCommandModel.png Tutorial

      +
      Topic +
      2D Drafting +
      Level +
      Intermediate +
      Time to complete +
      An hour or less +
      Author +
      Mark Stephen (Quick61) +
      FreeCAD version +
      0.14.3700 or greater +
      Example File(s) +
      None +

      + +
      +


      +

      +

      Introduction

      +

      This tutorial will take you through the basic creation and modification of a SVG graphics file for use as a drawing template within FreeCAD's Drawing Workbench. As of FreeCAD version 0.14, revision 2995, the Drawing Workbench will project the selected part onto the drawing template following rules set within the SVG document. Those rules define the Working space, in X / Y coordinates, where FreeCAD may project the part and automatically avoid intrusions into the space occupied by the Title block. +

      Anyone designing templates to be shared, all the basic guidelines laid out in this tutorial should be followed. Having the tags for “Working space” and “Title block” included in the template does not excluded it from being used in older versions of FreeCAD. While including these tags will make your template fully functional for current revisions. +

      This tutorial will begin with setting up a page in Inkscape and making a basic template drawing. Followed by adding some artwork to give that personal or professional touch to your work. Next, you will see how to edit your new template and what information it needs to contain for use with FreeCAD. +

      This tutorial assumes the reader to have basic knowledge of Inkscape, and a text editor. +


      +

      +

      The Basics

      +

      Page Setup

      +

      Begin with a new document within Inkscape. Referring to the FreeCAD Wiki page on Drawing templates, one pixel = one millimeter. That means if you wish to create a Drawing template for an ANSI A sized page, (letter size), which is 216mm X 279mm, our template should be sized 216px X 279px. If you wish for the page to be landscape orientated, those numbers would be reversed. For the purposes of this tutorial, landscape orientation will be used. The page is defined as being 279px wide and 216px high. +

      In Inkscape, pull down the File menu and select Document Properties You should now see the Document Properties window. Edit the Width and Height as mentioned and insure that the Units is set to px. +

      Inkscape Template tut 1.png +

      You should now have an Inkscape document that is 279px wide and 216px high. Now proceed to add a border. +

      +

      The Border

      +

      Next, make the border. While not necessary, for purposes of this tutorial, it will be referenced later on. +

      Using the “Draw Bezier curves and straight lines” tool, and selecting the Mode “Create a sequence of paraxial line segments”, make a rectangle within the borders of the document. Once this rectangle is closed, click on the Select and transform objects tool. The rectangle should now show it is selected. If not, use the tool and select it. +

      Using the Horizontal and Vertical coordinates of selection settings, along with the settings for Width and Height of selection, we will place the border 10 units, (px) in from the document edges. Enter the following. For X enter 10, for Y enter 10, for W enter 259, and for H enter 196. You will see that this set the lower left corner of the rectangle drawn for the border 10 up and 10 over from the lower left corner of the page. Entering the Width and Height sized the rectangle so it is now evenly spaced within the document boundaries. +

      Inkscape Template tut 2.png +

      +

      The Title Block

      +

      Next you will make a Title Block. This is where the editable text about the Drawing will be entered when used with FreeCAD. This tutorial will use a simple example. The Title Block can be as simple, or complex as one wishes. +

      This example Title Block will contain the following, Project Name, Date, Scale, and Author. It will then be placed in the lower right hand corner of the border. +

      First you start with making a rectangle somewhere within the borders of the document. Make it in the same manner as you did the border. Then divide it into 4 sections as you see fit. Once done, Select the box and the dividing lines, make them a group, and locate it at X =169, Y 10 and size it W=100, H=50, in the same manner done for the border. +

      Inkscape Template tut 3.png +

      +

      Fixed Text

      +

      Next, you will add the text blocks that will be fixed within the Title Block. These will be Project Name, Date, Scale, and Author. To do this, select the text tool and click it somewhere in the document. Then simply type in the text, one block to each name. Click the text tool in the document and after selecting the appropriate font size, (size 6 works for this example), type in Project Name. Then move the pointer to a new location and click again, starting a new text block and type in Date. Do the same for Scale, and Author. Now using the select tool the individual text blocks can be moved by dragging and / or the arrow keys to place them into the desired locations. +

      After the text blocks are placed they should all be selected, along with the title block and made a group. At this point the Title Block and the fixed text are joined together as one. +

      Inkscape Template tut 4.png +

      +

      Editable Text

      +

      Now you will add the text blocks that we will want to be editable from within FreeCAD. In the same manner that the fixed text was done, the editable text will be made and placed in their respective locations, You will use the text as follows. NAME, DATE, SCALE, AUTHOR, and make them font size 8. Once the text is placed, select the 4 text fields you wish to be editable and make them a separate group. Do not include them into the same group as the Title Block or Border. For now you are done with the editable text. After the graphical part of the template is done, you will complete the process of making this text editable from within FreeCAD. For now, we will complete this part with adding a little artwork to your template. +

      Inkscape Template tut 5.png +


      +

      +

      Advanced

      +

      Adding Artwork

      +

      Now that the basic template is done, you can add a bit of artwork to it. This can be whatever you wish. A company or personal graphical logo, a picture or rendering of the project, etc.. For this tutorial the FreeCAD logo, found in the Artwork section of the FreeCAD Wiki will be used. You can simply right click on it and select save image. Once saved, import it into Inkscape. With the image imported into your template, it can be sized and placed where ever you may wish it to be. Adding artwork to your template is as easy as that. +

      At this point, you can select File, then Save. In this tutorial, the file was simply named TemplateExample.svg but you may name it whatever you wish. +

      Inkscape Template tut 6.png +

      +

      Once Your Template Is Made

      +

      Opening The File With A Text Editor

      +

      Once your template is saved, open it with your favorite text editor. This can be something as basic as Windows Notepad or a more complete editor like Kate. In this tutorial, Kate will be used and all screenshots will be of that editor. +

      Opening the SVG file with your text editor you will see the following. +

      Kate1.png +

      +

      The “xmlns:freecad” Tag

      +

      The first thing is to insert the following line into the document. This line is the SVG namespace declaration and must be provided so that all SVG elements are identified as belonging to the SVG namespace. +

      +
      xmlns:freecad="http://www.freecadweb.org/wiki/index.php?title=Svg_Namespace"
      +
      +

      This line is added immediately following the first <svg tag, and in the same margin spacing as the other xmlns entries are placed. +

      Kate2.png +

      +

      Page Size

      +

      In order to allow a final drawing to be printed in the right scale, the template must contain it's dimensions in real world units. Otherwise the whole drawing page would be printed scaled down by a factor of 3.54 (90(px/in)/25.4(in/mm)). +Inside the the <SVG>-Tag the unit "mm" is added to the width and height fields. And a viewBox Attribute has to be added. +The viewBox ranges from 0 0 to the width and height of the template. This way the SVG user unit (px) is redefined to be 1mm long. In consequence programs like Inkscape will be able to print a resulting drawing up to scale. +Current versions of Inkscape handle this information very badly. Inkscape effectively rescales the whole document to 90dpi. This is not much of a problem for a final drawing, but imposes difficulties for editing drawing templates. After editing a template in Inkscape, it would have the same real word size on its own but elements of the drawing would be scaled down by a factor of 3.54. (Because the template would be in 90dpi but FreeCAD assumes 1px/mm.) +Therefore it's recommended to remove the "mm" from the width and height attributes before opening an existing template in inkscape and recreate the units and viewBox attribute afterwards. +

      +
      width="279mm"
      +height="216mm"
      +viewBox="0 0 279 216"
      +

      Kate2a.png +

      +

      Working space and Title block Tags

      +

      The next lines to add will be the Working space and Title block tag. These tags and their usage are defined on the Drawing Templates page. While these tags are not required, newer versions of the FreeCAD Drawing Workbench benefit from them and they will not affect older versions. +

      The Working space tag is used to define the space that FreeCAD may make projections into. This allows FreeCAD to make automatic projections on the drawing template and stay within the border that has be drawn, or withing any defined space on the page. +

      The Title block tag is used to define where within the Working space it resides. This information is used by FreeCAD to avoid using that space within the Working space. This can be referred to as Title block avoidance. +

      If both tags are used, the Working space tag must appear first and be immediately followed by the title block tag. Both tags must also appear before the first <metadata tag. These tags can be placed either at the top, following the <? xml tag or immediately before the <metadata tag. For this tutorial we will place them at the top. +

      +

      The Working space Tag

      +

      The first tag is the Working space tag and is formated as follows. +

      +
      <!-- Working space X1 Y1 X2 Y2 -->
      +

      Where X1, Y1, X2, Y2 are defined as: +

      +
      • X1 is the X axis distance from the left edge of the page to the left side of the Border.
      • +
      • Y1 is the Y axis distance from the top edge of the page the the top of the Border.
      • +
      • X2 is the X axis distance from the left edge of the page to the right side of the Border.
      • +
      • Y2 is the Y axis distance from the top edge of the page the the bottom of the Border.
      +

      So for this tutorial template, the Working space tag will be. +

      +
      <!-- Working space 10 10 259 196 -->
      +

      The Title block Tag

      +

      The next tag will be the Title block tag and is formated as follows: +

      +
      <!-- Title block X1a Y1a X2a Y2a -->
      +

      Where X1a, Y1a, X2a, Y2a are defined as: +

      +
      • X1a is the X axis distance from the left edge of the page to the left side of the Title block
      • +
      • Y1a is the Y axis distance from the top edge of the page the the top of the Title block
      • +
      • X2a is the X Axis distance from the left edge of the page to the right side of the Title block
      • +
      • Y2a is the Y axis distance from the top edge of the page the the bottom of the Title block
      • +
      • X1a <= X1 or X2a >= X2
      • +
      • Y1a <= Y1 or Y2a >= Y2
      +

      Again, referencing the template created with this tutorial, the title block tag will be as follows: +

      +
      <!-- Title block 169 156 259 196 -->
      +

      Placing these two tags, in proper order at the top of the document looks like this: +

      Kate3.png +

      +

      The freecad:editable Tag

      +

      Adding the freecad:editable tags into the SVG document allows FreeCAD to access the defined text blocks for editing. For those blocks of text that you wish to be editable from within FreeCAD, do the following. +

      Search down through the SVG document until you find the section that contains the text you wish to have editable. When making the template, you placed these in a group, and as a result, they should appear within the document as a group as well. Once this group of text elements is located, you will add the line freecad:editable=” “ to each text block where the text that you wish to make editable is contained within the quote marks. Place them as shown for all four lines of text to be editable. +

      Kate4.png +

      +

      The DrawingContent Tag

      +

      The last tag that is needed in the Template is the DrawingContent tag. Without it, FreeCAD can not access the drawing template. This tag informs FreeCAD where within the document it may write it's projections and other attributes. It is the one tag that must be within the SVG document for the drawing template to work with FreeCAD. +

      This tag is formated as follows and is inserted just before the last </svg> tag. +

      +
      <!-- DrawingContent -->
      +

      Kate5.png +

      That's it. The SVG document can now be saved and used with FreeCAD. +

      +

      Complete Example Template

      +

      Below is the finished SVG template. Sense it is in SVG format, you can save and open it in your text editor for review as reference to this tutorial and the creation of your own templates. +

      TemplateExample.svg +

      +

      Tools

      +

      The two tools used in this tutorial were Inkscape and Kate. They can be found by following the links provided below. +

      + +


      +

      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Drawing_View.html b/localwiki/Drawing_View.html new file mode 100644 index 0000000..726fa59 --- /dev/null +++ b/localwiki/Drawing_View.html @@ -0,0 +1,90 @@ +Drawing View

      Drawing View

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Drawing View.png Drawing View

      +
      Menu location +
      Drawing → Insert view in drawing +
      Workbenches +
      Drawing, Complete +
      Default shortcut +
      none +
      See also +
      Drawing Landscape A3 +

      + +
      +


      +

      This tool creates a new view of the selected object in the active drawing sheet. +


      +A drawing sheet with three views: front, top and isometric. +

      +

      How to use

      +

      Select an object either in the 3D view or the Project tree, then click on the Drawing View tool. By default, a top view scaled at 1:1 (real scale) will be placed at the top left of the page. It may not be visible if it's too small or too big for the page. +

      A View object is added to the Page object in the Project tree. For subsequent views, a three-digit number will be appended to the name. Click on the arrow in front of the Page object to unfold it and display the views it contains. +

      If only the object is selected in the Project Tree, the view is added to the first page of the project. If you have multiple pages in your project please select the object +and the page it should be added to. Then click on the icon to add the view to the selected page. +

      +

      Modify an existing view

      +

      Unfold the Page object in the Project tree, and select the View. Its parameters can be edited in the Property View Data tab. +

      Drawing View Properties.png +

      +
      Isometric view with smooth lines visibility off
      +
      Isometric view with smooth lines visibility on
      +
      • Label: changes the view's label in the Project tree. You can also click on the View in the tree and right-click → Rename, or press F2.
      • +
      • Rotation: rotates the view. For example, an isometric view will require a 60 degree rotation (see also Direction parameter below)
      • +
      • Scale: sets the view scale.
      • +
      • X: sets the view's horizontal position on the page in millimeters.
      • +
      • Y: sets the view's vertical position on the page in millimeters. Please note that coordinate (0,0) is located at the top left of the page, so the higher the number, the lower in the page the view will be.
      • +
      • Direction: changes the view direction. It is set by xyz values that define a vector normal to the page. Top view will be (0,0,1), and isometric will be (1,1,1). Values can be negative.
      • +
      • Show Hidden Lines: toggles the hidden lines visibility on or off by selecting True or False.
      • +
      • Show Smooth Lines: toggles the smooth lines visibility on or off by selecting True or False. Smooth lines are also called tangency edges. These edges indicate surface changes between tangent surfaces.
      +


      +

      +

      Drawing View Wizard

      +

      To generate a drawing sheet with standard views automatically, use the Automatic drawing Macro. +

      +
      +


      +

      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Drawing_View_Properties.png b/localwiki/Drawing_View_Properties.png new file mode 100644 index 0000000..2f31a71 Binary files /dev/null and b/localwiki/Drawing_View_Properties.png differ diff --git a/localwiki/Drawing_Workbench.html b/localwiki/Drawing_Workbench.html new file mode 100644 index 0000000..bfe4dad --- /dev/null +++ b/localwiki/Drawing_Workbench.html @@ -0,0 +1,263 @@ +Drawing Workbench

      Drawing Workbench

      (Redirected from Drawing Workbench)
      + +

      The Drawing module allows you to put your 3D work on paper. That is, to put views of your models in a 2D window and to insert that window in a drawing, for example a sheet with a border, a title and your logo and finally print that sheet. +

      +
      Development of the Drawing Module has stopped, and a new TechDraw Module aiming to replace it will be introduced in version 0.17. Both modules will be provided in v0.17, but the Drawing module may be removed in future releases.
      +


      +

      + + +

      GUI Tools

      +

      These are tools for creating, configuring and exporting 2D drawing sheets +

      + + +
      • Drawing View.png Insert a view: Inserts a view of the selected object in the active drawing sheet
      +
      • Drawing Annotation.png Annotation: Adds an annotation to the current drawing sheet
      +
      • Drawing Clip.png Clip: Adds a clip group to the current drawing sheet
      +
      • Drawing Openbrowser.png Open Browser: Opens a preview of the current sheet in the browser
      +
      • Drawing Orthoviews.png Ortho Views: Automatically creates orthographic views of an object on the current drawing sheet
      +
      • Drawing Symbol.png Symbol: Adds the contents of a SVG file as a symbol on the current drawing sheet
      +
      • Drawing DraftView.png Draft View: Inserts a special Draft view of the selected object in the current drawing sheet
      +
      • Drawing SpreadsheetView.png Spreadsheet View: Inserts a view of a selected spreadsheet in the current drawing sheet
      +
      • Drawing Save.png Save sheet: Saves the current sheet as a SVG file
      +
      • Project Shape: Creates a projection of the selected object (Source) in the 3D view.
      +

      Note +The Draft View tool is used mainly to place Draft objects on paper. It has a couple of extra capabilities over the standard Drawing tools, and supports specific objects like Draft dimensions. +


      +Drawing extraction.png +

      In the picture you see the main concepts of the Drawing module. The document contains a shape object (Schenkel) which we want to extract to a drawing. Therefore a "Page" is created. A page gets instantiated through a template, in this case the "A3_Landscape" template. The template is an SVG document which can hold your usual page frame, your logo or comply to your presentation standards. +

      In this page we can insert one or more views. Each view has a position on the page (Properties X,Y), a scale factor (Property scale) and additional properties. Every time the page or the view or the referenced object changes the page gets regenerated and the page display updated. +

      +

      Scripting

      +

      At the moment the end user(GUI) workflow is very limited, so the scripting API is more interesting. Here follow examples on how to use the scripting API of the drawing module. +

      Here a script that can easily fill the Macro_CartoucheFC leaf FreeCAD A3_Landscape. +

      +

      Simple example

      +

      First of all you need the Part and the Drawing module: +

      +
      import FreeCAD, Part, Drawing 
      +

      Create a small sample part +

      +
      Part.show(Part.makeBox(100,100,100).cut(Part.makeCylinder(80,100)).cut(Part.makeBox(90,40,100)).cut(Part.makeBox(20,85,100))) 
      +

      Direct projection. The G0 means hard edge, the G1 is tangent continuous. +

      +
      Shape = App.ActiveDocument.Shape.Shape
      +[visibleG0,visibleG1,hiddenG0,hiddenG1] = Drawing.project(Shape)
      +print "visible edges:", len(visibleG0.Edges)
      +print "hidden edges:", len(hiddenG0.Edges) 
      +

      Everything was projected on the Z-plane: +

      +
      print "Bnd Box shape: X=",Shape.BoundBox.XLength," Y=",Shape.BoundBox.YLength," Z=",Shape.BoundBox.ZLength
      +print "Bnd Box project: X=",visibleG0.BoundBox.XLength," Y=",visibleG0.BoundBox.YLength," Z=",visibleG0.BoundBox.ZLength 
      +

      Different projection vector +

      +
      [visibleG0,visibleG1,hiddenG0,hiddenG1] = Drawing.project(Shape,App.Vector(1,1,1)) 
      +

      Project to SVG +

      +
      resultSVG = Drawing.projectToSVG(Shape,App.Vector(1,1,1))
      +print resultSVG 
      +

      The parametric way

      +

      Create the body +

      +
      import FreeCAD
      +import Part
      +import Drawing
      +
      +# Create three boxes and a cylinder
      +App.ActiveDocument.addObject("Part::Box","Box")
      +App.ActiveDocument.Box.Length=100.00
      +App.ActiveDocument.Box.Width=100.00
      +App.ActiveDocument.Box.Height=100.00
      +
      +App.ActiveDocument.addObject("Part::Box","Box1")
      +App.ActiveDocument.Box1.Length=90.00
      +App.ActiveDocument.Box1.Width=40.00
      +App.ActiveDocument.Box1.Height=100.00
      +
      +App.ActiveDocument.addObject("Part::Box","Box2")
      +App.ActiveDocument.Box2.Length=20.00
      +App.ActiveDocument.Box2.Width=85.00
      +App.ActiveDocument.Box2.Height=100.00
      +
      +App.ActiveDocument.addObject("Part::Cylinder","Cylinder")
      +App.ActiveDocument.Cylinder.Radius=80.00
      +App.ActiveDocument.Cylinder.Height=100.00
      +App.ActiveDocument.Cylinder.Angle=360.00
      +# Fuse two boxes and the cylinder
      +App.ActiveDocument.addObject("Part::Fuse","Fusion")
      +App.ActiveDocument.Fusion.Base = App.ActiveDocument.Cylinder
      +App.ActiveDocument.Fusion.Tool = App.ActiveDocument.Box1
      +
      +App.ActiveDocument.addObject("Part::Fuse","Fusion1")
      +App.ActiveDocument.Fusion1.Base = App.ActiveDocument.Box2
      +App.ActiveDocument.Fusion1.Tool = App.ActiveDocument.Fusion
      +# Cut the fused shapes from the first box
      +App.ActiveDocument.addObject("Part::Cut","Shape")
      +App.ActiveDocument.Shape.Base = App.ActiveDocument.Box 
      +App.ActiveDocument.Shape.Tool = App.ActiveDocument.Fusion1
      +# Hide all the intermediate shapes 
      +Gui.ActiveDocument.Box.Visibility=False
      +Gui.ActiveDocument.Box1.Visibility=False
      +Gui.ActiveDocument.Box2.Visibility=False
      +Gui.ActiveDocument.Cylinder.Visibility=False
      +Gui.ActiveDocument.Fusion.Visibility=False
      +Gui.ActiveDocument.Fusion1.Visibility=False 
      +

      Insert a Page object and assign a template +

      +
      App.ActiveDocument.addObject('Drawing::FeaturePage','Page')
      +App.ActiveDocument.Page.Template = App.getResourceDir()+'Mod/Drawing/Templates/A3_Landscape.svg' 
      +

      Create a view on the "Shape" object, define the position and scale and assign it to a Page +

      +
      App.ActiveDocument.addObject('Drawing::FeatureViewPart','View')
      +App.ActiveDocument.View.Source = App.ActiveDocument.Shape
      +App.ActiveDocument.View.Direction = (0.0,0.0,1.0)
      +App.ActiveDocument.View.X = 10.0
      +App.ActiveDocument.View.Y = 10.0
      +App.ActiveDocument.Page.addObject(App.ActiveDocument.View) 
      +

      Create a second view on the same object but this time the view will be rotated by 90 degrees. +

      +
      App.ActiveDocument.addObject('Drawing::FeatureViewPart','ViewRot')
      +App.ActiveDocument.ViewRot.Source = App.ActiveDocument.Shape
      +App.ActiveDocument.ViewRot.Direction = (0.0,0.0,1.0)
      +App.ActiveDocument.ViewRot.X = 290.0
      +App.ActiveDocument.ViewRot.Y = 30.0
      +App.ActiveDocument.ViewRot.Scale = 1.0
      +App.ActiveDocument.ViewRot.Rotation = 90.0
      +App.ActiveDocument.Page.addObject(App.ActiveDocument.ViewRot) 
      +

      Create a third view on the same object but with an isometric view direction. The hidden lines are activated too. +

      +
      App.ActiveDocument.addObject('Drawing::FeatureViewPart','ViewIso')
      +App.ActiveDocument.ViewIso.Source = App.ActiveDocument.Shape
      +App.ActiveDocument.ViewIso.Direction = (1.0,1.0,1.0)
      +App.ActiveDocument.ViewIso.X = 335.0
      +App.ActiveDocument.ViewIso.Y = 140.0
      +App.ActiveDocument.ViewIso.ShowHiddenLines = True
      +App.ActiveDocument.Page.addObject(App.ActiveDocument.ViewIso) 
      +

      Change something and update. The update process changes the view and the page. +

      +
      App.ActiveDocument.View.X = 30.0
      +App.ActiveDocument.View.Y = 30.0
      +App.ActiveDocument.View.Scale = 1.5
      +App.ActiveDocument.recompute() 
      +

      Accessing the bits and pieces

      +

      Get the SVG fragment of a single view +

      +
      ViewSVG = App.ActiveDocument.View.ViewResult
      +print ViewSVG 
      +

      Get the whole result page (it's a file in the document's temporary directory, only read permission) +

      +
      print "Resulting SVG document: ",App.ActiveDocument.Page.PageResult
      +file = open(App.ActiveDocument.Page.PageResult,"r")
      +print "Result page is ",len(file.readlines())," lines long" 
      +

      Important: free the file! +

      +
      del file 
      +

      Insert a view with your own content: +

      +
      App.ActiveDocument.addObject('Drawing::FeatureView','ViewSelf')
      +App.ActiveDocument.ViewSelf.ViewResult = """<g id="ViewSelf"
      +  stroke="rgb(0, 0, 0)"
      +  stroke-width="0.35"
      +  stroke-linecap="butt"
      +  stroke-linejoin="miter"
      +  transform="translate(30,30)"
      +  fill="#00cc00"
      +  >
      +
      +  <ellipse cx="40" cy="40" rx="30" ry="15"/>
      +  </g>"""
      +App.ActiveDocument.Page.addObject(App.ActiveDocument.ViewSelf)
      +App.ActiveDocument.recompute()
      +
      +del ViewSVG 
      +

      That leads to the following result: +

      DrawingScriptResult.jpg +

      +

      General Dimensioning and Tolerancing

      +

      Drawing dimensions an tolerances are still under development but you can get some basic functionality with a bit of work. +

      First you need to get the gdtsvg python module from here (WARNING: This could be broken at any time!): +

      https://github.com/jcc242/FreeCAD +

      To get a feature control frame, try out the following: +

      +
      import gdtsvg as g # Import the module, I like to give it an easy handle
      +ourFrame = g.ControlFrame("0","0", g.Perpendicularity(), ".5", g.Diameter(), g.ModifyingSymbols("M"), "A",  
      +           g.ModifyingSymbols("F"), "B", g.ModifyingSymbols("L"), "C", g.ModifyingSymbols("I")) 
      +

      Here is a good breakdown of the contents of a feature control frame: http://www.cadblog.net/adding-geometric-tolerances.htm +

      The parameters to pass to control frame are: +

      +
      1. X-coordinate in SVG-coordinate system (type string)
      2. +
      3. Y-coordinate in SVG-coordinate system (type string)
      4. +
      5. The desired geometric characteristic symbol (tuple, svg string as first, width of symbol as second, height of symbol as third)
      6. +
      7. The tolerance (type string)
      8. +
      9. (optional) The diameter symbol (tuple, svg string as first, width of symbol as second, height of symbol as third)
      10. +
      11. (optional) The condition modifying material (tuple, svg string as first, width of symbol as second, height of symbol as third)
      12. +
      13. (optional) The first datum (type string)
      14. +
      15. (optional) The first datum's modifying condition (tuple, svg string as first, width of symbol as second, height of symbol as third)
      16. +
      17. (optional) The second datum (type string)
      18. +
      19. (optional) The second datum's modifying condition (tuple, svg string as first, width of symbol as second, height of symbol as third)
      20. +
      21. (optional) The third datum (type string)
      22. +
      23. (optional) The third datum's material condition (tuple, svg string as first, width of symbol as second, height of symbol as third)
      +

      The ControlFrame function returns a type containing (svg string, overall width of control frame, overall height of control frame) +

      To get a dimension, try out the following: +

      +
      import gdtsvg
      +ourDimension = linearDimension(point1, point2, textpoint, dimensiontext, linestyle=getStyle("visible"), 
      +               arrowstyle=getStyle("filled"), textstyle=getStyle("text") 
      +

      Inputs for linear dimension are: +

      +
      1. point1, an (x,y) tuple with svg-coordinates, this is one of the points you would like to dimension between
      2. +
      3. point2, an (x,y) tuple with svg-coordinates, this is the second point you would like to dimension between
      4. +
      5. textpoint, an (x,y) tuple of svg-coordinates, this is where the text of your dimension will be
      6. +
      7. dimensiontext, a string containing the text you want the dimension to say
      8. +
      9. linestyle, a string containing svg (i.e. css) styles, using the getStyle function to retrieve a preset string, for styling the how the lines look
      10. +
      11. arrowstyle, a string containing svg (i.e. css) styles, using the getStyle function to retrieve a preset string, for styling how the arrows look
      12. +
      13. textstyle, a string containing svg (i.e. css) styles, using the getStyle function to retrieve a preset string, for styling how the text looks
      +

      With those two, you can proceed as above for displaying them on the drawing page. This module is very buggy and can be broken at any given moment, bug reports are welcome on the github page for now, or contact jcc242 on the forums if you post a bug somewhere else. +

      +

      Templates

      +

      FreeCAD comes bundled with a set of default templates, but you can find more on the Drawing templates page. +

      +

      Extending the Drawing Module

      +

      Some notes on the programming side of the drawing module will be added to the Drawing Documentation page. This is to help quickly understand how the drawing module works, enabling programmers to rapidly start programming for it. +

      +

      Tutorials

      + +


      +

      +

      External links

      + +


      +

      + +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Drawing_templates.html b/localwiki/Drawing_templates.html new file mode 100644 index 0000000..dcf9fd4 --- /dev/null +++ b/localwiki/Drawing_templates.html @@ -0,0 +1,199 @@ +Drawing templates

      Drawing templates

      + +
      + +

      SVG templates creation

      +

      Creating templates for the Drawing module is very easy. See also the tutorial Drawing_Template_HowTo. Templates are svg files, created with any application capable of exporting svg files, such as Inkscape. However, you will often need to open the svg file in a text editor afterwards, to comply with the following rules. Only two rules must be followed: +

      +

      Base rules

      +
      • One pixel = one millimeter. You can have the page size specified inside the opening <svg> tag, either without units or with "mm". For example, these two forms are valid:
      +
      width="1067mm"
      +height="762mm"
      +
      +

      or +

      +
      width="1067"
      +height = "762"
      +
      +

      Although svg supports inches ("42 in"), these are currently not supported by FreeCAD, so it's always better to have your svg page size specified in millimeters. The "viewBox" attribute must have the same value, for example: +

      +
      viewBox="0 0 1067 762"
      +
      +
      • You must insert, somewhere inside your svg code, where you want the contents of the drawing to appear (for example at the end of the file, just before the last </svg> tag), the following line:
      +
       <!-- DrawingContent -->
      +

      This text above (which is actually an XML comment) must be on a separate line, and not embedded in the middle of other pieces of text. Beware that if you reopen and resave your template in inkscape, after adding the above line, inkscape will keep the line, but will add other xml elements on the same line, causing the template to not work anymore. You will need to edit it with a text editor and isolate the comment above on its own line again. +

      +

      Namespace

      +
      • Several objects (specifically those created with the Draft_Drawing command and if your template has editable texts) use a special Svg Namespace specific to FreeCAD. This makes FreeCAD able to detect specific items inside svg files, that other applications will just ignore. If you plan to use any of these, you must add this line inside the opening <svg> tag, for example together with the other xmlns lines added by inkscape:
      +
      xmlns:freecad="http://www.freecadweb.org/wiki/index.php?title=Svg_Namespace"
      +
      +

      Title block

      +

      In addition to these rules, since FreeCAD 0.14, information about the Border and Title block can be added to the template for use by the orthographic projection tool. This information defines where FreeCAD can, and can not place the projections. +

      To define the Border, the following line must appear before the <metadata> tag in the svg file. +

      +
      <!-- Working space X1 Y1 X2 Y2 -->
      +

      Where X1, Y1, X2, Y2 are defined as: +

      +
      • X1 is the X axis distance from the left edge of the page to the left side of the Border.
      • +
      • Y1 is the Y axis distance from the top edge of the page to the top of the Border.
      • +
      • X2 is the X axis distance from the left edge of the page to the right side of the Border.
      • +
      • Y2 is the Y axis distance from the top edge of the page to the bottom of the Border.
      +

      XY Working v2.svg +

      To define the Title block the following line must be inserted before the <metadata> tag and after the Working space tag. +

      +
      <!-- Title block X1a Y1a X2a Y2a -->
      +

      Where X1a, Y1a, X2a, Y2a are defined as: +

      +
      • X1a is the X axis distance from the left edge of the page to the left side of the Title block
      • +
      • Y1a is the Y axis distance from the top edge of the page to the top of the Title block
      • +
      • X2a is the X Axis distance from the left edge of the page to the right side of the Title block
      • +
      • Y2a is the Y axis distance from the top edge of the page to the bottom of the Title block
      • +
      • X1a <= X1 or X2a >= X2
      • +
      • Y1a <= Y1 or Y2a >= Y2
      +

      XY Title v2.svg +

      The following is an example of the code that defines the Working space and Title block areas that are to be inserted before the <metadata> tag. You needn't specify a title block, but if you do it must be defined on the next line immediately following the Working space: +

      +
      <!-- Working space X1 Y1 X2 Y2 -->
      +<!-- Title block X1a Y1a X2a Y2a -->
      +

      In order to enable up to scale printing, the real word size has to be given in the width and height attributes of the SVG-Tag. The size of the document in user units, (px), has to be given in the viewBox attribute. +

      The following is to be formatted like the example below where: +

      +
      • xxx = pixel width
      • +
      • yyy = pixel height
      +
      width="xxxmm"
      +height="yyymm"
      +viewBox="0 0 xxx yyy"
      +
      • Several custom attributes can be placed in templates. The list of currently supported attributes is available on the Svg Namespace page.
      +

      DXF templates

      +

      Since version 0.15, FreeCAD can reliably export a Drawing page to the DXF format. This system also uses templates. If a dxf file with the same name is found in the same folder as the SVG template used for a page, it will be used for export. If not, a default empty template is created on the fly. +

      Consequently, if you create your own SVG templates, and wish to be able to export the Drawing pages that you create with it to DXF, you just need to create a corresponding DXF template, and save it with the same name in the same folder. +

      DXF templates can be created with any application that produces DXF files, such as LibreCAD. You then need to edit them with a text editor, and add two additional lines, one at the beginning or end of the BLOCKS section, and another at the beginning or end of the ENTITIES section, which are where FreeCAD will add its own blocks and entities. +

      A very simple template looks like this: +

      +
      999
      +FreeCAD DXF exporter v0.15
      +0
      +SECTION
      +2
      +HEADER
      +9
      +$ACADVER
      +1
      +AC1009
      +0
      +ENDSEC
      +0
      +SECTION
      +2
      +BLOCKS
      +$blocks
      +0
      +ENDSEC
      +0
      +SECTION
      +2
      +ENTITIES
      +$entities
      +0
      +ENDSEC
      +0
      +EOF
      +
      +

      The above template doesn't contain any entity. If you create your DXF file with a CAD application, there will likely be much more content inside the HEADER, BLOCKS and ENTITIES sections. +

      The two lines that FreeCAD will be looking for are "$blocks" and "$entities". They must exist in the template, and they must be placed on their own line. You can choose to place them right after the BLOCKS or ENTITIES line, which is easier (just use the "search" function of your text editor to find them), or at the end, just before the "0 ENDSEC" lines (beware that there is one for each SECTION, make sure to use the ones relative to BLOCKS and ENTITIES). The latter method will place the FreeCAD objects after the objects defined in the template, which might be more logical. +

      +

      A3 templates

      +

      A3 Classic:

      +

      A3 Classic.svg +

      +

      A3 Clean:

      +

      A3 Clean.svg +

      +

      A3 Modern:

      +

      A3 Modern.svg +

      +

      A3 Showcase:

      +

      A3 Showcase.svg +

      +

      A3 Landscape english:

      +

      A3 Landscape english.svg +

      +

      A4 Templates

      +

      A4 Landscape english:

      +

      A4 Landscape english.svg +

      +

      A4 Portrait 1 english:

      +

      A4 Portrait 1 english.svg +

      +

      US Letter Templates

      +

      US Letter landscape:

      +

      US Letter landscape.svg +


      +

      +

      US Letter portrait:

      +

      US Letter portrait.svg +

      +

      US Letter ds Landscape:

      +

      US Letter ds Landscape.svg +

      +

      US Legal ds Landscape:

      +

      US Legal ds Landscape.svg +

      +

      US Ledger ds Landscape:

      +

      US Ledger ds Landscape.svg +

      +

      Other standards available

      + +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Drawing_tutorial.html b/localwiki/Drawing_tutorial.html new file mode 100644 index 0000000..d00d652 --- /dev/null +++ b/localwiki/Drawing_tutorial.html @@ -0,0 +1,170 @@ +Drawing tutorial

      Drawing tutorial

      + +

      + + + + + + + + + + + + + + + + + + + + + + + + + + + +
      +

      Base ExampleCommandModel.png Tutorial

      +
      Topic +
      Blueprints / Drawings +
      Level +
      Beginner +
      Time to complete +
      15 minutes +
      Author +
      Drei +
      FreeCAD version +
      0.16 or above +
      Example File(s) +
      +

      + +
      +


      +

      +

      Introduction

      +

      This tutorial is meant to introduce the reader to the basic workflow of the Drawing Workbench, as well as most of the tools that are available to create blueprints. +

      Drawing tutorial result.png +

      +

      Requirements

      +
      • FreeCAD version 0.16 or above
      • +
      • The reader has the basic knowledge to use the Part and PartDesign Workbenches
      • +
      • The reader has finished the Draft tutorial
      +

      Procedure

      +

      Preparations

      +

      To reduce the time required for this tutorial, it is compulsory to group together similar elements in the Tree View to apply operations at the same time to several elements. +

      +
      Grouping elements
      +
      1. In the Tree View, right-click on the name of the document. In this case Unnamed.
      2. +
      3. Select Create group. You can alter the name of the group by double clicking on it from the Tree View.
      4. +
      5. Select the elements that you wish to add and drag them into the group
      +

      Create the following groups: +

      +
      • Draft_objects
      • +
      • Draft_dimensions
      • +
      • Draft_annotations_text
      +

      Drawing Templates

      +

      Templates are the base for the creation of Drawings, you can use the templates provided or create your own. +

      +
      1. Slect the dropdown menu next to Drawing Landscape A3.png New A3 landscape drawing
      2. +
      3. Select A4 Landscape
      +

      We now have a folder called Page in the Tree View. This object will contain everything related to the Drawing. +

      +

      Projections

      +

      Projections are defined as the visual representation of an object on a specific plane, it displays the properties of the object that are visible from that specific orientation. +

      +
      Orthographic Projections
      +

      These are used in Engineering to specify the properties of an object that will be machined. There are two common standards: Third Angle and First Angle projections. +

      For this tutorial, these projections aren't used because our objects only have a meaningful representation in the XY plane. +

      +
      1. Select the object you wish to project into the drawing.
      2. +
      3. Select Drawing Orthoviews.png Ortho Views
      4. +
      5. Select the type of projection you want to use
      6. +
      7. Select the view you want to add
      +

      In the General and Axonometric tabs you can specify the location, scale and separation of each view. +

      +
      Other Part Projections
      +

      It is possible to create custom views of the object. +

      +
      1. Select the object you wish to project into the drawing.
      2. +
      3. Select Drawing View.png Insert a view
      4. +
      5. In the Data tab edit the Direction of the Shape View by altering the values for the X, Y, and Z axes. By default, the values are (0, 0, 1)
      +

      You can also alter the location, scale and rotation of the View from within the Data tab. The same can be done for the Orthographic Projections. +

      +
      Draft Projections
      +

      The preferred way to add elements created in the Draft Workbench is with a tool contained in the Draft Workbench designed specifically for this. With this procedure, it is possible to import Dimensions, Annotations, Shapestrings and any other element created whithin the Draft Workbench. +

      +
      1. Switch to the Draft Workbench
      2. +
      3. Select the group or elements that you wish to project. In this case Draft_dimensions
      4. +
      5. Select Draft PutOnSheet.png Drawing
      6. +
      7. Edit the X and Y coordinates to (140,100)
      8. +
      9. Set the scale to 0.5
      +

      Repeat for each group and set the values to the ones specified above. +

      +

      Exporting your work

      +

      FreeCAD supports the export of SVG and PDF files based on your Drawings +

      +
      SVG
      +
      1. Select Drawing Save.png Save sheet
      2. +
      3. Specify the path and name of the exported file
      +
      PDF
      +
      1. In the File menu, select Export PDF ...
      2. +
      3. Specify the path and name of the exported file
      +

      We are now finished with the basic workflow for the Drawing Module. +

      +

      Recommended Reading

      + +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Drone_Design_Full.jpg b/localwiki/Drone_Design_Full.jpg new file mode 100644 index 0000000..d3ddfde Binary files /dev/null and b/localwiki/Drone_Design_Full.jpg differ diff --git a/localwiki/DumpObjectsGui1.jpg b/localwiki/DumpObjectsGui1.jpg new file mode 100644 index 0000000..7586bbc Binary files /dev/null and b/localwiki/DumpObjectsGui1.jpg differ diff --git a/localwiki/DumpObjectsGui2.jpg b/localwiki/DumpObjectsGui2.jpg new file mode 100644 index 0000000..acec8a8 Binary files /dev/null and b/localwiki/DumpObjectsGui2.jpg differ diff --git a/localwiki/DumpObjectsScreenSnapshot.jpg b/localwiki/DumpObjectsScreenSnapshot.jpg new file mode 100644 index 0000000..19569e8 Binary files /dev/null and b/localwiki/DumpObjectsScreenSnapshot.jpg differ diff --git a/localwiki/Dxf_Importer_Install.html b/localwiki/Dxf_Importer_Install.html new file mode 100644 index 0000000..f229ec5 --- /dev/null +++ b/localwiki/Dxf_Importer_Install.html @@ -0,0 +1,241 @@ +Dxf Importer Install

      Dxf Importer Install

      + +
      + + + + + + + + + + + + + + + + + + + + + + + + + + + +
      +

      Base ExampleCommandModel.png Tutorial

      +
      Topic +
      SampleClass +
      Level +
      Medium user +
      Time to complete +
      15 minutes +
      Author +
      Mario52 +
      FreeCAD version +
      All +
      Example File(s) +
      None +

      + +
      +


      +

      +

      Description

      +

      This page explains step by step the margin to follow to install the package Draft-dxf-import yorikvanhavre for you to upload files in DXF format FreeCAD and import DWG files using the teighafileconverter utility. +This installation was made in the Windows Vista environment, but the principle of the system is the same for linux +

      +

      First step:

      +

      identify the macros folder FreeCAD +

      1 : open FreeCAD +

      +
      +

      If you have a version from 0.15 you can use the automatic update DXF package (expand to see) +

      +
      +
      Automatic DXF install
      +
      +
      +
      +


      +2 : click Menu > Macro > Macros or the click the bottom Std DlgMacroExecuteDirect.svg "Open a dialog to let you execute a macro Recorded" +

      +
      open FreeCAD
      +
      +


      +3 : one dialog box open +

      4 : copy the address of "Macro destination" (here C:\Users\d\AppData\Roaming\FreeCAD\) +In Ubuntu, this is normally /home/your_user_name/.FreeCAD +


      +

      +
      Open a dialog to let you execute a macro Recorded
      +
      +


      +5 : paste the address into your browser and confirm +

      +
      paste the address into your browser
      +
      +


      +6 : leave open the explorer +

      +
      Dxf Importer Install 04.png
      +
      +


      +7 : Close FreeCAD +

      +

      Second step:

      +

      Download the files +

      8 : download files on the page https://github.com/yorikvanhavre/Draft-dxf-importer +

      9 : and click the icon button Download ZIP for the default version. +

      +
      +

      (or choice for your development version see down page) (expand to see) +

      +
      +
      Automatic DXF install
      +
      +


      +

      +
      +
      +
      download files
      +
      +


      +10 : you must extract the file to a temporary directory (here c:\tmp) +

      +
      extract the file
      +
      +


      +11 : the decompresser creates a new folder named "Draft-dxf-import-master" +

      +
      decompresser creates a new folder
      +
      +


      +12 : the files are in this folder select all the files and "Cut" +

      +
      select all the files and Cut
      +
      +


      +13 : paste the files in the folder FreeCAD macros in the explorer open (step 6) (C:\Users\d\AppData\Roaming\FreeCAD\) +

      In Ubuntu, this is normally /home/your_user_name/.FreeCAD +

      +
      paste the files in the folder
      +
      +


      +14 : Open FreeCAD click the button Std DlgMacroExecuteDirect.svg , the necessary files in DXF format are present, close the window "Execute macro +

      +
      open FreeCAD
      +
      +


      +15 : load your DXF file +

      +
      load your DXF file
      +
      +


      +16 : DXF file can be used +

      +
      DXF file can be used
      +
      +


      +VERSIONS +

      This repository contains several versions of the DXF importer. The default version, that you download when you press the "download ZIP" button above, is always the version needed by the current stable version of FreeCAD. +

      If you use another version of FreeCAD, for example a development version or an older version, you might also need another verison of this DXF library. You can find out which version of the DXF library is needed by your version of FreeCAD, by entering the following code in the FreeCAD python console: +

      +
      import importDXF
      +print importDXF.CURRENTDXFLIB 
      +

      Third step:

      +

      Download Teigha converter for use DWG files +

      17 : teighafileconverter download on teighafileconverter page +

      +
      download Teigha
      +
      +


      +18 : choose the version that suits your Qt and OS +

      +
      choose the version
      +
      +


      +19 : and install it on your system +

      +
      install it on your system
      +
      +


      +20 : open FreeCAD and click the button Std DlgMacroExecuteDirect.svg "Open a dialog to let you execute a macro Recorded" +

      21 : close the macros window +

      22 : and activate the Draft workbench +

      +
      activate the Draft workbebch
      +
      +


      +23 : now let's get into the options page DXF / DWG click "Menu > Edit > Preferences" +

      +
      Menu > Preferences
      +
      +


      +24 : select "Draft > DXF / DWG options" tab +

      25 : In the DWG format option section, click the 3 points ... +

      +
      Draft > DXF / DWG options
      +
      +


      +26 : to give way Teigha converter that FreeCAD will use to convert DWG to DXF +

      27 : enter in the directory here in Window here "C:/Program Files/ODA/Teigha File Converter 4.00.1/" and select TeighaFileConverter.exe and confirm +

      +
      DWG format option
      +
      +


      +28 : the operation is completed click the OK you can test a DWG file +

      +
      directory Teigha File Converter 4.00.1
      +
      +


      +

      +

      Fourth step:

      +

      Using Teigha. Teigha is a full program and you can use it without FreeCAD +

      +
      directory Teigha File Converter 4.00.1
      +
      +


      +1 : Imput folder: folder path or are the DXF or DWG files to convert +

      2 : Output folder: path to the destination folder for the converted files +

      3 : Recurse folder: +

      4 : Audit: +

      5 : Input files filter: filter for only DXF, DWG or DXF and DWG +


      +6 : Output release: the file will be converted to the format and the selected version +

      7 : Start: launches the process +

      +

      Links

      +

      Video tutorial FreeCAD Tutorial 24 - DXF/DWG Import +

      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Dxf_Importer_Install_01.png b/localwiki/Dxf_Importer_Install_01.png new file mode 100644 index 0000000..79a9a61 Binary files /dev/null and b/localwiki/Dxf_Importer_Install_01.png differ diff --git a/localwiki/Dxf_Importer_Install_02.png b/localwiki/Dxf_Importer_Install_02.png new file mode 100644 index 0000000..fc868a5 Binary files /dev/null and b/localwiki/Dxf_Importer_Install_02.png differ diff --git a/localwiki/Dxf_Importer_Install_03.png b/localwiki/Dxf_Importer_Install_03.png new file mode 100644 index 0000000..d0d7876 Binary files /dev/null and b/localwiki/Dxf_Importer_Install_03.png differ diff --git a/localwiki/Dxf_Importer_Install_04.png b/localwiki/Dxf_Importer_Install_04.png new file mode 100644 index 0000000..32be8c5 Binary files /dev/null and b/localwiki/Dxf_Importer_Install_04.png differ diff --git a/localwiki/Dxf_Importer_Install_05.png b/localwiki/Dxf_Importer_Install_05.png new file mode 100644 index 0000000..0e9d03c Binary files /dev/null and b/localwiki/Dxf_Importer_Install_05.png differ diff --git a/localwiki/Dxf_Importer_Install_06.png b/localwiki/Dxf_Importer_Install_06.png new file mode 100644 index 0000000..85ca13a Binary files /dev/null and b/localwiki/Dxf_Importer_Install_06.png differ diff --git a/localwiki/Dxf_Importer_Install_07.png b/localwiki/Dxf_Importer_Install_07.png new file mode 100644 index 0000000..1c11ac5 Binary files /dev/null and b/localwiki/Dxf_Importer_Install_07.png differ diff --git a/localwiki/Dxf_Importer_Install_08.png b/localwiki/Dxf_Importer_Install_08.png new file mode 100644 index 0000000..6ecb681 Binary files /dev/null and b/localwiki/Dxf_Importer_Install_08.png differ diff --git a/localwiki/Dxf_Importer_Install_09.png b/localwiki/Dxf_Importer_Install_09.png new file mode 100644 index 0000000..0d41b6f Binary files /dev/null and b/localwiki/Dxf_Importer_Install_09.png differ diff --git a/localwiki/Dxf_Importer_Install_10.png b/localwiki/Dxf_Importer_Install_10.png new file mode 100644 index 0000000..8038998 Binary files /dev/null and b/localwiki/Dxf_Importer_Install_10.png differ diff --git a/localwiki/Dxf_Importer_Install_11.png b/localwiki/Dxf_Importer_Install_11.png new file mode 100644 index 0000000..d5c9db8 Binary files /dev/null and b/localwiki/Dxf_Importer_Install_11.png differ diff --git a/localwiki/Dxf_Importer_Install_12.png b/localwiki/Dxf_Importer_Install_12.png new file mode 100644 index 0000000..45bd2b1 Binary files /dev/null and b/localwiki/Dxf_Importer_Install_12.png differ diff --git a/localwiki/Dxf_Importer_Install_13.png b/localwiki/Dxf_Importer_Install_13.png new file mode 100644 index 0000000..ff453e1 Binary files /dev/null and b/localwiki/Dxf_Importer_Install_13.png differ diff --git a/localwiki/Dxf_Importer_Install_14.png b/localwiki/Dxf_Importer_Install_14.png new file mode 100644 index 0000000..bc9b379 Binary files /dev/null and b/localwiki/Dxf_Importer_Install_14.png differ diff --git a/localwiki/Dxf_Importer_Install_15.png b/localwiki/Dxf_Importer_Install_15.png new file mode 100644 index 0000000..85b1b41 Binary files /dev/null and b/localwiki/Dxf_Importer_Install_15.png differ diff --git a/localwiki/Dxf_Importer_Install_16.png b/localwiki/Dxf_Importer_Install_16.png new file mode 100644 index 0000000..2a175fd Binary files /dev/null and b/localwiki/Dxf_Importer_Install_16.png differ diff --git a/localwiki/Dxf_Importer_Install_17.png b/localwiki/Dxf_Importer_Install_17.png new file mode 100644 index 0000000..c6a8fa3 Binary files /dev/null and b/localwiki/Dxf_Importer_Install_17.png differ diff --git a/localwiki/Dxf_Importer_Install_18.png b/localwiki/Dxf_Importer_Install_18.png new file mode 100644 index 0000000..7f5e6b2 Binary files /dev/null and b/localwiki/Dxf_Importer_Install_18.png differ diff --git a/localwiki/Dxf_Importer_Install_19.png b/localwiki/Dxf_Importer_Install_19.png new file mode 100644 index 0000000..20036db Binary files /dev/null and b/localwiki/Dxf_Importer_Install_19.png differ diff --git a/localwiki/Dxf_Importer_Install_20.png b/localwiki/Dxf_Importer_Install_20.png new file mode 100644 index 0000000..372ea40 Binary files /dev/null and b/localwiki/Dxf_Importer_Install_20.png differ diff --git a/localwiki/Dxf_Importer_Install_21.png b/localwiki/Dxf_Importer_Install_21.png new file mode 100644 index 0000000..5af90c0 Binary files /dev/null and b/localwiki/Dxf_Importer_Install_21.png differ diff --git a/localwiki/Earth.svg b/localwiki/Earth.svg new file mode 100644 index 0000000..8ede57e --- /dev/null +++ b/localwiki/Earth.svg @@ -0,0 +1,165 @@ + + + + + + + + + + + + image/svg+xml + + + + + Pablo Gil + + + + + SVG + template + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Easy-cutouts.gif b/localwiki/Easy-cutouts.gif new file mode 100644 index 0000000..4fd78a0 Binary files /dev/null and b/localwiki/Easy-cutouts.gif differ diff --git a/localwiki/Edit-cleartext.svg b/localwiki/Edit-cleartext.svg new file mode 100644 index 0000000..fe7e2ea --- /dev/null +++ b/localwiki/Edit-cleartext.svg @@ -0,0 +1,1276 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + + + + + + + + + + + diff --git a/localwiki/Edit-copy.svg b/localwiki/Edit-copy.svg new file mode 100644 index 0000000..a4708f7 --- /dev/null +++ b/localwiki/Edit-copy.svg @@ -0,0 +1,327 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + Edit Copy + 2005-10-15 + + + Andreas Nilsson + + + + + edit + copy + + + + + + Jakub Steiner + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Edit-cut.svg b/localwiki/Edit-cut.svg new file mode 100644 index 0000000..fb05125 --- /dev/null +++ b/localwiki/Edit-cut.svg @@ -0,0 +1,496 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + Edit Cut + + + Garrett Le Sage + + + + + edit + cut + clipboard + + + + + + Jakub Steiner + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Edit-delete.svg b/localwiki/Edit-delete.svg new file mode 100644 index 0000000..146d32d --- /dev/null +++ b/localwiki/Edit-delete.svg @@ -0,0 +1,882 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + Delete + + + + Jakub Steiner + + + + + edit + delete + shredder + + + + + Novell, Inc. + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Edit-edit.svg b/localwiki/Edit-edit.svg new file mode 100644 index 0000000..77cb3ce --- /dev/null +++ b/localwiki/Edit-edit.svg @@ -0,0 +1,213 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Edit-paste.svg b/localwiki/Edit-paste.svg new file mode 100644 index 0000000..8d096b6 --- /dev/null +++ b/localwiki/Edit-paste.svg @@ -0,0 +1,529 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + Edit Paste + 2005-10-10 + + + Andreas Nilsson + + + + + edit + paste + + + + + + Jakub Steiner + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Edit-redo.svg b/localwiki/Edit-redo.svg new file mode 100644 index 0000000..44bdb40 --- /dev/null +++ b/localwiki/Edit-redo.svg @@ -0,0 +1,230 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + Jakub Steiner + + + http://jimmac.musichall.cz + + Edit Redo + + + edit + redo + again + reapply + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Edit-select-all.svg b/localwiki/Edit-select-all.svg new file mode 100644 index 0000000..2f63025 --- /dev/null +++ b/localwiki/Edit-select-all.svg @@ -0,0 +1,175 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + + + + + + + + + + diff --git a/localwiki/Edit-select-box.svg b/localwiki/Edit-select-box.svg new file mode 100644 index 0000000..24c6942 --- /dev/null +++ b/localwiki/Edit-select-box.svg @@ -0,0 +1,163 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + + + + + + + + + + diff --git a/localwiki/Edit-undo.svg b/localwiki/Edit-undo.svg new file mode 100644 index 0000000..ba1d1f5 --- /dev/null +++ b/localwiki/Edit-undo.svg @@ -0,0 +1,229 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + Jakub Steiner + + + http://jimmac.musichall.cz + + Edit Undo + + + edit + undo + revert + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Edit_Cancel.svg b/localwiki/Edit_Cancel.svg new file mode 100644 index 0000000..008bbf4 --- /dev/null +++ b/localwiki/Edit_Cancel.svg @@ -0,0 +1,151 @@ + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + + + + + + + + + + diff --git a/localwiki/Edit_OK.svg b/localwiki/Edit_OK.svg new file mode 100644 index 0000000..da595a2 --- /dev/null +++ b/localwiki/Edit_OK.svg @@ -0,0 +1,134 @@ + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + + + + + + + + diff --git a/localwiki/Elbow_dimension_length_82_mm.png b/localwiki/Elbow_dimension_length_82_mm.png new file mode 100644 index 0000000..d66810c Binary files /dev/null and b/localwiki/Elbow_dimension_length_82_mm.png differ diff --git a/localwiki/Elbow_equality_90%C2%B0to_vertical.png b/localwiki/Elbow_equality_90%C2%B0to_vertical.png new file mode 100644 index 0000000..cbf591a Binary files /dev/null and b/localwiki/Elbow_equality_90%C2%B0to_vertical.png differ diff --git a/localwiki/Elbow_equality_horizontal_vertical.png b/localwiki/Elbow_equality_horizontal_vertical.png new file mode 100644 index 0000000..bf0b20d Binary files /dev/null and b/localwiki/Elbow_equality_horizontal_vertical.png differ diff --git a/localwiki/Elbow_equality_perpendicular_vertical.png b/localwiki/Elbow_equality_perpendicular_vertical.png new file mode 100644 index 0000000..7bf8998 Binary files /dev/null and b/localwiki/Elbow_equality_perpendicular_vertical.png differ diff --git a/localwiki/Elbow_fix_point_onto_object_52mm.png b/localwiki/Elbow_fix_point_onto_object_52mm.png new file mode 100644 index 0000000..928920d Binary files /dev/null and b/localwiki/Elbow_fix_point_onto_object_52mm.png differ diff --git a/localwiki/Ellipse-example.png b/localwiki/Ellipse-example.png new file mode 100644 index 0000000..0bd439c Binary files /dev/null and b/localwiki/Ellipse-example.png differ diff --git a/localwiki/EllipseCenter2Point.png b/localwiki/EllipseCenter2Point.png new file mode 100644 index 0000000..d88fdd6 Binary files /dev/null and b/localwiki/EllipseCenter2Point.png differ diff --git a/localwiki/Embedding_FreeCAD.html b/localwiki/Embedding_FreeCAD.html new file mode 100644 index 0000000..a1dd250 --- /dev/null +++ b/localwiki/Embedding_FreeCAD.html @@ -0,0 +1,82 @@ +Embedding FreeCAD

      Embedding FreeCAD

      + +

      FreeCAD has the amazing ability to be importable as a python module in other programs or in a standalone python console, together with all its modules and components. It's even possible to import the FreeCAD GUI as python module -- with some restrictions, however. +

      +

      Using FreeCAD without GUI

      +One first, direct, easy and useful application you can make of this is to import FreeCAD documents into your program. In the following example, we'll import the Part geometry of a FreeCAD document into blender. Here is the complete script. I hope you'll be impressed by its simplicity:
      FREECADPATH = '/opt/FreeCAD/lib' # path to your FreeCAD.so or FreeCAD.dll file
      +import Blender, sys
      +sys.path.append(FREECADPATH)
      + 
      +def import_fcstd(filename):
      +   try:
      +       import FreeCAD
      +   except ValueError:
      +       Blender.Draw.PupMenu('Error%t|FreeCAD library not found. Please check the FREECADPATH variable in the import script is correct')
      +   else:
      +       scene = Blender.Scene.GetCurrent()
      +       import Part
      +       doc = FreeCAD.open(filename)
      +       objects = doc.Objects
      +       for ob in objects:
      +           if ob.Type[:4] == 'Part':
      +               shape = ob.Shape
      +               if shape.Faces:
      +                   mesh = Blender.Mesh.New()
      +                   rawdata = shape.tessellate(1)
      +                   for v in rawdata[0]:
      +                       mesh.verts.append((v.x,v.y,v.z))
      +                   for f in rawdata[1]:
      +                       mesh.faces.append.append(f)
      +                   scene.objects.new(mesh,ob.Name)
      +       Blender.Redraw()
      +
      +def main():
      +   Blender.Window.FileSelector(import_fcstd, 'IMPORT FCSTD', 
      +                        Blender.sys.makename(ext='.fcstd'))    
      + 
      +# This lets you import the script without running it
      +if __name__=='__main__':
      +   main()
      The first, important part is to make sure python will find our FreeCAD library. Once it finds it, all FreeCAD modules such as Part, that we'll use too, will be available automatically. So we simply take the sys.path variable, which is where python searches for modules, and we append the FreeCAD lib path. This modification is only temporary, and will be lost when we'll close our python interpreter. Another way could be making a link to your FreeCAD library in one of the python search paths. I kept the path in a constant (FREECADPATH) so it'll be easier for another user of the script to configure it to his own system. +

      Once we are sure the library is loaded (the try/except sequence), we can now work with FreeCAD, the same way as we would inside FreeCAD's own python interpreter. We open the FreeCAD document that is passed to us by the main() function, and we make a list of its objects. Then, as we chose only to care about Part geometry, we check if the Type property of each object contains "Part", then we tesselate it. +

      The tesselation produce a list of vertices and a list of faces defined by vertices indexes. This is perfect, since it is exactly the same way as blender defines meshes. So, our task is ridiculously simple, we just add both lists contents to the verts and faces of a blender mesh. When everything is done, we just redraw the screen, and that's it! +

      Of course this script is very simple (in fact I made a more advanced here), you might want to extend it, for example importing mesh objects too, or importing Part geometry that has no faces, or import other file formats that FreeCAD can read. You might also want to export geometry to a FreeCAD document, which can be done the same way. You might also want to build a dialog, so the user can choose what to import, etc... The beauty of all this actually lies in the fact that you let FreeCAD do the ground work while presenting its results in the program of your choice. +

      +

      Using FreeCAD with GUI

      +

      From version 4.2 on Qt has the intriguing ability to embed Qt-GUI-dependent plugins into non-Qt host applications and share the host's event loop. +

      Especially, for FreeCAD this means that it can be imported from within another application with its whole user interface where the host application has full control over FreeCAD, then. +

      The whole python code to achieve that has only two lines +

      +
       
      +import FreeCADGui 
      +FreeCADGui.showMainWindow()
      +

      If the host application is based on Qt then this solution should work on all platforms which Qt supports. However, the host should link the same Qt version as FreeCAD because otherwise you could run into unexpected runtime errors. +

      For non-Qt applications, however, there are a few limitations you must be aware of. This solution probably doesn't work together with all other toolkits. +For Windows it works as long as the host application is directly based on Win32 or any other toolkit that internally uses the Win32 API such as wxWidgets, MFC or WinForms. In order to get it working under X11 the host application must link the "glib" library. +

      Note, for any console application this solution of course doesn't work because there is no event loop running. +

      +

      Caveats

      +

      Although it is possible to import FreeCAD to an external Python interpreter, this is not a common usage scenario and requires some care. Generally, it is better to use the Python included with FreeCAD, run FreeCAD via command line, or as a subprocess. See Start up and Configuration for more on the last two options. +

      Since the FreeCAD Python module is compiled from C++ (rather than being a pure Python module), it can only be imported from a compatible Python interpreter. Generally this means that the Python interpreter must be compiled with the same C compiler as was used to build FreeCAD. Information about the compiler used to build a Python interpreter (including the one built with FreeCAD) can be found as follows: +

      +
      >>> import sys
      +>>> sys.version
      +'2.7.13 (default, Dec 17 2016, 23:03:43) \n[GCC 4.2.1 Compatible Apple LLVM 8.0.0 (clang-800.0.42.1)]'
      +


      +

      + +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Embedding_FreeCADGui.html b/localwiki/Embedding_FreeCADGui.html new file mode 100644 index 0000000..c2103a2 --- /dev/null +++ b/localwiki/Embedding_FreeCADGui.html @@ -0,0 +1,464 @@ +Embedding FreeCADGui

      Embedding FreeCADGui

      + +

      You already know that you can import the FreeCAD module into a python application, and use all its tools from the host application. But the FreeCAD User Interface (GUI) can also be imported as a python module. Normally you can only import the complete interface as a whole, not pieces of it. That is because the FreeCAD interface system is not only made of independent widgets and toolbars, but is a complex construction where several invisible components (such as the selection system, etc) are needed for the main 3D view to be able to function. +

      But, with a bit of hacking, it is possible to import the whole FreeCAD interface, then move the 3D view from it to your own Qt application. We show here 3 different methods. +

      + + +

      Using the FreeCAD 3D view widget directly

      +

      Be aware that there are a lot of problems with this approach. The Qt event handling doesn't seem to work (no idea why) and if you use the 3d view's context-menu the application crashes. A better way could be to create your own 3d view SoQtExaminerViewer or SoQtViewer and "push" the content of FreeCAD's 3d view to your view, as shown in the other sections below. +

      First, get the main window via PyQt: +

      +
      from PySide import QtGui
      +from PySide import QtCore
      +   
      +def getMainWindow():
      +   toplevel = QtGui.qApp.topLevelWidgets()
      +   for i in toplevel:
      +      if i.metaObject().className() == "Gui::MainWindow":
      +         return i
      +   raise Exception("No main window found")
      +
      +mw=getMainWindow()
      +

      Then get the View3DInventor view the same way: +

      +
      def get3dview(mw):
      +      childs=mw.findChildren(QtGui.QMainWindow)
      +      for i in childs:
      +         if i.metaObject().className()=="Gui::View3DInventor":
      +            return i
      +      return None
      +
      +v=get3dview(mw)
      +

      The following code is generated automatically, by creating a Ui-file with QtDesigner, and converting it to python code with the pyuic tool: +

      +
      # -*- coding: utf-8 -*-
      +
      +# Form implementation generated from reading ui file 'mainwindow.ui'
      +#
      +# Created: Sun Dec 27 11:18:56 2009
      +#      by: PySide UI code generator 4.6
      +#
      +# Modify for PySide 11/02/2015
      +#      Python version: 2.7.8
      +#      Qt version: 4.8.6
      +#
      +# WARNING! All changes made in this file will be lost!
      +
      +from PySide import QtCore, QtGui
      +
      +class Ui_MainWindow(object):
      +    def setupUi(self, MainWindow):
      +        MainWindow.setObjectName("MainWindow")
      +        MainWindow.resize(508, 436)
      +        self.centralwidget = QtGui.QWidget(MainWindow)
      +        self.centralwidget.setObjectName("centralwidget")
      +        self.gridLayout = QtGui.QGridLayout(self.centralwidget)
      +        self.gridLayout.setObjectName("gridLayout")
      +        self.mdiArea = QtGui.QMdiArea(self.centralwidget)
      +        self.mdiArea.setViewMode(QtGui.QMdiArea.TabbedView)
      +        self.mdiArea.setTabPosition(QtGui.QTabWidget.South)
      +        self.mdiArea.setObjectName("mdiArea")
      +        self.gridLayout.addWidget(self.mdiArea, 0, 0, 1, 1)
      +        MainWindow.setCentralWidget(self.centralwidget)
      +        self.menubar = QtGui.QMenuBar(MainWindow)
      +        self.menubar.setGeometry(QtCore.QRect(0, 0, 508, 27))
      +        self.menubar.setObjectName("menubar")
      +        MainWindow.setMenuBar(self.menubar)
      +        self.statusbar = QtGui.QStatusBar(MainWindow)
      +        self.statusbar.setObjectName("statusbar")
      +        MainWindow.setStatusBar(self.statusbar)
      +
      +        self.retranslateUi(MainWindow)
      +        QtCore.QMetaObject.connectSlotsByName(MainWindow)
      +
      +    def retranslateUi(self, MainWindow):
      +        MainWindow.setWindowTitle(QtGui.QApplication.translate("MainWindow", "MainWindow", None, QtGui.QApplication.UnicodeUTF8))
      +

      Then, create a main window that should be your application's main window, apply the UI setup above to it in order to add an MDI area and "move" our 3d view to it +

      +
      ui=Ui_MainWindow()
      +my_mw=QtGui.QMainWindow()
      +ui.setupUi(my_mw)
      +ui.mdiArea.addSubWindow(v)
      +my_mw.show()
      +

      Creating a soGui Examiner Viewer

      +

      Alternatively, you can also use the FreeCADGui module to extract a coin/openInventor representation of the objects of your scene, then use that coin data in an external viewer (your application). Here is an easy way to get the 3d representation of an object: +

      +
          FreeCAD.activeDocument().addObject("Part::Box","myBox")
      +    s=FreeCADGui.activeDocument().getObject("myBox").toString() # store as string
      +    from pivy import coin
      +    inp.setBuffer(s)
      +    myNode=coin.SoDB.readAll(inp) # restore from string
      +

      Then, create a standalone viewer with pivy: +

      +
      from pivy.sogui import *
      +from pivy.coin import *
      +import sys
      +
      +def myViewer():
      +    # Initialize Coin. This returns a main window to use.
      +    # If unsuccessful, exit.
      +    myWindow = SoGui.init(sys.argv[0])
      +    if myWindow == None: sys.exit(1)
      +
      +    # Make an empty scene and add our node to it
      +    scene = SoSeparator()
      +    scene.addChild(myNode)
      +
      +    # Create a viewer in which to see our scene graph.
      +    viewer = SoGuiExaminerViewer(myWindow)
      +
      +    # Put our scene into viewer, change the title
      +    viewer.setSceneGraph(scene)
      +    viewer.setTitle("FreeCAD Object Viewer")
      +    viewer.show()
      +
      +    SoGui.show(myWindow) # Display main window
      +    SoGui.mainLoop()     # Main Coin event loop
      +

      Then you just need to run your viewer: +

      +
      myViewer()
      +

      Using the quarter module

      +

      Instead of using the sogui viewer, you can also use the more modern quarter module. This is probably the best solution of the 3. +

      +
          #!/usr/bin/env python
      + 
      +    ###
      +    # Copyright (c) 2002-2008 Kongsberg SIM
      +    #
      +    # Permission to use, copy, modify, and distribute this software for any
      +    # purpose with or without fee is hereby granted, provided that the above
      +    # copyright notice and this permission notice appear in all copies.
      +    #
      +    # THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
      +    # WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
      +    # MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
      +    # ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
      +    # WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
      +    # ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
      +    # OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
      +    #
      + 
      +    import os
      +    import sys
      + 
      +    from PyQt4 import QtCore, QtGui
      +    from PyQt4.QtGui import QMainWindow, QWorkspace, QAction, QFileDialog, QApplication
      + 
      +    from pivy.coin import SoInput, SoDB
      +    from pivy.quarter import QuarterWidget
      + 
      +    import FreeCAD, FreeCADGui
      + 
      +    def getMainWindow():
      +       toplevel = QtGui.qApp.topLevelWidgets()
      +       for i in toplevel:
      +          if i.metaObject().className() == "Gui::MainWindow":
      +             return i
      +       raise Exception("No main window found")
      + 
      +    class MdiQuarterWidget(QuarterWidget):
      +        def __init__(self, parent, sharewidget):
      +            QuarterWidget.__init__(self, parent=parent, sharewidget=sharewidget)
      + 
      +        def loadFile(self, filename):
      +            in_ = SoInput()
      +            if (in_.openFile(str(filename.toLatin1()))):
      +                root = SoDB.readAll(in_)
      +            if (root):
      +                self.setSceneGraph(root)
      +                self.currentfile = filename
      +                self.setWindowTitle(filename)
      +                return True
      +            return False
      + 
      +        def currentFile(self):
      +            return self.currentfile
      + 
      +        def minimumSizeHint(self):
      +            return QtCore.QSize(640, 480)
      + 
      +    class MdiMainWindow(QMainWindow):
      +        def __init__(self, qApp):
      +            QMainWindow.__init__(self)
      +            self._firstwidget = None
      +            self._workspace = QWorkspace()
      +            self.setCentralWidget(self._workspace)
      +            self.setAcceptDrops(True)
      +            self.setWindowTitle("Pivy Quarter MDI example")
      + 
      +            filemenu = self.menuBar().addMenu("&File")
      +            windowmenu = self.menuBar().addMenu("&Windows")
      + 
      +            fileopenaction = QAction("&Create Box", self)
      +            fileexitaction = QAction("E&xit", self)
      +            tileaction = QAction("Tile", self)
      +            cascadeaction = QAction("Cascade", self)
      + 
      +            filemenu.addAction(fileopenaction)
      +            filemenu.addAction(fileexitaction)
      +            windowmenu.addAction(tileaction)
      +            windowmenu.addAction(cascadeaction)
      + 
      +            self.connect(fileopenaction, QtCore.SIGNAL("triggered()"), self.createBoxInFreeCAD)
      +            self.connect(fileexitaction, QtCore.SIGNAL("triggered()"), QtGui.qApp.closeAllWindows)
      +            self.connect(tileaction, QtCore.SIGNAL("triggered()"), self._workspace.tile)
      +            self.connect(cascadeaction, QtCore.SIGNAL("triggered()"), self._workspace.cascade)
      + 
      +            windowmapper = QtCore.QSignalMapper(self)
      +            self.connect(windowmapper, QtCore.SIGNAL("mapped(QWidget *)"), self._workspace.setActiveWindow)
      + 
      +            self.dirname = os.curdir       
      + 
      +        def dragEnterEvent(self, event):
      +            # just accept anything...
      +            event.acceptProposedAction()
      + 
      +        def dropEvent(self, event):
      +            mimedata = event.mimeData()
      +            if mimedata.hasUrls():
      +                path = mimedata.urls().takeFirst().path()
      +                self.open_path(path)
      + 
      +        def closeEvent(self, event):
      +            self._workspace.closeAllWindows()
      + 
      +        def open(self):
      +            self.open_path(QFileDialog.getOpenFileName(self, "", self.dirname))
      + 
      +        def open_path(self, filename):
      +            self.dirname = os.path.dirname(str(filename.toLatin1()))
      +            if not filename.isEmpty():
      +                existing = self.findMdiChild(filename)
      +                if existing:
      +                    self._workspace.setActiveWindow(existing)
      +                    return
      +            child = self.createMdiChild()
      +            if (child.loadFile(filename)):
      +                self.statusBar().showMessage("File loaded", 2000)
      +                child.show()
      +            else:
      +                child.close()
      + 
      +        def findMdiChild(self, filename):
      +            canonicalpath = QtCore.QFileInfo(filename).canonicalFilePath()
      +            for window in self._workspace.windowList():
      +                mdiwidget = window
      +                if mdiwidget.currentFile() == canonicalpath:
      +                    return mdiwidget
      +            return 0;
      + 
      +        def createMdiChild(self):
      +            widget = MdiQuarterWidget(None, self._firstwidget)
      +            self._workspace.addWindow(widget)
      +            if not self._firstwidget:
      +                self._firstwidget = widget
      +            return widget
      + 
      +        def createBoxInFreeCAD(self):
      +            widget = MdiQuarterWidget(None, self._firstwidget)
      +            self._workspace.addWindow(widget)
      +            if not self._firstwidget:
      +                self._firstwidget = widget
      +            widget.show()
      +            doc = FreeCAD.newDocument()
      +            doc.addObject("Part::Box","myBox")
      +            iv_=FreeCADGui.getDocument(doc.Name).getObject("myBox").toString()
      +            in_ = SoInput()
      +            in_.setBuffer(iv_)
      +            root = SoDB.readAll(in_)
      +            if (root):
      +                widget.setSceneGraph(root)
      + 
      +    def main():
      +        app = QApplication(sys.argv) 
      +        mdi = MdiMainWindow(app)   
      +        mdi.show()
      +        FreeCADGui.showMainWindow() # setup the GUI stuff of FreeCAD
      +        mw=getMainWindow()
      +        mw.hide() # hide all
      +        if len(sys.argv)==2:
      +            mdi.open_path(QtCore.QString(sys.argv[1]))
      +        sys.exit(app.exec_())
      + 
      +    def show():
      +        mdi = MdiMainWindow(QtGui.qApp)   
      +        mdi.show()
      +        mw=getMainWindow()
      +        #mw.hide() # hide all
      + 
      +    if __name__ == '__main__':
      +        main()
      +

      Without even firing up the FreeCAD Gui

      +

      Starting from FreeCAD rev2760, it is now possible to obtain the coin representation of any FreeCAD object without opening the main window. This makes it extremely easy to implement your own viewer and transparently have FreeCAD updating it. After importing the FreeCADGui module, you need to fire it up with the setupWithoutGUI() method, after which you can use all of FreeCAD's view providers to obtain coin/openInventor nodes. +

      +
          import os, sys, FreeCAD, FreeCADGui
      +    from PyQt4 import QtCore, QtGui
      +    from PyQt4.QtGui import QMainWindow, QWorkspace, QAction, QFileDialog, QApplication
      +    from pivy.coin import SoInput, SoDB, sogui
      + 
      +    class MdiMainWindow(QMainWindow):
      +        def __init__(self, qApp):
      +            QMainWindow.__init__(self)
      +            self._firstwidget = None
      +            self._workspace = QWorkspace()
      +            self.setCentralWidget(self._workspace)
      +            self.setAcceptDrops(True)
      +            self.setWindowTitle("Pivy Quarter MDI example")
      +            self.viewers=[]
      + 
      +            filemenu = self.menuBar().addMenu("&File")
      +            windowmenu = self.menuBar().addMenu("&Windows")
      + 
      +            fileopenaction = QAction("&Create Box", self)
      +            fileexitaction = QAction("E&xit", self)
      +            tileaction = QAction("Tile", self)
      +            cascadeaction = QAction("Cascade", self)
      + 
      +            filemenu.addAction(fileopenaction)
      +            filemenu.addAction(fileexitaction)
      +            windowmenu.addAction(tileaction)
      +            windowmenu.addAction(cascadeaction)
      + 
      +            self.connect(fileopenaction, QtCore.SIGNAL("triggered()"), self.createBoxInFreeCAD)
      +            self.connect(fileexitaction, QtCore.SIGNAL("triggered()"), QtGui.qApp.closeAllWindows)
      +            self.connect(tileaction, QtCore.SIGNAL("triggered()"), self._workspace.tile)
      +            self.connect(cascadeaction, QtCore.SIGNAL("triggered()"), self._workspace.cascade)
      + 
      +            windowmapper = QtCore.QSignalMapper(self)
      +            self.connect(windowmapper, QtCore.SIGNAL("mapped(QWidget *)"), self._workspace.setActiveWindow)
      + 
      +        def closeEvent(self, event):
      +            self._workspace.closeAllWindows()
      + 
      +        def createBoxInFreeCAD(self):
      +            widget = QtGui.QWidget(self._firstwidget)
      +            viewer = sogui.SoGuiExaminerViewer(widget)
      +            self._workspace.addWindow(widget)
      +            if not self._firstwidget:
      +                self._firstwidget = widget
      +            widget.show()
      +            self.viewers.append(viewer)
      +            doc = FreeCAD.newDocument()
      +            obj=doc.addObject("Part::Box","myBox")
      +            doc.recompute()
      +            root=FreeCADGui.subgraphFromObject(obj)
      +            viewer.setSceneGraph(root)
      + 
      +    def main():
      +        app = QApplication(sys.argv)
      +        mdi = MdiMainWindow(app)   
      +        mdi.show()
      +        FreeCADGui.setupWithoutGUI()
      +        sys.exit(app.exec_())
      + 
      +    if __name__ == '__main__':
      +        main()
      +

      Or, if using pivy's sogui module doesn't work for you (the sogui module is becoming obsoleted and the coin developers are now favoring the new quarter library, which has much better interaction with qt), this is the same script but with using quarter: +

      +
          #!/usr/bin/env python
      + 
      +    import os
      +    import sys
      + 
      +    from PyQt4 import QtCore, QtGui
      +    from PyQt4.QtGui import QMainWindow, QWorkspace, QAction, QApplication
      + 
      +    from pivy.coin import SoInput, SoDB
      +    from pivy.quarter import QuarterWidget
      +    import FreeCADGui
      + 
      + 
      +    class MdiQuarterWidget(QuarterWidget):
      +        def __init__(self, parent, sharewidget):
      +            QuarterWidget.__init__(self, parent=parent, sharewidget=sharewidget)
      + 
      +        def minimumSizeHint(self):
      +            return QtCore.QSize(640, 480)
      + 
      + 
      +    class MdiMainWindow(QMainWindow):
      +        def __init__(self, qApp):
      +            QMainWindow.__init__(self)
      +            self._firstwidget = None
      +            self._workspace = QWorkspace()
      +            self.setCentralWidget(self._workspace)
      +            self.setAcceptDrops(True)
      +            self.setWindowTitle("Pivy Quarter MDI example")
      + 
      +            filemenu = self.menuBar().addMenu("&File")
      +            windowmenu = self.menuBar().addMenu("&Windows")
      + 
      +            fileopenaction = QAction("&Create Box", self)
      +            fileexitaction = QAction("E&xit", self)
      +            tileaction = QAction("Tile", self)
      +            cascadeaction = QAction("Cascade", self)
      + 
      +            filemenu.addAction(fileopenaction)
      +            filemenu.addAction(fileexitaction)
      +            windowmenu.addAction(tileaction)
      +            windowmenu.addAction(cascadeaction)
      + 
      +            self.connect(fileopenaction, QtCore.SIGNAL("triggered()"), self.createBoxInFreeCAD)
      +            self.connect(fileexitaction, QtCore.SIGNAL("triggered()"), QtGui.qApp.closeAllWindows)
      +            self.connect(tileaction, QtCore.SIGNAL("triggered()"), self._workspace.tile)
      +            self.connect(cascadeaction, QtCore.SIGNAL("triggered()"), self._workspace.cascade)
      + 
      +            windowmapper = QtCore.QSignalMapper(self)
      +            self.connect(windowmapper, QtCore.SIGNAL("mapped(QWidget *)"), self._workspace.setActiveWindow)
      + 
      +            self.dirname = os.curdir       
      + 
      +        def closeEvent(self, event):
      +            self._workspace.closeAllWindows()
      + 
      +        def createBoxInFreeCAD(self):
      +            d=FreeCAD.newDocument()
      +            o=d.addObject("Part::Box")
      +            d.recompute()
      +            s=FreeCADGui.subgraphFromObject(o)
      +            child = self.createMdiChild()
      +            child.show()
      +            child.setSceneGraph(s)
      + 
      +        def createMdiChild(self):
      +            widget = MdiQuarterWidget(None, self._firstwidget)
      +            self._workspace.addWindow(widget)
      +            if not self._firstwidget:
      +                self._firstwidget = widget
      +            return widget
      + 
      + 
      +    def main():
      +        app = QApplication(sys.argv)
      +        FreeCADGui.setupWithoutGUI()        
      +        mdi = MdiMainWindow(app)   
      +        mdi.show()
      +        sys.exit(app.exec_())
      + 
      + 
      +    if __name__ == '__main__':
      +        main()
      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Example.png b/localwiki/Example.png new file mode 100644 index 0000000..cecfd33 Binary files /dev/null and b/localwiki/Example.png differ diff --git a/localwiki/Exercise_path_02.jpg b/localwiki/Exercise_path_02.jpg new file mode 100644 index 0000000..8594c1a Binary files /dev/null and b/localwiki/Exercise_path_02.jpg differ diff --git a/localwiki/Export_to_STL_or_OBJ.html b/localwiki/Export_to_STL_or_OBJ.html new file mode 100644 index 0000000..9ee524c --- /dev/null +++ b/localwiki/Export_to_STL_or_OBJ.html @@ -0,0 +1,118 @@ +Export to STL or OBJ

      Export to STL or OBJ

      + +
      + + + + + + + + + + + + + + + + + + + + + + + + + + + +
      +

      Base ExampleCommandModel.png Tutorial

      +
      Topic +
      Export to STL or OBJ +
      Level +
      Beginner +
      Time to complete +
      20 minutes +
      Author +
      r-frank +
      FreeCAD version +
      0.16.6703 +
      Example File(s) +
      +

      + +
      +


      +

      +

      Introduction

      +

      In this tutorial we will cover how to export STL/OBJ-files from FreeCAD. +Since the mesh-format STL/OBJ is dimensionless, FreeCAD will assume +on export that the units used in the model are in mm. +If this is not the case you have to scale your model . +

      +

      Sample part

      +

      You can use your own FreeCAD file, but you could also create a quick test file by +

      +
      • Opening FreeCAD
      • +
      • Create a new document
      • +
      • Switch to part workbench
      • +
      • Insert a cube by clicking on Part Box.png
      • +
      • Insert a cone by clicking on Part Cone.png
      • +
      • Select all two objects in the tree view
      • +
      • Apply a fusion by clicking on Part Fuse.png
      • +
      • Save your file
      +

      Export Method 1: Using "File > Export"

      +
      • Switch to mesh workbench or complete workbench
      • +
      • Choose Edit Preferences Import-Export Mesh Formats from the top menu
      • +
      • Here you can specify the maximum mesh deviation (0,1 mm is default) which controls how "fine" your mesh will get
      • +
      • Close dialogue with OK
      • +
      • Select the solid to be exported in the tree view
      • +
      • Choose File Export... and set file type to for example "STL mesh (*.stl *.ast)"
      • +
      • Type in your file name and don't forget the extension, choose Save
      +

      Export Method 2: Using the mesh workbench in FreeCAD

      +
      • Switch to mesh workbench
      • +
      • Select the solid to be meshed in the tree view
      • +
      • Choose MeshesMesh Mesh from Shape.svg Create Mesh from shape... from the top menu
      • +
      • Select one of the three available meshers and specify the available options, for more info refer to this page (Mesh from Shape)
      • +
      • Choose OK and the mesh object will be created in the tree view (with green mesh icon)
      • +
      • Select the mesh object in the tree view and right click on mesh object in the tree view
      • +
      • Choose Mesh ExportMesh.png Export mesh to export mesh
      • +
      • You will be prompted to choose file name (default is the name of the mesh object) and the file type (default is "Binary STL (*.stl)")
      • +
      • Choose Save and you are finished
      +

      Which Method too choose ?

      +
      • Method 2 is to be preferred. Especially when you have more than one Body to convert you can use Tools from Mesh Workbench , like fusioning Meshes before Exporting.
      +


      +

      +

      Links

      + +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Expression_usage1.png b/localwiki/Expression_usage1.png new file mode 100644 index 0000000..7f6061f Binary files /dev/null and b/localwiki/Expression_usage1.png differ diff --git a/localwiki/Expression_usage2.png b/localwiki/Expression_usage2.png new file mode 100644 index 0000000..a99fde3 Binary files /dev/null and b/localwiki/Expression_usage2.png differ diff --git a/localwiki/Expression_usage3.png b/localwiki/Expression_usage3.png new file mode 100644 index 0000000..da95e03 Binary files /dev/null and b/localwiki/Expression_usage3.png differ diff --git a/localwiki/Expressions.html b/localwiki/Expressions.html new file mode 100644 index 0000000..43bd9ab --- /dev/null +++ b/localwiki/Expressions.html @@ -0,0 +1,126 @@ +Expressions

      Expressions

      + +

      available in version 0.16 +


      +It is now possible to drive properties using mathematical expressions. From the GUI, spin boxes or input fields, that are bound to properties contain a blue icon Sketcher Expressions.png. Clicking on the icon, or typing the equal sign (=), brings up the expression editor for that particular property. +

      A FreeCAD expression is a mathematical expression, following normal notation for the standard mathematical operators (+, -, * and /) and functions as described below. In addition, the expression may reference other properties, and also use conditionals. Numbers in an expression may have an optional unit attached to it. +

      Operators and functions are unit-aware, and require valid combinations of units, if supplied. For example, 2mm+4mm is a valid expression, while 2mm+4 is not (the reason for this is that an expression like 1in + 4 will most likely be interpreted as 1in + 4in by humans, but all units are converted to the SI system internally, and the system is not able to guess this). +

      + + +

      Supported Functions

      +

      In expressions, the following functions are supported, taking one or two arguments: abs, acos, asin, atan, atan2, cos, cosh, exp, log, log10, mod, pow, sin, sinh, sqrt, tan, tanh, ceil, floor, trunc, and round. +

      Aggregate functions: min, max, count, sum, stddev, and average. +Aggregate functions can take one or more arguments, separated by comma or semicolon. Arguments may include ranges (two cells separated by a colon), e.g =average(B1:B8). These are interpreted as the properties B1, B2, ... B8. +

      Trigonometric functions use degrees as its default unit; supply "rad" if you want them to use radians. +

      The constants pi and e are predefined. +

      The conditional statement works like this: = condition ? resultTrue : resultFalse +

      The condition is defined as an expression that evaluates to either 0 (for false) or non-zero for true. The following comparison operators are defined: ==, !=, >, <, >=, and <=. +

      Formulas are written as e.g follows: 2 * Length, where Length is a property in the object holding the expression. +

      +

      Reference To CAD-Data

      +

      It is possible to use data from other parts of the construction in an expression. The syntax for a reference to a field is as follows: object.property. If the property is a compound of fields, they can be accessed by e.g object.property.field. +

      The following table shows some examples: +

      + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
      CAD-Data +Call in expression +Result +
      Parametric Length of a Part-Workbench Cube +Cube.Length +Length with units mm +
      Volume of the Cube +Cube.Shape.Volume +Volume in mm³ without units +
      Type of the Cube-shape +Cube.Shape.ShapeType +String: Solid +
      Label of the Cube +Cube.Label +String: Cube +
      x-coordinate of center of mass of the Cube +Cube.Shape.CenterOfMass.x +x-coordinate in mm without units +
      Value of constraint in a sketch +Constraints.Width +Numeric value of the named constraint 'Width' in the sketch +
      Value of a spreadsheet alias +Spreadsheet.Depth +Value of the alias "Depth" in the spreadsheet "Spreadsheet" +
      Value of a local property +Length +Value of the Length property in e.g a Pad object, if the expression is used in e.g Length2 in the same object. +
      +

      Document-wide global variables

      +

      There is no concept of global variables in FreeCAD at the moment. Instead, arbitrary variables can be defined as cells in a spreadsheet using the Spreadsheet workbench, and then be given a name using the alias property for the cell (right-click on cell). Then they can be accessed from any expression just as any other object property. +

      +

      Cross-document linking

      +

      It's possible that you have a spreadsheet in one document and reference values from there in other documents. +

      Important note: You use a document's name to reference it from other documents. Now, when saving the document the first time you choose a certain file name and this is usually different to "Unnamed1" (or its translated version) and then the links are lost after reopening it. So, it's recommended to create first the master document, create a spreadsheet, save and close it. After reopening the name is set to the above file name. Afterwards you can still make changes and save the file but you shouldn't rename it. +

      Then create the further documents where you want to add expressions to. Assuming you named the master document "master" you can access an alias like this: master#Spreadsheet.Length +

      Unfortunately, the integrated checker is more confusing than helping because it always gives parser errors or claims that this or that doesn't exist. So, just continue on typing. When you are finished and the content is correct the OK suddenly becomes active. +

      Of course, it's up to you to load the corresponding documents later when you want to change anything. +

      +

      Known issues / remaining tasks

      +
      • The dependency graphs is based on the relationship between document objects, not properties. This means that you cannot provide data to and query the same object in e.g a spreadsheet, even though there are no cyclic dependency when just the properties are considered. As a work-around, use multiple spreadsheets, e.g one to drive your model, and one for reporting.
      • +
      • There is no expression manager implemented where all expressions in a document are listed, and can be created, deleted, queries, etc.
      • +
      • Open bugs/tickets for Expressions can be found in the FreeCAD Bugtracker Expressions category
      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Extend_FEM_Module.html b/localwiki/Extend_FEM_Module.html new file mode 100644 index 0000000..6bf5cf6 --- /dev/null +++ b/localwiki/Extend_FEM_Module.html @@ -0,0 +1,202 @@ +Extend FEM Module

      Extend FEM Module

      + +
      + + + + + + + + + + + + + + + + + + + + + + + + + + + +
      +

      Base ExampleCommandModel.png Tutorial

      +
      Topic +
      +
      Level +
      +
      Time to complete +
      +
      Author +
      M42kus +
      FreeCAD version +
      +
      Example File(s) +
      +

      + +
      +


      +

      The FEM workbench already supports alot of different constraints and a handful of solver. Despite that people often need constraints not jet supported by FreeCAD. This page is the starting point to a series of tutorials and other resources describing how to extend the FEM workbench using the existing framework. While this series can prove helpful to software developers too the idea is to allow FEM users with a bit of interrest into python coding to add the stuff they need themselfs. +

      Adding new constraints, equations or solver is mostly routine work. But doing it for the first time will not be as easy as it might seem. An understanding of the following topics will prove helpful: +

      +
      • Python scripting in FreeCAD. +
      • +
      • Extending FreeCAD with Python. +
      • +
      • A solid understanding of the solver for which new objects shall be added (e.g. calculix) is important.
      • +
      • A little knowledge about build systems, especially cmake (build system used by FreeCAD)
      +

      Build System (cmake)

      +

      The build system must be modified regardless of which objects shall be added o the FEM workbench. Every python module (file) must be registerd. The FEM workbench even requries every new python module to be registerd twice. Once in Mod/Fem/CMakeLists.txt and a secound time in Mod/Fem/App/CMakeLists.txt. This is true regaredless of the type of the python module (gui or non-gui). Where exactely the module must be inserted depends on the role of the module. Solver, equations and constraints all use different lists. Searching for similar files and inserting the new file in the same list works most of the time. +

      As an example lets add a new constraint pressure. A new constraint requires at least the following new modules: FemConstraint<name>.py, ViewProviderFemConstraint<name>.py, CommandFemConstraint<name>.py. These three files must be added to CMakeLists.txt as well as App/CMakeLists.txt. +

      Mod/Fem/CMakeLists.txt +

      +
      INSTALL(
      +    FILES
      +        PyObjects/__init__.py
      +        PyObjects/_FemConstraintSelfWeight.py
      +        PyObjects/_FemConstraintBodyHeatFlux.py
      +        PyObjects/_FemConstraintFlowVelocity.py
      ++       PyObjects/_FemConstraintFlowPressure.py
      +        PyObjects/_FemElementFluid1D.py
      +        PyObjects/_FemElementGeometry1D.py
      +        PyObjects/_FemElementGeometry2D.py
      +        ...
      +    DESTINATION
      +        Mod/Fem/PyObjects
      +)
      +
      +INSTALL(
      +    FILES
      +        PyGui/FemCommands.py
      +        PyGui/__init__.py
      +        PyGui/_CommandFemSolverElmer.py
      +        PyGui/_CommandFemEquation.py
      +        PyGui/_CommandFemConstraintBodyHeatFlux.py
      +        PyGui/_CommandFemConstraintFlowVelocity.py
      ++       PyGui/_CommandFemConstraintFlowPressure.py
      +        PyGui/_CommandFemAnalysis.py
      +        PyGui/_CommandFemElementFluid1D.py
      +        PyGui/_CommandFemElementGeometry1D.py
      +        ...
      +        PyGui/_ViewProviderFemConstraintSelfWeight.py
      +        PyGui/_ViewProviderFemConstraintBodyHeatFlux.py
      +        PyGui/_ViewProviderFemConstraintFlowVelocity.py
      ++       PyGui/_ViewProviderFemConstraintFlowPressure.py
      +        PyGui/_ViewProviderFemElementFluid1D.py
      +        PyGui/_ViewProviderFemElementGeometry1D.py
      +        PyGui/_ViewProviderFemElementGeometry2D.py
      +        ...
      +    DESTINATION
      +        Mod/Fem/PyGui
      +)
      +

      Mod/Fem/App/CMakeLists.txt +

      +
      SET(FemObjectsScripts_SRCS
      +    PyObjects/__init__.py
      +    PyObjects/_FemConstraintSelfWeight.py
      +    PyObjects/_FemConstraintBodyHeatFlux.py
      +    PyObjects/_FemConstraintFlowVelocity.py
      ++   PyObjects/_FemConstraintFlowPressure.py
      +    PyObjects/_FemElementFluid1D.py
      +    PyObjects/_FemElementGeometry1D.py
      +    PyObjects/_FemElementGeometry2D.py
      +    PyObjects/_FemMaterialMechanicalNonlinear.py
      +    PyObjects/_FemMeshBoundaryLayer.py
      +    PyObjects/_FemMeshGmsh.py
      +    PyObjects/_FemMeshGroup.py
      +    PyObjects/_FemMeshResult.py
      +    PyObjects/_FemMeshRegion.py
      +    PyObjects/_FemResultMechanical.py
      +    PyObjects/_FemSolverCalculix.py
      +    PyObjects/_FemMaterial.py
      +)
      +
      +SET(FemGuiScripts_SRCS
      +    PyGui/FemCommands.py
      +    PyGui/__init__.py
      +    PyGui/_CommandFemAnalysis.py
      +    PyGui/_CommandFemConstraintSelfWeight.py
      +    PyGui/_CommandFemConstraintBodyHeatFlux.py
      +    PyGui/_CommandFemConstraintFlowVelocity.py
      ++   PyGui/_CommandFemConstraintFlowPressure.py
      +    PyGui/_CommandFemElementFluid1D.py
      +    PyGui/_CommandFemElementGeometry1D.py
      +    ...
      +    PyGui/_ViewProviderFemConstraintBodyHeatFlux.py
      +    PyGui/_ViewProviderFemConstraintFlowVelocity.py
      ++   PyGui/_ViewProviderFemConstraintFlowPressure.py
      +    PyGui/_ViewProviderFemElementFluid1D.py
      +    PyGui/_ViewProviderFemElementGeometry1D.py
      +    PyGui/_ViewProviderFemElementGeometry2D.py
      +    ...
      +)
      +

      Source Organization

      +

      For organizing the python code the FEM module uses a similar abbroach to that used for the C++ code thoughout FreeCAD. The module is split into two packages. PyObjects, which contains all non-gui like python proxies for document objects and PyGui containing everything gui related like python proxies for view provider, task panels, ui files and commands. +

      One package doesn't follow this pattern: FemSolver. It has its place on the same level as PyObjects and PyGui (src/Mod/Fem/FemSolver). The package contains solver and equation related packages and modules and it is organized the following way: +

      +
      .FemSolver
      +.FemSolver.Elmer
      +.FemSolver.Elmer.Equations
      +.FemSolver.Calculix
      +.FemSolver.Calculix.Equations
      +.FemSolver.Z88
      +.FemSolver.Z88.Equations
      +

      Solver

      +

      In FreeCAD a solver can be split into two parts. One is the document object used by the user to interact with the solver. Though it solver parameter can be set and it is also used to control the solving process. The other one are the so called tasks of a solver. The solving process is split into those tasks, namely: check, prepare, solve and results. Those do the actual work of exporting the analysis into a format understood by the solver executable, starting the executable and loading the results back into FreeCAD. +

      Most files related to a solver reside in a sub-package of the FemSolver package (e.g. FemSolver.Elmer). The following list enumerates all files related to the implementation of a solver. Those are the files that need to be copied and modified to add support for a new solver to FreeCAD. +

      +
      • FemSolver/Elmer/Object.py: Document object visible in the tree-view. Implemented in python via a document proxy and view proxy.
      • +
      • FemSolver/Elmer/Tasks.py: Module containing one task class per task required for a solver implementation. Those tasks divide the process of solving a analysis into the following steps: check, prepare, solve, results.
      • +
      • PyGui/_CommandFemElmer.py: Adds the solver document object to the active document. Required to access the solver object from the GUI.
      +

      Equations

      +

      An equation represets a particular physics that shall be considered when solving the analysis (e.g. Flow, Heat). Not all solver in FreeCAD support equations. Equations are represented by child objects of the corresponding solver object. In the tree-view this looks like this: +

      +
      • ElmerSolver +
        • Elasticity
        • +
        • Heat
        • +
        • Flow
      +

      Most solver specific options (max iterations, method of solving, etc) are set via the equation objects. One consequence of this is that each solver must have it's own implementation of "the same" equation. Calculix would have a different Heat object that Elmer. To avoid having multiple buttons for the same physics in the GUI each solver object adds it's equations itself. +

      The actual implementation can be split into the generic and the solver specific part. The generic part can be found in the FemSolver.EquationBase module. The solver specific part resides inside individual Equations sub-packages of the solver packages (e.g. FemSolver/Elmer/Equations). +

      Adding a new equations to elmer should be very easy. For newcomers there exists a tutorial which shows how to add a new equation to elmer by adding the existing elasticity solver to FreeCAD: Add FEM Equation Tutorial. +

      +

      Constraints

      +

      Constraints define boundary conditions for the problem that shall be solved. In FreeCAD constraints aren't specific to a particular solver. A problem setup can be solved by all solver that support all conditions in the analysis. +

      Adding new constraints is quite staight foreward. For newcomers there is a tutorial: Add FEM Constraint Tutorial. +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/External_workbenches.html b/localwiki/External_workbenches.html new file mode 100644 index 0000000..712c606 --- /dev/null +++ b/localwiki/External_workbenches.html @@ -0,0 +1,56 @@ +External workbenches

      External workbenches

      + +

      Power users have extended FreeCAD with various custom external workbenches, that are not integrated into the FreeCAD source code (yet!), +but are easy to install on an existing FreeCAD installation. Instructions are provided on the pages linked below: +

      TODO: +

      +
      • Bolts
      • +
      • Cfd
      • +
      • EaglePCB_2_FreeCAD
      • +
      • Gears
      • +
      • FreeCAD-CuraEngine
      • +
      • Animation
      • +
      • Lattice
      • +
      • Lattice2
      • +
      • Exploded Animation
      • +
      • Fasteners
      • +
      • Flamingo
      • +
      • GeoData
      • +
      • Nurbs
      • +
      • Persistent toolbars
      • +
      • Retr3D
      • +
      • Sheetmetal
      • +
      • Timber
      • +
      • Manipulator
      • +
      • Kicad StepUp
      • +
      • WebTools
      +

      Assembly2

      +

      The Assembly 2 workbench provides tools to create multi-part assemblies, and is a very good alternative for the official Assembly workbench which is still under development (see forum thread). +

      Assembly2 example.jpg +

      +

      Drawing Dimensioning

      +

      The Drawing dimensioning workbench adds powerful dimensioning and annotation tools to the Drawing workbench (see forum thread). +

      Drawing Dimensioning example.jpg +

      +

      Work Features

      +

      The WorkFeature macro adds a wide range of helper objects such as alignment planes or axes, and tools to help you to position and align objects along those helper objects (see forum thread). +

      See WF wf.png Macro WorkFeatures in the wiki. +


      +WF.png +


      +

      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Extra_python_modules.html b/localwiki/Extra_python_modules.html new file mode 100644 index 0000000..f9c0fac --- /dev/null +++ b/localwiki/Extra_python_modules.html @@ -0,0 +1,457 @@ +Extra python modules

      Extra python modules

      + +

      This page lists several additional python modules or other pieces of software that can be downloaded freely from the internet, and add functionality to your FreeCAD installation. +

      + + +

      PySide (previously PyQt4)

      + +

      PySide (previously PyQt) is required by several modules of FreeCAD to access FreeCAD's Qt interface. It is already bundled in the windows verison of FreeCAD, and is usually installed automatically by FreeCAD on Linux, when installing from official repositories. If those modules (Draft, Arch, etc) are enabled after FreeCAD is installed, it means PySide (previously PyQt) is already there, and you don't need to do anything more. +

      Note: FreeCAD progressively moved away from PyQt after version 0.13, in favour of PySide, which does exactly the same job but has a license (LGPL) more compatible with FreeCAD. +

      +

      Installation

      +

      Linux

      +

      The simplest way to install PySide is through your distribution's package manager. On Debian/Ubuntu systems, the package name is generally python-PySide, while on RPM-based systems it is named pyside. The necessary dependencies (Qt and SIP) will be taken care of automatically. +

      +

      Windows

      +

      The program can be downloaded from http://qt-project.org/wiki/Category:LanguageBindings::PySide::Downloads . You'll need to install the Qt and SIP libraries before installing PySide (to be documented). +

      +

      MacOSX

      +

      PyQt on Mac can be installed via homebrew or port. See CompileOnMac#Install_Dependencies for more information. +

      +

      Usage

      +

      Once it is installed, you can check that everything is working by typing in FreeCAD python console: +

      +
      import PySide 
      +

      To access the FreeCAD interface, type : +

      +
      from PySide import QtCore,QtGui
      +FreeCADWindow = FreeCADGui.getMainWindow() 
      +

      Now you can start to explore the interface with the dir() command. You can add new elements, like a custom widget, with commands like : +

      +
      FreeCADWindow.addDockWidget(QtCore.Qt.RghtDockWidgetArea,my_custom_widget) 
      +

      Working with Unicode : +

      +
      text = text.encode('utf-8') 
      +

      Working with QFileDialog and OpenFileName : +

      +
      path = FreeCAD.ConfigGet("AppHomePath")
      +#path = FreeCAD.ConfigGet("UserAppData")
      +OpenName, Filter = PySide.QtGui.QFileDialog.getOpenFileName(None, "Read a txt file", path, "*.txt") 
      +

      Working with QFileDialog and SaveFileName : +

      +
      path = FreeCAD.ConfigGet("AppHomePath")
      +#path = FreeCAD.ConfigGet("UserAppData")
      +SaveName, Filter = PySide.QtGui.QFileDialog.getSaveFileName(None, "Save a file txt", path, "*.txt") 
      +

      Example of transition from PyQt4 and PySide

      +

      PS: these examples of errors were found in the transition PyQt4 to PySide and these corrections were made, other solutions are certainly available with the examples above +

      +
      try:
      +    import PyQt4                                        # PyQt4
      +    from PyQt4 import QtGui ,QtCore                     # PyQt4
      +    from PyQt4.QtGui import QComboBox                   # PyQt4
      +    from PyQt4.QtGui import QMessageBox                 # PyQt4
      +    from PyQt4.QtGui import QTableWidget, QApplication  # PyQt4
      +    from PyQt4.QtGui import *                           # PyQt4
      +    from PyQt4.QtCore import *                          # PyQt4
      +except Exception:
      +    import PySide                                       # PySide
      +    from PySide import QtGui ,QtCore                    # PySide
      +    from PySide.QtGui import QComboBox                  # PySide
      +    from PySide.QtGui import QMessageBox                # PySide
      +    from PySide.QtGui import QTableWidget, QApplication # PySide
      +    from PySide.QtGui import *                          # PySide
      +    from PySide.QtCore import *                         # PySide 
      +

      To access the FreeCAD interface, type : +You can add new elements, like a custom widget, with commands like : +

      +
      myNewFreeCADWidget = QtGui.QDockWidget()          # create a new dockwidget
      +myNewFreeCADWidget.ui = Ui_MainWindow()           # myWidget_Ui()             # load the Ui script
      +myNewFreeCADWidget.ui.setupUi(myNewFreeCADWidget) # setup the ui
      +try:
      +    app = QtGui.qApp                              # PyQt4 # the active qt window, = the freecad window since we are inside it
      +    FCmw = app.activeWindow()                     # PyQt4 # the active qt window, = the freecad window since we are inside it
      +    FCmw.addDockWidget(QtCore.Qt.RightDockWidgetArea,myNewFreeCADWidget) # add the widget to the main window
      +except Exception:
      +    FCmw = FreeCADGui.getMainWindow()             # PySide # the active qt window, = the freecad window since we are inside it 
      +    FCmw.addDockWidget(QtCore.Qt.RightDockWidgetArea,myNewFreeCADWidget) # add the widget to the main window 
      +

      Working with Unicode : +

      +
      try:
      +    text = unicode(text, 'ISO-8859-1').encode('UTF-8')  # PyQt4
      +except Exception:
      +    text = text.encode('utf-8')                         # PySide 
      +

      Working with QFileDialog and OpenFileName : +

      +
      OpenName = ""
      +try:
      +    OpenName = QFileDialog.getOpenFileName(None,QString.fromLocal8Bit("Lire un fichier FCInfo ou txt"),path,"*.FCInfo *.txt") # PyQt4
      +except Exception:
      +    OpenName, Filter = PySide.QtGui.QFileDialog.getOpenFileName(None, "Lire un fichier FCInfo ou txt", path, "*.FCInfo *.txt")#PySide 
      +

      Working with QFileDialog and SaveFileName : +

      +
      SaveName = ""
      +try:
      +    SaveName = QFileDialog.getSaveFileName(None,QString.fromLocal8Bit("Sauver un fichier FCInfo"),path,"*.FCInfo") # PyQt4
      +except Exception:
      +    SaveName, Filter = PySide.QtGui.QFileDialog.getSaveFileName(None, "Sauver un fichier FCInfo", path, "*.FCInfo")# PySide 
      +

      The MessageBox: +

      +
      def errorDialog(msg):
      +    diag = QtGui.QMessageBox(QtGui.QMessageBox.Critical,u"Error Message",msg )
      +    try:
      +        diag.setWindowFlags(PyQt4.QtCore.Qt.WindowStaysOnTopHint) # PyQt4 # this function sets the window before
      +    except Exception:    
      +        diag.setWindowFlags(PySide.QtCore.Qt.WindowStaysOnTopHint)# PySide # this function sets the window before
      +#    diag.setWindowModality(QtCore.Qt.ApplicationModal)       # function has been disabled to promote "WindowStaysOnTopHint"
      +    diag.exec_() 
      +

      Working with setProperty (PyQt4) and setValue (PySide) +

      +
      self.doubleSpinBox.setProperty("value", 10.0)  # PyQt4 
      +

      replace to : +

      +
      self.doubleSpinBox.setValue(10.0)  # PySide 
      +

      Working with setToolTip +

      +
      self.doubleSpinBox.setToolTip(_translate("MainWindow", "Coordinate placement Axis Y", None))  # PyQt4 
      +

      replace to : +

      +
      self.doubleSpinBox.setToolTip(_fromUtf8("Coordinate placement Axis Y"))  # PySide 
      +

      or : +

      +
      self.doubleSpinBox.setToolTip(u"Coordinate placement Axis Y.")# PySide 
      +

      Additional documentation

      +

      Some pyQt4 tutorials (including how to build interfaces with Qt Designer to use with python): +

      + +

      Pivy

      + +

      Pivy is a needed by several modules to access the 3D view of FreeCAD. On windows, Pivy is already bundled inside the FreeCAD installer, and on Linux it is usually automatically installed when you install FreeCAD from an official repository. On MacOSX, unfortunately, you will need to compile pivy yourself. +

      +

      Installation

      +

      Prerequisites

      +

      I believe before compiling Pivy you will want to have Coin and SoQt installed. +

      I found for building on Mac it was sufficient to install the Coin3 binary package. Attempting to install coin from MacPorts was problematic: tried to add a lot of X Windows packages and ultimately crashed with a script error. +

      For Fedora I found an RPM with Coin3. +

      SoQt compiled from source fine on Mac and Linux. +

      +

      Debian & Ubuntu

      +

      Starting with Debian Squeeze and Ubuntu Lucid, pivy will be available directly from the official repositories, saving us a lot of hassle. In the meantime, you can either download one of the packages we made (for debian and ubuntu karmic) availables on the Download pages, or compile it yourself. +

      The best way to compile pivy easily is to grab the debian source package for pivy and make a package with debuild. It is the same source code from the official pivy site, but the debian people made several bug-fixing additions. It also compiles fine on ubuntu karmic: http://packages.debian.org/squeeze/python-pivy download the .orig.gz and the .diff.gz file, then unzip both, then apply the .diff to the source: go to the unzipped pivy source folder, and apply the .diff patch: +

      +
      patch -p1 < ../pivy_0.5.0~svn765-2.diff 
      +

      then +

      +
      debuild 
      +

      to have pivy properly built into an official installable package. Then, just install the package with gdebi. +

      +

      Other linux distributions

      +

      First get the latest sources from the project's repository: +

      +
      hg clone http://hg.sim.no/Pivy/default Pivy 
      +

      As of March 2012, the latest version is Pivy-0.5. +

      Then you need a tool called SWIG to generate the C++ code for the Python bindings. Pivy-0.5 reports that it has only been tested with SWIG 1.3.31, 1.3.33, 1.3.35, and 1.3.40. So you can download a source tarball for one of these old versions from http://www.swig.org. Then unpack it and from a command line do (as root): +

      +
      ./configure
      +make
      +make install (or checkinstall if you use it) 
      +

      It takes just a few seconds to build. +

      Alternatively, you can try building with a more recent SWIG. As of March 2012, a typical repository version is 2.0.4. Pivy has a minor compile problem with SWIG 2.0.4 on Mac OS (see below) but seems to build fine on Fedora Core 15. +

      After that go to the pivy sources and call +

      +
      python setup.py build 
      +

      which creates the source files. Note that build can produce thousands of warnings, but hopefully there will be no errors. +

      This is probably obsolete, but you may run into a compiler error where a 'const char*' cannot be converted in a 'char*'. To fix that you just need to write a 'const' before in the appropriate lines. There are six lines to fix. +

      After that, install by issuing (as root): +

      +
      python setup.py install (or checkinstall python setup.py install) 
      +

      That's it, pivy is installed. +

      +

      Mac OS

      +

      These instructions may not be complete. Something close to this worked for OS 10.7 as of March 2012. I use MacPorts for repositories, but other options should also work. +

      As for linux, get the latest source: +

      +
      hg clone http://hg.sim.no/Pivy/default Pivy 
      +

      If you don't have hg, you can get it from MacPorts: +

      +
      port install mercurial 
      +

      Then, as above you need SWIG. It should be a matter of: +

      +
      port install swig 
      +

      I found I needed also: +

      +
      port install swig-python 
      +

      As of March 2012, MacPorts SWIG is version 2.0.4. As noted above for linux, you might be better off downloading an older version. SWIG 2.0.4 seems to have a bug that stops Pivy building. See first message in this digest: https://sourceforge.net/mailarchive/message.php?msg_id=28114815 +

      This can be corrected by editing the 2 source locations to add dereferences: *arg4, *arg5 in place of arg4, arg5. Now Pivy should build: +

      +
      python setup.py build
      +sudo python setup.py install 
      +

      Windows

      +

      Assuming you are using Visual Studio 2005 or later you should open a command prompt with 'Visual Studio 2005 Command prompt' from the Tools menu. +If the Python interpreter is not yet in the system path do +

      +
      set PATH=path_to_python_2.5;%PATH% 
      +

      To get pivy working you should get the latest sources from the project's repository: +

      +
      svn co https://svn.coin3d.org/repos/Pivy/trunk Pivy 
      +

      Then you need a tool called SWIG to generate the C++ code for the Python bindings. It is recommended to use version 1.3.25 of SWIG, not the latest version, because at the moment pivy will only function correctly with 1.3.25. Download the binaries for 1.3.25 from http://www.swig.org. Then unpack it and from the command line add it to the system path +

      +
      set PATH=path_to_swig_1.3.25;%PATH% 
      +

      and set COINDIR to the appropriate path +

      +
      set COINDIR=path_to_coin 
      +

      On Windows the pivy config file expects SoWin instead of SoQt as default. I didn't find an obvious way to build with SoQt, so I modified the file setup.py directly. +In line 200 just remove the part 'sowin' : ('gui._sowin', 'sowin-config', 'pivy.gui.') (do not remove the closing parenthesis). +

      After that go to the pivy sources and call +

      +
      python setup.py build 
      +

      which creates the source files. You may run into a compiler error several header files couldn't be found. In this case adjust the INCLUDE variable +

      +
      set INCLUDE=%INCLUDE%;path_to_coin_include_dir 
      +

      and if the SoQt headers are not in the same place as the Coin headers also +

      +
      set INCLUDE=%INCLUDE%;path_to_soqt_include_dir 
      +

      and finally the Qt headers +

      +
      set INCLUDE=%INCLUDE%;path_to_qt4\include\Qt 
      +

      If you are using the Express Edition of Visual Studio you may get a python keyerror exception. +In this case you have to modify a few things in msvccompiler.py located in your python installation. +

      Go to line 122 and replace the line +

      +
      vsbase = r"Software\Microsoft\VisualStudio\%0.1f" % version 
      +

      with +

      +
      vsbase = r"Software\Microsoft\VCExpress\%0.1f" % version 
      +

      Then retry again. +If you get a second error like +

      +
      error: Python was built with Visual Studio 2003;... 
      +

      you must also replace line 128 +

      +
      self.set_macro("FrameworkSDKDir", net, "sdkinstallrootv1.1") 
      +

      with +

      +
      self.set_macro("FrameworkSDKDir", net, "sdkinstallrootv2.0") 
      +

      Retry once again. If you get again an error like +

      +
      error: Python was built with Visual Studio version 8.0, and extensions need to be built with the same version of the compiler, but it isn't installed. 
      +

      then you should check the environment variables DISTUTILS_USE_SDK and MSSDK with +

      +
      echo %DISTUTILS_USE_SDK%
      +echo %MSSDK% 
      +

      If not yet set then just set it e.g. to 1 +

      +
      set DISTUTILS_USE_SDK=1
      +set MSSDK=1 
      +

      Now, you may run into a compiler error where a 'const char*' cannot be converted in a 'char*'. To fix that you just need to write a 'const' before in the appropriate lines. There are six lines to fix. +After that copy the generated pivy directory to a place where the python interpreter in FreeCAD can find it. +

      +

      Usage

      +

      To check if Pivy is correctly installed: +

      +
      import pivy 
      +

      To have Pivy access the FreeCAD scenegraph do the following: +

      +
      from pivy import coin
      +App.newDocument() # Open a document and a view 
      +view = Gui.ActiveDocument.ActiveView 
      +FCSceneGraph = view.getSceneGraph() # returns a pivy Python object that holds a SoSeparator, the main "container" of the Coin scenegraph
      +FCSceneGraph.addChild(coin.SoCube()) # add a box to scene 
      +

      You can now explore the FCSceneGraph with the dir() command. +

      +

      Additonal Documentation

      +

      Unfortunately documentation about pivy is still almost inexistant on the net. But you might find Coin documentation useful, since pivy simply translate Coin functions, nodes and methods in python, everything keeps the same name and properties, keeping in mind the difference of syntax between C and python: +

      + +

      You can also look at the Draft.py file in the FreeCAD Mod/Draft folder, since it makes big use of pivy. +

      +

      pyCollada

      + +

      pyCollada is a python library that allow programs to read and write Collada (*.DAE) files. When pyCollada is installed on your system, FreeCAD will be able to handle importing and exporting in the Collada file format. +

      +

      Installation

      +

      Pycollada is usually not yet available in linux distributions repositories, but since it is made only of python files, it doesn't require compilation, and is easy to install. You have 2 ways, or directly from the official pycollada git repository, or with the easy_install tool. +

      +

      Linux

      +

      In either case, you'll need the following packages already installed on your system: +

      +
      python-lxml 
      +python-numpy
      +python-dateutil 
      +
      From the git repository
      +
      git clone git://github.com/pycollada/pycollada.git pycollada
      +cd pycollada
      +sudo python setup.py install 
      +
      With easy_install
      +

      Assuming you have a complete python installation already, the easy_install utility should be present already: +

      +
      easy_install pycollada 
      +

      You can check if pycollada was correctly installed by issuing in a python console: +

      +
      import collada 
      +

      If it returns nothing (no error message), then all is OK +

      +

      Windows

      +

      On Windows since 0.15 pycollada is included in both the FreeCAD release and developer builds so no additional steps are necessary. +

      +

      Mac OS

      +

      If you are using the Homebrew build of FreeCAD you can install pycollada into your system Python using pip. +

      If you need to install pip: +

      +
      $ sudo easy_install pip 
      +

      Install pycollada: +

      +
      $ sudo pip install pycollada 
      +

      If you are using a binary version of FreeCAD, you can tell pip to install pycollada into the site-packages inside FreeCAD.app: +

      +
      $ pip install --target="/Applications/FreeCAD.app/Contents/lib/python2.7/site-packages" pycollada 
      +

      or after downloading the pycollada code +

      +
      $ export PYTHONPATH=/Applications/FreeCAD\ 0.16.6706.app/Contents/lib/python2.7/site-packages:$PYTHONPATH
      +$ python setup.py install --prefix=/Applications/FreeCAD\ 0.16.6706.app/Contents 
      +

      IfcOpenShell

      + +

      IFCOpenShell is a library currently in development, that allows to import (and soon export) Industry foundation Classes (*.IFC) files. IFC is an extension to the STEP format, and is becoming the standard in BIM workflows. When ifcopenshell is correctly installed on your system, the FreeCAD Arch Module will detect it and use it to import IFC files, instead of its built-in rudimentary importer. Since ifcopenshell is based on OpenCasCade, like FreeCAD, the quality of the import is very high, producing high-quality solid geometry. +

      +

      Installation

      +

      Since ifcopenshell is pretty new, you'll likely need to compile it yourself. +

      +

      Linux

      +

      You will need a couple of development packages installed on your system in order to compile ifcopenshell: +

      +
      liboce-*-dev
      +python-dev
      +swig 
      +

      but since FreeCAD requires all of them too, if you can compile FreeCAD, you won't need any extra dependency to compile IfcOpenShell. +

      Grab the latest source code from here: +

      +
      git clone https://github.com/IfcOpenShell/IfcOpenShell.git 
      +

      The build process is very easy: +

      +
      mkdir ifcopenshell-build
      +cd ifcopenshell-build
      +cmake ../IfcOpenShell/cmake 
      +

      or, if you are using oce instead of opencascade: +

      +
      cmake -DOCC_INCLUDE_DIR=/usr/include/oce ../ifcopenshell/cmake 
      +

      Since ifcopenshell is made primarily for Blender, it uses python3 by default. To use it inside FreeCAD, you need to compile it against the same version of python that is used by FreeCAD. So you might need to force the python version with additional cmake parameters (adjust the python version to yours): +

      +
      cmake -DOCC_INCLUDE_DIR=/usr/include/oce -DPYTHON_INCLUDE_DIR=/usr/include/python2.7 -DPYTHON_LIBRARY=/usr/lib/python2.7.so ../ifcopenshell/cmake 
      +

      Then: +

      +
      make
      +sudo make install 
      +

      You can check that ifcopenshell was correctly installed by issuing in a python console: +

      +
      import ifcopenshell 
      +

      If it returns nothing (no error message), then all is OK +

      +

      Windows

      +

      Copied from the IfcOpenShell README file +

      Users are advised to use the Visual Studio .sln file in the win/ folder. For Windows users a prebuilt Open CASCADE version is available from the http://opencascade.org website. Download and install this version and provide the paths to the Open CASCADE header and library files to MS Visual Studio C++. +

      For building the IfcPython wrapper, SWIG needs to be installed. Please download the latest swigwin version from http://www.swig.org/download.html . After extracting the .zip file, please add the extracted folder to the PATH environment variable. Python needs to be installed, please provide the include and library paths to Visual Studio. +

      +

      Links

      +

      Tutorial Import/Export IFC - compiling IfcOpenShell +

      +

      Teigha Converter

      + +

      The Teigha Converter is a small freely available utility that allows to convert between several versions of DWG and DXF files. FreeCAD can use it to offer DWG import and export, by converting DWG files to the DXF format under the hood,then using its standard DXF importer to import the file contents. The restrictions of the DXF importer apply. +

      +

      Installation

      +

      On all platforms, only by installing the appropriate package from http://www.opendesign.com/guestfiles/Teigha_File_Converter . After installation, if the utility is not found automatically by FreeCAD, you might need to set the path to the converter executable manually, Change workbench to "Draft", than in the menu Edit -> Preferences -> Import/Export -> DWG and fill "Path to Teigha File Converter" appropriately. +

      + +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/FAQ.html b/localwiki/FAQ.html new file mode 100644 index 0000000..3034bb3 --- /dev/null +++ b/localwiki/FAQ.html @@ -0,0 +1,340 @@ +FAQ

      FAQ

      + +

      This page attempts to answer the most common questions asked on the FreeCAD forums. If you have a problem or question regarding FreeCAD, check below first. Then, if you cannot find an answer for your specific question, head to the FreeCAD forum! +

      +

      Contents

      + +
      + +

      Installation

      +

      What is the easiest way to install FreeCAD on my system?

      +

      If you are on Windows or Mac OS, the simplest way is to head to the Download page, where you'll find several ready-to-install packages. If you are on Debian, Fedora or Ubuntu and some other distributions, FreeCAD is already included in the standard software repositories and you can simply install it with the software manager. On Ubuntu, the FreeCAD team also maintains its own PPA repositories. +For further details about installation, refer to the Installing page. +

      +

      What are the prerequisites for running FreeCAD?

      +

      In contrast to most 3D CAD software, FreeCAD can run smoothly on the most modest computers - it's been known to run on Pentium IV and Intel Core2 Solo CPUs. If your computer is running a current operating system, chances are FreeCAD will run. The only prerequisite is that your graphics card or chipset must support OpenGL, preferably no older than v2.0. In case of problems, refer to the Troubleshooting section of this FAQ. +

      +

      Multithreading

      +

      FreeCAD's underlying geometric modeling kernel (which is a third-party library called Open CASCADE Technology, or OCC for short) does not support multithreading at this time +has partial mulitithreading support at this time. +

      +

      For Mac users

      +

      Only the MacIntel architecture is supported. There are no builds available for the PowerPC architecture. +

      +

      What if I want to compile FreeCAD myself?

      +

      The source code of FreeCAD is always available in the project source code repository. Compiling FreeCAD yourself allows you to use the most recent features being developed, but requires a bit of computer knowledge, although the procedure is fairly simple. Access to the source code is explained here, and we have detailed instructions for compiling on Windows, Linux and Mac OSX. +

      +

      FreeCAD tells me some module or application is missing

      +

      FreeCAD depends on a lot of things to offer all its functionality. All the main required components are usually bundled within your FreeCAD installation or provided by your package manager, so normally you have nothing to worry about. If you installed FreeCAD from unofficial sources, however, or compiled FreeCAD yourself, some piece might be missing, which is not critical to FreeCAD itself, but might cause some functionality to be unavailable. Some specific file formats such as Collada or DWG also require extra components, which cannot be bundled into FreeCAD, and must be installed by yourself separately. +

      All those components and the appropriate way to install them are listed on the Extra python modules page. +

      +

      Troubleshooting

      +

      FreeCAD doesn't start at all

      +

      There might be a lot of reasons for that, the most likely is that some library is missing. Try starting FreeCAD from a terminal (type freecad at a terminal prompt) to see if some error message appears. Also, read the rest of this FAQ as it can give you more clues to detect the cause of the problem. If nothing helps, tell about it on the forum, there will surely be someone who can help. +

      On some older Windows XP systems you may get an error message like this: The application can't start, because the side-by-side configuration is wrong. The reinstallation of the application may solve the problem. The reason for this problem is that on your system either the CRT runtime libraries are missing or the version installed is too old because FreeCAD was linked against a newer version. In this case you have to install the Microsoft Visual C++ Redistributable Package which you'll find at Microsoft. See also the corresponding forum message. +

      +

      FreeCAD starts normally, but not all icons are displayed, some of them are replaced by a black 'X'

      +

      Some parts of FreeCAD depend on an external Python module called Pivy. On Windows, pivy is included in the FreeCAD installation. On Debian/Ubuntu systems, the python-pivy package is part of standard software repositories. On other systems, at the moment, you might have to compile pivy yourself. Note that although some tools are not available without pivy, the rest of FreeCAD works normally. +

      +

      I have display problems, the 3D view doesn't behave correctly, there is garbage when I move/rotate the view, etc...

      +

      FreeCAD depends on OpenGL for displaying 3D contents, and therefore requires a working OpenGL environment. On some systems, OpenGL is not activated by default, and you might need to install or upgrade your graphics drivers. This problems happens most often on Linux systems or on virtual systems. If you are on a linux-based system, try the following steps: +

      +
      • verify that your computer has a 3D-capable graphic board
      • +
      • type glxinfo in a terminal window, and check in the output that Direct Rendering is set to "yes", and that the OpenGL vendor/renderer/version matches your graphic card.
      • +
      • install other OpenGl-based software ([Blender] for example) and check if it runs and displays correctly.
      +

      FreeCAD crashes on startup

      +

      A crash might indicate a more serious bug, or some problem in your configuration. Most startup crashes occur because of one of the two following reasons: +

      +

      OpenGL drivers are not installed, or not working properly

      +

      This is a very common cause of problem. The symptoms are simply that FreeCAD crashes at startup, or whenever you open a 3D view (for example by creating a new document). Try to find out what your graphic chip is, then find out if it supports OpenGL (most recent chips do), then find the correct driver and install it. A good way to doublecheck if OpenGL is available is to try to run another OpenGL application such as blender. +

      And as a general tip to get some more information about crashes with FreeCAD you can start it with the program parameter --write-log. This will create the file FreeCAD.log in $HOME/.FreeCAD on Linux and Mac OS X or %APPDATA\FreeCAD% on Windows systems. +

      In some rare cases you may have a graphic driver installed that doesn't fit to your graphic card. We had a case where the user's laptop had an Intel on-board graphic but some ATI drivers were installed. [1] +After removing the files and re-installing the correct driver FreeCAD started to work. +

      +

      Some library, needed by FreeCAD, is not present on your system, or wasn't found by FreeCAD

      +

      There can be two declinations to this problem: either some library is simply missing, therefore FreeCAD will refuse to start, or the library is there, but it is an older version than the one FreeCAD expects, so a crash will occur when FreeCAD will try to use a missing feature from that library. A common example is when you have Qt3 and Qt4 installed on your system, FreeCAD might detect Qt4 but if your Qt installation is not properly configured, some pieces of Qt3 might still be used, provoking crashes. +

      Please review the installing procedure, make sure you installed all the required libraries (on most linux systems this is done automatically), and check what is the minimum version number for each of the components. +

      If everything seems correct, describe the problem on the forum or submit a bug. If you are on a linux system, it is easy to do a debug backtrace, which provides very useful information about the crash to the developers: +

      +
      • in a terminal, type: gdb freecad (assuming package gdb is installed)
      • +
      • inside gdb, type run
      • +
      • after the crash, type bt to get the backtrace, that you can include in your bug report.
      +

      FreeCAD freezes after startup

      +

      When starting FreeCAD the GUI appears almost immediately but the GUI is frozen and the cpu is about 99%. This can happen on the KDE desktop when using the Oxygen theme. That's a bug in the Oxygen theme and choosing another theme should fix this issue. +

      +

      FreeCAD crashes on creating a new document or opening a file

      +

      If FreeCAD crashes when it creates a new 3D view, try launching FreeCAD from a terminal. If a message error appears when the crash occurs, mentioning "Assertion Failed" and a component name beginning with "So" (SoBase, SoFieldContainer, etc...), the chances are very high, especially if you are on linux, that FreeCAD tries to use two different versions of the coin library, which causes the crash. +To verify if that is indeed the problem, try the following: +

      +
      • Locate the FreeCAD executable (usually in /usr/lib/FreeCAD/bin)
      • +
      • Run the command 'ldd FreeCAD' from a terminal
      • +
      • Note down the version of the libCoin.so library that FreeCAD is using (for example libCoin.so.60)
      • +
      • Locate the libSoQt.so library (usually in /usr/lib)
      • +
      • run 'ldd libSoQt.so' and check if it links to the same coin version as FreeCAD
      +

      If there is any difference, either FreeCAD or SoQt must be recompiled (better to recompile the one that uses the oldest Coin version). The normal behavior is to try to contact the persons responsible for packaging either SoQt or FreeCAD and kindly ask them to consider recompiling. +If you want to undertake that step for yourself, and it is not possible to recompile SoQt because it breaks other applications on your system, you can force FreeCAD to compile with the required Coin version with ./configure --with-coin=DIR. But you have to make sure that the correct devel package to this Coin version is installed. +

      +

      FreeCAD crashes after Edit -> Alignment

      +

      A segmentation fault happens at vbo_save_playback_vertex_list(). This means that the implementation of VBO of the graphic driver is bad. In order to avoid to cache OpenGL calls you can try to set the environment variable IV_SEPARATOR_MAX_CACHES=0 and restart FreeCAD. +

      +

      I have trouble running FreeCAD on Mac OSX

      +

      The Mac platform is less easy to support than Windows or Linux, since none of the core developers owns one. The OSX packages are compiled by volunteering FreeCAD users, and they might sometimes not work correctly on your machine, depending on your system. Your best chance is probably to head to the forums, look for Mac OSX-related threads, and discuss your problem there or see if someone else encountered a solution. +

      +

      I cannot change numeric values in FreeCAD's properties panels

      +
      language options
      +

      You most likely have bad windows regional settings set-up. Please check if you have same symbol for decimal separator and digit grouping symbol in your regional settings. If you do, adapt your system settings to use the different character for digit grouping symbol and decimal separator. Note that it is not mandatory to have dot as decimal separator. It is mandatory to use different symbols in this two settings. +

      +
      +


      +

      +

      FreeCAD was running normally, and suddenly it doesn't start anymore

      +

      This can also happen if you had an older version of FreeCAD installed, and you upgraded to a newer version. In that process, the configuration files of FreeCAD might have been corrupted for some reason, and now FreeCAD cannot read them anymore, and fails to start. The solution is simply to delete these configuration files, so FreeCAD will recreate them on first run. +

      +
      • On Windows: Open the file explorer, and write "%APPDATA%\FreeCAD" as the file path. Once there, delete the files user.cfg and system.cfg
      • +
      • On Linux: Navigate to "/home/USERNAME/.FreeCAD" and delete the files user.cfg and system.cfg
      • +
      • On Mac: Navigate to "/Users/USERNAME/Library/Preferences/FreeCAD" and delete the files user.cfg and system.cfg
      +

      FreeCAD should now start again normally with all its settings reset. +

      +

      Using FreeCAD

      +

      Is FreeCAD really free? Even for commercial use?

      +

      FreeCAD is open-source software, and is free not only to use, for yourself or for doing commercial work, but also to distribute, modify, or even use in a closed-source application. To review, you are free to do (almost) anything you want with it. See the Licence page for more details. +

      +

      How do I rotate the 3D view?

      +
      + +
      +
      +

      FreeCAD has several different navigation modes available, that can be set in the preferences settings dialog or changed by right-clicking in the 3D view. For full details about the modes, see the Mouse Model page. For the default mode ("CAD Navigation"), the commands are as follows, +

      +
      + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
      Select +Pan +Zoom +Rotate View +Rotate View +

      Alternate Method +

      +
      Hand cursor.png +Pan cursor.png +Zoom cursor.png +Rotate cursor.png +Rotate cursor.png +
      to Select +to Pan +to Zoom in or out +to Rotate view +to Rotate view +
      Press the left mouse button over an object you want to select. Holding down ctrl allows the selection of multiple objects. +Click the middle mouse button and move the object around to pan +Use the mouse wheel to zoom in and out. Clicking the middle mouse button re-centers the view to the location of the cursor. +Click first with the middle mouse button, hold it down, and then click the left mouse button and drag the mouse in the desired direction. The cursor location at the middle mouse button click determines the center of rotation. Rotation works like spinning a ball which rotates around its center. If the buttons are released before you stop the mouse motion, the object continues spinning, if this is enabled. A double click with the middle mouse button sets a new center of rotation. +Click first with the middle mouse button, hold it down, and then click the right mouse button and drag the mouse in the desired direction. This method works just like the previously described Rotate View that uses Middle Mouse Button + Left Mouse Button, except that the middle mouse button may be released after the right mouse button is pressed. Users who use the mouse with their right hand may find this Rotate View method easier than the previous method. +
      +to Pan +to Zoom +to rotate + +
      +For the Pan mode, press the Ctrl key and press the right mouse button to pan (rev 0.17) +For the Zoom mode, press the Ctrl and Shift key and press the right mouse button to Zoom (rev 0.17) +For the Rotate mode, press the Shift key and press the right mouse button to rotate (rev 0.17) + +
      +


      +

      +

      What can I do with FreeCAD? Where do I start?

      +

      Head to the Getting started page for a quick description of the tools you can use. There is also a new Tutorials section containing a few resources. The User hub section contains more detailed information about the different workbenches of FreeCAD. Note that since FreeCAD is relatively new, its user interface is still very bare and doesn't feature many tools. But much more advanced functionality is already available to you from python scripting. +

      +

      Is there documentation for newcomers? How can I learn to use FreeCAD?

      +

      There is at the moment still little documentation for beginners, unfortunately, but the Tutorials section contains some pages to help you getting started. +

      +

      I want to import/export data in format XYZ to/from FreeCAD. How to do that ?

      +

      Please refer to the page FreeCAD Howto Import Export. Maybe your questions are already answerded there. +

      +

      Working with Part geometry

      +

      How do I extrude stuff into solids? I don't get the right result

      +

      The theory is simple: Lines (or wires), when extruded, form faces. Faces, when extruded, form solids. +If you extrude something and the result is not a solid, then the something was not a face. If you have lines and you want to extrude a solid from them, you must first select lines that form a closed perimeter (select several objects by pressing CTRL), join them into a wire (Upgrade tool), then make a face from that wire (Upgrade tool again). There you are, if all went well you can now extrude it to a solid. +

      Now, there can be many little twists that make you obtain the wrong result. The best way to make sure is to check what's inside the object you are extruding. Objects contents can be easily explored with python. Assuming for example you have an object called "Wire", you could type this into the python console: +

      +
      obj = FreeCAD.ActiveDocument.Wire
      +shp = obj.Shape
      +print shp.Faces
      +print shp.Wires
      +if shp.Wires:
      +    for w in shp.Wires:
      +        print w.isClosed()
      +

      The above code retrieves the shape from an object, shows the faces and wires your object has (if any), and, if there are wires, prints if those wires are closed. If you don't have any face, you won't get a solid. If there is no closed wire, it won't become a face. If you are interested, there is more info about what you can check with python on the part scripting page. If you cannot join several lines into a wire, the most probable cause is that their endpoints don't meet, there must be small gaps between (some of) them. There, I'm afraid, my experience tells me the quickest way would be to redraw a wire on top of them... +

      +

      My boolean operations fail, or give weird results

      +

      The Open CASCADE geometric modeling kernel used in FreeCAD for Part geometry, although probably the best open-source geometry kernel available, has its flaws and limitations. Indeed the boolean operations (fusion, subtraction, intersection) are not its best features, and often give strange results. This is a current limitation we have no way to solve at once, so your best path is to try obtaining the desired result by modeling another way. For example, problems with primitives such as cylinder can often be solved by using an extruded circle instead. Coplanar surfaces between parts can cause trouble, as well as surface tangency. As a general rule, if a shape doesn't work, try remodeling it a different way. In 99% of the cases at the end you will manage to obtain the result you want. +

      +

      When I Export (or View) My Model, The Holes Are Filled In

      +

      Don't use Crtl + A (Select All) to export everything from the hierarchy tree. If the model is of one single item, try selecting only the newest item (usually the last one) in the hierarchy tree. +

      As we create a model in the Part Design workbench, each feature takes the shape of the last one and adds or removes something, creating linear dependencies from feature to feature as the model is created. Hence a "Cut" feature is not only the cut hole itself, but the whole part with the cut. This is why the user usually should only have the newest item (feature) in the model tree visible, because otherwise the phases of the model overlay each other, and holes are filled in by the earlier model features. +

      To toggle visibility of an object on or off, select it in the hierarchy tree and press the Spacebar. Usually everything but the last item in the hierarchy tree should be greyed out and therefore not visible in the 3D view. +

      +

      Contributing to FreeCAD

      +

      FreeCAD is such a great program! How can I help?

      +

      There are a lot of different ways to help, even if you are not a programmer. Here are a couple of things you can do: +

      +
      • Give some feedback to the FreeCAD developers: It is always useful to know what people think, what they found good, what they miss, etc. Drop a note on the forum giving your opinion or make a request on our issue tracker!
      • +
      • Help with writing documentation: The documentation we have here on this site is sometime very limited. If you discovered something that is not well documented, add your knowledge there!
      • +
      • Help others newcomers: Hang around the forum, and help new people to solve basic questions, like how do I install, how do I add a cube, etc...
      • +
      • Translate the documentation in your own language
      • +
      • Translate FreeCAD in your own language
      • +
      • Write Tutorials, or record video tutorials: Tutorials are a very easy way for newcomers to learn a new software. If you did some nice stuff, why not show other people how to do it?
      • +
      • Contribute with assets and examples: We still miss good example files in FreeCAD. If you created something good, share it with us!
      • +
      • Submit bugs: It is very important to have all the possible bugs fixed. If you find one, report it as clearly as possible, so we can understand exactly what's happening.
      • +
      • Try to do some python coding: You never programmed before but you want to try? Python is easy. Read our introduction to Python... But beware, you might get addicted quickly!
      • +
      • See the Help FreeCAD page for more details on how to contribute.
      +

      How can I get edit permission on the wiki?

      +

      See the Work on the documentation page paragraph for more details on how to contribute. +

      +

      Does FreeCAD participate to the Google Summer of Code?

      +

      Yes. Beginning from 2016 FreeCAD participates to the Google Summer of Code. See this topic in the forum and [this wiki page] +

      +

      I want to start translating the wiki in my own language. What do I do?

      +

      This wiki is hosting a lot of contents. The most up-to-date and interesting material is gathered in the manual. +

      See the Translate the documentation page paragraph for more details on how to translate the wiki. +

      +

      Licensing, copying and reuse

      +

      Do I have to pay something to use FreeCAD?

      +

      No. FreeCAD is totally free to use, to download, to redistribute, or to modify. It is open-source software, published under the terms of 2 free software licenses (GPL and LGPL), which guarantee you those freedoms, and, even more important, guarantee you that these freedoms will never be taken from you. +

      +

      Can I reuse any part of the FreeCAD artwork or pieces of the website?

      +

      Sure. All the artwork (icons, banners, etc...) of FreeCAD is LGPL, same as the FreeCAD code. Help yourself on the Artwork page. The website is a standard mediawiki site, all graphic elements can freely be reused, and if you are curious about how to tweak the mediawiki software like we did, look for the special Common css and js pages. +

      +

      Can I reuse pieces of FreeCAD in another application?

      +

      Yes, with a few minor considerations because some parts of the code are LGPL while others are GPL, and the fact that the third-parties used by FreeCAD may have other conditions as well. More details on the Licence page. +

      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/FC017_Navigation_Indicator_01.png b/localwiki/FC017_Navigation_Indicator_01.png new file mode 100644 index 0000000..82e01e0 Binary files /dev/null and b/localwiki/FC017_Navigation_Indicator_01.png differ diff --git a/localwiki/FC017_Navigation_Indicator_02.png b/localwiki/FC017_Navigation_Indicator_02.png new file mode 100644 index 0000000..1c19b6c Binary files /dev/null and b/localwiki/FC017_Navigation_Indicator_02.png differ diff --git a/localwiki/FC017_Sketcher_B-spline_01.png b/localwiki/FC017_Sketcher_B-spline_01.png new file mode 100644 index 0000000..ff2acc1 Binary files /dev/null and b/localwiki/FC017_Sketcher_B-spline_01.png differ diff --git a/localwiki/FCCamera_00.png b/localwiki/FCCamera_00.png new file mode 100644 index 0000000..b1d9b96 Binary files /dev/null and b/localwiki/FCCamera_00.png differ diff --git a/localwiki/FCCamera_01.png b/localwiki/FCCamera_01.png new file mode 100644 index 0000000..1369593 Binary files /dev/null and b/localwiki/FCCamera_01.png differ diff --git a/localwiki/FCCamera_02.png b/localwiki/FCCamera_02.png new file mode 100644 index 0000000..7c43b4d Binary files /dev/null and b/localwiki/FCCamera_02.png differ diff --git a/localwiki/FCCamera_03.png b/localwiki/FCCamera_03.png new file mode 100644 index 0000000..1aa56de Binary files /dev/null and b/localwiki/FCCamera_03.png differ diff --git a/localwiki/FCCamera_04.png b/localwiki/FCCamera_04.png new file mode 100644 index 0000000..547b261 Binary files /dev/null and b/localwiki/FCCamera_04.png differ diff --git a/localwiki/FCCamera_05.png b/localwiki/FCCamera_05.png new file mode 100644 index 0000000..ab5f34e Binary files /dev/null and b/localwiki/FCCamera_05.png differ diff --git a/localwiki/FCCamera_06.png b/localwiki/FCCamera_06.png new file mode 100644 index 0000000..ca64cdd Binary files /dev/null and b/localwiki/FCCamera_06.png differ diff --git a/localwiki/FCCamera_07.png b/localwiki/FCCamera_07.png new file mode 100644 index 0000000..65afe26 Binary files /dev/null and b/localwiki/FCCamera_07.png differ diff --git a/localwiki/FCCamera_08.png b/localwiki/FCCamera_08.png new file mode 100644 index 0000000..113256c Binary files /dev/null and b/localwiki/FCCamera_08.png differ diff --git a/localwiki/FCCamera_Axis_rotation_D.png b/localwiki/FCCamera_Axis_rotation_D.png new file mode 100644 index 0000000..2cca41e Binary files /dev/null and b/localwiki/FCCamera_Axis_rotation_D.png differ diff --git a/localwiki/FCCamera_Axis_rotation_X.png b/localwiki/FCCamera_Axis_rotation_X.png new file mode 100644 index 0000000..87c0f5a Binary files /dev/null and b/localwiki/FCCamera_Axis_rotation_X.png differ diff --git a/localwiki/FCCamera_Axis_rotation_Y.png b/localwiki/FCCamera_Axis_rotation_Y.png new file mode 100644 index 0000000..0fd0ad4 Binary files /dev/null and b/localwiki/FCCamera_Axis_rotation_Y.png differ diff --git a/localwiki/FCCamera_Axis_rotation_Z.png b/localwiki/FCCamera_Axis_rotation_Z.png new file mode 100644 index 0000000..1b4294b Binary files /dev/null and b/localwiki/FCCamera_Axis_rotation_Z.png differ diff --git a/localwiki/FCCircularTextButtom.png b/localwiki/FCCircularTextButtom.png new file mode 100644 index 0000000..6295db6 Binary files /dev/null and b/localwiki/FCCircularTextButtom.png differ diff --git a/localwiki/FCCircularTextButtom.svg b/localwiki/FCCircularTextButtom.svg new file mode 100644 index 0000000..aee0c55 --- /dev/null +++ b/localwiki/FCCircularTextButtom.svg @@ -0,0 +1,758 @@ + + + + + + + + image/svg+xml + + + + + + + + diff --git a/localwiki/FCCircularText_06.png b/localwiki/FCCircularText_06.png new file mode 100644 index 0000000..1396c7e Binary files /dev/null and b/localwiki/FCCircularText_06.png differ diff --git a/localwiki/FCCircularText_07.png b/localwiki/FCCircularText_07.png new file mode 100644 index 0000000..086d18e Binary files /dev/null and b/localwiki/FCCircularText_07.png differ diff --git a/localwiki/FCCircularText_08.png b/localwiki/FCCircularText_08.png new file mode 100644 index 0000000..e75ec31 Binary files /dev/null and b/localwiki/FCCircularText_08.png differ diff --git a/localwiki/FCCircularText_09.png b/localwiki/FCCircularText_09.png new file mode 100644 index 0000000..bebc8e3 Binary files /dev/null and b/localwiki/FCCircularText_09.png differ diff --git a/localwiki/FCCircularText_10.png b/localwiki/FCCircularText_10.png new file mode 100644 index 0000000..9ce98d6 Binary files /dev/null and b/localwiki/FCCircularText_10.png differ diff --git a/localwiki/FCCircularText_11.png b/localwiki/FCCircularText_11.png new file mode 100644 index 0000000..2f58af2 Binary files /dev/null and b/localwiki/FCCircularText_11.png differ diff --git a/localwiki/FCCircularText_12.png b/localwiki/FCCircularText_12.png new file mode 100644 index 0000000..5c8de52 Binary files /dev/null and b/localwiki/FCCircularText_12.png differ diff --git a/localwiki/FCCircularText_13.png b/localwiki/FCCircularText_13.png new file mode 100644 index 0000000..22ee324 Binary files /dev/null and b/localwiki/FCCircularText_13.png differ diff --git a/localwiki/FCCircularText_14.png b/localwiki/FCCircularText_14.png new file mode 100644 index 0000000..cf5286f Binary files /dev/null and b/localwiki/FCCircularText_14.png differ diff --git a/localwiki/FCCircularText_15.png b/localwiki/FCCircularText_15.png new file mode 100644 index 0000000..56f5186 Binary files /dev/null and b/localwiki/FCCircularText_15.png differ diff --git a/localwiki/FCCircularText_16.png b/localwiki/FCCircularText_16.png new file mode 100644 index 0000000..cf52258 Binary files /dev/null and b/localwiki/FCCircularText_16.png differ diff --git a/localwiki/FCCircularText_17.png b/localwiki/FCCircularText_17.png new file mode 100644 index 0000000..d7f8a6b Binary files /dev/null and b/localwiki/FCCircularText_17.png differ diff --git a/localwiki/FCCircularText_18.png b/localwiki/FCCircularText_18.png new file mode 100644 index 0000000..1ea1927 Binary files /dev/null and b/localwiki/FCCircularText_18.png differ diff --git a/localwiki/FCCircularText_19.png b/localwiki/FCCircularText_19.png new file mode 100644 index 0000000..45f9437 Binary files /dev/null and b/localwiki/FCCircularText_19.png differ diff --git a/localwiki/FCCircularText_20.png b/localwiki/FCCircularText_20.png new file mode 100644 index 0000000..bc1f8f5 Binary files /dev/null and b/localwiki/FCCircularText_20.png differ diff --git a/localwiki/FCCircularText_21.png b/localwiki/FCCircularText_21.png new file mode 100644 index 0000000..ef45d89 Binary files /dev/null and b/localwiki/FCCircularText_21.png differ diff --git a/localwiki/FCCircularText_22.png b/localwiki/FCCircularText_22.png new file mode 100644 index 0000000..9e07fa4 Binary files /dev/null and b/localwiki/FCCircularText_22.png differ diff --git a/localwiki/FCCircularText_23.png b/localwiki/FCCircularText_23.png new file mode 100644 index 0000000..dfc3b40 Binary files /dev/null and b/localwiki/FCCircularText_23.png differ diff --git a/localwiki/FCCircularText_24.png b/localwiki/FCCircularText_24.png new file mode 100644 index 0000000..7cfce62 Binary files /dev/null and b/localwiki/FCCircularText_24.png differ diff --git a/localwiki/FCCircularText_Correction.gif b/localwiki/FCCircularText_Correction.gif new file mode 100644 index 0000000..5e7f220 Binary files /dev/null and b/localwiki/FCCircularText_Correction.gif differ diff --git a/localwiki/FCCreaLoft.png b/localwiki/FCCreaLoft.png new file mode 100644 index 0000000..fa4cc36 Binary files /dev/null and b/localwiki/FCCreaLoft.png differ diff --git a/localwiki/FCGear_00.png b/localwiki/FCGear_00.png new file mode 100644 index 0000000..d33d2a7 Binary files /dev/null and b/localwiki/FCGear_00.png differ diff --git a/localwiki/FCInfo.png b/localwiki/FCInfo.png new file mode 100644 index 0000000..5bb7df3 Binary files /dev/null and b/localwiki/FCInfo.png differ diff --git a/localwiki/FCInfoSpreadsheet.png b/localwiki/FCInfoSpreadsheet.png new file mode 100644 index 0000000..9c24eec Binary files /dev/null and b/localwiki/FCInfoSpreadsheet.png differ diff --git a/localwiki/FCInfoToMouse.png b/localwiki/FCInfoToMouse.png new file mode 100644 index 0000000..68f25da Binary files /dev/null and b/localwiki/FCInfoToMouse.png differ diff --git a/localwiki/FCInfo_begin_00.gif b/localwiki/FCInfo_begin_00.gif new file mode 100644 index 0000000..7d239fa Binary files /dev/null and b/localwiki/FCInfo_begin_00.gif differ diff --git a/localwiki/FCSpring_Helix_Variable.png b/localwiki/FCSpring_Helix_Variable.png new file mode 100644 index 0000000..9a15693 Binary files /dev/null and b/localwiki/FCSpring_Helix_Variable.png differ diff --git a/localwiki/FCSpring_Helix_Variable_Icon_01.png b/localwiki/FCSpring_Helix_Variable_Icon_01.png new file mode 100644 index 0000000..2b3ec65 Binary files /dev/null and b/localwiki/FCSpring_Helix_Variable_Icon_01.png differ diff --git a/localwiki/FCSpring_Helix_Variable_Icon_02.png b/localwiki/FCSpring_Helix_Variable_Icon_02.png new file mode 100644 index 0000000..0edfc0e Binary files /dev/null and b/localwiki/FCSpring_Helix_Variable_Icon_02.png differ diff --git a/localwiki/FCSpring_Helix_Variable_Icon_02b.png b/localwiki/FCSpring_Helix_Variable_Icon_02b.png new file mode 100644 index 0000000..d06ad7f Binary files /dev/null and b/localwiki/FCSpring_Helix_Variable_Icon_02b.png differ diff --git a/localwiki/FCSpring_Helix_Variable_Icon_03.png b/localwiki/FCSpring_Helix_Variable_Icon_03.png new file mode 100644 index 0000000..02a4773 Binary files /dev/null and b/localwiki/FCSpring_Helix_Variable_Icon_03.png differ diff --git a/localwiki/FCSpring_Helix_Variable_Icon_03b.png b/localwiki/FCSpring_Helix_Variable_Icon_03b.png new file mode 100644 index 0000000..87f1e83 Binary files /dev/null and b/localwiki/FCSpring_Helix_Variable_Icon_03b.png differ diff --git a/localwiki/FCSpring_Helix_Variable_Icon_04.png b/localwiki/FCSpring_Helix_Variable_Icon_04.png new file mode 100644 index 0000000..2f020f7 Binary files /dev/null and b/localwiki/FCSpring_Helix_Variable_Icon_04.png differ diff --git a/localwiki/FCSpring_Helix_Variable_Icon_05.png b/localwiki/FCSpring_Helix_Variable_Icon_05.png new file mode 100644 index 0000000..885895c Binary files /dev/null and b/localwiki/FCSpring_Helix_Variable_Icon_05.png differ diff --git a/localwiki/FCSpring_Helix_Variable_Icon_06.png b/localwiki/FCSpring_Helix_Variable_Icon_06.png new file mode 100644 index 0000000..d7b9093 Binary files /dev/null and b/localwiki/FCSpring_Helix_Variable_Icon_06.png differ diff --git a/localwiki/FCTemplateHow.png b/localwiki/FCTemplateHow.png new file mode 100644 index 0000000..312a2ed Binary files /dev/null and b/localwiki/FCTemplateHow.png differ diff --git a/localwiki/FCTexture.png b/localwiki/FCTexture.png new file mode 100644 index 0000000..0d32501 Binary files /dev/null and b/localwiki/FCTexture.png differ diff --git a/localwiki/FCTexture.svg b/localwiki/FCTexture.svg new file mode 100644 index 0000000..caa6535 --- /dev/null +++ b/localwiki/FCTexture.svg @@ -0,0 +1,655 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + 07-06-14 + + + Sebastian Kraft + + + + + graphics + paint + brush + canvas + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/FCTexture_Example.gif b/localwiki/FCTexture_Example.gif new file mode 100644 index 0000000..c4cacf1 Binary files /dev/null and b/localwiki/FCTexture_Example.gif differ diff --git a/localwiki/FCTexture_Example_Mesh.png b/localwiki/FCTexture_Example_Mesh.png new file mode 100644 index 0000000..431e306 Binary files /dev/null and b/localwiki/FCTexture_Example_Mesh.png differ diff --git a/localwiki/FCTreeView.gif b/localwiki/FCTreeView.gif new file mode 100644 index 0000000..731d10c Binary files /dev/null and b/localwiki/FCTreeView.gif differ diff --git a/localwiki/FC_Christmas.svg b/localwiki/FC_Christmas.svg new file mode 100644 index 0000000..76bfe89 --- /dev/null +++ b/localwiki/FC_Christmas.svg @@ -0,0 +1,288 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/FEMForceConstraintProperties.PNG b/localwiki/FEMForceConstraintProperties.PNG new file mode 100644 index 0000000..8297fe8 Binary files /dev/null and b/localwiki/FEMForceConstraintProperties.PNG differ diff --git a/localwiki/FEMMaterialProperties.PNG b/localwiki/FEMMaterialProperties.PNG new file mode 100644 index 0000000..f589c26 Binary files /dev/null and b/localwiki/FEMMaterialProperties.PNG differ diff --git a/localwiki/FEM_Analysis.html b/localwiki/FEM_Analysis.html new file mode 100644 index 0000000..6147d6d --- /dev/null +++ b/localwiki/FEM_Analysis.html @@ -0,0 +1,112 @@ +FEM Analysis

      FEM Analysis

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      FEM Analysis.png FEM Analysis

      +
      Menu location +
      Model → Analysis container‏‎ +
      Workbenches +
      FEM +
      Default shortcut +
      N,A +
      See also +
      FEM tutorial +

      + +
      +


      +

      +

      Description

      +

      The FEM Analysis could be seen as a Container that holds all objects of a Finite Element Analysis. It is mandatory to have a analysis container which holds all the needed objects. At least one of the following objects is needed for a mechanical analysis: +

      + +


      +

      +

      How to use

      +
      1. Press the FEM Analysis.png Analysis container button, or press N then A keys. A new Analysis is created and set to active.
      2. +
      3. Other objects could be added or removed to the analysis container by drag and drop.
      4. +
      5. To add new FEM Objects to the document the analysis has to be active. Double click on the analysis does activate the analysis.
      +


      +

      +

      Options

      +
      • Up to date there is no option to choose.
      • +
      • A frequency analysis in in development. See [1] for more informations.
      +


      +

      +

      Properties

      +
      • DATAOutpuDir: Specifies the working directory of the analysis
      +


      +

      +

      Scripting

      +

      most code here is depreciated in 0.17. +

      +
      • new analysis
      +
      MechanicalAnalysis.makeMechanicalAnalysis( name ) 
      +
      • add object to the analysis
      +
      App.ActiveDocument.MechanicalAnalysis.Member = App.ActiveDocument.MechanicalAnalysis.Member + [ (object) ] 
      +
      • remove object from the analysis
      +
      member = App.ActiveDocument.MechanicalAnalysis.Member
      +member.remove( documentobject )
      + App.ActiveDocument.MechanicalAnalysis.Member = member 
      +


      +Examples: +

      +
      import MechanicalAnalysis
      +analysis = MechanicalAnalysis.makeMechanicalAnalysis("MechanicalAnalysis")
      +FemGui.setActiveAnalysis(analysis)
      +
      +addobj = App.ActiveDocument.getObject("MechanicalMaterial")
      +App.ActiveDocument.MechanicalAnalysis.Member = App.ActiveDocument.MechanicalAnalysis.Member + [addobj]
      +
      +removeobj = App.ActiveDocument.getObject("MechanicalMaterial")
      +member = App.ActiveDocument.MechanicalAnalysis.Member
      +member.remove(removeobj)
      +App.ActiveDocument.MechanicalAnalysis.Member = member 
      +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/FEM_CalculiX.html b/localwiki/FEM_CalculiX.html new file mode 100644 index 0000000..118c6b2 --- /dev/null +++ b/localwiki/FEM_CalculiX.html @@ -0,0 +1,61 @@ +FEM CalculiX

      FEM CalculiX

      + +
      + +

      Preface

      +

      This page collects all informations about the current solver used by FreeCAD's FEM Module. The interface between the solver and FreeCAD in pre- as well as post processing is also described. At the moment (Begin 2016 and FreeCAD 0.16dev) the only supported solver by the FEM Module is [CalculiX]. Depending on the operating system you are working with you need to install CalculiX first. Check out [FEM Install]. +

      +

      Interface

      +

      Interaction between FEM Module and CalculiX is done by text files. The FEM Module writes a CalculiX input file, starts CalculiX, logs the output of CalculiX and read the output files of CalculiX if they are available. The FEM Control Solver tool manages the whole process. User interaction in the process is possible. +

      +

      Preprocessing interface

      +

      CalculiX uses abaqus input file format. The input file could be edited before the solver is started. The units used in the CalculiX input file are independet from the units used in FreeCAD. They will be mm and N. (ToDo: check this. What happens with the mesh if inch is used in FreeCAD. Density was introduced. With this we have kg and s and no longer N?! how about this !?!) +

      The FEM Module - CalculiX interface supports the following objects: +

      +
      FEM Elements
      + +
      Analysis
      +
      • linear static analysis
      • +
      • Frequency analysis
      • +
      • Coupled thermal structural analysis
      +
      Materials
      +
      • one linear elastic isotropic (uniformity in all directions) material
      • +
      • multiple material is in development
      +

      Postprocessing interface

      +

      read resulting stress (Von Mises) and all displacement +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/FEM_CalculiX_Cantilever_3D.html b/localwiki/FEM_CalculiX_Cantilever_3D.html new file mode 100644 index 0000000..9a01dfe --- /dev/null +++ b/localwiki/FEM_CalculiX_Cantilever_3D.html @@ -0,0 +1,191 @@ +FEM CalculiX Cantilever 3D

      FEM CalculiX Cantilever 3D

      + +
      + + + + + + + + + + + + + + + + + + + + + + + + + + + +
      +

      Base ExampleCommandModel.png Tutorial

      +
      Topic +
      Finite Element Analysis +
      Level +
      Beginner +
      Time to complete +
      10 minutes +
      Author +
      Bernd +
      FreeCAD version +
      0.16.6377 or above +
      Example File(s) +
      +

      + +
      +


      +


      +

      +

      Introduction

      +

      This example is meant to show how a simple Finite Element Analysis (FEA) in FreeCADs FEM Module does look like and how the results can be visualized. It is shown how to trigger a FEA and how to change the load value and load direction. Furthermore since the example file is provided with any FreeCAD installation it is easy to check if the FEM module is set up properly. +


      +FEM example01 pic00.jpg +


      +

      +

      Requirements

      +
      • FreeCAD version = 0.16.6377 or above.
      • +
      • This could be checked at the menu Help --> about FreeCAD. The Revision number has to be higher than 6377
      • +
      • No external software is needed for loading the example file, viewing the mesh and geometry as well as for visualizing the results.
      • +
      • For rerunning the FEA the solver software CalculiX has to be installed on your computer. Probably the solver has been installed together with FreeCAD already. If the solver CalculiX is not installed see FEM Install.
      +


      +

      +

      Set up the example file

      +

      Load Start Workbench

      +
      • Start FreeCAD
      • +
      • The Start Workbench should be loaded
      +


      +

      +

      Load the example file

      +
      • Go to the example projects and click on "Load an FEM analysis example"
      • +
      • If due to further operations some geometry, constraints or the results are broken or deleted just repeat the steps above.
      +

      FEM example01 pic01.jpg +


      +

      +

      Activate the analysis container

      +
      • To work with an analysis the analysis has to be activated.
      • +
      • In tree view right click on the FEM Analysis.png MechanicalAnalysis --> Activate analysis
      +

      FEM example01 pic02.jpg +


      +

      +

      Analysis container and its objects

      +
      • If the analysis is activated FreeCAD itself will change the current workbench to FEM.
      • +
      • There are at least the 5 objects needed to make an static mechanical analysis.
      • +
      • FEM Analysis.png analysis container
      +
      1. FEM Solver.png a solver
      2. +
      3. FEM Material.png a material
      4. +
      5. FEM FixedConstraint.png a fixed constraint
      6. +
      7. FEM ForceConstraint.png a force constraint
      8. +
      9. FEM Create.png a FEM mesh
      +
      • Since in the example here the results are included as well there is a sixth object, the results FEM ShowResult.png.
      +


      +

      +

      Visualizing Results

      +
      • Be sure the analysis is activated.
      • +
      • Be sure the analysis still contains the result object, if not just reload the example file.
      • +
      • Click in icon toolbar on FEM ShowResult.png Show result
      • +
      • In task window choose z-Displacement. It shows -88.443 mm in negative z-direction.
      • +
      • This makes sense since the force is in negative z-direction as well.
      • +
      • Activate the check box besides the bottom slider of displacement show.
      • +
      • The slider can be used to alter the mesh to view the deformation in a simplified manner.
      • +
      • Choose among the different Result types to view all in the GUI available result types.
      +

      FEM example01 pic03.jpg +


      +

      +

      Purging Results

      +
      • Be sure the analysis is activated.
      • +
      • To remove the results select in the icon toolbar FEM PurgeResults.png Purge results
      +


      +

      +

      Running the FEA

      +
      • In Tree view double click on the solver object FEM Solver.png.
      • +
      • In task window of the solver object make sure static analysis is selected.
      • +
      • Click on write .inp file in the same task window. Watch the log window until it prints "write completed."
      • +
      • Click on Run CalculiX. Since this is a very small analysis it should take less than a second to run.
      • +
      • In the text window it should print in green letters "CalculiX done!" and in the next line "loading result sets ..."
      • +
      • You just have finished your first FEA in FreeCAD if there has not been any error message.
      • +
      • Click on Close in the task window.
      • +
      • A new result object should be created. You know how to visualize the results already.
      • +
      • If you get an error message no solver binary or similar when triggering the analysis check FEM Install.
      +

      FEM example01 pic04.jpg +


      +

      +

      Running the FEA the fast Way

      +
      • In tree view select the solver object FEM Solver.png of the analysis FEM Analysis.png.
      • +
      • In the icon toolbar click on FEM RunCalculiXccx.png Quick Analysis.
      • +
      • The Calculix input file will be written, CalculiX will be triggered and the result object should be created.
      +


      +

      +

      Changing Load Direction and Load Value

      +
      • In tree view select the FEM mesh object FEM Create.png and press the space key.
      • +
      • The visibility of the FEM mesh will be turned off. The geometrical model is still visible.
      • +
      • In tree view double click on the force constraint object to open its task window.
      • +
      • In the task window change the load value to 500000000 N = 500 MN (force unit in task window has to be in N)
      • +
      • Click on Button Direction.
      • +
      • On the geometrical model click on on of the long edges in x-direction.
      • +
      • The red arrows of the force will change their direction in x-direction. They show to the fixed direction.
      • +
      • Since tension should be applied to the box the Reverse Direction needs to be triggered by clicking on it.
      • +
      • The red arrows of the force will change their direction.
      • +
      • Click on OK in task window.
      +

      FEM example01 pic05.jpg +

      +
      • Turn the visibility of the FEM mesh FEM Create.png on by selecting it in tree view and pressing the space key.
      • +
      • You know how to trigger an analysis and how to visualize results already.
      • +
      • The deformation in x-direction should be 19.05 mm.
      +

      FEM example01 pic06.jpg +


      +

      +

      What next ?

      +
      • We are now finished with the basic workflow for the FEM Module.
      • +
      • You are now prepared to do the second FEM tutorial.
      • +
      • We will create the CalculiX cantilever by ourselves and compare the results with the beam theory.
      +


      +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/FEM_ConstraintBearing.html b/localwiki/FEM_ConstraintBearing.html new file mode 100644 index 0000000..1cf0425 --- /dev/null +++ b/localwiki/FEM_ConstraintBearing.html @@ -0,0 +1,71 @@ +FEM ConstraintBearing

      FEM ConstraintBearing

      + +
      +

      This documentation is not finished. Please help and contribute documentation. +

      See Draft ShapeString for good documented Command. Gui Command gives an overview over commands. And see List of Commands for other commands. +

      Go to Help FreeCAD to contribute. +

      +
      + + + + + + + + + + + + + + + + + + + + +
      +

      FEM ConstraintBearing.png FEM ConstraintBearing

      +
      Menu location +
      Model → Mechanical Constraints → Constraint bearing +
      Workbenches +
      FEM +
      Default shortcut +
      +
      See also +
      FEM tutorial +

      + +
      +


      +


      +

      +

      Description

      +

      Not supported by CalculiX Interface! +


      +

      +

      How to use

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/FEM_ConstraintBodyHeatSource.html b/localwiki/FEM_ConstraintBodyHeatSource.html new file mode 100644 index 0000000..734b826 --- /dev/null +++ b/localwiki/FEM_ConstraintBodyHeatSource.html @@ -0,0 +1,67 @@ +FEM ConstraintBodyHeatSource

      FEM ConstraintBodyHeatSource

      + +

      +

      This documentation is not finished. Please help and contribute documentation. +

      See Draft ShapeString for good documented Command. Gui Command gives an overview over commands. And see List of Commands for other commands. +

      Go to Help FreeCAD to contribute. +

      +
      + + + + + + + + + + + + + + + + + + + + +
      +

      Official icon not found FEM ConstraintBodyHeatSource

      +
      Menu location +
      Model → Thermal constraints → Constraint body heat source +
      Workbenches +
      FEM +
      Default shortcut +
      +
      See also +
      FEM tutorial +

      + +
      +


      +


      +

      ToDo +


      +
      +

      +
      +


      +

      + + +
      + +
      +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/FEM_ConstraintContact.html b/localwiki/FEM_ConstraintContact.html new file mode 100644 index 0000000..312de3c --- /dev/null +++ b/localwiki/FEM_ConstraintContact.html @@ -0,0 +1,76 @@ +FEM ConstraintContact

      FEM ConstraintContact

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      FEM ConstraintContact.png FEM ConstraintContact

      +
      Menu location +
      Model → Mechanical Constraints → Constraint contact +
      Workbenches +
      FEM +
      Default shortcut +
      +
      See also +
      FEM tutorial +

      + +
      +


      +

      +

      Description

      +

      Creates a FEM constraint for contact between 2 surfaces. +

      +

      How to use

      +
      1. Click on FEM ConstraintContact.png or choose ModelMechanical ConstraintsFEM ConstraintContact.png Constraint contact from the top menu.
      2. +
      3. Select the master face.
      4. +
      5. Select the slave face.
      6. +
      7. Enter a contact stiffness.
      8. +
      9. Enter a friction coefficient.
      +

      Limitations

      +
      1. The contact constraint can only be applied to two faces.
      +

      Notes

      +
      1. The contact stiffness should be 10 times the young's modulus of the material for hard contact. The higher the value for contact stiffness, the harder the contact between surfaces.
      2. +
      3. The slave face is the face which penetrates into the master face, and therefore experiences more deformation.
      4. +
      5. The *CONTACT PAIR card is used for modeling contact in CalculiX. The constraint uses Face-to-Face penalty contact and the contact formulation is explained in detail at http://web.mit.edu/calculix_v2.7/CalculiX/ccx_2.7/doc/ccx/node112.html
      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/FEM_ConstraintDisplacement.html b/localwiki/FEM_ConstraintDisplacement.html new file mode 100644 index 0000000..8a2d0b3 --- /dev/null +++ b/localwiki/FEM_ConstraintDisplacement.html @@ -0,0 +1,76 @@ +FEM ConstraintDisplacement

      FEM ConstraintDisplacement

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      FEM ConstraintDisplacement.png FEM ConstraintDisplacement

      +
      Menu location +
      Model → Mechanical Constraints → Constraint displacement +
      Workbenches +
      FEM +
      Default shortcut +
      +
      See also +
      FEM tutorial +

      + +
      +


      +

      +

      Description

      +

      Creates a FEM constraint for a prescribed displacement of a selected object for a specified degree of freedom. +

      +

      How to use

      +
      1. Click on FEM ConstraintDisplacement.png or choose ModelMechanical ConstraintsFEM ConstraintDisplacement.png Constraint displacement from the top menu.
      2. +
      3. Select in the 3D-view the object the constraint should be applied to, which can be +
        1. vertices (corners)
        2. +
        3. edges
        4. +
        5. faces
      4. +
      5. Choose a degree of freedom to fix or prescribe a displacement to.
      +

      Limitations

      +

      Notes

      +
      1. The constraint uses the *BOUNDARY card in CalculiX. Fixing a degree of freedom is explained at http://web.mit.edu/calculix_v2.7/CalculiX/ccx_2.7/doc/ccx/node164.html and prescribing a displacement for a degree of freedom is explained at http://web.mit.edu/calculix_v2.7/CalculiX/ccx_2.7/doc/ccx/node165.html
      +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/FEM_ConstraintFixed.html b/localwiki/FEM_ConstraintFixed.html new file mode 100644 index 0000000..3d5a11f --- /dev/null +++ b/localwiki/FEM_ConstraintFixed.html @@ -0,0 +1,75 @@ +FEM ConstraintFixed

      FEM ConstraintFixed

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      FEM ConstraintFixed.png FEM ConstraintFixed

      +
      Menu location +
      Model → Mechanical Constraints → Constraint fixed +
      Workbenches +
      FEM +
      Default shortcut +
      +
      See also +
      FEM tutorial +

      + +
      +


      +

      +

      Description

      +

      Creates a FEM constraint for a fixed geometry entry by locking all 6 degrees of freedom of the selected object. +

      +

      How to use

      +
      1. Click on FEM ConstraintFixed.png or choose ModelMechanical ConstraintsFEM ConstraintFixed.png Constraint fixed from the top menu.
      2. +
      3. Select in the 3D-view the object the constraint should be applied to, which can be +
        1. vertices (corners)
        2. +
        3. edges
        4. +
        5. faces
      +

      Limitations

      +

      You cannot mix object-types within the same constraint. +Use one fixed constraint for each object type. +

      +

      Notes

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/FEM_ConstraintFlowVelocity.html b/localwiki/FEM_ConstraintFlowVelocity.html new file mode 100644 index 0000000..a2f1c97 --- /dev/null +++ b/localwiki/FEM_ConstraintFlowVelocity.html @@ -0,0 +1,67 @@ +FEM ConstraintFlowVelocity

      FEM ConstraintFlowVelocity

      + +

      +

      This documentation is not finished. Please help and contribute documentation. +

      See Draft ShapeString for good documented Command. Gui Command gives an overview over commands. And see List of Commands for other commands. +

      Go to Help FreeCAD to contribute. +

      +
      + + + + + + + + + + + + + + + + + + + + +
      +

      Official icon not found FEM ConstraintFlowVelocity

      +
      Menu location +
      Model → Fluid constraints → Constraint flow velocity +
      Workbenches +
      FEM +
      Default shortcut +
      +
      See also +
      FEM tutorial +

      + +
      +


      +


      +

      ToDo +


      +
      +

      +
      +


      +

      + + +
      + +
      +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/FEM_ConstraintFluidBoundary.html b/localwiki/FEM_ConstraintFluidBoundary.html new file mode 100644 index 0000000..d1679ab --- /dev/null +++ b/localwiki/FEM_ConstraintFluidBoundary.html @@ -0,0 +1,67 @@ +FEM ConstraintFluidBoundary

      FEM ConstraintFluidBoundary

      + +

      +

      This documentation is not finished. Please help and contribute documentation. +

      See Draft ShapeString for good documented Command. Gui Command gives an overview over commands. And see List of Commands for other commands. +

      Go to Help FreeCAD to contribute. +

      +
      + + + + + + + + + + + + + + + + + + + + +
      +

      FEM ConstraintFluidBoundary.png FEM ConstraintFluidBoundary

      +
      Menu location +
      Model → Fluid constraints → Constraint fluid boundary +
      Workbenches +
      FEM +
      Default shortcut +
      +
      See also +
      FEM tutorial +

      + +
      +


      +


      +

      ToDo +


      +
      +

      +
      +


      +

      + + +
      + +
      +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/FEM_ConstraintForce.html b/localwiki/FEM_ConstraintForce.html new file mode 100644 index 0000000..ee38d5c --- /dev/null +++ b/localwiki/FEM_ConstraintForce.html @@ -0,0 +1,95 @@ +FEM ConstraintForce

      FEM ConstraintForce

      + +
      +

      This documentation is not finished. Please help and contribute documentation. +

      See Draft ShapeString for good documented Command. Gui Command gives an overview over commands. And see List of Commands for other commands. +

      Go to Help FreeCAD to contribute. +

      +
      + + + + + + + + + + + + + + + + + + + + +
      +

      FEM ConstraintForce.png FEM ConstraintForce

      +
      Menu location +
      Model → Mechanical Constraints → Constraint force +
      Workbenches +
      FEM +
      Default shortcut +
      +
      See also +
      FEM tutorial +

      + +
      +


      +


      +

      +

      Description

      +

      This command applies a force of given value [N] to selected target geometry. +

      +

      How to use

      +

      1) Applying a force in normal direction to a face +

      +
        • In FEM workbench, click on Constraint Force or select ModelMechanical ConstraintsConstraint force to open Force Constraint properties dialog
      +

      FEMForceConstraintProperties.PNG +

      +
        • If you have Mesh displayed, you need to hide it (select the mesh object and press spacebar or right click and select Hide item) and show the original model.
        • +
        • Click on a face to which a force should be applied. It will appear in the list of geometrical objects.
        • +
        • Fill in Line load with a force value in [N] (attention: Not in [N/m])
      +

      ApplyingForceToFace.PNG +

      +
        • Direction: In a typical case, you'll click this field empty to apply a force in normal direction to the face. You can revert the direction of the force by clicking Reverse direction. In other cases, you need to pick a face or plane, which is in normal to the force direction (it could differ from the face, to which the force is being applied)
        • +
        • Click Close to finish the dialog and create FEM ConstraintForce.png ConstraintForce object
      +


      +2) Applying a force in to line in selected direction +

      +
        • In FEM workbench, click on Constraint Force or select ModelMechanical ConstraintsConstraint force to open Force Constraint properties dialog
        • +
        • If you have Mesh displayed, you need to hide it (select the mesh object and press spacebar or right click and select Hide item) and show the original model.
        • +
        • Click on a line segment to which a force should be applied. It will appear in the list of geometrical objects.
        • +
        • Fill in Area load with a force value in [N]
        • +
        • Direction: Now, with line segment selected, it si likely that the force is applied in a wrong direction. We need to specify the direction by clicking the button Direction and then clicking a face pointing with its normal to the direction of the force (or reversed direction). Again, you can revert the direction of the force by clicking Reverse direction.
      +

      FEMforceonline.PNG +

      +
        • Click Close to finish the dialog and create FEM ConstraintForce.png ConstraintForce object
      +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/FEM_ConstraintGear.html b/localwiki/FEM_ConstraintGear.html new file mode 100644 index 0000000..b767ab6 --- /dev/null +++ b/localwiki/FEM_ConstraintGear.html @@ -0,0 +1,71 @@ +FEM ConstraintGear

      FEM ConstraintGear

      + +
      +

      This documentation is not finished. Please help and contribute documentation. +

      See Draft ShapeString for good documented Command. Gui Command gives an overview over commands. And see List of Commands for other commands. +

      Go to Help FreeCAD to contribute. +

      +
      + + + + + + + + + + + + + + + + + + + + +
      +

      FEM ConstraintGear.png FEM ConstraintGear

      +
      Menu location +
      Model → Mechanical Constraints → Constraint gear +
      Workbenches +
      FEM +
      Default shortcut +
      +
      See also +
      FEM tutorial +

      + +
      +


      +


      +

      +

      Description

      +

      Not supported by CalculiX Interface! +


      +

      +

      Use

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/FEM_ConstraintHeatflux.html b/localwiki/FEM_ConstraintHeatflux.html new file mode 100644 index 0000000..eb160b7 --- /dev/null +++ b/localwiki/FEM_ConstraintHeatflux.html @@ -0,0 +1,73 @@ +FEM ConstraintHeatflux

      FEM ConstraintHeatflux

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      FEM ConstraintHeatflux.png FEM ConstraintHeatflux

      +
      Menu location +
      Model → Thermal Constraints → Constraint heatflux +
      Workbenches +
      FEM +
      Default shortcut +
      +
      See also +
      FEM tutorial +

      + +
      +


      +

      +

      Description

      +

      This constraint specifies film heat transfer of a surface at temperature T and with a film coefficient h to the environment or sink at temperature T0 . The convective heat flux q will satisfy: q = h(T -T0) +

      +

      Use

      +
      1. Click on FEM ConstraintHeatflux.png or choose ModelThermal ConstraintsFEM ConstraintHeatflux.png Constraint heatflux from the top menu.
      2. +
      3. Select in the 3D-view the surface(s) the constraint should be applied to.
      4. +
      5. Enter the desired surface temperature, film coefficient and environment temperature.
      +

      Limitations

      +

      Notes

      +
      1. The constraint uses the *FILM card in CalculiX. The heatflux constraint is explained at http://web.mit.edu/calculix_v2.7/CalculiX/ccx_2.7/doc/ccx/node203.html
      +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/FEM_ConstraintInitialFlowVelocity.html b/localwiki/FEM_ConstraintInitialFlowVelocity.html new file mode 100644 index 0000000..dd1e746 --- /dev/null +++ b/localwiki/FEM_ConstraintInitialFlowVelocity.html @@ -0,0 +1,67 @@ +FEM ConstraintInitialFlowVelocity

      FEM ConstraintInitialFlowVelocity

      + +

      +

      This documentation is not finished. Please help and contribute documentation. +

      See Draft ShapeString for good documented Command. Gui Command gives an overview over commands. And see List of Commands for other commands. +

      Go to Help FreeCAD to contribute. +

      +
      + + + + + + + + + + + + + + + + + + + + +
      +

      Official icon not found FEM ConstraintInitialFlowVelocity

      +
      Menu location +
      Model → Fluid constraints → Constraint initial flow velocity +
      Workbenches +
      FEM +
      Default shortcut +
      +
      See also +
      FEM tutorial +

      + +
      +


      +


      +

      ToDo +


      +
      +

      +
      +


      +

      + + +
      + +
      +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/FEM_ConstraintInitialTemperature.html b/localwiki/FEM_ConstraintInitialTemperature.html new file mode 100644 index 0000000..432ad8c --- /dev/null +++ b/localwiki/FEM_ConstraintInitialTemperature.html @@ -0,0 +1,74 @@ +FEM ConstraintInitialTemperature

      FEM ConstraintInitialTemperature

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      FEM ConstraintInitialTemperature.png FEM ConstraintInitialTemperature

      +
      Menu location +
      Model → Thermal Constraints → Constraint initial temperature +
      Workbenches +
      FEM +
      Default shortcut +
      +
      See also +
      FEM tutorial +

      + +
      +


      +

      +

      Description

      +

      Creates an initial temperature constraint for a thermo-mechanical analysis. +

      +

      Use

      +
      1. Click on FEM ConstraintInitialTemperature.png or choose ModelThermal ConstraintsFEM ConstraintInitialTemperature.png Constraint initial temperature from the top menu.
      2. +
      3. Enter an initial temperature value for the analysis.
      +

      Limitations

      +

      The constraint applies the initial temperature to all nodes in the FEA model +

      +

      Notes

      +
      1. The constraint uses the **INITIAL CONDITIONS card in CalculiX. The initial temperature constraint is explained at http://web.mit.edu/calculix_v2.7/CalculiX/ccx_2.7/doc/ccx/node215.html
      +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/FEM_ConstraintPlaneRotation.html b/localwiki/FEM_ConstraintPlaneRotation.html new file mode 100644 index 0000000..051e2bc --- /dev/null +++ b/localwiki/FEM_ConstraintPlaneRotation.html @@ -0,0 +1,72 @@ +FEM ConstraintPlaneRotation

      FEM ConstraintPlaneRotation

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      FEM ConstraintPlaneRotation.png FEM ConstraintPlaneRotation

      +
      Menu location +
      Model → Mechanical Constraints → Constraint plane rotation +
      Workbenches +
      FEM +
      Default shortcut +
      +
      See also +
      FEM tutorial +

      + +
      +


      +

      +

      Description

      +

      Creates a FEM constraint for keeping the nodes in a planar surface in the same plane. +

      +

      How to use

      +
      1. Click on FEM ConstraintPlaneRotation.png or choose ModelMechanical ConstraintsFEM ConstraintPlaneRotation.png Constraint plane rotation from the top menu.
      2. +
      3. Select in the 3D-view the object the constraint should be applied to, which can be a face.
      +

      Limitations

      +
      1. Plane rotation constraint can only be applied to a single planar face.
      2. +
      3. When a plane rotation constraint is applied to the same face as a displacement/fixed constraint, the displacement/fixed constraint takes preference.
      +

      Notes

      +
      1. The constraint uses the *MPC card in CalculiX. The card is explained in detail at http://web.mit.edu/calculix_v2.7/CalculiX/ccx_2.7/doc/ccx/node220.html
      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/FEM_ConstraintPressure.html b/localwiki/FEM_ConstraintPressure.html new file mode 100644 index 0000000..cb1d415 --- /dev/null +++ b/localwiki/FEM_ConstraintPressure.html @@ -0,0 +1,74 @@ +FEM ConstraintPressure

      FEM ConstraintPressure

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      FEM ConstraintPressure.png FEM ConstraintPressure

      +
      Menu location +
      Model → Mechanical Constraints → Constraint pressure +
      Workbenches +
      FEM +
      Default shortcut +
      +
      See also +
      FEM tutorial +

      + +
      +


      +

      +

      Description

      +

      Applies a pressure constraint to a face. +

      +

      How to use

      +
      1. Click on FEM ConstraintPressure.png or choose ModelMechanical ConstraintsFEM ConstraintPressure.png Constraint pressure from the top menu.
      2. +
      3. Click on Add reference and select face in 3D view
      4. +
      5. Edit appropriate window to specify pressure load in MPa
      6. +
      7. Tick box to reverse direction if necessary
      +

      Limitations

      +

      Notes

      +

      Distribution of pressure on face is always uniform and always perpendicular to face. +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/FEM_ConstraintPulley.html b/localwiki/FEM_ConstraintPulley.html new file mode 100644 index 0000000..1e0bafd --- /dev/null +++ b/localwiki/FEM_ConstraintPulley.html @@ -0,0 +1,71 @@ +FEM ConstraintPulley

      FEM ConstraintPulley

      + +
      +

      This documentation is not finished. Please help and contribute documentation. +

      See Draft ShapeString for good documented Command. Gui Command gives an overview over commands. And see List of Commands for other commands. +

      Go to Help FreeCAD to contribute. +

      +
      + + + + + + + + + + + + + + + + + + + + +
      +

      FEM ConstraintPulley.png FEM ConstraintPulley

      +
      Menu location +
      Model → Mechanical Constraints → Constraint pulley +
      Workbenches +
      FEM +
      Default shortcut +
      +
      See also +
      FEM tutorial +

      + +
      +


      +


      +

      +

      Description

      +

      Not supported by CalculiX Interface! +


      +

      +

      Use

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/FEM_ConstraintSelfWeight.html b/localwiki/FEM_ConstraintSelfWeight.html new file mode 100644 index 0000000..6d31988 --- /dev/null +++ b/localwiki/FEM_ConstraintSelfWeight.html @@ -0,0 +1,97 @@ +FEM ConstraintSelfWeight

      FEM ConstraintSelfWeight

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      FEM ConstraintSelfWeight.png FEM ConstraintSelfWeight

      +
      Menu location +
      Model → Mechanical Constraints → Constraint self weight +
      Workbenches +
      FEM +
      Default shortcut +
      C,W +
      See also +
      FEM tutorial +

      + +
      +


      +

      +

      Description

      +

      Constraint self weight defines gravity acceleration 9,81 m/s^2 acting on the whole model in the prescribed direction. +

      +

      How to use

      +
      1. Click on FEM ConstraintSelfWeight.png or choose ModelMechanical ConstraintsFEM ConstraintSelfWeight.png Constraint self weight from the top menu or press C then W keys.
      2. +
      3. You can modify the direction of gravitation by changing its vector coordinates in the property bar of newly created ConstraintSelfWeight object.
      +

      Scripting

      +
      • new object
      +
      import ObjectsFem
      +ObjectsFem.makeConstraintSelfWeight( name ) 
      +
      • add object to the analysis named Analysis
      +
      App.ActiveDocument.Analysis.Member = App.ActiveDocument.Analysis.Member + [ (object) ] 
      +
      • example:
      +
      import ObjectsFem
      +selfweight_obj = ObjectsFem.makeConstraintSelfWeight( 'MySelfWeightObject' )
      +App.ActiveDocument.Analysis.Member = App.ActiveDocument.Analysis.Member + [selfweight_obj] 
      +

      Solver CalculiX

      +

      Limitations

      +
      • You need to modify .inp file to edit gravity acceleration.
      • +
      • Self weight is applied to the element set Eall means to the whole model.
      +

      Editing CalculiX input file

      +

      Acceleration constant can be edited by hand modification after generating CalculiX input file. +

      Example of lines in .inp file: +

      +
      *DLOAD
      +Eall,GRAV,9810,0.0,0.0,-1.0 
      +

      where 9810 is gravity acceleration in [mm/s^2] +

      +

      Solver Z88

      +
      • not implemented in Z88 solver (March 2017)
      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/FEM_ConstraintTemperature.html b/localwiki/FEM_ConstraintTemperature.html new file mode 100644 index 0000000..4a5e361 --- /dev/null +++ b/localwiki/FEM_ConstraintTemperature.html @@ -0,0 +1,76 @@ +FEM ConstraintTemperature

      FEM ConstraintTemperature

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      FEM ConstraintTemperature.png FEM ConstraintTemperature

      +
      Menu location +
      Model → Thermal Constraints → Constraint temperature +
      Workbenches +
      FEM +
      Default shortcut +
      +
      See also +
      FEM tutorial +

      + +
      +


      +

      +

      Description

      +

      Creates a FEM constraint for a temperature boundary condition. +

      +

      Use

      +
      1. Click on FEM ConstraintTemperature.png or choose ModelThermal ConstraintsFEM ConstraintTemperature.png Constraint temperature from the top menu.
      2. +
      3. Select in the 3D-view the object(s) the constraint should be applied to, which can be: +
        1. vertices (corners)
        2. +
        3. edges
        4. +
        5. faces
      4. +
      5. Enter a temperature to apply to the object.
      +

      Limitations

      +

      Notes

      +
      1. The temperature constraint uses the *BOUNDARY card in CalculiX. the temperature constraint is explained at http://web.mit.edu/calculix_v2.7/CalculiX/ccx_2.7/doc/ccx/node163.html
      +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/FEM_ConstraintTransform.html b/localwiki/FEM_ConstraintTransform.html new file mode 100644 index 0000000..b4d32a3 --- /dev/null +++ b/localwiki/FEM_ConstraintTransform.html @@ -0,0 +1,67 @@ +FEM ConstraintTransform

      FEM ConstraintTransform

      + +

      +

      This documentation is not finished. Please help and contribute documentation. +

      See Draft ShapeString for good documented Command. Gui Command gives an overview over commands. And see List of Commands for other commands. +

      Go to Help FreeCAD to contribute. +

      +
      + + + + + + + + + + + + + + + + + + + + +
      +

      FEM ConstraintTransform.png FEM ConstraintTransform

      +
      Menu location +
      Model → Mechanical constraints → Constraint transform +
      Workbenches +
      FEM +
      Default shortcut +
      +
      See also +
      FEM tutorial +

      + +
      +


      +


      +

      ToDo +


      +
      +

      +
      +


      +

      + + +
      + +
      +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/FEM_CreateNodesSet.html b/localwiki/FEM_CreateNodesSet.html new file mode 100644 index 0000000..a0073a8 --- /dev/null +++ b/localwiki/FEM_CreateNodesSet.html @@ -0,0 +1,78 @@ +FEM CreateNodesSet

      FEM CreateNodesSet

      + +
      +

      This documentation is not finished. Please help and contribute documentation. +

      See Draft ShapeString for good documented Command. Gui Command gives an overview over commands. And see List of Commands for other commands. +

      Go to Help FreeCAD to contribute. +

      +
      + + + + + + + + + + + + + + + + + + + + +
      +

      FEM CreateNodesSet.png FEM CreateNodesSet

      +
      Menu location +
      Mesh → Nodes set +
      Workbenches +
      FEM +
      Default shortcut +
      +
      See also +
      FEM tutorial +

      + +
      +


      +


      +

      +

      Description

      +

      How to use

      +

      Options

      +

      Properties

      +

      Limitations

      +

      Notes

      +

      Scripting

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/FEM_ElementFluid1D.html b/localwiki/FEM_ElementFluid1D.html new file mode 100644 index 0000000..4c20916 --- /dev/null +++ b/localwiki/FEM_ElementFluid1D.html @@ -0,0 +1,75 @@ +FEM ElementFluid1D

      FEM ElementFluid1D

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      FEM ElementFluid1D.png FEM ElementFluid1D

      +
      Menu location +
      Model → Fluid section for 1D flow +
      Workbenches +
      FEM +
      Default shortcut +
      +
      See also +
      FEM tutorial +

      + +
      +


      +

      +

      Description

      +

      Creates a FEM fluid section element for aerodynamic and hydraulic networks +

      +

      How to use

      +
      1. Click on FEM ElementFluid1D.png or choose ModelFEM ElementFluid1D.png Fluid section for 1D flow from the top menu.
      2. +
      3. Select Fluid type: Liquid, Gas or Open Channel
      4. +
      5. Select Section type: Pipe Manning, Pipe Inlet etc.
      6. +
      7. Enter Section type parameters.
      8. +
      9. Select and add edge.
      +

      Limitations

      +
      1. The card only works with a 3 noded network element type. Information can be found here: http://web.mit.edu/calculix_v2.7/CalculiX/ccx_2.7/doc/ccx/node54.html
      +

      Notes

      +
      1. An example of the set up of a hydraulic network can be found here: http://web.mit.edu/calculix_v2.7/CalculiX/ccx_2.7/doc/ccx/node13.html
      2. +
      3. The *FLUID SECTION card is used to model fluid elements for 1D flow. Information on the card can be found here: http://web.mit.edu/calculix_v2.7/CalculiX/ccx_2.7/doc/ccx/node205.html
      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/FEM_ElementGeometry1D.html b/localwiki/FEM_ElementGeometry1D.html new file mode 100644 index 0000000..6575dae --- /dev/null +++ b/localwiki/FEM_ElementGeometry1D.html @@ -0,0 +1,78 @@ +FEM ElementGeometry1D

      FEM ElementGeometry1D

      + +
      +

      This documentation is not finished. Please help and contribute documentation. +

      See Draft ShapeString for good documented Command. Gui Command gives an overview over commands. And see List of Commands for other commands. +

      Go to Help FreeCAD to contribute. +

      +
      + + + + + + + + + + + + + + + + + + + + +
      +

      FEM ElementGeometry1D.png FEM ElementGeometry1D

      +
      Menu location +
      Model → Beam cross section +
      Workbenches +
      FEM +
      Default shortcut +
      C,B +
      See also +
      FEM tutorial +

      + +
      +


      +


      +

      +

      Description

      +

      How to use

      +

      Options

      +

      Properties

      +

      Limitations

      +

      Notes

      +

      Scripting

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/FEM_ElementGeometry2D.html b/localwiki/FEM_ElementGeometry2D.html new file mode 100644 index 0000000..9bdf0b3 --- /dev/null +++ b/localwiki/FEM_ElementGeometry2D.html @@ -0,0 +1,68 @@ +FEM ElementGeometry2D

      FEM ElementGeometry2D

      + +
      +

      This documentation is not finished. Please help and contribute documentation. +

      See Draft ShapeString for good documented Command. Gui Command gives an overview over commands. And see List of Commands for other commands. +

      Go to Help FreeCAD to contribute. +

      +
      + + + + + + + + + + + + + + + + + + + + +
      +

      FEM ElementGeometry2D.png FEM ElementGeometry2D

      +
      Menu location +
      Model →Shell plate tickness +
      Workbenches +
      FEM +
      Default shortcut +
      C,S +
      See also +
      FEM tutorial +

      + +
      +


      +


      +

      +

      Description

      +

      How to use

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/FEM_ElementRotation1D.html b/localwiki/FEM_ElementRotation1D.html new file mode 100644 index 0000000..4e3eb3a --- /dev/null +++ b/localwiki/FEM_ElementRotation1D.html @@ -0,0 +1,67 @@ +FEM ElementRotation1D

      FEM ElementRotation1D

      + +

      +

      This documentation is not finished. Please help and contribute documentation. +

      See Draft ShapeString for good documented Command. Gui Command gives an overview over commands. And see List of Commands for other commands. +

      Go to Help FreeCAD to contribute. +

      +
      + + + + + + + + + + + + + + + + + + + + +
      +

      Official icon not found FEM ElementRotation1D

      +
      Menu location +
      Model → Beam rotation +
      Workbenches +
      FEM +
      Default shortcut +
      +
      See also +
      FEM tutorial +

      Contents

      + +
      + +
      +


      +


      +

      ToDo +


      +
      +

      +
      +


      +

      + + +
      + +
      +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/FEM_Element_Types.html b/localwiki/FEM_Element_Types.html new file mode 100644 index 0000000..e71bb93 --- /dev/null +++ b/localwiki/FEM_Element_Types.html @@ -0,0 +1,1168 @@ +FEM Element Types

      FEM Element Types

      + +

      This description is based on the MED format as described here. +

      + + +

      Segment element

      +

      Segments.gif +

      + + + + + + + + + + + +
      Edges of Seg2 and Seg3 +
      Edge Node 1 Node 2 Middle node +
      E1 N1 N2 N3 +
      +


      +

      +


      +

      Triangle element

      +

      Triangles.gif +

      + + + + + + + + + + + + + + + + + + + + + +
      Edges of Tria3 and Tria6 +
      Edge Node 1 Node 2 Middle node +
      E1 N1 N2 N4 +
      E2 N2 N3 N5 +
      E3 N3 N1 N6 +
      + + + + + + + + + + + +
      Face by Edges of Tria3 and Tria6 +
      Face Edge 1 Edge 2 Edge 3 +
      F1 E1 E2 E3 +
      + + + + + + + + + + + + + +
      Face by Nodes of Tria3 +
      Face Node 1 Node 2 Node 3 Node 1 +
      F1 N1 N2 N3 N1 +
      + + + + + + + + + + + + + + + + + + + +
      Face by Nodes of Tria6 +
      Face Node 1 Node 2 Node 3 Node 4 Node 5 Node 6 Node 1 +
      F1 N1 N4 N2 N5 N3 N6 N1 +
      +


      +

      +


      +

      Quadratic element

      +

      Quadrangles.gif +

      + + + + + + + + + + + + + + + + + + + + + + + + + + +
      Edges of Quad4 and Quad8 +
      Edge Node 1 Node 2 Middle node +
      E1 N1 N2 N5 +
      E2 N2 N3 N6 +
      E3 N3 N4 N7 +
      E4 N4 N1 N8 +
      + + + + + + + + + + + + + +
      Face by Edges of Quad4 and Quad8 +
      Face Edge 1 Edge 2 Edge 3 Edge 4 +
      F1 E1 E2 E3 E4 +
      + + + + + + + + + + + + + + + +
      Face by Nodes of Quad4 +
      Face Node 1 Node 2 Node 3 Node 4 Node 1 +
      F1 N1 N2 N3 N4 N1 +
      + + + + + + + + + + + + + + + + + + + + + + + +
      Face by Nodes of Quad8 +
      Face Node 1 Node 2 Node 3 Node 4 Node 5 Node 6 Node 7 Node 8 Node 1 +
      F1 N1 N5 N2 N6 N3 N7 N4 N8 N1 +
      +


      +

      Tetrahedron element

      +

      Tetraedres.gif +


      +

      + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
      Edges of Tetra4 and Tetra10 +
      Edge Node 1 Node 2 Middle node +
      E1 N1 N2 N5 +
      E2 N2 N3 N6 +
      E3 N3 N1 N7 +
      E4 N1 N4 N8 +
      E5 N2 N4 N9 +
      E6 N3 N4 N10 +
      + + + + + + + + + + + + + + + + + + + + + + + + + + +
      Faces by Edges of Tetra4 and Tetra10 +
      Face Edge 1 Edge 2 Edge 3 +
      F1 E1 E2 E3 +
      F2 E4 -E5 -E1 +
      F3 E5 -E6 -E2 +
      F4 E6 -E4 -E3 +
      + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
      Faces by Nodes of Tetra4 +
      Face Node 1 Node 2 Node 3 Node 1 +
      F1 N1 N2 N3 N1 +
      F2 N1 N4 N2 N1 +
      F3 N2 N4 N3 N2 +
      F4 N3 N4 N1 N3 +
      + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
      Faces by Nodes of Tetra10 +
      Face Node 1 Node 2 Node 3 Node 4 Node 5 Node 6 Node 1 +
      F1 N1 N5 N2 N6 N3 N7 N1 +
      F2 N1 N8 N4 N9 N2 N5 N1 +
      F3 N2 N9 N4 N10 N3 N6 N2 +
      F4 N3 N10 N4 N8 N1 N7 N3 +
      +


      +

      Pyramid element

      +

      Pyramides.gif +

      + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
      Edges of Pyra5 and Pyra13 +
      Edge Node 1 Node 2 Middle node +
      E1 N1 N2 N6 +
      E2 N2 N3 N7 +
      E3 N3 N4 N8 +
      E4 N4 N1 N9 +
      E5 N1 N5 N10 +
      E6 N2 N5 N11 +
      E7 N3 N5 N12 +
      E8 N4 N5 N13 +
      + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
      Faces by Edges of Pyra5 and Pyra13 +
      Face Edge 1 Edge 2 Edge 3 Edge 4 +
      F1 E1 E2 E3 E4 +
      F2 E5 -E6 -E1 _ +
      F3 E6 -E7 -E2 _ +
      F4 E7 -E8 -E3 _ +
      F5 E8 E5 -E4 _ +
      + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
      Faces by Nodes of Pyra5 +
      Face Node 1 Node 2 Node 3 Node4 Node1 +
      F1 N1 N2 N3 N4 N1 +
      F2 N1 N5 N2 _ N1 +
      F3 N2 N5 N3 _ N2 +
      F4 N3 N5 N4 _ N3 +
      F5 N4 N5 N1 _ N4 +
      + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
      Faces by Nodes of Pyra13 +
      Face Node 1 Node 2 Node 3 Node4 Node 5 Node 6 Node 7 Node8 Node1 +
      F1 N1 N6 N2 N7 N3 N8 N4 N9 N1 +
      F2 N1 N10 N5 N11 N2 N6 _ _ N1 +
      F3 N2 N11 N5 N12 N13 N7 _ _ N2 +
      F4 N3 N12 N5 N13 N4 N8 _ _ N3 +
      F5 N4 N13 N5 N10 N1 N9 _ _ N4 +
      +


      +

      Hexahedron element

      +

      Hexaedres.gif +

      + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
      Edges of Hexa8 and Hexa20 +
      Edge Node 1 Node 2 Middle node +
      E1 N1 N2 N9 +
      E2 N2 N3 N10 +
      E3 N3 N4 N11 +
      E4 N4 N1 N12 +
      E5 N5 N6 N13 +
      E6 N6 N7 N14 +
      E7 N7 N8 N15 +
      E8 N8 N5 N16 +
      E9 N1 N5 N17 +
      E10 N2 N6 N18 +
      E11 N3 N7 N19 +
      E12 N4 N8 N20 +
      + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
      Faces by Edges of Hexa8 and Hexa20 +
      Face Edge 1 Edge 2 Edge 3 Edge 4 +
      F1 E1 E2 E3 E4 +
      F2 -E8 -E7 -E6 -E5 +
      F3 E9 E5 -E10-E1 +
      F4 E10 E6 -E11-E2 +
      F5 E11 E7 -E12-E3 +
      F6 E12 E8 -E9 -E4 +
      + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
      Faces by Nodes of Hexa8 +
      Face Node 1 Node 2 Node 3 Node 4 Node 1 +
      F1 N1 N2 N3 N4 N1 +
      F2 N5 N8 N7 N6 N5 +
      F3 N1 N5 N6 N2 N1 +
      F4 N2 N6 N7 N3 N2 +
      F5 N3 N7 N8 N4 N3 +
      F6 N4 N8 N5 N1 N4 +
      + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
      Faces by Nodes of Hexa20 +
      Face Node 1 Node 2 Node 3 Node 4 Node 5 Node 6 Node 7 Node 8 Node1 +
      F1 N1 N9 N2 N10 N3 N11 N4 N12 N1 +
      F2 N5 N16 N8 N15 N7 N14 N6 N13 N5 +
      F3 N1 N17 N5 N13 N6 N18 N2 N9 N1 +
      F4 N2 N18 N6 N14 N7 N19 N3 N10 N2 +
      F5 N3 N19 N7 N15 N8 N20 N4 N11 N3 +
      F6 N4 N20 N8 N16 N5 N17 N1 N12 N4 +
      +


      +

      Pentahedron element

      +

      Pentaedres.gif +

      + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
      Edges of Penta6 and Penta15 +
      Edge Node 1 Node 2 Middle node +
      E1 N1 N2 N7 +
      E2 N2 N3 N8 +
      E3 N3 N1 N9 +
      E4 N4 N5 N10 +
      E5 N5 N6 N11 +
      E6 N6 N4 N12 +
      E7 N1 N4 N13 +
      E8 N2 N5 N14 +
      E9 N3 N6 N15 +
      + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
      Faces by Edges of Penta6 and Penta15 +
      Face Edge 1 Edge 2 Edge 3 Edge 4 +
      F1 E1 E2 E3 _ +
      F2 -E6 -E5 -E4 _ +
      F3 E7 E4 -E8 -E1 +
      F4 E8 E5 -E9 -E2 +
      F5 E9 E6 -E7 -E3 +
      + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
      Faces by Nodes of Penta6 +
      Face Node 1 Node 2 Node 3 Node 4 Node 1 +
      F1 N1 N2 N3 _ N1 +
      F2 N4 N6 N5 _ N4 +
      F3 N1 N4 N5 N2 N1 +
      F4 N2 N5 N6 N3 N2 +
      F5 N3 N6 N4 N1 N3 +
      + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
      Faces by Nodes of Penta15 +
      Face Node 1 Node 2 Node 3 Node 4 Node 5 Node 6 Node 7 Node 8 Node 1 +
      F1 N1 N7 N2 N8 N3 N9 _ _ N1 +
      F2 N4 N12 N6 N11 N5 N10 _ _ N4 +
      F3 N1 N13 N4 N10 N5 N14 N2 N7 N1 +
      F4 N2 N14 N5 N11 N6 N15 N3 N8 N2 +
      F5 N3 N15 N6 N12 N4 N13 N1 N9 N3 +
      +


      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/FEM_EquationElasticity.html b/localwiki/FEM_EquationElasticity.html new file mode 100644 index 0000000..65b4cbb --- /dev/null +++ b/localwiki/FEM_EquationElasticity.html @@ -0,0 +1,67 @@ +FEM EquationElasticity

      FEM EquationElasticity

      + +

      +

      This documentation is not finished. Please help and contribute documentation. +

      See Draft ShapeString for good documented Command. Gui Command gives an overview over commands. And see List of Commands for other commands. +

      Go to Help FreeCAD to contribute. +

      +
      + + + + + + + + + + + + + + + + + + + + +
      +

      Official icon not found FEM EquationElasticity

      +
      Menu location +
      Solve → Equation elasticity +
      Workbenches +
      FEM +
      Default shortcut +
      +
      See also +
      FEM tutorial +

      Contents

      + +
      + +
      +


      +


      +

      ToDo +


      +
      +

      +
      +


      +

      + + +
      + +
      +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/FEM_EquationElectrostatic.html b/localwiki/FEM_EquationElectrostatic.html new file mode 100644 index 0000000..b78905b --- /dev/null +++ b/localwiki/FEM_EquationElectrostatic.html @@ -0,0 +1,67 @@ +FEM EquationElectrostatic

      FEM EquationElectrostatic

      + +

      +

      This documentation is not finished. Please help and contribute documentation. +

      See Draft ShapeString for good documented Command. Gui Command gives an overview over commands. And see List of Commands for other commands. +

      Go to Help FreeCAD to contribute. +

      +
      + + + + + + + + + + + + + + + + + + + + +
      +

      Official icon not found FEM EquationElectrostatic

      +
      Menu location +
      Solve → Equation electrostatic +
      Workbenches +
      FEM +
      Default shortcut +
      +
      See also +
      FEM tutorial +

      + +
      +


      +


      +

      ToDo +


      +
      +

      +
      +


      +

      + + +
      + +
      +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/FEM_EquationFlow.html b/localwiki/FEM_EquationFlow.html new file mode 100644 index 0000000..3b8b078 --- /dev/null +++ b/localwiki/FEM_EquationFlow.html @@ -0,0 +1,67 @@ +FEM EquationFlow

      FEM EquationFlow

      + +

      +

      This documentation is not finished. Please help and contribute documentation. +

      See Draft ShapeString for good documented Command. Gui Command gives an overview over commands. And see List of Commands for other commands. +

      Go to Help FreeCAD to contribute. +

      +
      + + + + + + + + + + + + + + + + + + + + +
      +

      Official icon not found FEM EquationFlow

      +
      Menu location +
      Solve → Equation flow +
      Workbenches +
      FEM +
      Default shortcut +
      +
      See also +
      FEM tutorial +

      Contents

      + +
      + +
      +


      +


      +

      ToDo +


      +
      +

      +
      +


      +

      + + +
      + +
      +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/FEM_EquationFluxsolver.html b/localwiki/FEM_EquationFluxsolver.html new file mode 100644 index 0000000..1153693 --- /dev/null +++ b/localwiki/FEM_EquationFluxsolver.html @@ -0,0 +1,67 @@ +FEM EquationFluxsolver

      FEM EquationFluxsolver

      + +

      +

      This documentation is not finished. Please help and contribute documentation. +

      See Draft ShapeString for good documented Command. Gui Command gives an overview over commands. And see List of Commands for other commands. +

      Go to Help FreeCAD to contribute. +

      +
      + + + + + + + + + + + + + + + + + + + + +
      +

      Official icon not found FEM EquationFluxsolver

      +
      Menu location +
      Solve → Equation fluxsolver +
      Workbenches +
      FEM +
      Default shortcut +
      +
      See also +
      FEM tutorial +

      Contents

      + +
      + +
      +


      +


      +

      ToDo +


      +
      +

      +
      +


      +

      + + +
      + +
      +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/FEM_EquationHeat.html b/localwiki/FEM_EquationHeat.html new file mode 100644 index 0000000..640ecbb --- /dev/null +++ b/localwiki/FEM_EquationHeat.html @@ -0,0 +1,67 @@ +FEM EquationHeat

      FEM EquationHeat

      + +

      +

      This documentation is not finished. Please help and contribute documentation. +

      See Draft ShapeString for good documented Command. Gui Command gives an overview over commands. And see List of Commands for other commands. +

      Go to Help FreeCAD to contribute. +

      +
      + + + + + + + + + + + + + + + + + + + + +
      +

      Official icon not found FEM EquationHeat

      +
      Menu location +
      Solve → Equation heat +
      Workbenches +
      FEM +
      Default shortcut +
      +
      See also +
      FEM tutorial +

      Contents

      + +
      + +
      +


      +


      +

      ToDo +


      +
      +

      +
      +


      +

      + + +
      + +
      +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/FEM_FemMesh2Mesh.html b/localwiki/FEM_FemMesh2Mesh.html new file mode 100644 index 0000000..8cff68a --- /dev/null +++ b/localwiki/FEM_FemMesh2Mesh.html @@ -0,0 +1,104 @@ +FEM FemMesh2Mesh

      FEM FemMesh2Mesh

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      FEM FemMesh2Mesh.png FEM FemMesh2Mesh

      +
      Menu location +
      Mesh → FEM mesh to mesh +
      Workbenches +
      FEM +
      Default shortcut +
      +
      See also +
      FEM tutorial +

      + +
      +


      +

      +

      Description

      +

      This tool converts surfaces of 3D elements of a selected FEM mesh to mesh. Internally it picks FEM mesh element faces which are unique (not shared by two elements) and uses them to create faces of a mesh. Optionally it allows to create a deformed mesh caused by the action of the defined forces. This is done by adding the displacement of the FEM results to the mesh nodes. +

      Two dimensional elements from the FEM mesh are not taken into account. If you need to convert them, you can use a python script below. +

      +

      How to use

      +
      1. Select a FEM mesh object (optionally select additionally the FEM results)
      2. +
      3. Press the FEM FemMesh2Mesh.pngFEM mesh to mesh button
      +

      Scripting

      +

      Example: +

      +
      • Load FreeCAD's 3D FEM example from the Start Workbench and run the following code
      +
      femmesh_obj = App.ActiveDocument.getObject("Result_mesh").FemMesh
      +result = App.ActiveDocument.getObject("CalculiX_static_results")
      +import femmesh.femmesh2mesh
      +out_mesh = femmesh.femmesh2mesh.femmesh_2_mesh(femmesh_obj, result)
      +import Mesh
      +Mesh.show(Mesh.Mesh(out_mesh)) 
      +

      Converting 2D elements

      +

      Select a mesh and run the following python script +

      +
      import Mesh
      +
      +def extend_by_triangle(i, j, k):
      +    triangle = [input_mesh.getNodeById(element_nodes[i]),
      +                input_mesh.getNodeById(element_nodes[j]),
      +                input_mesh.getNodeById(element_nodes[k])]
      +    return output_mesh.extend(triangle) 
      +
      +selection = FreeCADGui.Selection.getSelection()
      +input_mesh = App.ActiveDocument.getObject(selection[0].Name).FemMesh
      +output_mesh = []
      +for element in input_mesh.Faces:
      +    element_nodes = input_mesh.getElementNodes(element)
      +    if len(element_nodes) in [3, 6]:  # tria3 or tria6 (ignoring mid-nodes)
      +        extend_by_triangle(0, 1, 2)
      +    elif len(element_nodes) in [4, 8]:  # quad4 or quad8 (ignoring mid-nodes)
      +        extend_by_triangle(0, 1, 2)
      +        extend_by_triangle(2, 3, 0)
      +
      +obj = Mesh.Mesh(output_mesh)
      +Mesh.show(obj) 
      +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/FEM_Install.html b/localwiki/FEM_Install.html new file mode 100644 index 0000000..e6666e3 --- /dev/null +++ b/localwiki/FEM_Install.html @@ -0,0 +1,121 @@ +FEM Install

      FEM Install

      + +
      + +

      Introduction

      +

      To be able to do a Finite Element Analysis (FEA) using the FEM Worbench FreeCAD makes use of two external programms. One is used for generating the FEM-Mesh and the other for solving the system of equations. If your FreeCAD is set up to do mechanical Finite Element Analysis’s could be checked easily by loading and analyzing an example file. See FEM_CalculiX_Cantilever_3D +

      +
      FEM Solver
      +

      For solving the system of equations CalculiX is used. See http://www.calculix.de/ FreeCAD writes an CalculiX input file starts CalculiX and reads the output of CalculiX. It means CalculiX binary is standalone and independent from FreeCAD. Because of this and since there are more possibilities to get a valid FEM-Mesh it is recommended to install the Solver first. Up To date (mid 2015) CalculiX is the only supported Solver of the FEM module. +

      +
      FEM Mesh Generator
      +

      As meshing tool to create a FEM-Mesh netgen is used. See https://sourceforge.net/projects/netgen-mesher/ To use Netgen in FEM module FreeCAD needs to be compiled against netgen libraries. Apart from Netgen a common way to create a FEM Mesh is the use FEM GMSH mesh tool. For the use of this tool GMSH has to be installed on your system. Check out FEM_Mesh#Create_a_FEM_Mesh for the various possibilities to create an FEM Mesh in FreeCAD. +

      +

      Installation of external FEM Module Software

      +

      Windows

      +

      If either a stable or development version from Download is used no further software needs to be installed. Netgen and CalculiX are included in the FreeCAD download package. +

      +

      Linux

      +

      Ubuntu PPA

      +

      The easiest possibility to get an working FEM Workbench on Linux is the use of the Ubuntu PPA Version. Check out Download#Ubuntu_PPA_packages. The netgen FEM Mesh Generator is allready included in the ppa version. CalculiX is an extra package provided by the Ubuntu PPA Version as well. If the Ubuntu PPA repository is allready added to your package manager install CalculiX by +

      +
      apt-get install ccx
      +
      +

      The following FreeCAD Ubuntu PPA packages have Netgen and CalculiX: +

      +
      • Ubuntu 14.04 (Trusty Tahr)
      • +
      • Ubuntu 14.10 (Utopic Unicorn)
      • +
      • Ubuntu 15.04 (Vivid Vervet)
      +

      For Developers: There is a huge forum thread in which the creation of the Ubuntu PPA packages was disscussed. It may be usefull if the Ubuntu PPA packages needs to be updated. On Launchpad there are more than one CalculiX packages. Only one CalculiX package should be installed and any of them should work. There is a simple reason for not taking the one which was allready on Launchpad. We did not know about it (see http://forum.freecadweb.org/viewtopic.php?f=18&t=10393&start=90#p85498) +

      +

      Other

      +

      On other Linux distributions you need to make sure to get the appropriate software and libraries installed yourself before using FEM workbench. +

      +

      CalculiX

      +

      Since CalculiX is a standalone software you either can install a CalculiX binary or compile CalculiX yourself. Any CalculiX version from 2.7.X works with FreeCAD. Since there hasn't been much changes in CalculiX resently lower versions than 2.7.X might work as well. +

      +
      Install CalculiX Binary
      +

      There are only a few Linux Distributions which are known to have CalculiX Packages in their Repositories. Following a list: +

      + +

      On the CalculiX Website it is possible to download a generic Linux binary of CalculiX. Check out http://www.dhondt.de/ Since any Linux Distribution could have different library paths it is likely possible this binary will not work out of the box at your linux distribution. Check out the following FreeCAD forum threads for more infomation: +

      + +
      Compile CalculiX
      +

      Compiling CalculiX is not as easy as it is with many OpenSource software. There are many different resources at FreeCAD forum and the internet. Check out the following: +

      + +

      Netgen

      +

      There have been mixed results with the Netgen mesher and the compilation of FreeCAD with Netgen support. +

      +
      • ToDo
      +

      Further Informations

      +

      The FreeCAD forum is a very good resource for informations in this regard. Check out google search on FreeCAD forum page by : +

      + +

      OSX

      +

      The OSX development packages of FreeCAD 0.17.xxxxx do include Netgen [1] but they do not include CalculiX. +

      +

      CalculiX

      +

      See this forum post FreeCAD Fem on OSX how to install CalculiX on OSX +Following informations might be outdated: +

      + +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/FEM_Material.png b/localwiki/FEM_Material.png new file mode 100644 index 0000000..d3d57a1 Binary files /dev/null and b/localwiki/FEM_Material.png differ diff --git a/localwiki/FEM_MaterialFluid.html b/localwiki/FEM_MaterialFluid.html new file mode 100644 index 0000000..1ed5891 --- /dev/null +++ b/localwiki/FEM_MaterialFluid.html @@ -0,0 +1,67 @@ +FEM MaterialFluid

      FEM MaterialFluid

      + +

      +

      This documentation is not finished. Please help and contribute documentation. +

      See Draft ShapeString for good documented Command. Gui Command gives an overview over commands. And see List of Commands for other commands. +

      Go to Help FreeCAD to contribute. +

      +
      + + + + + + + + + + + + + + + + + + + + +
      +

      FEM MaterialFluid.png FEM MaterialFluid

      +
      Menu location +
      Model → Material for fluid +
      Workbenches +
      FEM +
      Default shortcut +
      +
      See also +
      FEM tutorial +

      Contents

      + +
      + +
      +


      +


      +

      ToDo +


      +
      +

      +
      +


      +

      + + +
      + +
      +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/FEM_MaterialMechanicalNonlinear.html b/localwiki/FEM_MaterialMechanicalNonlinear.html new file mode 100644 index 0000000..05f8f83 --- /dev/null +++ b/localwiki/FEM_MaterialMechanicalNonlinear.html @@ -0,0 +1,67 @@ +FEM MaterialMechanicalNonlinear

      FEM MaterialMechanicalNonlinear

      + +

      +

      This documentation is not finished. Please help and contribute documentation. +

      See Draft ShapeString for good documented Command. Gui Command gives an overview over commands. And see List of Commands for other commands. +

      Go to Help FreeCAD to contribute. +

      +
      + + + + + + + + + + + + + + + + + + + + +
      +

      FEM MaterialMechanicalNonlinear.png FEM MaterialMechanicalNonlinear

      +
      Menu location +
      Model → Nonlinear mechanical material +
      Workbenches +
      FEM +
      Default shortcut +
      +
      See also +
      FEM tutorial +

      + +
      +


      +


      +

      ToDo +


      +
      +

      +
      +


      +

      + + +
      + +
      +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/FEM_MaterialSolid.html b/localwiki/FEM_MaterialSolid.html new file mode 100644 index 0000000..a33c9c3 --- /dev/null +++ b/localwiki/FEM_MaterialSolid.html @@ -0,0 +1,77 @@ +FEM MaterialSolid

      FEM MaterialSolid

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      FEM MaterialSolid.png FEM MaterialSolid

      +
      Menu location +
      Model → FEM material for solid +
      Workbenches +
      FEM +
      Default shortcut +
      M,M +
      See also +
      FEM tutorial +

      + +
      +


      +

      +

      Description

      +

      Adds material properties to a part. +

      +

      How to use

      +
      • Click on FEM MaterialSolid.png or choose ModelFEM MaterialSolid.png FEM material for solid from the top menu.
      • +
      • Double click the created FEM MaterialSolid.png SolidMaterial object
      +

      FEMMaterialProperties.PNG +

      +
        • Select a material. For engineering mecanical analysis, CalculiX-Steel is a typical option.
        • +
        • Provided that you are applying material to the whole object, don't select any geometrical entities (leave reference list empty). Material will be applied to whole model. Otherwise assign material to particular model parts manually by selecting some of them for each inserted material, but don't leave any part of the model without material assigned.
        • +
        • You can adjust material properties such as density, young's modulus, poisson ratio, etc., however most of the common materials are already available in the presets and they don't need any tweaking.
        • +
        • If you make modifications, you can save your customized material.
      • +
      • Click Close to close the dialog and create FEM MaterialSolid.png SolidMaterial object
      +

      Limitations

      +

      Notes

      +
      1. The mechanical material uses the *MATERIAL card in CalculiX. Details about the mechanical material is explained at http://web.mit.edu/calculix_v2.7/CalculiX/ccx_2.7/doc/ccx/node216.html
      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/FEM_Mesh.html b/localwiki/FEM_Mesh.html new file mode 100644 index 0000000..9025975 --- /dev/null +++ b/localwiki/FEM_Mesh.html @@ -0,0 +1,780 @@ +FEM Mesh

      FEM Mesh

      + +
      + +

      Create a FEM Mesh

      +

      There are different possibilities to create a FEM Mesh in FreeCAD: +

      +
      • The FreeCAD FEM mesh Netgen tool MeshNetgenFromShape by GUI usage or by Python
      • +
      • The FreeCAD FEM mesh GMSH tool MeshGmshFromShape by GUI usage or by Python
      • +
      • Python directly means make the FEM Mesh by Hand
      • +
      • Import a FEM Mesh
      +

      Objects created in PartDesign and Part are supported, as well as simple copies of those bodies. There are two meshers available to the user: Netgen and GMSH. Netgen is included in FreeCAD. For GMSH an external binary needs to be installed. Refer to FEM Install +

      +

      FEM Mesh Elements in FreeCAD

      +

      FreeCAD supports various element types. There is an external blog link which explains about the differences and when to use which element type: https://www.comsol.com/blogs/meshing-your-geometry-various-element-types/ +

      + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
      Import and Export of FEM Mesh Elements +
      Element Element FreeCAD API FreeCAD GUI med unv inp frd txt xml +
      Med CalculiX Python FEM Mesh SMESH IDEAS/FreeCAD Abaqus/CalculiX Result Mesh Z88 Fenics +
      Name Name create elements view elements import/export import/export import/export import import/export import/export +
      seg 2 B31 Edit OK.svg Edit OK.svg Edit OK.svg Edit OK.svg Edit OK.svg Edit OK.svg Edit OK.svg Edit OK.svg +
      seg 3 B32 Edit OK.svg Edit OK.svg Edit OK.svg Edit OK.svg Edit OK.svg Edit OK.svg ni - +
      tria 3 S3 Edit OK.svg Edit OK.svg Edit OK.svg Edit OK.svg Edit OK.svg Edit OK.svg - Edit OK.svg +
      tria 6 S6 Edit OK.svg Edit OK.svg Edit OK.svg Edit OK.svg Edit OK.svg Edit OK.svg Edit OK.svg - +
      quad 4 S4 Edit OK.svg Edit OK.svg Edit OK.svg Edit OK.svg Edit OK.svg Edit OK.svg - Edit OK.svg +
      quad 8 S8 Edit OK.svg Edit OK.svg Edit OK.svg Edit OK.svg Edit OK.svg Edit OK.svg Edit OK.svg - +
      tetra 4 C3D4 Edit OK.svg Edit OK.svg Edit OK.svg Edit OK.svg Edit OK.svg Edit OK.svg Edit OK.svg Edit OK.svg +
      tetra 10 C3D10 Edit OK.svg Edit OK.svg Edit OK.svg Edit OK.svg Edit OK.svg Edit OK.svg Edit OK.svg - +
      pyra 5 - Edit OK.svg Edit OK.svg Edit OK.svg - - - - - +
      pyra 13 - Edit OK.svg Edit OK.svg Edit OK.svg - - - - - +
      hexa 8 C3D8 Edit OK.svg Edit OK.svg Edit OK.svg Edit OK.svg Edit OK.svg Edit OK.svg Edit OK.svg (-) [format allows it, but not readable/writable by fenics] +
      hexa 20 C3D20 Edit OK.svg Edit OK.svg Edit OK.svg Edit OK.svg Edit OK.svg Edit OK.svg Edit OK.svg - +
      penta 6 C3D6 Edit OK.svg Edit OK.svg Edit OK.svg Edit OK.svg Edit OK.svg Edit OK.svg  ? - +
      penta 15 C3D15 Edit OK.svg Edit OK.svg Edit OK.svg Edit OK.svg Edit OK.svg Edit OK.svg  ? - +
      +
      • "ni" means the element type is not implemented in FreeCAD but the format would support it.
      • +
      • "-" means the format specification does not support this element type, thus FreeCAD can not support it.
      • +
      • "?" it is not known if the format supports this element type.
      +

      FEM Element Types

      +

      General

      +

      More informations about the FEM element types and their data structure inside FreeCAD can be find on FEM Element Types. +

      +

      Segment element

      +

      Segments.gif +

      +


      +

      Triangle element

      +

      Triangles.gif +

      +


      +

      Quadratic element

      +

      Quadrangles.gif +

      +


      +

      Tetrahedron element

      +

      Tetraedres.gif +

      +


      +

      Pyramid element

      +

      Pyramides.gif +

      +


      +

      Hexahedron element

      +

      Hexaedres.gif +

      +


      +

      Pentahedron element

      +

      Pentaedres.gif +

      +


      +

      Scripting

      +

      Create a FEM Mesh totally py python

      +

      Creating a mesh with one Tet-10 Elements

      +
      import FreeCAD, Fem
      +# create a empty mesh
      +m = Fem.FemMesh()
      +#create the nodes
      +m.addNode(0,1,0)
      +m.addNode(0,0,1)
      +m.addNode(1,0,0)
      +m.addNode(0,0,0)
      +m.addNode(0,0.5,0.5)
      +m.addNode(0.5,0.03,.5)
      +m.addNode(0.5,0.5,0.03)
      +m.addNode(0,0.5,0)
      +m.addNode(0.03,0,0.5)
      +m.addNode(0.5,0,0)
      +# add the volume with the created nodes
      +m.addVolume([1,2,3,4,5,6,7,8,9,10])
      +
      +Fem.show(m) 
      +

      If you want to have predefined element and node numbering: +

      +
      m.addNode(0.0,1.0,0.0,1)
      +m.addVolume([1,2,3,4,5,6,7,8,9,10],1) 
      +


      +

      +

      Visual handling

      +

      Highlight some nodes on the view: +

      +
      import FreeCAD, Fem
      +
      +m = Fem.FemMesh()
      +
      +m.addNode(0,1,0)
      +m.addNode(0,0,1)
      +m.addNode(1,0,0)
      +m.addNode(0,0,0)
      +m.addNode(0,0.5,0.5)
      +m.addNode(0.5,0.03,.5)
      +m.addNode(0.5,0.5,0.03)
      +m.addNode(0,0.5,0)
      +m.addNode(0.03,0,0.5)
      +m.addNode(0.5,0,0)
      +m.addVolume([1,2,3,4,5,6,7,8,9,10])
      +
      +Fem.show(m)
      +Gui.ActiveDocument.ActiveObject.HighlightedNodes = [1,2,3] 
      +

      Postprocessing colors and displacement: +Highlight some nodes on the view: +

      +
      # set the volume 1 to red
      +Gui.ActiveDocument.ActiveObject.ElementColor= {1:(1,0,0)}
      +# set the node 1 and 2 to a certain Color and interpolate the survace
      +Gui.ActiveDocument.ActiveObject.NodeColor= {1:(1,0,0),2:(1,0,0)}
      +# set the node 1 and 2 to a certain displacement
      +Gui.ActiveDocument.ActiveObject.NodeDisplacement= {1:FreeCAD.Vector(1,0,0),2:FreeCAD.Vector(1,0,0)}
      +# double the factor of the displacement shown
      +Gui.ActiveDocument.ActiveObject.animate(2.0) 
      +

      Script one Element of each supported Element Type

      +
      import Fem
      +#################################################
      +# Beams
      +# 2 node line --> seg2 ##########################
      +seg2 = Fem.FemMesh()
      +seg2.addNode( 0,  0, 0, 1)
      +seg2.addNode(10,  0, 0, 2)
      +seg2.addEdge(1, 2)
      +seg2
      +obj = App.ActiveDocument.addObject("Fem::FemMeshObject","seg2")
      +obj.FemMesh = seg2
      +obj.Placement.Base = (0,110,0)
      +obj.ViewObject.DisplayMode = "Faces, Wireframe & Nodes"
      +
      +
      +# 3 node line --> seg3 ##########################
      +
      +seg3 = Fem.FemMesh()
      +seg3.addNode( 0,  0, 0, 1)
      +seg3.addNode(10,  0, 0, 2)
      +seg3.addNode( 5,  0, 0, 3)
      +seg3.addEdge([1, 2, 3])
      +seg3
      +obj = App.ActiveDocument.addObject("Fem::FemMeshObject","seg3")
      +obj.FemMesh = seg3
      +obj.Placement.Base = (30,110,0)
      +obj.ViewObject.DisplayMode = "Faces, Wireframe & Nodes"
      +
      +
      +#################################################
      +# Shells
      +# 3 node triangle --> tria3 #####################
      +tria3 = Fem.FemMesh()
      +tria3.addNode( 0,  0, 0, 1)
      +tria3.addNode( 6, 12, 0, 2)
      +tria3.addNode(12,  0, 0, 3)
      +tria3.addFace([1,  2,  3])
      +tria3
      +obj = App.ActiveDocument.addObject("Fem::FemMeshObject","tria3")
      +obj.FemMesh = tria3
      +obj.Placement.Base = (0,80,0)
      +obj.ViewObject.DisplayMode = "Faces, Wireframe & Nodes"
      +obj.ViewObject.BackfaceCulling = False
      +# add Face with element number
      +elemtria3 = Fem.FemMesh()
      +nds = tria3.Nodes
      +for n in nds:
      +    elemtria3.addNode(nds[n].x, nds[n].y, nds[n].z, n)
      +
      +elemtria3.addFace([1,  2,  3], 88)
      +obj = App.ActiveDocument.addObject("Fem::FemMeshObject","elemtria3")
      +obj.FemMesh = elemtria3
      +obj.Placement.Base = (200,80,0)
      +obj.ViewObject.DisplayMode = "Faces, Wireframe & Nodes"
      +obj.ViewObject.BackfaceCulling = False
      +elemtria3.Faces
      +
      +
      +# 6 node triangle --> tria 6 ####################
      +tria6 = Fem.FemMesh()
      +tria6.addNode( 0,  0, 0, 1)
      +tria6.addNode( 6, 12, 0, 2)
      +tria6.addNode(12,  0, 0, 3)
      +tria6.addNode( 3,  6, 0, 4)
      +tria6.addNode( 9,  6, 0, 5)
      +tria6.addNode( 6,  0, 0, 6)
      +tria6.addFace([1,  2, 3,  4, 5, 6])
      +tria6
      +obj = App.ActiveDocument.addObject("Fem::FemMeshObject","tria6")
      +obj.FemMesh = tria6
      +obj.Placement.Base = (30,80,0)
      +obj.ViewObject.DisplayMode = "Faces, Wireframe & Nodes"
      +obj.ViewObject.BackfaceCulling = False
      +# add Face with element number
      +elemtria6 = Fem.FemMesh()
      +nds = tria6.Nodes
      +for n in nds:
      +    elemtria6.addNode(nds[n].x, nds[n].y, nds[n].z, n)
      +
      +elemtria6.addFace([1,  2,  3,  4, 5, 6], 88)
      +obj = App.ActiveDocument.addObject("Fem::FemMeshObject","elemtria6")
      +obj.FemMesh = elemtria6
      +obj.Placement.Base = (230,80,0)
      +obj.ViewObject.DisplayMode = "Faces, Wireframe & Nodes"
      +obj.ViewObject.BackfaceCulling = False
      +elemtria6.Faces
      +
      +
      +# 4 node quad --> quad4 #########################
      +quad4 = Fem.FemMesh()
      +quad4.addNode( 0, 10, 0, 1)
      +quad4.addNode(10, 10, 0, 2)
      +quad4.addNode(10,  0, 0, 3)
      +quad4.addNode( 0,  0, 0, 4)
      +quad4.addFace([1,  2,  3, 4])
      +quad4
      +obj = App.ActiveDocument.addObject("Fem::FemMeshObject","quad4")
      +obj.FemMesh = quad4
      +obj.Placement.Base = (60,80,0)
      +obj.ViewObject.DisplayMode = "Faces, Wireframe & Nodes"
      +obj.ViewObject.BackfaceCulling = False
      +# add Face with element number
      +elemquad4 = Fem.FemMesh()
      +nds = quad4.Nodes
      +for n in nds:
      +    elemquad4.addNode(nds[n].x, nds[n].y, nds[n].z, n)
      +
      +elemquad4.addFace([1,  2,  3,  4], 88)
      +obj = App.ActiveDocument.addObject("Fem::FemMeshObject","elemquad4")
      +obj.FemMesh = elemquad4
      +obj.Placement.Base = (260,80,0)
      +obj.ViewObject.DisplayMode = "Faces, Wireframe & Nodes"
      +obj.ViewObject.BackfaceCulling = False
      +elemquad4.Faces
      +
      +
      +# 8 node quad --> quad8 #########################
      +quad8 = Fem.FemMesh()
      +quad8.addNode( 0, 10, 0, 1)
      +quad8.addNode(10, 10, 0, 2)
      +quad8.addNode(10,  0, 0, 3)
      +quad8.addNode( 0,  0, 0, 4)
      +quad8.addNode( 5, 10, 0, 5)
      +quad8.addNode(10,  5, 0, 6)
      +quad8.addNode( 5,  0, 0, 7)
      +quad8.addNode( 0,  5, 0, 8)
      +quad8.addFace([1,  2,  3, 4, 5, 6, 7, 8])
      +quad8
      +obj = App.ActiveDocument.addObject("Fem::FemMeshObject","quad8")
      +obj.FemMesh = quad8
      +obj.ViewObject.BackfaceCulling = False
      +obj.Placement.Base = (90,80,0)
      +obj.ViewObject.DisplayMode = "Faces, Wireframe & Nodes"
      +# add Face with element number
      +elemquad8 = Fem.FemMesh()
      +nds = quad8.Nodes
      +for n in nds:
      +    elemquad8.addNode(nds[n].x, nds[n].y, nds[n].z, n)
      +
      +elemquad8.addFace([1,  2,  3,  4, 5, 6, 7, 8], 88)
      +obj = App.ActiveDocument.addObject("Fem::FemMeshObject","elemquad8")
      +obj.FemMesh = elemquad8
      +obj.Placement.Base = (290,80,0)
      +obj.ViewObject.DisplayMode = "Faces, Wireframe & Nodes"
      +obj.ViewObject.BackfaceCulling = False
      +elemquad8.Faces
      +
      +
      +#################################################
      +# Volumes
      +# 4 node tetrahedron --> tetra4 #################
      +tetra4 = Fem.FemMesh()
      +tetra4.addNode( 6, 12, 18, 1)
      +tetra4.addNode( 0,  0, 18, 2)
      +tetra4.addNode(12,  0, 18, 3)
      +tetra4.addNode( 6,  6,  0, 4)
      +tetra4.addVolume([1,  2,  3, 4])
      +tetra4
      +obj = App.ActiveDocument.addObject("Fem::FemMeshObject","tetra4")
      +obj.FemMesh = tetra4
      +obj.Placement.Base = (0,50,0)
      +obj.ViewObject.DisplayMode = "Faces, Wireframe & Nodes"
      +# add Volume with element number
      +elemtetra4 = Fem.FemMesh()
      +nds = tetra4.Nodes
      +for n in nds:
      +    elemtetra4.addNode(nds[n].x, nds[n].y, nds[n].z, n)
      +
      +elemtetra4.addVolume([1,  2,  3, 4], 88)
      +obj = App.ActiveDocument.addObject("Fem::FemMeshObject","elemtetra4")
      +obj.FemMesh = elemtetra4
      +obj.Placement.Base = (200,50,0)
      +obj.ViewObject.DisplayMode = "Faces, Wireframe & Nodes"
      +elemtetra4.Volumes
      +
      +
      +# 10 node tetrahedron --> tetra10 ###############
      +tetra10 = Fem.FemMesh()
      +tetra10.addNode( 6, 12, 18, 1)
      +tetra10.addNode( 0,  0, 18, 2)
      +tetra10.addNode(12,  0, 18, 3)
      +tetra10.addNode( 6,  6,  0, 4)
      +
      +tetra10.addNode( 3,  6, 18, 5)
      +tetra10.addNode( 6,  0, 18, 6)
      +tetra10.addNode( 9,  6, 18, 7)
      +
      +tetra10.addNode( 6,  9,  9, 8)
      +tetra10.addNode( 3,  3,  9, 9)
      +tetra10.addNode( 9,  3,  9,10)
      +tetra10.addVolume([1, 2, 3, 4, 5, 6, 7, 8, 9, 10])
      +tetra10
      +obj = App.ActiveDocument.addObject("Fem::FemMeshObject","tetra10")
      +obj.FemMesh = tetra10
      +obj.Placement.Base = (30,50,0)
      +obj.ViewObject.DisplayMode = "Faces, Wireframe & Nodes"
      +# add Volume with element number
      +elemtetra10 = Fem.FemMesh()
      +nds = tetra10.Nodes
      +for n in nds:
      +    elemtetra10.addNode(nds[n].x, nds[n].y, nds[n].z, n)
      +
      +elemtetra10.addVolume([1,  2,  3, 4, 5, 6, 7, 8, 9, 10], 88)
      +obj = App.ActiveDocument.addObject("Fem::FemMeshObject","elemtetra10")
      +obj.FemMesh = elemtetra10
      +obj.Placement.Base = (230,50,0)
      +obj.ViewObject.DisplayMode = "Faces, Wireframe & Nodes"
      +elemtetra10.Volumes
      +
      +
      +# 8 node Hexahedron --> hexa8 ###################
      +hexa8 = Fem.FemMesh()
      +hexa8.addNode( 0, 10, 10, 1)
      +hexa8.addNode( 0,  0, 10, 2)
      +hexa8.addNode(10,  0, 10, 3)
      +hexa8.addNode(10, 10, 10, 4)
      +hexa8.addNode( 0, 10,  0, 5)
      +hexa8.addNode( 0,  0,  0, 6)
      +hexa8.addNode(10,  0,  0, 7)
      +hexa8.addNode(10, 10,  0, 8)
      +hexa8.addVolume([1, 2, 3, 4, 5, 6, 7, 8])
      +hexa8
      +obj = App.ActiveDocument.addObject("Fem::FemMeshObject","hexa8")
      +obj.FemMesh = hexa8
      +obj.Placement.Base = (60,50,0)
      +obj.ViewObject.DisplayMode = "Faces, Wireframe & Nodes"
      +# add Volume with element number
      +elemhexa8 = Fem.FemMesh()
      +nds = hexa8.Nodes
      +for n in nds:
      +    elemhexa8.addNode(nds[n].x, nds[n].y, nds[n].z, n)
      +
      +elemhexa8.addVolume([1,  2,  3, 4, 5, 6, 7, 8], 88)
      +obj = App.ActiveDocument.addObject("Fem::FemMeshObject","elemhexa8")
      +obj.FemMesh = elemhexa8
      +obj.Placement.Base = (260,50,0)
      +obj.ViewObject.DisplayMode = "Faces, Wireframe & Nodes"
      +elemhexa8.Volumes
      +
      +
      +# 20 node Hexahedron --> hexa20 #################
      +hexa20 = Fem.FemMesh()
      +hexa20.addNode( 0, 10, 10,  1)
      +hexa20.addNode( 0,  0, 10,  2)
      +hexa20.addNode(10,  0, 10,  3)
      +hexa20.addNode(10, 10, 10,  4)
      +hexa20.addNode( 0, 10,  0,  5)
      +hexa20.addNode( 0,  0,  0,  6)
      +hexa20.addNode(10,  0,  0,  7)
      +hexa20.addNode(10, 10,  0,  8)
      +
      +hexa20.addNode( 0,  5, 10,  9)
      +hexa20.addNode( 5,  0, 10, 10)
      +hexa20.addNode(10,  5, 10, 11)
      +hexa20.addNode( 5, 10, 10, 12)
      +
      +hexa20.addNode( 0,  5,  0, 13)
      +hexa20.addNode( 5,  0,  0, 14)
      +hexa20.addNode(10,  5,  0, 15)
      +hexa20.addNode( 5, 10,  0, 16)
      +
      +hexa20.addNode( 0, 10,  5, 17)
      +hexa20.addNode( 0,  0,  5, 18)
      +hexa20.addNode(10,  0,  5, 19)
      +hexa20.addNode(10, 10,  5, 20)
      +hexa20.addVolume([1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19, 20])
      +hexa20
      +obj = App.ActiveDocument.addObject("Fem::FemMeshObject","hexa20")
      +obj.FemMesh = hexa20
      +obj.Placement.Base = (90,50,0)
      +obj.ViewObject.DisplayMode = "Faces, Wireframe & Nodes"
      +# add Volume with element number
      +elemhexa20 = Fem.FemMesh()
      +nds = hexa20.Nodes
      +for n in nds:
      +    elemhexa20.addNode(nds[n].x, nds[n].y, nds[n].z, n)
      +
      +elemhexa20.addVolume([1,  2,  3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19, 20], 88)
      +obj = App.ActiveDocument.addObject("Fem::FemMeshObject","elemhexa20")
      +obj.FemMesh = elemhexa20
      +obj.Placement.Base = (290,50,0)
      +obj.ViewObject.DisplayMode = "Faces, Wireframe & Nodes"
      +elemhexa20.Volumes
      +
      +
      +# 6 node pentahedron --> penta6 #################
      +penta6 = Fem.FemMesh()
      +penta6.addNode(10,10,10, 1)
      +penta6.addNode( 0, 0,10, 2)
      +penta6.addNode(20, 0,10, 3)
      +penta6.addNode(10,10, 0, 4)
      +penta6.addNode( 0, 0, 0, 5)
      +penta6.addNode(20, 0, 0, 6)
      +penta6.addVolume([1, 2, 3, 4, 5, 6])
      +penta6
      +obj = App.ActiveDocument.addObject("Fem::FemMeshObject","penta6")
      +obj.FemMesh = penta6
      +obj.Placement.Base = (0,0,0)
      +obj.ViewObject.DisplayMode = "Faces, Wireframe & Nodes"
      +# add Volume with element number
      +elempenta6 = Fem.FemMesh()
      +nds = penta6.Nodes
      +for n in nds:
      +    elempenta6.addNode(nds[n].x, nds[n].y, nds[n].z, n)
      +
      +elempenta6.addVolume([ 1,  2,  3, 4, 5, 6], 88)
      +obj = App.ActiveDocument.addObject("Fem::FemMeshObject","elempenta6")
      +obj.FemMesh = elempenta6
      +obj.Placement.Base = (200,0,0)
      +obj.ViewObject.DisplayMode = "Faces, Wireframe & Nodes"
      +elempenta6.Volumes
      +
      +
      +# 15 node pentahedron --> penta15 ###############
      +penta15 = Fem.FemMesh()
      +penta15.addNode(10,10,10, 1)
      +penta15.addNode( 0, 0,10, 2)
      +penta15.addNode(20, 0,10, 3)
      +penta15.addNode(10,10, 0, 4)
      +penta15.addNode( 0, 0, 0, 5)
      +penta15.addNode(20, 0, 0, 6)
      +
      +penta15.addNode( 5, 5,10, 7)
      +penta15.addNode(10, 0,10, 8)
      +penta15.addNode(15, 5,10, 9)
      +
      +penta15.addNode( 5, 5, 0,10)
      +penta15.addNode(10, 0, 0,11)
      +penta15.addNode(15, 5, 0,12)
      +
      +penta15.addNode(10,10, 5,13)
      +penta15.addNode( 0, 0, 5,14)
      +penta15.addNode(20, 0, 5,15)
      +penta15.addVolume([1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15])
      +penta15
      +obj = App.ActiveDocument.addObject("Fem::FemMeshObject","penta15")
      +obj.FemMesh = penta15
      +obj.Placement.Base = (40,0,0)
      +obj.ViewObject.DisplayMode = "Faces, Wireframe & Nodes"
      +# add Volume with element number
      +elempenta15 = Fem.FemMesh()
      +nds = penta15.Nodes
      +for n in nds:
      +    elempenta15.addNode(nds[n].x, nds[n].y, nds[n].z, n)
      +
      +elempenta15.addVolume([1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15], 88)
      +obj = App.ActiveDocument.addObject("Fem::FemMeshObject","elempenta15")
      +obj.FemMesh = elempenta15
      +obj.Placement.Base = (240,0,0)
      +obj.ViewObject.DisplayMode = "Faces, Wireframe & Nodes"
      +elempenta15.Volumes
      +
      +
      +# 5 node pyramid --> pyra5 ######################
      +pyra5 = Fem.FemMesh()
      +pyra5.addNode( 0,20, 0, 1)
      +pyra5.addNode(20,20, 0, 2)
      +pyra5.addNode(20, 0, 0, 3)
      +pyra5.addNode( 0, 0, 0, 4)
      +pyra5.addNode(10,10,10, 5)
      +pyra5.addVolume([1, 2, 3, 4, 5])
      +pyra5
      +obj = App.ActiveDocument.addObject("Fem::FemMeshObject","pyra5")
      +obj.FemMesh = pyra5
      +obj.Placement.Base = (80,0,0)
      +obj.ViewObject.DisplayMode = "Faces, Wireframe & Nodes"
      +# add Volume with element number
      +elempyra5 = Fem.FemMesh()
      +nds = pyra5.Nodes
      +for n in nds:
      +    elempyra5.addNode(nds[n].x, nds[n].y, nds[n].z, n)
      +
      +elempyra5.addVolume([1,  2,  3, 4, 5], 88)
      +obj = App.ActiveDocument.addObject("Fem::FemMeshObject","elempyra5")
      +obj.FemMesh = elempyra5
      +obj.Placement.Base = (280,0,0)
      +obj.ViewObject.DisplayMode = "Faces, Wireframe & Nodes"
      +elempyra5.Volumes
      +
      +
      +# 13 node pyramid --> pyra13 ####################
      +pyra13 = Fem.FemMesh()
      +pyra13.addNode( 0,20, 0, 1)
      +pyra13.addNode(20,20, 0, 2)
      +pyra13.addNode(20, 0, 0, 3)
      +pyra13.addNode( 0, 0, 0, 4)
      +pyra13.addNode(10,10,10, 5)
      +
      +pyra13.addNode(10,20, 0, 6)
      +pyra13.addNode(20,10, 0, 7)
      +pyra13.addNode(10, 0, 0, 8)
      +pyra13.addNode( 0,10, 0, 9)
      +
      +pyra13.addNode( 5,15, 5,10)
      +pyra13.addNode(15,15, 5,11)
      +pyra13.addNode(15, 5, 5,12)
      +pyra5 = Fem.FemMesh()
      +pyra13.addNode( 5, 5, 5,13)
      +pyra13.addVolume([1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13])
      +pyra13
      +obj = App.ActiveDocument.addObject("Fem::FemMeshObject","pyra13")
      +obj.FemMesh = pyra13
      +obj.Placement.Base = (120,0,0)
      +obj.ViewObject.DisplayMode = "Faces, Wireframe & Nodes"
      +# add Volume with element number
      +elempyra13 = Fem.FemMesh()
      +nds = pyra13.Nodes
      +for n in nds:
      +    elempyra13.addNode(nds[n].x, nds[n].y, nds[n].z, n)
      +
      +elempyra13.addVolume([1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13], 88)
      +obj = App.ActiveDocument.addObject("Fem::FemMeshObject","elempyra13")
      +obj.FemMesh = elempyra13
      +obj.Placement.Base = (320,0,0)
      +obj.ViewObject.DisplayMode = "Faces, Wireframe & Nodes"
      +elempyra13.Volumes 
      +

      Fem Workbench +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/FEM_MeshBoundaryLayer.html b/localwiki/FEM_MeshBoundaryLayer.html new file mode 100644 index 0000000..b96e6f2 --- /dev/null +++ b/localwiki/FEM_MeshBoundaryLayer.html @@ -0,0 +1,67 @@ +FEM MeshBoundaryLayer

      FEM MeshBoundaryLayer

      + +

      +

      This documentation is not finished. Please help and contribute documentation. +

      See Draft ShapeString for good documented Command. Gui Command gives an overview over commands. And see List of Commands for other commands. +

      Go to Help FreeCAD to contribute. +

      +
      + + + + + + + + + + + + + + + + + + + + +
      +

      Official icon not found FEM MeshBoundaryLayer

      +
      Menu location +
      Mesh → FEM Mesh boundary layer +
      Workbenches +
      FEM +
      Default shortcut +
      +
      See also +
      FEM tutorial +

      Contents

      + +
      + +
      +


      +


      +

      ToDo +


      +
      +

      +
      +


      +

      + + +
      + +
      +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/FEM_MeshClear.html b/localwiki/FEM_MeshClear.html new file mode 100644 index 0000000..84aa54c --- /dev/null +++ b/localwiki/FEM_MeshClear.html @@ -0,0 +1,67 @@ +FEM MeshClear

      FEM MeshClear

      + +

      +

      This documentation is not finished. Please help and contribute documentation. +

      See Draft ShapeString for good documented Command. Gui Command gives an overview over commands. And see List of Commands for other commands. +

      Go to Help FreeCAD to contribute. +

      +
      + + + + + + + + + + + + + + + + + + + + +
      +

      Official icon not found FEM MeshClear

      +
      Menu location +
      Context menue on mesh object → FEM mesh clear +
      Workbenches +
      FEM +
      Default shortcut +
      +
      See also +
      FEM tutorial +

      Contents

      + +
      + +
      +


      +


      +

      ToDo +


      +
      +

      +
      +


      +

      + + +
      + +
      +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/FEM_MeshGmshFromShape.html b/localwiki/FEM_MeshGmshFromShape.html new file mode 100644 index 0000000..d22a924 --- /dev/null +++ b/localwiki/FEM_MeshGmshFromShape.html @@ -0,0 +1,74 @@ +FEM MeshGmshFromShape

      FEM MeshGmshFromShape

      + +
      +

      This documentation is not finished. Please help and contribute documentation. +

      See Draft ShapeString for good documented Command. Gui Command gives an overview over commands. And see List of Commands for other commands. +

      Go to Help FreeCAD to contribute. +

      +
      + + + + + + + + + + + + + + + + + + + + +
      +

      FEM MeshGmshFromShape.png FEM MeshGmshFromShape

      +
      Menu location +
      Mesh → FEM mesh from shape by Gmsh +
      Workbenches +
      FEM +
      Default shortcut +
      None +
      See also +
      FEM tutorial +

      + +
      +


      +

      +

      Description

      +

      For a finite elements analysis the geometry needs to be discretized into a FEM_Mesh. This command uses gmsh (which needs to be installed on the system) for calculating the mesh. +

      +

      How to use

      +
      1. Select the shape you want to analyze. For volume FEM this needs to be a solid or compsolid. A compsolid is necessary if your part is made from multiple materials. (A compsolid can be created with the BooleanFragments command.) -- For shell and beam FEM somebody needs to fill in the details here.
      2. +
      3. Press the FEM MeshGmshFromShape.png FEM mesh from shape by GMSH button
      4. +
      5. Optionally edit the minimal and maximal element size. (Autodetection works fine unless you apply complicated boundary conditions.)
      6. +
      7. Click the Apply button and wait for the computation of the mesh to complete
      8. +
      9. Close the task. You now should see a new FEMMeshGMSH object in your active analysis container.
      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/FEM_MeshGroup.html b/localwiki/FEM_MeshGroup.html new file mode 100644 index 0000000..77f84d6 --- /dev/null +++ b/localwiki/FEM_MeshGroup.html @@ -0,0 +1,67 @@ +FEM MeshGroup

      FEM MeshGroup

      + +

      +

      This documentation is not finished. Please help and contribute documentation. +

      See Draft ShapeString for good documented Command. Gui Command gives an overview over commands. And see List of Commands for other commands. +

      Go to Help FreeCAD to contribute. +

      +
      + + + + + + + + + + + + + + + + + + + + +
      +

      FEM MeshGroup.png FEM MeshGroup

      +
      Menu location +
      Mesh → FEM Mesh group +
      Workbenches +
      FEM +
      Default shortcut +
      +
      See also +
      FEM tutorial +

      Contents

      + +
      + +
      +


      +


      +

      ToDo +


      +
      +

      +
      +


      +

      + + +
      + +
      +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/FEM_MeshNetgenFromShape.html b/localwiki/FEM_MeshNetgenFromShape.html new file mode 100644 index 0000000..6b59e13 --- /dev/null +++ b/localwiki/FEM_MeshNetgenFromShape.html @@ -0,0 +1,67 @@ +FEM MeshNetgenFromShape

      FEM MeshNetgenFromShape

      + +
      +

      This documentation is not finished. Please help and contribute documentation. +

      See Draft ShapeString for good documented Command. Gui Command gives an overview over commands. And see List of Commands for other commands. +

      Go to Help FreeCAD to contribute. +

      +
      + + + + + + + + + + + + + + + + + + + + +
      +

      FEM MeshNetgenFromShape.png FEM MeshNetgenFromShape

      +
      Menu location +
      FEM → FEM mesh from shape by Netgen +
      Workbenches +
      FEM +
      Default shortcut +
      +
      See also +
      FEM tutorial +

      + +
      +


      +


      +

      ToDo +


      +
      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/FEM_MeshPrintInfo.html b/localwiki/FEM_MeshPrintInfo.html new file mode 100644 index 0000000..6334d39 --- /dev/null +++ b/localwiki/FEM_MeshPrintInfo.html @@ -0,0 +1,67 @@ +FEM MeshPrintInfo

      FEM MeshPrintInfo

      + +

      +

      This documentation is not finished. Please help and contribute documentation. +

      See Draft ShapeString for good documented Command. Gui Command gives an overview over commands. And see List of Commands for other commands. +

      Go to Help FreeCAD to contribute. +

      +
      + + + + + + + + + + + + + + + + + + + + +
      +

      Official icon not found FEM MeshPrintInfo

      +
      Menu location +
      Context menue on mesh object → FEM mesh print info +
      Workbenches +
      FEM +
      Default shortcut +
      +
      See also +
      FEM tutorial +

      Contents

      + +
      + +
      +


      +


      +

      ToDo +


      +
      +

      +
      +


      +

      + + +
      + +
      +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/FEM_MeshRegion.html b/localwiki/FEM_MeshRegion.html new file mode 100644 index 0000000..ffb818b --- /dev/null +++ b/localwiki/FEM_MeshRegion.html @@ -0,0 +1,67 @@ +FEM MeshRegion

      FEM MeshRegion

      + +

      +

      This documentation is not finished. Please help and contribute documentation. +

      See Draft ShapeString for good documented Command. Gui Command gives an overview over commands. And see List of Commands for other commands. +

      Go to Help FreeCAD to contribute. +

      +
      + + + + + + + + + + + + + + + + + + + + +
      +

      FEM MeshRegion.png FEM MeshRegion

      +
      Menu location +
      Mesh → FEM Mesh region +
      Workbenches +
      FEM +
      Default shortcut +
      +
      See also +
      FEM tutorial +

      Contents

      + +
      + +
      +


      +


      +

      ToDo +


      +
      +

      +
      +


      +

      + + +
      + +
      +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/FEM_Mesh_CalculiX.html b/localwiki/FEM_Mesh_CalculiX.html new file mode 100644 index 0000000..917954b --- /dev/null +++ b/localwiki/FEM_Mesh_CalculiX.html @@ -0,0 +1,214 @@ +FEM Mesh CalculiX

      FEM Mesh CalculiX

      + +
      + +

      FEM Element Types CalculiX

      +

      For detailed information about FreeCAD FEM Element Types checkt the FEM_Mesh and FEM_Element_Types Wiki pages. +

      +

      Segment element

      + + + + + + + + + + + + + + + + + + + +
      Segment element from FreeCAD to CalculiX -- node assignment +
      seg2 FreeCAD nodes seg3 FreeCAD nodes +
      Seg2.png Seg3--fc.png +
      seg2 (B31) CalculiX nodes seg3 (B32) CalculiX nodes +
      Seg2.png Seg3--ccx.png +
      FreeCAD --> CalculiX, Nodes +
      N1, N2 N1, N3, N2 +
      +


      +

      Triangle element

      + + + + + + + + + + + + + + + + + + + +
      Triangle element from FreeCAD to CalculiX -- node assignment +
      tria3 FreeCAD nodes tria6 FreeCAD nodes +
      Tria3--fc.png Tria6--fc.png +
      tria3 (S3) CalculiX nodes tria6 (S6) CalculiX nodes +
      Tria3--ccx.png Tria6--ccx.png +
      FreeCAD --> CalculiX, Nodes +
      N1, N2, N3 N1, N2, N3, N4, N5, N6 +
      +


      +

      Quadratic element

      + + + + + + + + + + + + + + + + + + + +
      Quadratic element from FreeCAD to CalculiX -- node assignment +
      quad4 FreeCAD nodes quad8 FreeCAD nodes +
      Quad4--fc.png Quad8--fc.png +
      quad4 (S4) CalculiX nodes quad8 (S8) CalculiX nodes +
      Quad4--ccx.png Quad8--ccx.png +
      FreeCAD --> CalculiX, Nodes +
      N1, N2, N3, N4 N1, N2, N3, N4, N5, N6, N7, N8 +
      +


      +

      Tetrahedron element

      +

      The following node order is not implemented ! TODO: verify node order (do not forget getccxVolumesByFace()). +

      + + + + + + + + + + + + + + + + + + + +
      Tetrahedron element from FreeCAD to CalculiX -- node assignment +
      tetra4 FreeCAD nodes tetra10 FreeCAD nodes +
      Tetra4--fc.png Tetra10--fc.png +
      tetra4 (C3D4) CalculiX nodes tetra10 (C3D10) CalculiX nodes +
      Tetra4--ccx.png Tetra10--ccx.png +
      FreeCAD --> CalculiX, Nodes +
      N2, N3, N4, N1 N2, N3, N4, N1, N6, N10, N9, N5, N7, N8 +
      +


      +

      Hexahedron element

      + + + + + + + + + + + + + + + + + + + +
      Hexahedron element from FreeCAD to CalculiX -- node assignment +
      hexa8 FreeCAD nodes hexa20 FreeCAD nodes +
      Hexa8--fc.png Hexa20--fc.png +
      hexa8 (C3D8) CalculiX nodes hexa20 (C3D20) CalculiX nodes +
      Hexa8--ccx.png Hexa20--ccx.png +
      FreeCAD --> CalculiX, Nodes +
      N6, N7, N8, N5, N2, N3, N4, N1 N6, N7, N8, N5, N2, N3, N4, N1 , N14, N15, N16, N13, N10, N11, N12, N9, N18, N19, N20, N17 +
      +


      +

      Pentahedron element

      + + + + + + + + + + + + + + + + + + + +
      Pentahedron element from FreeCAD to CalculiX -- node assignment +
      penta6 FreeCAD nodes penta15 FreeCAD nodes +
      Penta6--fc.png Penta15--fc.png +
      penta6 (C3D6) CalculiX nodes penta15 (C3D15) CalculiX nodes +
      Penta6--ccx.png Penta15--ccx.png +
      FreeCAD --> CalculiX, Nodes +
      N5, N6, N4, N2, N3, N1 N5, N6, N4, N2, N3, N1, N11, N12, N10, N8, N9, N7, N14, N15, N13 +
      +


      +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/FEM_Module.html b/localwiki/FEM_Module.html new file mode 100644 index 0000000..c81cf7e --- /dev/null +++ b/localwiki/FEM_Module.html @@ -0,0 +1,135 @@ +FEM Module

      FEM Module

      + +

      The FEM Workbench provides modern Finite Element Analysis (FEA) workflow for FreeCAD. Mainly this means all tools to make an Finite Element Analysis are combined in one GUI. +

      FemWorkbench.jpg
      +

      The steps to do a FEA in FreeCAD FEM Workbench GUI are: +

      +
      • Preprocessing +
        • Modeling the geometry, in which FreeCAD is already a nearly full-grown software.
        • +
        • Create an Analysis: +
          • Create an FEM Mesh out of the geometrical model.
          • +
          • Add Constraints such as loads and support fixes to the analysis model.
          • +
          • Add a Material to the analysis model
      • +
      • Solving +
        • Solve the system of equations from within the FreeCAD GUI.
      • +
      • Postprocessing +
        • View Results inside FreeCAD GUI.
      +

      The above mainly describes how a FEA analysis is done inside FreeCAD FEM Workbench. For further documentation refer to the GUI Tools described later here. +

      As of FreeCAD version 0.15 the FEM-Module can be used on Windows, Mac OSX and Linux platforms. Since FEM Workbench makes use of external software, the amount of manual intervention until the FEM workbench is ready to use will depend on the OS that you are using. Check out FEM Install. +

      +

      Tools

      + +


      +

      + +


      +

      + +


      +

      + +


      +

      + +


      +

      +
      • Preferences Menu +
      +

      Tutorials

      +

      Tutorial 1 FEM CalculiX Cantilever 3D +

      Tutorial 2 FEM Tutorial +

      Tutorial 3 FEM Tutorial Python +

      Tutorial 4 FEM Shear of a Composite Block +

      Coupled thermal mechanical analysis tutorials PDF's +

      Video Tutorial 1 Forum post with you tube link +

      Video Tutorial 2 Forum post with you tube link +

      Further video Tutorials Forum post with you tube link +

      + +

      Links

      +

      FEM Install for a detailed description how to set up a working FEM Module. +

      FEM Mesh for further Information about the FEM Mesh in FreeCAD +

      FEM CalculiX for further Information about the interface between FEM Module and the current Solver CalculiX +

      FEM Project for more detailed informations about the Units, Limitations and the Development of FEM Module. +

      + +


      +

      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/FEM_PostApplyChanges.html b/localwiki/FEM_PostApplyChanges.html new file mode 100644 index 0000000..78f4373 --- /dev/null +++ b/localwiki/FEM_PostApplyChanges.html @@ -0,0 +1,67 @@ +FEM PostApplyChanges

      FEM PostApplyChanges

      + +

      +

      This documentation is not finished. Please help and contribute documentation. +

      See Draft ShapeString for good documented Command. Gui Command gives an overview over commands. And see List of Commands for other commands. +

      Go to Help FreeCAD to contribute. +

      +
      + + + + + + + + + + + + + + + + + + + + +
      +

      FEM PostApplyChanges.png FEM PostApplyChanges

      +
      Menu location +
      Results → apply changes to pipeline +
      Workbenches +
      FEM +
      Default shortcut +
      +
      See also +
      FEM tutorial +

      Contents

      + +
      + +
      +


      +


      +

      ToDo +


      +
      +

      +
      +


      +

      + + +
      + +
      +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/FEM_PostApplyChanges.png b/localwiki/FEM_PostApplyChanges.png new file mode 100644 index 0000000..9f0059c Binary files /dev/null and b/localwiki/FEM_PostApplyChanges.png differ diff --git a/localwiki/FEM_PostCreateClipFilter.html b/localwiki/FEM_PostCreateClipFilter.html new file mode 100644 index 0000000..7c19bbb --- /dev/null +++ b/localwiki/FEM_PostCreateClipFilter.html @@ -0,0 +1,67 @@ +FEM PostCreateClipFilter

      FEM PostCreateClipFilter

      + +

      +

      This documentation is not finished. Please help and contribute documentation. +

      See Draft ShapeString for good documented Command. Gui Command gives an overview over commands. And see List of Commands for other commands. +

      Go to Help FreeCAD to contribute. +

      +
      + + + + + + + + + + + + + + + + + + + + +
      +

      FEM PostCreateClipFilter.png FEM PostCreateClipFilter

      +
      Menu location +
      Results → clip filter +
      Workbenches +
      FEM +
      Default shortcut +
      +
      See also +
      FEM tutorial +

      + +
      +


      +


      +

      ToDo +


      +
      +

      +
      +


      +

      + + +
      + +
      +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/FEM_PostCreateCutFilter.html b/localwiki/FEM_PostCreateCutFilter.html new file mode 100644 index 0000000..7fad933 --- /dev/null +++ b/localwiki/FEM_PostCreateCutFilter.html @@ -0,0 +1,67 @@ +FEM PostCreateCutFilter

      FEM PostCreateCutFilter

      + +

      +

      This documentation is not finished. Please help and contribute documentation. +

      See Draft ShapeString for good documented Command. Gui Command gives an overview over commands. And see List of Commands for other commands. +

      Go to Help FreeCAD to contribute. +

      +
      + + + + + + + + + + + + + + + + + + + + +
      +

      FEM PostCreateCutFilter.png FEM PostCreateCutFilter

      +
      Menu location +
      Results → Cut filter +
      Workbenches +
      FEM +
      Default shortcut +
      +
      See also +
      FEM tutorial +

      + +
      +


      +


      +

      ToDo +


      +
      +

      +
      +


      +

      + + +
      + +
      +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/FEM_PostCreateDataAlongLineFilter.html b/localwiki/FEM_PostCreateDataAlongLineFilter.html new file mode 100644 index 0000000..8653cc9 --- /dev/null +++ b/localwiki/FEM_PostCreateDataAlongLineFilter.html @@ -0,0 +1,67 @@ +FEM PostCreateDataAlongLineFilter

      FEM PostCreateDataAlongLineFilter

      + +

      +

      This documentation is not finished. Please help and contribute documentation. +

      See Draft ShapeString for good documented Command. Gui Command gives an overview over commands. And see List of Commands for other commands. +

      Go to Help FreeCAD to contribute. +

      +
      + + + + + + + + + + + + + + + + + + + + +
      +

      Official icon not found FEM PostCreateDataAlongLineFilter

      +
      Menu location +
      Results → Data along line filter +
      Workbenches +
      FEM +
      Default shortcut +
      +
      See also +
      FEM tutorial +

      + +
      +


      +


      +

      ToDo +


      +
      +

      +
      +


      +

      + + +
      + +
      +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/FEM_PostCreateDataAtPointFilter.html b/localwiki/FEM_PostCreateDataAtPointFilter.html new file mode 100644 index 0000000..744e77c --- /dev/null +++ b/localwiki/FEM_PostCreateDataAtPointFilter.html @@ -0,0 +1,67 @@ +FEM PostCreateDataAtPointFilter

      FEM PostCreateDataAtPointFilter

      + +

      +

      This documentation is not finished. Please help and contribute documentation. +

      See Draft ShapeString for good documented Command. Gui Command gives an overview over commands. And see List of Commands for other commands. +

      Go to Help FreeCAD to contribute. +

      +
      + + + + + + + + + + + + + + + + + + + + +
      +

      Official icon not found FEM PostCreateDataAtPointFilter

      +
      Menu location +
      Results → Data at point filter +
      Workbenches +
      FEM +
      Default shortcut +
      +
      See also +
      FEM tutorial +

      + +
      +


      +


      +

      ToDo +


      +
      +

      +
      +


      +

      + + +
      + +
      +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/FEM_PostCreateFunctions.html b/localwiki/FEM_PostCreateFunctions.html new file mode 100644 index 0000000..adfb3d6 --- /dev/null +++ b/localwiki/FEM_PostCreateFunctions.html @@ -0,0 +1,67 @@ +FEM PostCreateFunctions

      FEM PostCreateFunctions

      + +

      +

      This documentation is not finished. Please help and contribute documentation. +

      See Draft ShapeString for good documented Command. Gui Command gives an overview over commands. And see List of Commands for other commands. +

      Go to Help FreeCAD to contribute. +

      +
      + + + + + + + + + + + + + + + + + + + + +
      +

      FEM PostCreateFunctions.png FEM PostCreateFunctions

      +
      Menu location +
      Results → Filter Functions +
      Workbenches +
      FEM +
      Default shortcut +
      +
      See also +
      FEM tutorial +

      + +
      +


      +


      +

      ToDo +


      +
      +

      +
      +


      +

      + + +
      + +
      +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/FEM_PostCreateLinearizedStressesFilter.html b/localwiki/FEM_PostCreateLinearizedStressesFilter.html new file mode 100644 index 0000000..ebfd6a7 --- /dev/null +++ b/localwiki/FEM_PostCreateLinearizedStressesFilter.html @@ -0,0 +1,67 @@ +FEM PostCreateLinearizedStressesFilter

      FEM PostCreateLinearizedStressesFilter

      + +

      +

      This documentation is not finished. Please help and contribute documentation. +

      See Draft ShapeString for good documented Command. Gui Command gives an overview over commands. And see List of Commands for other commands. +

      Go to Help FreeCAD to contribute. +

      +
      + + + + + + + + + + + + + + + + + + + + +
      +

      Official icon not found FEM PostCreateLinearizedStressesFilter

      +
      Menu location +
      Results → Linearized stresses filter +
      Workbenches +
      FEM +
      Default shortcut +
      +
      See also +
      FEM tutorial +

      + +
      +


      +


      +

      ToDo +


      +
      +

      +
      +


      +

      + + +
      + +
      +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/FEM_PostCreateScalarClipFilter.html b/localwiki/FEM_PostCreateScalarClipFilter.html new file mode 100644 index 0000000..782c868 --- /dev/null +++ b/localwiki/FEM_PostCreateScalarClipFilter.html @@ -0,0 +1,67 @@ +FEM PostCreateScalarClipFilter

      FEM PostCreateScalarClipFilter

      + +

      +

      This documentation is not finished. Please help and contribute documentation. +

      See Draft ShapeString for good documented Command. Gui Command gives an overview over commands. And see List of Commands for other commands. +

      Go to Help FreeCAD to contribute. +

      +
      + + + + + + + + + + + + + + + + + + + + +
      +

      FEM PostCreateScalarClipFilter.png FEM PostCreateScalarClipFilter

      +
      Menu location +
      Results → scalar clip filter +
      Workbenches +
      FEM +
      Default shortcut +
      +
      See also +
      FEM tutorial +

      + +
      +


      +


      +

      ToDo +


      +
      +

      +
      +


      +

      + + +
      + +
      +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/FEM_PostCreateWarpVectorFilter.html b/localwiki/FEM_PostCreateWarpVectorFilter.html new file mode 100644 index 0000000..14e1975 --- /dev/null +++ b/localwiki/FEM_PostCreateWarpVectorFilter.html @@ -0,0 +1,67 @@ +FEM PostCreateWarpVectorFilter

      FEM PostCreateWarpVectorFilter

      + +

      +

      This documentation is not finished. Please help and contribute documentation. +

      See Draft ShapeString for good documented Command. Gui Command gives an overview over commands. And see List of Commands for other commands. +

      Go to Help FreeCAD to contribute. +

      +
      + + + + + + + + + + + + + + + + + + + + +
      +

      FEM PostCreateWarpVectorFilter.png FEM PostCreateWarpVectorFilter

      +
      Menu location +
      Results → Wrap vector filter +
      Workbenches +
      FEM +
      Default shortcut +
      +
      See also +
      FEM tutorial +

      + +
      +


      +


      +

      ToDo +


      +
      +

      +
      +


      +

      + + +
      + +
      +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/FEM_PostPipelineFromResult.html b/localwiki/FEM_PostPipelineFromResult.html new file mode 100644 index 0000000..e07aea1 --- /dev/null +++ b/localwiki/FEM_PostPipelineFromResult.html @@ -0,0 +1,90 @@ +FEM PostPipelineFromResult

      FEM PostPipelineFromResult

      + +

      +

      This documentation is not finished. Please help and contribute documentation. +

      See Draft ShapeString for good documented Command. Gui Command gives an overview over commands. And see List of Commands for other commands. +

      Go to Help FreeCAD to contribute. +

      +
      + + + + + + + + + + + + + + + + + + + + +
      +

      FEM PostPipelineFromResult.png FEM PostPipelineFromResult

      +
      Menu location +
      Results → post pipeline from result +
      Workbenches +
      FEM +
      Default shortcut +
      +
      See also +
      FEM tutorial +

      + +
      +


      +


      +

      +

      Description

      +

      Pipeline is a result object, which creates a new graphical representation of FEM analysis results on the analysed part. It adds color scale and more display options. +

      +

      How to use

      +
      • You need a valid result object in the FEM Analysis.png Analysis container, such as CalculiX_static_results.
      • +
      • Select the result object
      • +
      • Click FEM PostPipelineFromResult.png button, or click on menu Results and item Post Pipeline from results. A new object called "Pipeline" will be added to your document; note if will appear outside of the Analysis container.
      • +
      • Double click the new Pipeline object in the Model tree and select type of properties to display. Typical settings are: Mode: Select Surface, Field: I.e. Von Mises stress Pipeline.PNG +
        • Mode: How to draw the results
        • +
        • Field: Which result property to draw
        • +
        • Vector: If a property is a vector, you might restrict the data to an axis (X, Y, Z) or select Magnitude to use the vector value.
      • +
      • If you see no model in the graphical area, go to EditPreferences, select Display category and check a checkbox Enagle backlight color
      • +
      • If you double-click the scale, you can modify display properties.
      +

      SIMTUT 05.PNG +

      +
        • Gradient: You can select reversed order of the default color gradient or either Black-White or White-Black.
        • +
        • Parameter range: Minimum and maximum values are filled-in automatically, when you select a property to evaluate on the Pipeline object; you can modify them, however make sure you know what you are doing. You can also amend number of displayed labels and number of decimal places to be displayed.
      +

      Limitations

      +

      Once again, note, that the Pipeline representation of the results (called VTK) on the displayed part is different from the color gradient results which are visible when you finish solution. Values in the gradient scale cannot be applied to the solution result object. +

      This tool is available in version 0.17 +


      +
      +

      +
      +


      +

      + + +
      + +
      +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/FEM_ResultShow.html b/localwiki/FEM_ResultShow.html new file mode 100644 index 0000000..2ccc171 --- /dev/null +++ b/localwiki/FEM_ResultShow.html @@ -0,0 +1,68 @@ +FEM ResultShow

      FEM ResultShow

      + +
      +

      This documentation is not finished. Please help and contribute documentation. +

      See Draft ShapeString for good documented Command. Gui Command gives an overview over commands. And see List of Commands for other commands. +

      Go to Help FreeCAD to contribute. +

      +
      + + + + + + + + + + + + + + + + + + + + +
      +

      FEM ShowResult.png FEM ShowResult

      +
      Menu location +
      Results → Show result +
      Workbenches +
      FEM +
      Default shortcut +
      S,R +
      See also +
      FEM tutorial +

      + +
      +


      +


      +

      +

      Description

      +

      Use

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/FEM_ResultsPurge.html b/localwiki/FEM_ResultsPurge.html new file mode 100644 index 0000000..25218be --- /dev/null +++ b/localwiki/FEM_ResultsPurge.html @@ -0,0 +1,69 @@ +FEM ResultsPurge

      FEM ResultsPurge

      + +
      +

      This documentation is not finished. Please help and contribute documentation. +

      See Draft ShapeString for good documented Command. Gui Command gives an overview over commands. And see List of Commands for other commands. +

      Go to Help FreeCAD to contribute. +

      +
      + + + + + + + + + + + + + + + + + + + + +
      +

      FEM PurgeResults.png FEM PurgeResults

      +
      Menu location +
      Results → Purge results +
      Workbenches +
      FEM +
      Default shortcut +
      S,S +
      See also +
      FEM tutorial +

      + +
      +


      +


      +


      +

      +

      Description

      +

      Use

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/FEM_Shear_of_a_Composite_Block.html b/localwiki/FEM_Shear_of_a_Composite_Block.html new file mode 100644 index 0000000..dfd2d96 --- /dev/null +++ b/localwiki/FEM_Shear_of_a_Composite_Block.html @@ -0,0 +1,158 @@ +FEM Shear of a Composite Block

      FEM Shear of a Composite Block

      + +
      + + + + + + + + + + + + + + + + + + + + + + + + + + + +
      +

      Base ExampleCommandModel.png Tutorial

      +
      Topic +
      Finite Element Analysis +
      Level +
      Beginner/Intermediate +
      Time to complete +
      30 minutes +
      Author +
      HarryvL +
      FreeCAD version +
      0.17.12960 or above +
      Example File(s) +
      +

      + +
      +


      +

      +

      Introduction

      +

      In this tutorial we analyse the shear deformation of a composite block consisting of a stiff core embedded in a soft matrix. It demonstrates the use of BooleanFragments and CompoundFilter to create solids for the block and the matrix from two concentric cubes. This workflow ensures that separate MeshRegions, Materials and Boundary Conditions can be defined for the block and the surrounding matrix. To select internal regions we make us of the macro by Markus Hovorka (https://github.com/drhooves/SelectionTools). The CalculiX results clearly show the effect of the stiff core on the response of the composite block. +

      +

      Geometry

      +

      First we create two concentric cubes, one size 10mm and the other size 5mm. This is done in the workbench "Part". By default the cube is placed at the origin [0, 0, 0], so the smaller cube needs to be scaled down and shifted by changing the settings in the Data tab of the property panel. To make the core visible, the Transparency of the outer block is set to 50 in the View tab of the property panel. The result is shown below. +


      +Pic1.png +


      +Next highlight the two blocks in the tree and create a BooleanFragments object (Part > Split > Boolean Fragments). In the "Property Window - Data Tab" change Mode to CompSolid. Now highlight the BooleanFragments in the Object tree and create a CompoundFilter (Part > Compound > Compound Filter). +


      +Pic2.png +

      +

      Mesh and Mesh Regions

      +

      From workbench FEM we create an Analysis container. This will contain all definitions required for the CalculiX analysis and its results. Note that this Analysis container needs to be activated (right-click and select "Activate analysis") whenever re-loading the file or after switching back from other analyses. To start the meshing process, highlight the CompoundFilter in the Object Tree and activate the meshing dialog "Mesh > FEM mesh from shape by Gmsh". Leave the dialog by clicking OK. +

      A Mesh object is now created in the Object Tree. Highlight this object and create a Mesh Region object via "Mesh > FEM mesh region". Open the dialog box for this Mesh Region by double clicking and tick the radio button for Solid. Next click the "Add Reference" button and select the CompoundFilter object in the Graphical Window. This should add a reference to "CompoundFilter:Solid1" in the object list of the Mesh Region. Finally specify the maximum element size for this region (5mm in the current analysis). Leave the dialog by clicking OK. +


      +Pic3.png +


      +Next create a new Mesh object as above and use the selection macro (shortcut S, E) to select the Cube_Core object in the Graphical Window. This time the reference list should show "CompoundFilter:Solid2", as below. We chose a maximum element size of 1mm. +

      Note1: Selection of "CompoundFilter:Solid2" requires selection of one of its faces. +

      Note2: If you have difficulty selecting "CompoundFilter:Solid2" it may be because you forgot to set the BooleanFragments mode to CompSolid. +


      +Pic4.png +

      +

      Material Assignment

      +

      Material is assigned to Mesh Regions via a SolidMaterial object. In this tutorial we assign two materials; one for the Matrix and one for the Core. +


      +Start by selecting the CompoundFilter in the object tree. Then create a SolidMaterial object via menu option "Model > FEM material for solid". Open the dialog and tick the radio button for Solid, press "Add Reference" and select the CompoundFilter object from the Graphical Window. The reference list should now show "CompoundFilter:Solid1", as before. We assign ABS material to the Matrix, with a Young's modules approximately 1% that of steel. +


      +Pic5.png +


      +Repeat the above procedure for the Core ("CompoundFilter:Solid2") with the help of the selection macro. This time we assign CalculiX-Steel, which is much stiffer than the ABS material for the Matrix. +

      +

      Sliding Support

      +

      To create a "Simple Shear" condition for the composite block the deformations at the boundaries need to be unconstrained. To achieve this, the block is placed on a sliding support. This leaves three degrees of freedom in the plane of the support (2 translations and a rotation) and those will be constrained later. (Note: as the plane prevents warping of the face, it still induces a minor constraint, which could be eliminated by a different choice of boundary conditions). To create a sliding boundary condition add a FemConstraintDisplacement object (Model > Mechanical Constraints > Constraint displacement). With the dialog box open first select the face to which the boundary conditions is to be applied and then click the Add button. As the block is allowed to slide in the x-y plane, only the "Fixed" radio button for "Displacement z" is selected and the other radio buttons are all left as "Free". +


      +Pic6.png +

      +

      Fixed Nodes

      +

      To prevent rigid body motion in the plane of sliding, three independent degrees of freedom need to be eliminated. To achieve this, one vertex in the plane of sliding is constrained in x and y direction (eliminating 2 degrees of freedom) and one vertex is fixed in the x direction (eliminating the last degree of freedom). For this purpose two additional FemConstraintDisplacement objects are created and the result is shown below. +


      +Pic7.png +

      +

      Shear Forces

      +

      The final step in the Analysis definition is the application of loads. To create a Simple Shear condition, a set of shear loads is applied as shown below. Each load is chosen as 1000 N and considering the directions of application, force and moment equilibrium is achieved for all translation and rotional degrees of freedom. In FC this requires addition of four FemConstraintForce objects (Model > Mechanical Constraints > Constraint force) - one for each face. With the dialog box open first press the Add Reference button and then select the face to which the boundary condition is to be applied (Note: this is a different sequence than with FemConstraintDisplacement). By default, this creates a set of forces perpendicular to the face (i.e. a normal force). To change this to a shear force, press the direction button and select a cube edge that runs in the desired direction. If the resulting force points in opposite direction of what is required, then select the radio button for "Reverse direction". +


      +Pic8.png +

      +

      CalculiX Analysis

      +

      Now all mesh regions, material and boundary conditions have been defined we are ready to analyse the deformation of the block with CalculiX. Activate the Analysis by right clicking "Activate analysis", open the CalculiX dialog by double clicking the CalculiXccxTools object and select a directory for the temporary files created by both FC and CCX. Write CCX Input file and check for any warning or error messages. +


      +PIC9.png +


      +After that the analysis can be started by pressing the RunCalculiX button. If all goes well, the CCX output window should show the following messages. +


      +Pic10.png +

      +

      CalculiX Results

      +

      Upon completion of the analysis double click the "CalculiX_static_results" object and select the "Abs displacement" option. The maximum displacement of ~ 0.08mm will show up in the relevant output box. As the maximum displacement is relatively small compared to the dimensions of the block (<1% of the block size), the displacements need to be scaled up. This can be done under the heading "Displacement" by ticking the "Show" radio button and scaling the displacement by a factor of -say- 20. The maximum displacement will now be exaggerated to approximately 20% of the box size. After closing the dialog window, the deformed mesh can be made visible again by highlighting the Result_mesh object and pressing the space bar. +


      +Figure 11 Deformed Mesh.png +


      +To investigate the deformation of the core we have to slice the block. This can be done by creating a clip filter. To activate this functionality, we first need to create a "post processing pipeline" by highlighting the "CalculiX_static_results" object and choosing "Results > Post Pipeline from Result" from the menu. Next, with the Pipeline selected create a Warp Filter (Results > Warp filter), set Vector=Displacement and Value=20 to scale the displacement and Display Mode = "Surface with Edges", Coloring Field = "Displacement", Vector = "Magnitude" to show colored displacement contours. Press Apply and OK. As a final step add a Clip Filter (Results > Clip filter) and create a plane with origin [5.0,2.5,5.0] and normal [0,1,0], i.e. at a core face with normal in the y-direction. Tick the "Cut Cells" radio button to create a flat surface. As before set Display Mode = "Surface with Edges", Coloring Field = "Displacement", Vector = "Magnitude" to show colored displacement contours. Press Apply and OK. Finally switch the Warp Filter to invisible to only show the cut block. +


      +Figure12 Deformed Mesh Clipped View (2).png +


      +From the result it is clear that the core remains largely undeformed and helps to resist the deformation of the soft matrix (compare the shear angle of the blue colored part to that of the green colored part). What it also highlights though is that under Simple Shear conditions the faces of the composite block do warp, implying that the sliding boundary condition at the base of the cube does provide an undue constraint. +


      +

      +

      Further work

      +

      The following challenges may be interesting to take up as a further exercise: +

      1) Correct for the undue constraint imposed by the sliding boundary condition +

      2) Try and create contact boundary conditions between the core and the matrix to see if separation occurs +

      The FC file for this tutorial is attached below as a starting point. +


      +https://forum.freecadweb.org/viewtopic.php?f=18&t=26517&start=20 +


      +Have fun ! +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/FEM_SolverCalculiX.html b/localwiki/FEM_SolverCalculiX.html new file mode 100644 index 0000000..131f235 --- /dev/null +++ b/localwiki/FEM_SolverCalculiX.html @@ -0,0 +1,67 @@ +FEM SolverCalculiX

      FEM SolverCalculiX

      + +

      +

      This documentation is not finished. Please help and contribute documentation. +

      See Draft ShapeString for good documented Command. Gui Command gives an overview over commands. And see List of Commands for other commands. +

      Go to Help FreeCAD to contribute. +

      +
      + + + + + + + + + + + + + + + + + + + + +
      +

      Official icon not found FEM SolverCalculiX

      +
      Menu location +
      Solve → solver CalculiX experimental +
      Workbenches +
      FEM +
      Default shortcut +
      +
      See also +
      FEM tutorial +

      Contents

      + +
      + +
      +


      +


      +

      ToDo +


      +
      +

      +
      +


      +

      + + +
      + +
      +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/FEM_SolverCalculixCxxtools.html b/localwiki/FEM_SolverCalculixCxxtools.html new file mode 100644 index 0000000..ee070ac --- /dev/null +++ b/localwiki/FEM_SolverCalculixCxxtools.html @@ -0,0 +1,128 @@ +FEM SolverCalculixCxxtools

      FEM SolverCalculixCxxtools

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      FEM Solver.png FEM Solver

      +
      Menu location +
      Solve → Solver CalculiX Standard +
      Workbenches +
      FEM +
      Default shortcut +
      +
      See also +
      FEM tutorial +

      + +
      +


      +

      +

      Description

      +

      CalculiXccxTools enable to use CalculiX solver. You can use it to +

      +
      1. set analysis parameters
      2. +
      3. select working directory
      4. +
      5. run the CalculiX solver.
      +

      How to use

      +
      1. FEM Solver.png CalculiXccxTools object is created automatically with creation of FEM Analysis.png Analysis container. Otherwise use SolveSolver CalculiX Standard , or press S then X keys
      2. +
      3. Optionally set data properties of the FEM Solver.png CalculiXccxTools object
      4. +
      5. Double click on the FEM Solver.png CalculiXccxTools object
      6. +
      7. Select type of the analysis
      8. +
      9. Click Write .inp file
      10. +
      11. Click Run CalculiX
      +

      Options

      +

      By using Edit .inp file you can display and edit CalculiX input file manually before running analysis. In this case it might be useful to use parameter "Split Input Writer = true". +

      +

      Properties

      +

      Default values can be set in the menu EditPreferencesFEMCalculiX +

      +
      • DATAAnalysis Type: +
        • static
        • +
        • frequency
        • +
        • thermomech - for mechanical and thermal loads
      +
      • DATABeam Shell Result Output 3D: note that CalculiX internally expands 1D and 2D elements into 3D elements to accomplish FE analysis +
        • false - results of 1D and 2D elements will be averaged to the nodes of original 1D or 2D mesh (i.e. purely bended beam will show 0 nodal stresses due to averaging)
        • +
        • true - resulting mesh will contain 1D and 2D elements expanded to 3D elements
      +
      • DATAEigenmode High Limit: Eigenvalues above this limit will not be calculated
      +
      • DATAEigenmode Low Limit: Eigenvalues below this limit will not be calculated
      +
      • DATAEigenmodes Count: number of lowest eigenmodes to be calculated
      +
      • DATAGeometric Nonlinearity: +
        • linear - linear analysis will be performed if model does not contain nonlinear material
        • +
        • nonlinear - nonlinear analysis will be performed
      +
      • DATAIterations Control parameter Cutb: defines second line of advanced iteration parameters under *CONTROLS card, used when "Iterations Control Parameter Time Use" is true
      +
      • DATAIterations Control Parameter Iter: defines first line of advanced iteration parameters under *CONTROLS card, used when "Iterations Control Parameter Time Use" is true
      +
      • DATAIterations Control Parameter Time Use +
        • true - activates "Iterations Control Parameter Cutb" and "Iterations Control Parameter Iter"
      +
      • DATAIterations Thermo Mech Maximum: maximum number of increments in thermomechanical analysis after which the job will be stopped.
      +
      • DATAIterations User Defined Incrementations: +
        • true - automatic incrementation control will be switched off by DIRECT parameter
        • +
        • false - incrementation control will be automatic
      +
      • DATAIterations User Defined Time Step Length: +
        • true - activates "Time End" and "Time Initial Step" parameters
      +
      • DATAMaterial Nonlinearity: +
        • linear - only linear material properties will be included in the analysis
        • +
        • nonlinear - nonlinear material properties will be used from FEM MaterialMechanicalNonlinear.png Nonlinear mechanical material object
      +
      • DATAMatrix Solver Type: type of the solver to solve equation system inside FE analysis. It may significantly affect calculation speed and memory demands. Suitability depends on your FE model and available hardware +
        • default - automatically selects matrix solver depending on available solvers (probably it will be Spooles)
        • +
        • spooles - direct solver with support of multiple CPUs. Number of CPUs need to be set in EditPreferencesFEMCalculiX → Solver defaults → Number of CPU's to use)
        • +
        • iterativescaling - iterative solver with least memory demands, suitable if model contains mostly 3D elements
        • +
        • iterativecholesky - iterative solver with preconditioning with and with low memory demands, suitable if model contains mostly 3D elements
      +
      • DATASplit Input Writer: +
        • false - write whole input into one *.inp file to be used by CalculiX solver
        • +
        • true - split solver inputs into more *.inp files, that can clarify hand editing
      +
      • DATAThermo Mechanical Steady State: +
        • true - steady state thermo mechanical analysis
        • +
        • false - transient thermo mechanical analysis
      +
      • DATATime End: time period of the step, used when parameter "Iterations User Defined Incrementations" or "Iterations User Defined Time Step Length" is true
      +
      • DATATime Initial Step: initial time increment of the step, used when parameter "Iterations User Defined Incrementations" or "Iterations User Defined Time Step Length" is true
      +
      • DATAWorking Dir: path to the working directory which will be used for CalculiX analysis files.
      +

      Limitations

      +

      Notes

      +

      Original CalculiX documentation can be found at http://dhondt.de/ in the "ccx" paragraph. +

      +

      Scripting

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/FEM_SolverControl.html b/localwiki/FEM_SolverControl.html new file mode 100644 index 0000000..364acb6 --- /dev/null +++ b/localwiki/FEM_SolverControl.html @@ -0,0 +1,68 @@ +FEM SolverControl

      FEM SolverControl

      + +
      +

      This documentation is not finished. Please help and contribute documentation. +

      See Draft ShapeString for good documented Command. Gui Command gives an overview over commands. And see List of Commands for other commands. +

      Go to Help FreeCAD to contribute. +

      +
      + + + + + + + + + + + + + + + + + + + + +
      +

      FEM ControlSolver.png FEM ControlSolver

      +
      Menu location +
      Solve → Solver job control +
      Workbenches +
      FEM +
      Default shortcut +
      S,C +
      See also +
      FEM tutorial +

      + +
      +


      +


      +

      +

      Description

      +

      Use

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/FEM_SolverElmer.html b/localwiki/FEM_SolverElmer.html new file mode 100644 index 0000000..cb32151 --- /dev/null +++ b/localwiki/FEM_SolverElmer.html @@ -0,0 +1,67 @@ +FEM SolverElmer

      FEM SolverElmer

      + +

      +

      This documentation is not finished. Please help and contribute documentation. +

      See Draft ShapeString for good documented Command. Gui Command gives an overview over commands. And see List of Commands for other commands. +

      Go to Help FreeCAD to contribute. +

      +
      + + + + + + + + + + + + + + + + + + + + +
      +

      Official icon not found FEM SolverElmer

      +
      Menu location +
      Solve → solver Elmer +
      Workbenches +
      FEM +
      Default shortcut +
      +
      See also +
      FEM tutorial +

      Contents

      + +
      + +
      +


      +


      +

      ToDo +


      +
      +

      +
      +


      +

      + + +
      + +
      +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/FEM_SolverRun.html b/localwiki/FEM_SolverRun.html new file mode 100644 index 0000000..3bf10bb --- /dev/null +++ b/localwiki/FEM_SolverRun.html @@ -0,0 +1,68 @@ +FEM SolverRun

      FEM SolverRun

      + +
      +

      This documentation is not finished. Please help and contribute documentation. +

      See Draft ShapeString for good documented Command. Gui Command gives an overview over commands. And see List of Commands for other commands. +

      Go to Help FreeCAD to contribute. +

      +
      + + + + + + + + + + + + + + + + + + + + +
      +

      FEM RunSolver.png FEM RunSolver

      +
      Menu location +
      Solve → Run solver calculations +
      Workbenches +
      FEM +
      Default shortcut +
      R,C +
      See also +
      FEM tutorial +

      + +
      +


      +


      +

      +

      Description

      +

      Use

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/FEM_SolverZ88.html b/localwiki/FEM_SolverZ88.html new file mode 100644 index 0000000..077d578 --- /dev/null +++ b/localwiki/FEM_SolverZ88.html @@ -0,0 +1,67 @@ +FEM SolverZ88

      FEM SolverZ88

      + +

      +

      This documentation is not finished. Please help and contribute documentation. +

      See Draft ShapeString for good documented Command. Gui Command gives an overview over commands. And see List of Commands for other commands. +

      Go to Help FreeCAD to contribute. +

      +
      + + + + + + + + + + + + + + + + + + + + +
      +

      FEM SolverZ88.png FEM SolverZ88

      +
      Menu location +
      Solve → solver Z88 +
      Workbenches +
      FEM +
      Default shortcut +
      +
      See also +
      FEM tutorial +

      Contents

      + +
      + +
      +


      +


      +

      ToDo +


      +
      +

      +
      +


      +

      + + +
      + +
      +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/FEM_Tutorial_Python.html b/localwiki/FEM_Tutorial_Python.html new file mode 100644 index 0000000..57f9dc6 --- /dev/null +++ b/localwiki/FEM_Tutorial_Python.html @@ -0,0 +1,537 @@ +FEM Tutorial Python

      FEM Tutorial Python

      + +
      + + + + + + + + + + + + + + + + + + + + + + + + + + + +
      +

      Base ExampleCommandModel.png Tutorial

      +
      Topic +
      Finite Element Analysis +
      Level +
      Intermediates +
      Time to complete +
      30 minutes +
      Author +
      Bernd +
      FreeCAD version +
      0.17.12995 or above +
      Example File(s) +
      +

      + +
      +


      +


      +

      +

      Introduction

      +

      This example is meant to show how a simple Finite Element Analysis (FEA) in FreeCADs FEM Module is done by python. The model from FEM_CalculiX_Cantilever_3D will be taken for this example. +


      +FEM example01 pic00.jpg +


      +

      +

      Requirements

      +
      • FreeCAD version --> according tutorial overview
      • +
      • This could be checked at the menu Help --> about FreeCAD.
      • +
      • Al thought due to the continuing changes in FEM module it is recommended to use the latest development snapshot of FreeCAD for python scripted FEM analysis's.
      • +
      • A set up FEM module. Check FEM_CalculiX_Cantilever_3D
      +

      Let's start

      +

      New document and the part to analyze

      +
      # new document
      +doc = App.newDocument("Scripted_CalculiX_Cantilever3D")
      +
      +# part
      +import Part
      +box_obj = doc.addObject('Part::Box', 'Box')
      +box_obj.Height = box_obj.Width = 1000
      +box_obj.Length = 8000
      +
      +# see how our part looks like
      +import FreeCADGui
      +FreeCADGui.ActiveDocument.activeView().viewAxonometric()
      +FreeCADGui.SendMsgToActiveView("ViewFit")
      +
      +# 
      +

      Analysis and analysis objects

      +
      # let us create some objects
      +
      +# import to create objects
      +import ObjectsFem
      +
      +# analysis
      +analysis_object = ObjectsFem.makeAnalysis(doc, "Analysis")
      +
      +# solver (we gone use the well tested CcxTools solver object)
      +solver_object = ObjectsFem.makeSolverCalculixCcxTools(doc, "CalculiX")
      +solver_object.GeometricalNonlinearity = 'linear'
      +solver_object.ThermoMechSteadyState = True
      +solver_object.MatrixSolverType = 'default'
      +solver_object.IterationsControlParameterTimeUse = False
      +analysis_object.addObject(solver_object)
      +
      +# material
      +material_object = ObjectsFem.makeMaterialSolid(doc, "SolidMaterial")
      +mat = material_object.Material
      +mat['Name'] = "Steel-Generic"
      +mat['YoungsModulus'] = "210000 MPa"
      +mat['PoissonRatio'] = "0.30"
      +mat['Density'] = "7900 kg/m^3"
      +material_object.Material = mat
      +analysis_object.addObject(material_object)
      +
      +# fixed_constraint
      +fixed_constraint = ObjectsFem.makeConstraintFixed(doc, "FemConstraintFixed")
      +fixed_constraint.References = [(doc.Box, "Face1")]
      +analysis_object.addObject(fixed_constraint)
      +
      +# force_constraint
      +force_constraint = ObjectsFem.makeConstraintForce(doc, "FemConstraintForce")
      +force_constraint.References = [(doc.Box, "Face2")]
      +force_constraint.Force = 9000000.0
      +force_constraint.Direction = (doc.Box, ["Edge5"])
      +force_constraint.Reversed = True
      +analysis_object.addObject(force_constraint)
      +
      +# 
      +

      FEM mesh

      +

      see Additional informations for how to script mesh generation with GMSH or Netgen mesh object. +

      +
      # mesh
      +import Fem
      +femmesh = Fem.FemMesh()
      +
      +# nodes
      +femmesh.addNode(8000.0, 1000.0, 0.0, 1)
      +femmesh.addNode(8000.0, 1000.0, 1000.0, 2)
      +femmesh.addNode(8000.0, 0.0, 0.0, 3)
      +femmesh.addNode(8000.0, 0.0, 1000.0, 4)
      +femmesh.addNode(0.0, 1000.0, 0.0, 5)
      +femmesh.addNode(0.0, 1000.0, 1000.0, 6)
      +femmesh.addNode(0.0, 0.0, 0.0, 7)
      +femmesh.addNode(0.0, 0.0, 1000.0, 8)
      +femmesh.addNode(728.0, 1000.0, 1000.0, 9)
      +femmesh.addNode(1456.0, 1000.0, 1000.0, 10)
      +femmesh.addNode(2184.0, 1000.0, 1000.0, 11)
      +femmesh.addNode(2912.0, 1000.0, 1000.0, 12)
      +femmesh.addNode(3640.0, 1000.0, 1000.0, 13)
      +femmesh.addNode(4368.0, 1000.0, 1000.0, 14)
      +femmesh.addNode(5096.0, 1000.0, 1000.0, 15)
      +femmesh.addNode(5824.0, 1000.0, 1000.0, 16)
      +femmesh.addNode(6552.0, 1000.0, 1000.0, 17)
      +femmesh.addNode(7280.0, 1000.0, 1000.0, 18)
      +femmesh.addNode(728.0, 0.0, 1000.0, 19)
      +femmesh.addNode(1456.0, 0.0, 1000.0, 20)
      +femmesh.addNode(2184.0, 0.0, 1000.0, 21)
      +femmesh.addNode(2912.0, 0.0, 1000.0, 22)
      +femmesh.addNode(3640.0, 0.0, 1000.0, 23)
      +femmesh.addNode(4368.0, 0.0, 1000.0, 24)
      +femmesh.addNode(5096.0, 0.0, 1000.0, 25)
      +femmesh.addNode(5824.0, 0.0, 1000.0, 26)
      +femmesh.addNode(6552.0, 0.0, 1000.0, 27)
      +femmesh.addNode(7280.0, 0.0, 1000.0, 28)
      +femmesh.addNode(728.0, 1000.0, 0.0, 29)
      +femmesh.addNode(1456.0, 1000.0, 0.0, 30)
      +femmesh.addNode(2184.0, 1000.0, 0.0, 31)
      +femmesh.addNode(2912.0, 1000.0, 0.0, 32)
      +femmesh.addNode(3640.0, 1000.0, 0.0, 33)
      +femmesh.addNode(4368.0, 1000.0, 0.0, 34)
      +femmesh.addNode(5096.0, 1000.0, 0.0, 35)
      +femmesh.addNode(5824.0, 1000.0, 0.0, 36)
      +femmesh.addNode(6552.0, 1000.0, 0.0, 37)
      +femmesh.addNode(7280.0, 1000.0, 0.0, 38)
      +femmesh.addNode(728.0, 0.0, 0.0, 39)
      +femmesh.addNode(1456.0, 0.0, 0.0, 40)
      +femmesh.addNode(2184.0, 0.0, 0.0, 41)
      +femmesh.addNode(2912.0, 0.0, 0.0, 42)
      +femmesh.addNode(3640.0, 0.0, 0.0, 43)
      +femmesh.addNode(4368.0, 0.0, 0.0, 44)
      +femmesh.addNode(5096.0, 0.0, 0.0, 45)
      +femmesh.addNode(5824.0, 0.0, 0.0, 46)
      +femmesh.addNode(6552.0, 0.0, 0.0, 47)
      +femmesh.addNode(7280.0, 0.0, 0.0, 48)
      +femmesh.addNode(8000.0, 500.0, 500.0, 49)
      +femmesh.addNode(0.0, 500.0, 500.0, 50)
      +femmesh.addNode(4731.99999977, 500.000001086, 499.999998599, 51)
      +femmesh.addNode(0.0, 500.0, 1000.0, 52)
      +femmesh.addNode(364.0, 1000.0, 1000.0, 53)
      +femmesh.addNode(1092.0, 1000.0, 1000.0, 54)
      +femmesh.addNode(1820.0, 1000.0, 1000.0, 55)
      +femmesh.addNode(2548.0, 1000.0, 1000.0, 56)
      +femmesh.addNode(3276.0, 1000.0, 1000.0, 57)
      +femmesh.addNode(4004.0, 1000.0, 1000.0, 58)
      +femmesh.addNode(4732.0, 1000.0, 1000.0, 59)
      +femmesh.addNode(5460.0, 1000.0, 1000.0, 60)
      +femmesh.addNode(6188.0, 1000.0, 1000.0, 61)
      +femmesh.addNode(6916.0, 1000.0, 1000.0, 62)
      +femmesh.addNode(7640.0, 1000.0, 1000.0, 63)
      +femmesh.addNode(8000.0, 500.0, 1000.0, 64)
      +femmesh.addNode(364.0, 0.0, 1000.0, 65)
      +femmesh.addNode(1092.0, 0.0, 1000.0, 66)
      +femmesh.addNode(1820.0, 0.0, 1000.0, 67)
      +femmesh.addNode(2548.0, 0.0, 1000.0, 68)
      +femmesh.addNode(3276.0, 0.0, 1000.0, 69)
      +femmesh.addNode(4004.0, 0.0, 1000.0, 70)
      +femmesh.addNode(4732.0, 0.0, 1000.0, 71)
      +femmesh.addNode(5460.0, 0.0, 1000.0, 72)
      +femmesh.addNode(6188.0, 0.0, 1000.0, 73)
      +femmesh.addNode(6916.0, 0.0, 1000.0, 74)
      +femmesh.addNode(7640.0, 0.0, 1000.0, 75)
      +femmesh.addNode(0.0, 500.0, 0.0, 76)
      +femmesh.addNode(364.0, 1000.0, 0.0, 77)
      +femmesh.addNode(1092.0, 1000.0, 0.0, 78)
      +femmesh.addNode(1820.0, 1000.0, 0.0, 79)
      +femmesh.addNode(2548.0, 1000.0, 0.0, 80)
      +femmesh.addNode(3276.0, 1000.0, 0.0, 81)
      +femmesh.addNode(4004.0, 1000.0, 0.0, 82)
      +femmesh.addNode(4732.0, 1000.0, 0.0, 83)
      +femmesh.addNode(5460.0, 1000.0, 0.0, 84)
      +femmesh.addNode(6188.0, 1000.0, 0.0, 85)
      +femmesh.addNode(6916.0, 1000.0, 0.0, 86)
      +femmesh.addNode(7640.0, 1000.0, 0.0, 87)
      +femmesh.addNode(8000.0, 500.0, 0.0, 88)
      +femmesh.addNode(364.0, 0.0, 0.0, 89)
      +femmesh.addNode(1092.0, 0.0, 0.0, 90)
      +femmesh.addNode(1820.0, 0.0, 0.0, 91)
      +femmesh.addNode(2548.0, 0.0, 0.0, 92)
      +femmesh.addNode(3276.0, 0.0, 0.0, 93)
      +femmesh.addNode(4004.0, 0.0, 0.0, 94)
      +femmesh.addNode(4732.0, 0.0, 0.0, 95)
      +femmesh.addNode(5460.0, 0.0, 0.0, 96)
      +femmesh.addNode(6188.0, 0.0, 0.0, 97)
      +femmesh.addNode(6916.0, 0.0, 0.0, 98)
      +femmesh.addNode(7640.0, 0.0, 0.0, 99)
      +femmesh.addNode(8000.0, 1000.0, 500.0, 100)
      +femmesh.addNode(0.0, 1000.0, 500.0, 101)
      +femmesh.addNode(8000.0, 0.0, 500.0, 102)
      +femmesh.addNode(0.0, 0.0, 500.0, 103)
      +femmesh.addNode(364.0, 500.0, 1000.0, 104)
      +femmesh.addNode(728.0, 500.0, 1000.0, 105)
      +femmesh.addNode(1092.0, 500.0, 1000.0, 106)
      +femmesh.addNode(1456.0, 500.0, 1000.0, 107)
      +femmesh.addNode(1820.0, 500.0, 1000.0, 108)
      +femmesh.addNode(2184.0, 500.0, 1000.0, 109)
      +femmesh.addNode(2548.0, 500.0, 1000.0, 110)
      +femmesh.addNode(3276.0, 500.0, 1000.0, 111)
      +femmesh.addNode(3640.0, 500.0, 1000.0, 112)
      +femmesh.addNode(4004.0, 500.0, 1000.0, 113)
      +femmesh.addNode(4368.0, 500.0, 1000.0, 114)
      +femmesh.addNode(4732.0, 500.0, 1000.0, 115)
      +femmesh.addNode(5096.0, 500.0, 1000.0, 116)
      +femmesh.addNode(5460.0, 500.0, 1000.0, 117)
      +femmesh.addNode(5824.0, 500.0, 1000.0, 118)
      +femmesh.addNode(6188.0, 500.0, 1000.0, 119)
      +femmesh.addNode(6552.0, 500.0, 1000.0, 120)
      +femmesh.addNode(6916.0, 500.0, 1000.0, 121)
      +femmesh.addNode(7640.0, 500.0, 1000.0, 122)
      +femmesh.addNode(2912.0, 500.0, 1000.0, 123)
      +femmesh.addNode(7280.0, 500.0, 1000.0, 124)
      +femmesh.addNode(364.0, 500.0, 0.0, 125)
      +femmesh.addNode(1092.0, 500.0, 0.0, 126)
      +femmesh.addNode(728.0, 500.0, 0.0, 127)
      +femmesh.addNode(1820.0, 500.0, 0.0, 128)
      +femmesh.addNode(1456.0, 500.0, 0.0, 129)
      +femmesh.addNode(2548.0, 500.0, 0.0, 130)
      +femmesh.addNode(2184.0, 500.0, 0.0, 131)
      +femmesh.addNode(3640.0, 500.0, 0.0, 132)
      +femmesh.addNode(3276.0, 500.0, 0.0, 133)
      +femmesh.addNode(4004.0, 500.0, 0.0, 134)
      +femmesh.addNode(5096.0, 500.0, 0.0, 135)
      +femmesh.addNode(4732.0, 500.0, 0.0, 136)
      +femmesh.addNode(5460.0, 500.0, 0.0, 137)
      +femmesh.addNode(6188.0, 500.0, 0.0, 138)
      +femmesh.addNode(5824.0, 500.0, 0.0, 139)
      +femmesh.addNode(6916.0, 500.0, 0.0, 140)
      +femmesh.addNode(6552.0, 500.0, 0.0, 141)
      +femmesh.addNode(7640.0, 500.0, 0.0, 142)
      +femmesh.addNode(2912.0, 500.0, 0.0, 143)
      +femmesh.addNode(4368.0, 500.0, 0.0, 144)
      +femmesh.addNode(7280.0, 500.0, 0.0, 145)
      +femmesh.addNode(364.0, 1000.0, 500.0, 146)
      +femmesh.addNode(728.0, 1000.0, 500.0, 147)
      +femmesh.addNode(1092.0, 1000.0, 500.0, 148)
      +femmesh.addNode(1456.0, 1000.0, 500.0, 149)
      +femmesh.addNode(1820.0, 1000.0, 500.0, 150)
      +femmesh.addNode(2184.0, 1000.0, 500.0, 151)
      +femmesh.addNode(2548.0, 1000.0, 500.0, 152)
      +femmesh.addNode(3276.0, 1000.0, 500.0, 153)
      +femmesh.addNode(3640.0, 1000.0, 500.0, 154)
      +femmesh.addNode(4004.0, 1000.0, 500.0, 155)
      +femmesh.addNode(4368.0, 1000.0, 500.0, 156)
      +femmesh.addNode(4732.0, 1000.0, 500.0, 157)
      +femmesh.addNode(5096.0, 1000.0, 500.0, 158)
      +femmesh.addNode(5460.0, 1000.0, 500.0, 159)
      +femmesh.addNode(5824.0, 1000.0, 500.0, 160)
      +femmesh.addNode(6188.0, 1000.0, 500.0, 161)
      +femmesh.addNode(6552.0, 1000.0, 500.0, 162)
      +femmesh.addNode(6916.0, 1000.0, 500.0, 163)
      +femmesh.addNode(7640.0, 1000.0, 500.0, 164)
      +femmesh.addNode(2912.0, 1000.0, 500.0, 165)
      +femmesh.addNode(7280.0, 1000.0, 500.0, 166)
      +femmesh.addNode(364.0, 0.0, 500.0, 167)
      +femmesh.addNode(1092.0, 0.0, 500.0, 168)
      +femmesh.addNode(728.0, 0.0, 500.0, 169)
      +femmesh.addNode(1820.0, 0.0, 500.0, 170)
      +femmesh.addNode(1456.0, 0.0, 500.0, 171)
      +femmesh.addNode(2548.0, 0.0, 500.0, 172)
      +femmesh.addNode(2184.0, 0.0, 500.0, 173)
      +femmesh.addNode(3640.0, 0.0, 500.0, 174)
      +femmesh.addNode(3276.0, 0.0, 500.0, 175)
      +femmesh.addNode(4004.0, 0.0, 500.0, 176)
      +femmesh.addNode(5096.0, 0.0, 500.0, 177)
      +femmesh.addNode(4732.0, 0.0, 500.0, 178)
      +femmesh.addNode(5460.0, 0.0, 500.0, 179)
      +femmesh.addNode(6188.0, 0.0, 500.0, 180)
      +femmesh.addNode(5824.0, 0.0, 500.0, 181)
      +femmesh.addNode(6916.0, 0.0, 500.0, 182)
      +femmesh.addNode(6552.0, 0.0, 500.0, 183)
      +femmesh.addNode(7640.0, 0.0, 500.0, 184)
      +femmesh.addNode(2912.0, 0.0, 500.0, 185)
      +femmesh.addNode(4368.0, 0.0, 500.0, 186)
      +femmesh.addNode(7280.0, 0.0, 500.0, 187)
      +femmesh.addNode(8000.0, 250.0, 250.0, 188)
      +femmesh.addNode(8000.0, 250.0, 750.0, 189)
      +femmesh.addNode(8000.0, 750.0, 750.0, 190)
      +femmesh.addNode(8000.0, 750.0, 250.0, 191)
      +femmesh.addNode(0.0, 250.0, 750.0, 192)
      +femmesh.addNode(0.0, 250.0, 250.0, 193)
      +femmesh.addNode(0.0, 750.0, 250.0, 194)
      +femmesh.addNode(0.0, 750.0, 750.0, 195)
      +femmesh.addNode(1456.0, 500.0, 500.0, 196)
      +femmesh.addNode(6552.0, 500.0, 500.0, 197)
      +femmesh.addNode(6916.0, 500.0, 500.0, 198)
      +femmesh.addNode(2184.0, 500.0, 500.0, 199)
      +femmesh.addNode(2548.0, 500.0, 500.0, 200)
      +femmesh.addNode(2912.0, 500.0, 500.0, 201)
      +femmesh.addNode(1820.0, 500.0, 500.0, 202)
      +femmesh.addNode(7640.0, 750.0, 250.0, 203)
      +femmesh.addNode(7640.0, 750.0, 750.0, 204)
      +femmesh.addNode(7280.0, 500.0, 500.0, 205)
      +femmesh.addNode(7640.0, 250.0, 250.0, 206)
      +femmesh.addNode(5460.0, 500.0, 500.0, 207)
      +femmesh.addNode(5096.0, 500.0, 500.0, 208)
      +femmesh.addNode(6188.0, 500.0, 500.0, 209)
      +femmesh.addNode(5824.0, 500.0, 500.0, 210)
      +femmesh.addNode(364.0, 750.0, 250.0, 211)
      +femmesh.addNode(364.0, 750.0, 750.0, 212)
      +femmesh.addNode(364.0, 250.0, 250.0, 213)
      +femmesh.addNode(1092.0, 500.0, 500.0, 214)
      +femmesh.addNode(728.0, 500.0, 500.0, 215)
      +femmesh.addNode(364.0, 250.0, 750.0, 216)
      +femmesh.addNode(4549.99999989, 250.000000543, 249.9999993, 217)
      +femmesh.addNode(4549.99999989, 750.000000543, 249.9999993, 218)
      +femmesh.addNode(4549.99999989, 750.000000543, 749.9999993, 219)
      +femmesh.addNode(4368.0, 500.0, 500.0, 220)
      +femmesh.addNode(4549.99999989, 250.000000543, 749.9999993, 221)
      +femmesh.addNode(4913.99999989, 250.000000543, 749.9999993, 222)
      +femmesh.addNode(4913.99999989, 750.000000543, 749.9999993, 223)
      +femmesh.addNode(3276.0, 500.0, 500.0, 224)
      +femmesh.addNode(3640.0, 500.0, 500.0, 225)
      +femmesh.addNode(4004.0, 500.0, 500.0, 226)
      +femmesh.addNode(4913.99999989, 750.000000543, 249.9999993, 227)
      +femmesh.addNode(4913.99999989, 250.000000543, 249.9999993, 228)
      +
      +# elements
      +femmesh.addVolume([40, 19, 10, 20, 168, 106, 196, 171, 66, 107], 149)
      +femmesh.addVolume([10, 31, 30, 40, 150, 79, 149, 196, 128, 129], 150)
      +femmesh.addVolume([38, 17, 18, 47, 163, 62, 166, 140, 197, 198], 151)
      +femmesh.addVolume([32, 41, 11, 12, 130, 199, 152, 165, 200, 56], 152)
      +femmesh.addVolume([12, 32, 41, 42, 165, 130, 200, 201, 143, 92], 153)
      +femmesh.addVolume([42, 21, 12, 22, 172, 110, 201, 185, 68, 123], 154)
      +femmesh.addVolume([10, 31, 40, 11, 150, 128, 196, 55, 151, 202], 155)
      +femmesh.addVolume([11, 12, 41, 21, 56, 200, 199, 109, 110, 173], 156)
      +femmesh.addVolume([20, 41, 11, 40, 170, 199, 108, 171, 91, 202], 157)
      +femmesh.addVolume([20, 41, 21, 11, 170, 173, 67, 108, 199, 109], 158)
      +femmesh.addVolume([32, 11, 41, 31, 152, 199, 130, 80, 151, 131], 159)
      +femmesh.addVolume([11, 10, 20, 40, 55, 107, 108, 202, 196, 171], 160)
      +femmesh.addVolume([38, 17, 47, 37, 163, 197, 140, 86, 162, 141], 161)
      +femmesh.addVolume([38, 18, 49, 48, 166, 204, 203, 145, 205, 206], 162)
      +femmesh.addVolume([46, 15, 45, 36, 207, 208, 96, 139, 159, 137], 163)
      +femmesh.addVolume([47, 16, 46, 37, 209, 210, 97, 141, 161, 138], 164)
      +femmesh.addVolume([18, 4, 2, 49, 122, 64, 63, 204, 189, 190], 165)
      +femmesh.addVolume([18, 17, 27, 47, 62, 120, 121, 198, 197, 183], 166)
      +femmesh.addVolume([38, 18, 48, 47, 166, 205, 145, 140, 198, 98], 167)
      +femmesh.addVolume([12, 23, 42, 22, 111, 175, 201, 123, 69, 185], 168)
      +femmesh.addVolume([26, 47, 27, 17, 180, 183, 73, 119, 197, 120], 169)
      +femmesh.addVolume([50, 29, 9, 6, 211, 147, 212, 195, 146, 53], 170)
      +femmesh.addVolume([27, 48, 18, 47, 182, 205, 121, 183, 98, 198], 171)
      +femmesh.addVolume([8, 7, 39, 50, 103, 89, 167, 192, 193, 213], 172)
      +femmesh.addVolume([40, 9, 39, 30, 214, 215, 90, 129, 148, 126], 173)
      +femmesh.addVolume([42, 21, 41, 12, 172, 173, 92, 201, 110, 200], 174)
      +femmesh.addVolume([50, 9, 29, 39, 212, 147, 211, 213, 215, 127], 175)
      +femmesh.addVolume([29, 7, 50, 39, 125, 193, 211, 127, 89, 213], 176)
      +femmesh.addVolume([31, 11, 41, 40, 151, 199, 131, 128, 202, 91], 177)
      +femmesh.addVolume([47, 16, 37, 17, 209, 161, 141, 197, 61, 162], 178)
      +femmesh.addVolume([40, 9, 30, 10, 214, 148, 129, 196, 54, 149], 179)
      +femmesh.addVolume([2, 38, 49, 1, 164, 203, 190, 100, 87, 191], 180)
      +femmesh.addVolume([2, 38, 18, 49, 164, 166, 63, 190, 203, 204], 181)
      +femmesh.addVolume([48, 49, 38, 3, 206, 203, 145, 99, 188, 142], 182)
      +femmesh.addVolume([38, 49, 1, 3, 203, 191, 87, 142, 188, 88], 183)
      +femmesh.addVolume([49, 4, 3, 48, 189, 102, 188, 206, 184, 99], 184)
      +femmesh.addVolume([28, 48, 4, 18, 187, 184, 75, 124, 205, 122], 185)
      +femmesh.addVolume([49, 18, 4, 48, 204, 122, 189, 206, 205, 184], 186)
      +femmesh.addVolume([7, 50, 5, 29, 193, 194, 76, 125, 211, 77], 187)
      +femmesh.addVolume([50, 6, 5, 29, 195, 101, 194, 211, 146, 77], 188)
      +femmesh.addVolume([50, 9, 19, 6, 212, 105, 216, 195, 53, 104], 189)
      +femmesh.addVolume([50, 19, 9, 39, 216, 105, 212, 213, 169, 215], 190)
      +femmesh.addVolume([50, 19, 8, 6, 216, 65, 192, 195, 104, 52], 191)
      +femmesh.addVolume([40, 9, 10, 19, 214, 54, 196, 168, 105, 106], 192)
      +femmesh.addVolume([51, 44, 34, 14, 217, 144, 218, 219, 220, 156], 193)
      +femmesh.addVolume([51, 24, 44, 14, 221, 186, 217, 219, 114, 220], 194)
      +femmesh.addVolume([25, 15, 24, 51, 116, 115, 71, 222, 223, 221], 195)
      +femmesh.addVolume([43, 12, 32, 13, 224, 165, 133, 225, 57, 153], 196)
      +femmesh.addVolume([43, 12, 23, 42, 224, 111, 174, 93, 201, 175], 197)
      +femmesh.addVolume([43, 12, 13, 23, 224, 57, 225, 174, 111, 112], 198)
      +femmesh.addVolume([43, 12, 42, 32, 224, 201, 93, 133, 165, 143], 199)
      +femmesh.addVolume([34, 13, 14, 44, 155, 58, 156, 144, 226, 220], 200)
      +femmesh.addVolume([14, 24, 15, 51, 114, 115, 59, 219, 221, 223], 201)
      +femmesh.addVolume([23, 24, 14, 44, 70, 114, 113, 176, 186, 220], 202)
      +femmesh.addVolume([33, 32, 13, 43, 81, 153, 154, 132, 133, 225], 203)
      +femmesh.addVolume([34, 33, 13, 43, 82, 154, 155, 134, 132, 225], 204)
      +femmesh.addVolume([35, 14, 15, 51, 157, 59, 158, 227, 219, 223], 205)
      +femmesh.addVolume([25, 45, 15, 51, 177, 208, 116, 222, 228, 223], 206)
      +femmesh.addVolume([44, 43, 13, 23, 94, 225, 226, 176, 174, 112], 207)
      +femmesh.addVolume([35, 34, 14, 51, 83, 156, 157, 227, 218, 219], 208)
      +femmesh.addVolume([46, 15, 36, 16, 207, 159, 139, 210, 60, 160], 209)
      +femmesh.addVolume([36, 35, 15, 45, 84, 158, 159, 137, 135, 208], 210)
      +femmesh.addVolume([37, 36, 16, 46, 85, 160, 161, 138, 139, 210], 211)
      +femmesh.addVolume([25, 26, 16, 46, 72, 118, 117, 179, 181, 210], 212)
      +femmesh.addVolume([47, 16, 17, 26, 209, 61, 197, 180, 118, 119], 213)
      +femmesh.addVolume([47, 16, 26, 46, 209, 118, 180, 97, 210, 181], 214)
      +femmesh.addVolume([27, 28, 18, 48, 74, 124, 121, 182, 187, 205], 215)
      +femmesh.addVolume([35, 34, 51, 45, 83, 218, 227, 135, 136, 228], 216)
      +femmesh.addVolume([13, 14, 44, 23, 58, 220, 226, 112, 113, 176], 217)
      +femmesh.addVolume([44, 25, 24, 51, 178, 71, 186, 217, 222, 221], 218)
      +femmesh.addVolume([44, 45, 25, 51, 95, 177, 178, 217, 228, 222], 219)
      +femmesh.addVolume([46, 15, 16, 25, 207, 60, 210, 179, 116, 117], 220)
      +femmesh.addVolume([46, 15, 25, 45, 207, 116, 179, 96, 208, 177], 221)
      +femmesh.addVolume([50, 8, 19, 39, 192, 65, 216, 213, 167, 169], 222)
      +femmesh.addVolume([35, 51, 15, 45, 227, 223, 158, 135, 228, 208], 223)
      +femmesh.addVolume([34, 44, 43, 13, 144, 94, 134, 155, 226, 225], 224)
      +femmesh.addVolume([51, 44, 45, 34, 217, 95, 228, 218, 144, 136], 225)
      +femmesh.addVolume([9, 29, 39, 30, 147, 127, 215, 148, 78, 126], 226)
      +femmesh.addVolume([40, 9, 19, 39, 214, 105, 168, 90, 215, 169], 227)
      +
      +#
      +# add it to the analysis
      +femmesh_obj = doc.addObject('Fem::FemMeshObject', 'Box_Mesh')
      +femmesh_obj.FemMesh = femmesh
      +analysis_object.addObject(femmesh_obj)
      +
      +# 
      +

      Recompute

      +
      # recompute
      +doc.recompute()
      +
      +# 
      +

      Run the analysis

      +
      # run the analysis
      +import FemGui
      +FemGui.setActiveAnalysis(doc.Analysis)
      +from femtools import ccxtools
      +fea = ccxtools.FemToolsCcx()
      +fea.update_objects()
      +message = fea.check_prerequisites()
      +if not message:
      +    fea.reset_all()
      +    fea.run()
      +    fea.load_results()
      +else:
      +    FreeCAD.Console.PrintError("Houston, we have a problem! {}\n".format(message))  # in report view
      +    print("Houston, we have a problem! {}\n".format(message))  # in python console
      +
      +# 
      +

      Show the results

      +
      # show some results
      +for m in analysis_object.Group:
      +    if m.isDerivedFrom('Fem::FemResultObject'):
      +        result_object = m
      +        break
      +
      +femmesh_obj.ViewObject.setNodeDisplacementByVectors(result_object.NodeNumbers, result_object.DisplacementVectors)
      +femmesh_obj.ViewObject.applyDisplacement(10)
      +
      +# 
      +

      Additional Information

      +
      Scripting FEM mesh objects
      +

      Scripting the Netgen mesh object was tried here: http://forum.freecadweb.org/viewtopic.php?f=18&t=16944#p134519 , but has some limitations. On the contrary the GMSH mesh object fully supports python scripting. See forum topic http://forum.freecadweb.org/viewtopic.php?f=18&t=20087 +

      +
      Scripting multiple analysis
      +

      See forum post: http://forum.freecadweb.org/viewtopic.php?f=18&t=19549#p151385 +

      +
      Scripting results
      +

      See forum posts: http://forum.freecadweb.org/viewtopic.php?f=18&t=4677&start=20#p148982 and http://forum.freecadweb.org/viewtopic.php?f=18&t=4677&start=30#p149043 and http://forum.freecadweb.org/viewtopic.php?t=18415#p144028 +

      +
      Console mode
      +

      Writing the input file in FreeCAD console mode (no Gui) could be done in test mode. See forum post in this regard: https://forum.freecadweb.org/viewtopic.php?f=22&t=25852&p=208897#p208897 +

      +

      Appendix

      +

      Have Fun! +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/FEM_project.html b/localwiki/FEM_project.html new file mode 100644 index 0000000..453c61b --- /dev/null +++ b/localwiki/FEM_project.html @@ -0,0 +1,246 @@ +FEM project

      FEM project

      + +

      This is the project plan for the FreeCAD FEM integration as part of the Development roadmap. +


      +

      + + +

      Units

      + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
      Units +
      Length Time Mass Force Pressure Velocity Density Energy Gravity +
      m s kg kg m/s2 N/m2 m/s kg/m3 kgm2/s2 9.81 +
      m s kg N Pa m/s m kg/l J 9.81 +
      m s g mN mPa m/s micro kg/l mJ 9.81 +
      m s Mg (ton) kN kPa m/s kg/l kJ 9.81 +
      m ms kg MN MPa km/s m kg/l MJ 9.81e-6 +
      m ms g kN kPa km/s micro kg/l kJ 9.81e-6 +
      m ms Mg (ton) GN GPa km/s kg/l GJ 9.81e-6 +
      mm s kg mN kPa mm/s M kg/l micro J 9.81e+3 +
      mm s g micro N Pa mm/s g/mm3 nJ 9.81e+3 +
      mm s Mg (ton) N MPa mm/s Mg/mm3 mJ 9.81e+3 +
      mm ms kg kN GPa m/s M kg/l J 9.81e-3 +
      mm ms g N MPa m/s k kg/l mJ 9.81e-3 +
      mm ms Mg (ton) MN TPa m/s G kg/l kJ 9.81e-3 +
      cm ms g daN 10^5 Pa (bar) dam/s kg/l dJ 9.81e-4 +
      cm ms kg 10^4 N (kdaN) 10^8 Pa (kbar) dam/s k kg/l hJ 9.81e-4 +
      cm ms Mg (ton) 10^7 N(MdaN) 10^11 Pa (Mbar) dam/s M kg/l 10^5 J 9.81e-4 +
      +


      +

      +

      Brainstorming

      +

      potential Meshers

      +
      Netgen.jpg
      +

      Some meshers out there +

      +
      • Netgen very good mesher, LGPL with some library suport
      • +
      • Salome complicated package, hard to get the code we need!?
      • +
      • PythonOCC python library wrapping Salome and Netgen meshers may be the quickest and most complete way to integrate meshers
      +

      potential Solvers

      +

      some solver out there +

      +
      • Calculix
      • +
      • Code-Aster very broad solver with python bindings
      • +
      • PythonOCC python library that also offers a (currently) rough interface to Code_Aster which would also be a quick way to have a 1st working solution
      +

      calculix examples

      + +

      Mesher

      +
      • Testing the mesh generators by experts
      • +
      • Analysing software structure and possible integration
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/FEM_tutorial.html b/localwiki/FEM_tutorial.html new file mode 100644 index 0000000..c1b2f20 --- /dev/null +++ b/localwiki/FEM_tutorial.html @@ -0,0 +1,169 @@ +FEM tutorial

      FEM tutorial

      + +
      + + + + + + + + + + + + + + + + + + + + + + + + + + + +
      +

      Base ExampleCommandModel.png Tutorial

      +
      Topic +
      Finite Element Analysis +
      Level +
      Beginner +
      Time to complete +
      10 minutes + Solver time +
      Author +
      Drei +
      FreeCAD version +
      0.16.6700 or above +
      Example File(s) +
      +

      + +
      +


      +

      +

      Introduction

      +

      This tutorial is meant to introduce the reader to the basic workflow of the FEM Workbench, as well as most of the tools that are available to perform a static analysis. +

      FEM tutorial result.png +

      +

      Requirements

      +
      • FreeCAD version 0.16.6700 or above
      • +
      • Netgen and/or GMSH is installed on the system
      • +
      • In the case of GMSH, installation of psicofil's macro is recommended
      • +
      • Calculix is installed on the system
      • +
      • The reader has the basic knowledge to use the Part and PartDesign Workbenches
      +

      Procedure

      +

      Modeling

      +

      In this example a Cube is used as the study object, but models created in the Part or PartDesign Workbenches can be used instead. +

      +
      1. Create a new document
      2. +
      3. Activate the Part Workbench
      4. +
      5. Create a Cube
      6. +
      7. Change its Dimensions to the following: +
        1. Height: 1.000 mm
        2. +
        3. Length: 8.000 mm
        4. +
        5. Width: 1.000 mm
      +

      Now we have a model with which to work with. +

      +

      Creating the Analysis

      +
      Netgen
      +
      1. Select the model
      2. +
      3. Click FEM Analysis.png New mechanical analysis from the menu to create an analysis from the object that was selected
      4. +
      5. In the meshing dialog, click OK
      +

      You can also drag and drop a mesh to a Mechanical Analysis that does not have a mesh within the Tree View. +

      +
      GMSH
      +

      The usage of psicofil's macro is recommended, and is used for this example. +

      +
      1. Activate the macro
      2. +
      3. Select the object you wish to use, in this case our Cube
      4. +
      5. Check the box Create Mechanical Analysis from mesh
      6. +
      7. Click OK
      +

      We have now meshed our object and are ready to add constraints and forces. +

      +

      Constraints and Forces

      +
      1. Hide the mesh from the Tree View.
      2. +
      3. Show the original model
      4. +
      5. Select FEM FixedConstraint.png Create FEM fixed constraint
      6. +
      7. Select the back face of the Cube (face on the YZ axis) and click OK
      8. +
      9. Select FEM ForceConstraint.png Create FEM force constraint
      10. +
      11. Select the front face of the Cube (the face parallel to the back face) and set the Area load value to 9000000.00
      12. +
      13. Set the Direction to -Z by selecting one of the face edges parallel to that direction.
      14. +
      15. Click OK
      +

      We now have established the restrictions and forces for our static study. +

      +

      Final preparations

      +
      1. Select FEM Material.png Mechanical material... and choose Calculix as the material
      2. +
      3. Click OK
      +

      Running the Solver

      +
      Standard Procedure
      +
      1. Select the solver object FEM Solver.png contained in the Mechanical Analysis
      2. +
      3. Select FEM Calculation.png Start calculation from the menu
      4. +
      5. Select Write Calculix Input File
      6. +
      7. Select Run Calculix
      8. +
      9. Click Close
      +
      Quick Procedure
      +
      1. Select the solver object FEM Solver.png contained in the Mechanical Analysis
      2. +
      3. Click on FEM RunCalculiXccx.png Quick Analysis.
      +

      Analyzing Results

      +
      1. From the Object Tree, select the Results object
      2. +
      3. Select FEM ShowResult.png Show result
      4. +
      5. Choose among the different Result types to view the results
      6. +
      7. The slider at the bottom can be used to alter the mesh visualization. This allows us to visualize the deformation experienced by the object, keep in mind that this is an approximation.
      8. +
      9. To remove the results select FEM PurgeResults.png Purge results
      +
      Comparison to previous example file +

      If you select the Z displacement result type, you can see that the obtained value is almost identical to the test example provided by FreeCAD. Differences may occur due to the quality of the mesh and the number of nodes it possesses. +

      +
      +


      +We are now finished with the basic workflow for the FEM Module. +


      +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/FEMforceonline.PNG b/localwiki/FEMforceonline.PNG new file mode 100644 index 0000000..af9a803 Binary files /dev/null and b/localwiki/FEMforceonline.PNG differ diff --git a/localwiki/Fcblender.jpg b/localwiki/Fcblender.jpg new file mode 100644 index 0000000..c910c59 Binary files /dev/null and b/localwiki/Fcblender.jpg differ diff --git a/localwiki/Fcstd_file_format.html b/localwiki/Fcstd_file_format.html new file mode 100644 index 0000000..e488313 --- /dev/null +++ b/localwiki/Fcstd_file_format.html @@ -0,0 +1,258 @@ +Fcstd file format

      Fcstd file format

      (Redirected from Fcstd file format)
      + +

      The FreeCAD Standard file format (.FCStd) is FreeCAD's main file format. It is a compound format, supports compression and embedding of different kinds of data. +

      + + +

      Internals of .FCStd files

      +

      FCStd is a standard zip file, containing one or more files in a specific Structure. As such, it is possible to unpack a FCStd file using a regular zip decompression tool, but care needs to be taken while packing the contents of a FCStd file. FreeCAD contains a "Project Utility" to re-pack FCStd files, it's use is described in #Change the source of the file .FCStd below. +

      +

      Contents

      +

      Document.xml

      +

      This is the main xml file describing all the objects inside a FreeCAD document, that is, only the geometric and parametric definition of the objects, not their visual representation. If FreeCAD is ran in console mode (without the GUI), only this xml document will be used.= +

      +
      Example Document.xml
      +
       <?xml version='1.0' encoding='utf-8'?>
      + <!--
      + FreeCAD Document, see http://free-cad.sourceforge.net for more informations...
      + -->
      + <Document SchemaVersion="4">
      +    <Properties Count="9">
      +       <Property name="Comment" type="App::PropertyString">
      +          <String value=""/>
      +       </Property>
      +       <Property name="Company" type="App::PropertyString">
      +          <String value=""/>
      +       </Property>
      +       <Property name="CreatedBy" type="App::PropertyString">
      +          <String value=""/>
      +       </Property>
      +       <Property name="CreationDate" type="App::PropertyString">
      +          <String value="Fri Jan 29 15:14:38 2010 "/>
      +       </Property>
      +       <Property name="FileName" type="App::PropertyString">
      +          <String value="/tmp/test.FCStd"/>
      +       </Property>
      +       <Property name="Id" type="App::PropertyString">
      +          <String value="201b746f-a1ed-4297-bf3d-65d5ec11abe0"/>
      +       </Property>
      +       <Property name="Label" type="App::PropertyString">
      +          <String value="names"/>
      +       </Property>
      +       <Property name="LastModifiedBy" type="App::PropertyString">
      +          <String value=""/>
      +       </Property>
      +       <Property name="LastModifiedDate" type="App::PropertyString">
      +          <String value="Fri Jan 29 15:15:21 2010 "/>
      +       </Property>
      +    </Properties>
      +    <Objects Count="2">
      +       <Object type="Mesh::Cube" name="Cube" />
      +       <Object type="Part::Box" name="Box" />
      +    </Objects>
      +    <ObjectData Count="2">
      +       <Object name="Cube">
      +          <Properties Count="7">
      +             <Property name="Height" type="App::PropertyFloatConstraint">
      +                <Float value="10"/>
      +             </Property>
      +             <Property name="Label" type="App::PropertyString">
      +                <String value="Cube"/>
      +             </Property>
      +             <Property name="Length" type="App::PropertyFloatConstraint">
      +                <Float value="10"/>
      +             </Property>
      +             <Property name="Mesh" type="Mesh::PropertyMeshKernel">
      +                <Mesh file="MeshKernel.bms"/>
      +             </Property>
      +             <Property name="Placement" type="App::PropertyPlacement">
      +                <PropertyPlacement Px="0" Py="0" Pz="0" Q0="0" Q1="0" Q2="0" Q3="1"/>
      +             </Property>
      +             <Property name="Pos" type="App::PropertyPlacementLink">
      +                <Link value=""/>
      +             </Property>
      +             <Property name="Width" type="App::PropertyFloatConstraint">
      +                <Float value="10"/>
      +             </Property>
      +          </Properties>
      +       </Object>
      +       <Object name="Box">
      +          <Properties Count="7">
      +             <Property name="Height" type="App::PropertyLength">
      +                <Float value="10"/>
      +             </Property>
      +             <Property name="Label" type="App::PropertyString">
      +                <String value="Box2"/>
      +             </Property>
      +             <Property name="Length" type="App::PropertyLength">
      +                <Float value="10"/>
      +             </Property>
      +             <Property name="Placement" type="App::PropertyPlacement">
      +                <PropertyPlacement Px="0" Py="0" Pz="0" Q0="0" Q1="0" Q2="0" Q3="1"/>
      +             </Property>
      +             <Property name="Pos" type="App::PropertyPlacementLink">
      +                <Link value=""/>
      +             </Property>
      +             <Property name="Shape" type="Part::PropertyPartShape">
      +                <Part file="PartShape.brp2"/>
      +             </Property>
      +             <Property name="Width" type="App::PropertyLength">
      +                <Float value="10"/>
      +             </Property>
      +          </Properties>
      +       </Object>
      +    </ObjectData>
      + </Document>
      +

      GuiDocument.xml

      +

      This is the GUI counterpart of the Document.xml file. For each object described in the Document.xml, there is one corresponding object in GuiDocument.xml, describing the visual representation of that object (color, linewidth, etc). +

      +

      Thumbnails/thumbnail.png

      +

      This is a 128x128 pixels thumbnail image of the document, which is a screenshot of the 3D view at save time. Thumbnails are generated only if the corresponding option is enabled in the FreeCAD preferences. +

      +

      Templates/*.svg

      +

      In the Templates folder are stored the template svg files used in Drawing pages. +

      +

      *.brep

      +

      These are the .brep shapes of all objects that have a Part shape in the Document.xml. Each object, even if it is parametric, has its shape stored as an individual .brep file, so it can be accessed by components without the need to recalculate the shape. +

      +

      Structure

      +

      Structure of a typical FCStd file: +

      +
       --File.fcstd
      +  |
      +  --Document.xml
      +  --GuiDocument.xml
      +   |
      +   --Thumbnails
      +    |
      +    --thumbnail.png
      +   |
      +   --Templates
      +    |
      +    --MyPage.svg
      +  --Shape1.brep
      +  --Shape2.brep
      +  --etc...
      +

      Change the source of the file .FCStd

      +
      ATTENTION ALWAYS WORK ON A COPY OF YOUR PROJECT !
      +


      +It is possible to change the source of a file .FCStd but the procedure is not without risk it is for this reason that we need to work on a copy. +

      After having made an copy of your project, follow these steps : +

      Create a new directory and place your copy in that directory (there may be many files in your FCStd). +

      +
      • Go in Menu > tools > Project utility... Project utility
      +

      Project utility en.png +

      +
      • Source : Give your copy to unpack path.
      • +
      • Destination : Give the path to the unzipped files.
      • +
      • Click Extract
      • +
      • Go to your directory and open both files GuiDocument.xml andt Document.xml using Notepad++ (Windows) (Notepad++ to modify a word in all open documents).
      • +
      • GuiDocument.xml : contains all your project information to the interface, display in the Combo view, the configuration of FreeCAD . . . +
        • Example with Text004
      +
      <ViewProvider name="Text004">
      +<Properties Count="9">
      +<Property name="DisplayMode" type="App::PropertyEnumeration">
      +<Integer value="1"/>
      +</Property>
      +<Property name="FontName" type="App::PropertyString">
      +<String value="Arial"/>
      +</Property>
      +<Property name="FontSize" type="App::PropertyFloat">
      +<Float value="5.199999809265"/>
      +</Property>
      +<Property name="Justification" type="App::PropertyEnumeration">
      +<Integer value="0"/>
      +</Property>
      +<Property name="LineSpacing" type="App::PropertyFloat">
      +<Float value="0.600000023842"/>
      +</Property>
      +<Property name="Rotation" type="App::PropertyAngle">
      +<Float value="0.000000000000"/>
      +</Property>
      +<Property name="RotationAxis" type="App::PropertyEnumeration">
      +<Integer value="2"/>
      +</Property>
      +<Property name="TextColor" type="App::PropertyColor">
      +<PropertyColor value="4294901760"/>
      +</Property>
      +<Property name="Visibility" type="App::PropertyBool">
      +<Bool value="true"/>
      +</Property>
      +</Properties>
      +</ViewProvider>
      +
      • Document.xml : contains all information relating to the constituent objects your project. +
        • Example with Text004
      +
      <Object type="App::Annotation" name="Text004" />
      +


      +

      +
      <Object name="Text004">
      +<Properties Count="3">
      +<Property name="Label" type="App::PropertyString">
      +<String value="Text004"/>
      +</Property>
      +<Property name="LabelText" type="App::PropertyStringList">
      +<StringList count="1">
      +<String value="135"/>
      +</StringList>
      +</Property>
      +<Property name="Position" type="App::PropertyVector">
      +<PropertyVector valueX="-30.000000000000" valueY="26.000000000000" valueZ="0.000000000000"/>
      +</Property>
      +</Properties>
      +</Object>
      +
      • Information such as :
      +
      <VectorList file="Points1"/> 
      +<ColorList file="DiffuseColor"/> 
      +<Mesh file="MeshKernel.bms"/> 
      +<Part file="PartShape.brp2"/>
      +. . . .
      +
      • as well as other definitions containers file= relate has a file and if you change example "DiffuseColor" in <ColorList file="DiffuseColor"/> You must also change the name of the file for correspondence.
      • +
      • Once the Word change is identified, search (your Word) and Replace by (your new word) and click on Replace in all open documents and your change will be the same in both files GuiDocument.xml and Document.xml.
      • +
      • When changes are complete, return to the tool Menu > Tools > Project utility... Create project
      • +
      • Source : Give the path of the file that you just changed and that is to restore.
      • +
      • Destination : Give the path of the FCStd file to restore.
      • +
      • Click ... In the new window click on Create a new folder (to avoid errors by rewriting the file) and you post. Click on Create you can check the "Load project file after creation".
      • +
      • If you have checked "Load project file after creation" your project will load in FreeCAD.
      • +
      • PS : It is imperative that it have concordance GuiDocument.xml, Document.xml documents and files without which there will be errors in your .FCStd file. To do this should always work on a copy of your project.
      +

      Other

      +

      Here, a file Converter utility ImageConv. +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Fctutorial-complete.jpg b/localwiki/Fctutorial-complete.jpg new file mode 100644 index 0000000..ed1ffd2 Binary files /dev/null and b/localwiki/Fctutorial-complete.jpg differ diff --git a/localwiki/Feature-CAM.jpg b/localwiki/Feature-CAM.jpg new file mode 100644 index 0000000..309265f Binary files /dev/null and b/localwiki/Feature-CAM.jpg differ diff --git a/localwiki/Feature-arch.jpg b/localwiki/Feature-arch.jpg new file mode 100644 index 0000000..53482ed Binary files /dev/null and b/localwiki/Feature-arch.jpg differ diff --git a/localwiki/Feature-assembly.jpg b/localwiki/Feature-assembly.jpg new file mode 100644 index 0000000..fd24197 Binary files /dev/null and b/localwiki/Feature-assembly.jpg differ diff --git a/localwiki/Feature-raytracing.jpg b/localwiki/Feature-raytracing.jpg new file mode 100644 index 0000000..3bb39f3 Binary files /dev/null and b/localwiki/Feature-raytracing.jpg differ diff --git a/localwiki/Feature.svg b/localwiki/Feature.svg new file mode 100644 index 0000000..714a669 --- /dev/null +++ b/localwiki/Feature.svg @@ -0,0 +1,119 @@ + + + + + + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Feature1.jpg b/localwiki/Feature1.jpg new file mode 100644 index 0000000..a127168 Binary files /dev/null and b/localwiki/Feature1.jpg differ diff --git a/localwiki/Feature3.jpg b/localwiki/Feature3.jpg new file mode 100644 index 0000000..1ebefb5 Binary files /dev/null and b/localwiki/Feature3.jpg differ diff --git a/localwiki/Feature4.jpg b/localwiki/Feature4.jpg new file mode 100644 index 0000000..ad74f41 Binary files /dev/null and b/localwiki/Feature4.jpg differ diff --git a/localwiki/Feature5.jpg b/localwiki/Feature5.jpg new file mode 100644 index 0000000..51391da Binary files /dev/null and b/localwiki/Feature5.jpg differ diff --git a/localwiki/Feature7.jpg b/localwiki/Feature7.jpg new file mode 100644 index 0000000..fcc6b0c Binary files /dev/null and b/localwiki/Feature7.jpg differ diff --git a/localwiki/Feature8.jpg b/localwiki/Feature8.jpg new file mode 100644 index 0000000..509365b Binary files /dev/null and b/localwiki/Feature8.jpg differ diff --git a/localwiki/Feature9.jpg b/localwiki/Feature9.jpg new file mode 100644 index 0000000..41268d3 Binary files /dev/null and b/localwiki/Feature9.jpg differ diff --git a/localwiki/FeatureSelectionView.jpg b/localwiki/FeatureSelectionView.jpg new file mode 100644 index 0000000..62f5691 Binary files /dev/null and b/localwiki/FeatureSelectionView.jpg differ diff --git a/localwiki/Feature_list.html b/localwiki/Feature_list.html new file mode 100644 index 0000000..3feab4f --- /dev/null +++ b/localwiki/Feature_list.html @@ -0,0 +1,85 @@ +Feature list

      Feature list

      + +

      This is an extensive, hence not complete, list of features FreeCAD implements. If you want to look into the future see the Development roadmap for a quick overview of what's coming next. Also, the Screenshots are a nice place to go. +

      + + +

      Release notes

      + +

      Key features

      +
      • Feature1.jpg
        A complete Open CASCADE Technology-based geometry kernel allowing complex 3D operations on complex shape types, with native support for concepts like brep, nurbs curves and surfaces, a wide range of geometric entities, boolean operations and fillets, and built-in support of STEP and IGES formats
      +
      • Feature3.jpg
        A full parametric model. All FreeCAD objects are natively parametric, which means their shape can be based on properties or even depend on other objects, all changes being recalculated on demand, and recorded by the undo/redo stack. New object types can be added easily, that can even be fully programmed in Python
      +
      • Feature4.jpg
        A modular architecture that allow plugins (modules) to add functionality to the core application. Those extensions can be as complex as whole new applications programmed in C++ or as simple as Python scripts or self-recorded macros. You have complete access from the Python built-in interpreter, macros or external scripts to almost any part of FreeCAD, being geometry creation and transformation, the 2D or 3D representation of that geometry (scenegraph) or even the FreeCAD interface
      + +
      • Feature7.jpg
        A Sketcher with constraint-solver, allowing to sketch geometry-constrained 2D shapes. The sketcher currently allows you to build several types of constrained geometry, and use them as a base to build other objects throughout FreeCAD.
      +
      • Feature9.jpg
        A Robot simulation module that allows to study robot movements. The robot module already has an extended graphical interface allowing GUI-only workflow.
      +
      • Feature8.jpg
        A comfortable new module for creating traditional drawing sheets with options like detail view, cross sections, dimensioning and others, that permit to put 2D views of your 3D models on a sheet. This modules then produces ready-to-export SVG or PDF sheets. There exist still the older Drawing module with its sparse Gui-commands but a powerful Python functionality.
      +
      • Feature-raytracing.jpg
        A Rendering module that can export 3D objects for rendering with external renderers. Currently only supports povray and LuxRender, but is expected to be extended to other renderers in the future.
      + +
      • Feature-CAM.jpg
        Path module dedicated to mechanical machining like milling (CAM), and is able to output, display and adjust G code.
      + +


      +

      +

      General features:

      +
      • FreeCAD is multi-platform. It runs and behaves exactly the same way on Windows Linux and macOS platforms.
      +
      • FreeCAD is a full GUI application. FreeCAD has a complete Graphical User Interface based on the famous Qt framework, with a 3D viewer based on Open Inventor, allowing fast rendering of 3D scenes and a very accessible scene graph representation.
      +
      • FreeCAD also runs as a command line application, with low memory footprint. In command line mode, FreeCAD runs without its interface, but with all its geometry tools. It can be, for example, used as server to produce content for other applications.
      +
      • FreeCAD can be imported as a Python module, inside other applications that can run Python scripts, or in a Python console. Like in console mode, the interface part of FreeCAD is unavailable, but all geometry tools are accessible.
      +
      • Workbench concept: In the FreeCAD interface, tools are grouped by workbenches. This allows to display only the tools used to accomplish a certain task, keeping the workspace uncluttered and responsive, and the application fast to load.
      +
      • Plugin/Module framework for late loading of features/data-types. FreeCAD is divided into a core application and modules, that are loaded only when needed. Almost all the tools and geometry types are stored in modules. Modules behave like plugins, and can be added or removed to an existing installation of FreeCAD.
      +
      • Parametric associative document objects: All objects in a FreeCAD document can be defined by parameters. Those parameters can be modified on the fly, and recomputed anytime. The relationship between objects is also stored, so modifying one object also modifies its dependent objects.
      +
      • Parametric primitive creation (box, sphere, cylinder, etc)
      +
      • Graphical modification operations like translation, rotation, scaling, mirroring, offset (trivial or after Jung/Shin/Choi) or shape conversion, in any plane of the 3D space
      + +
      • Graphical creation of planar geometry like lines, wires, rectangles, b-splines, circular or elliptic arcs in any plane of the 3D space
      +
      • Modeling with straight or revolution extrusions, sections and fillets.
      +
      • Topological components like vertices, edges, wires and planes (also via Python scripting).
      +
      • Testing and repairing tools for meshes: solid test, non-two-manifolds test, self-intersection test, hole filling and uniform orientation.
      +
      • Annotations like texts or dimensions
      +
      • Undo/Redo framework: Everything is undo/redoable, with access to the undo stack, so multiple steps can be undone at a time.
      +
      • Transaction management: The undo/redo stack stores document transactions and not single actions, allowing each tool to define exactly what must be undone or redone.
      +
      • Built-in scripting framework: FreeCAD features a built-in Python interpreter, and an API that covers almost any part of the application, the interface, the geometry and the representation of this geometry in the 3D viewer. The interpreter can run single commands up to complex scripts, in fact entire modules can even be programmed completely in Python.
      +
      • Built-in Python console with syntax highlighting, autocomplete and class browser: Python commands can be issued directly in FreeCAD and immediately return results, permitting scriptwriters to test functionality on the fly, explore the contents of the modules and easily learn about FreeCAD internals.
      +
      • User interaction mirroring on the console: Everything the user does in the FreeCAD interface executes Python code, which can be printed on the console and recorded in macros.
      +
      • Full macro recording & editing: The Python commands issued when the user manipulates the interface can then be recorded, edited if needed, and saved to be reproduced later.
      +
      • Compound (ZIP based) document save format: FreeCAD documents saved with .fcstd extension can contain many different types of information, such as geometry, scripts or thumbnail icons. The .fcstd file is itself a zip container, so a saved FreeCAD file has already been compressed.
      +
      • Fully customizable/scriptable Graphical User Interface. The Qt-based interface of FreeCAD is entirely accessible via the Python interpreter. Aside from the simple functions that FreeCAD itself provides to workbenches, the whole Qt framework is accessible too, allowing any operation on the GUI, such as creating, adding, docking, modifying or removing widgets and toolbars.
      +
      • Thumbnailer (Linux systems only at the moment): The FreeCAD document icons show the contents of the file in most file manager applications such as Gnome's Nautilus.
      +
      • A modular MSI installer allows flexible installations on Windows systems. Packages for Ubuntu systems are also maintained.
      +

      In development

      +
      • Feature-assembly.jpg
        An Assembly module that allows to work with multiple projects, multiple shapes, multiple documents, multiple files, multiple relationships... This module is currently in planning state.
      +


      +

      +

      Extra Workbenches

      +

      Power users have created various custom external workbenches. +

      + +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Feature_spreadsheet.png b/localwiki/Feature_spreadsheet.png new file mode 100644 index 0000000..efb0330 Binary files /dev/null and b/localwiki/Feature_spreadsheet.png differ diff --git a/localwiki/Fem-DataAlongLine.svg b/localwiki/Fem-DataAlongLine.svg new file mode 100644 index 0000000..b6b8291 --- /dev/null +++ b/localwiki/Fem-DataAlongLine.svg @@ -0,0 +1,55 @@ + + + + + + + + + + + image/svg+xml + + + + + [Alexander Gryson] + + + fem-DataAlongLine + 2017-03-11 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/ + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Fem-add-fem-mesh.svg b/localwiki/Fem-add-fem-mesh.svg new file mode 100644 index 0000000..a42edbe --- /dev/null +++ b/localwiki/Fem-add-fem-mesh.svg @@ -0,0 +1,244 @@ + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Fem-add-material.svg b/localwiki/Fem-add-material.svg new file mode 100644 index 0000000..c7ddb7a --- /dev/null +++ b/localwiki/Fem-add-material.svg @@ -0,0 +1,523 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + + + + + + + + + diff --git a/localwiki/Fem-add-part.svg b/localwiki/Fem-add-part.svg new file mode 100644 index 0000000..8081c63 --- /dev/null +++ b/localwiki/Fem-add-part.svg @@ -0,0 +1,446 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + + + + + + + diff --git a/localwiki/Fem-analysis.svg b/localwiki/Fem-analysis.svg new file mode 100644 index 0000000..79be343 --- /dev/null +++ b/localwiki/Fem-analysis.svg @@ -0,0 +1,121 @@ + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + + + A + + diff --git a/localwiki/Fem-beam-rotation.svg b/localwiki/Fem-beam-rotation.svg new file mode 100644 index 0000000..cafbda4 --- /dev/null +++ b/localwiki/Fem-beam-rotation.svg @@ -0,0 +1,575 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [Bernd Hahnebach] + + + fem-beam-section + 2015-09-18 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/ + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Fem-beam-section.svg b/localwiki/Fem-beam-section.svg new file mode 100644 index 0000000..3a5561c --- /dev/null +++ b/localwiki/Fem-beam-section.svg @@ -0,0 +1,285 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + diff --git a/localwiki/Fem-box.svg b/localwiki/Fem-box.svg new file mode 100644 index 0000000..fa4b3b5 --- /dev/null +++ b/localwiki/Fem-box.svg @@ -0,0 +1,77 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [Stefan Tröger] + + + fem-box + 2015-11-15 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/ + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + diff --git a/localwiki/Fem-cfd-analysis.svg b/localwiki/Fem-cfd-analysis.svg new file mode 100644 index 0000000..670dd14 --- /dev/null +++ b/localwiki/Fem-cfd-analysis.svg @@ -0,0 +1,70 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [qingfengxia] + + + fem-cfd-analysis + 2016-08-10 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/ + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Fem-clip-scalar.svg b/localwiki/Fem-clip-scalar.svg new file mode 100644 index 0000000..b41ed40 --- /dev/null +++ b/localwiki/Fem-clip-scalar.svg @@ -0,0 +1,71 @@ + + + + + + + image/svg+xml + + + + + [Alexander Gryson] + + + fem-clip-scalar + 2017-03-11 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/ + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Fem-clip.svg b/localwiki/Fem-clip.svg new file mode 100644 index 0000000..f34670c --- /dev/null +++ b/localwiki/Fem-clip.svg @@ -0,0 +1,68 @@ + + + + + + + image/svg+xml + + + + + [Alexander Gryson] + + + fem-clip + 2017-03-11 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/ + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Fem-constraint-InitialTemperature.svg b/localwiki/Fem-constraint-InitialTemperature.svg new file mode 100644 index 0000000..9acf1c2 --- /dev/null +++ b/localwiki/Fem-constraint-InitialTemperature.svg @@ -0,0 +1,222 @@ + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Fem-constraint-bearing.svg b/localwiki/Fem-constraint-bearing.svg new file mode 100644 index 0000000..8b9904b --- /dev/null +++ b/localwiki/Fem-constraint-bearing.svg @@ -0,0 +1,435 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Fem-constraint-contact.svg b/localwiki/Fem-constraint-contact.svg new file mode 100644 index 0000000..62b16eb --- /dev/null +++ b/localwiki/Fem-constraint-contact.svg @@ -0,0 +1,1025 @@ + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Fem-constraint-displacement.svg b/localwiki/Fem-constraint-displacement.svg new file mode 100644 index 0000000..b28939c --- /dev/null +++ b/localwiki/Fem-constraint-displacement.svg @@ -0,0 +1,108 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [vginkeo] + + + fem-constraint-displacement + 2016-02-11 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/ + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Fem-constraint-electrostatic-potential.svg b/localwiki/Fem-constraint-electrostatic-potential.svg new file mode 100644 index 0000000..ce25811 --- /dev/null +++ b/localwiki/Fem-constraint-electrostatic-potential.svg @@ -0,0 +1,78 @@ + + + + + + + + image/svg+xml + + + + + + + Pes + + + diff --git a/localwiki/Fem-constraint-fixed.svg b/localwiki/Fem-constraint-fixed.svg new file mode 100644 index 0000000..9c42928 --- /dev/null +++ b/localwiki/Fem-constraint-fixed.svg @@ -0,0 +1,192 @@ + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Fem-constraint-flow-velocity.svg b/localwiki/Fem-constraint-flow-velocity.svg new file mode 100644 index 0000000..1856666 --- /dev/null +++ b/localwiki/Fem-constraint-flow-velocity.svg @@ -0,0 +1,76 @@ + + + + + + + + image/svg+xml + + + + + + + V + + + diff --git a/localwiki/Fem-constraint-fluid-boundary.svg b/localwiki/Fem-constraint-fluid-boundary.svg new file mode 100644 index 0000000..ad30ba4 --- /dev/null +++ b/localwiki/Fem-constraint-fluid-boundary.svg @@ -0,0 +1,85 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [qingfengxia] + + + fem-constraint-fluid-boundary + 2016-08-10 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/ + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Fem-constraint-force.svg b/localwiki/Fem-constraint-force.svg new file mode 100644 index 0000000..18874f7 --- /dev/null +++ b/localwiki/Fem-constraint-force.svg @@ -0,0 +1,106 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [Przemo Firszt] + + + fem-constraint-force + 2015-07-28 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/ + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Fem-constraint-gear.svg b/localwiki/Fem-constraint-gear.svg new file mode 100644 index 0000000..186772d --- /dev/null +++ b/localwiki/Fem-constraint-gear.svg @@ -0,0 +1,1175 @@ + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Fem-constraint-heatflux.svg b/localwiki/Fem-constraint-heatflux.svg new file mode 100644 index 0000000..8507c1e --- /dev/null +++ b/localwiki/Fem-constraint-heatflux.svg @@ -0,0 +1,109 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [vdwalts] + + + fem-constraint-heatflux + 2016-08-01 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/ + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Fem-constraint-initial-flow-velocity.svg b/localwiki/Fem-constraint-initial-flow-velocity.svg new file mode 100644 index 0000000..a1c2983 --- /dev/null +++ b/localwiki/Fem-constraint-initial-flow-velocity.svg @@ -0,0 +1,62 @@ + + + + + + + image/svg+xml + + + + + + + V + + + I + diff --git a/localwiki/Fem-constraint-planerotation.svg b/localwiki/Fem-constraint-planerotation.svg new file mode 100644 index 0000000..181a205 --- /dev/null +++ b/localwiki/Fem-constraint-planerotation.svg @@ -0,0 +1,105 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [vdwalts] + + + fem-constraint-planerotation + 2016-08-01 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/ + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Fem-constraint-pressure.svg b/localwiki/Fem-constraint-pressure.svg new file mode 100644 index 0000000..1411753 --- /dev/null +++ b/localwiki/Fem-constraint-pressure.svg @@ -0,0 +1,121 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [Przemo Firszt] + + + fem-constraint-pressure + 2015-07-28 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/ + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Fem-constraint-pulley.svg b/localwiki/Fem-constraint-pulley.svg new file mode 100644 index 0000000..860d613 --- /dev/null +++ b/localwiki/Fem-constraint-pulley.svg @@ -0,0 +1,272 @@ + + + + + + image/svg+xml + + + + + [Przemo Firszt] + + + fem-constraint-pulley + 2015-07-28 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/ + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Fem-constraint-selfweight.svg b/localwiki/Fem-constraint-selfweight.svg new file mode 100644 index 0000000..c271a99 --- /dev/null +++ b/localwiki/Fem-constraint-selfweight.svg @@ -0,0 +1,87 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [Bernd Hahnebach] + + + fem-constraint-selfweight + 2016-07-21 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/ + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Fem-constraint-temperature.svg b/localwiki/Fem-constraint-temperature.svg new file mode 100644 index 0000000..e61b292 --- /dev/null +++ b/localwiki/Fem-constraint-temperature.svg @@ -0,0 +1,105 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [vdwalts] + + + fem-constraint-temperature + 2016-08-01 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/ + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Fem-constraint-transform.svg b/localwiki/Fem-constraint-transform.svg new file mode 100644 index 0000000..1d39707 --- /dev/null +++ b/localwiki/Fem-constraint-transform.svg @@ -0,0 +1,81 @@ + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [kgoao] + + + fem-constraint-transform + 2016-09-25 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/ + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Fem-control-solver.svg b/localwiki/Fem-control-solver.svg new file mode 100644 index 0000000..f9fa2dd --- /dev/null +++ b/localwiki/Fem-control-solver.svg @@ -0,0 +1,454 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + + + + + + + diff --git a/localwiki/Fem-cut.svg b/localwiki/Fem-cut.svg new file mode 100644 index 0000000..803b013 --- /dev/null +++ b/localwiki/Fem-cut.svg @@ -0,0 +1,68 @@ + + + + + + + image/svg+xml + + + + + [Alexander Gryson] + + + fem-cut + 2017-03-11 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/ + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Fem-cylinder.svg b/localwiki/Fem-cylinder.svg new file mode 100644 index 0000000..6b4ca98 --- /dev/null +++ b/localwiki/Fem-cylinder.svg @@ -0,0 +1,65 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [Stefan Tröger] + + + fem-cylinder + 2015-11-15 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/ + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + diff --git a/localwiki/Fem-data.svg b/localwiki/Fem-data.svg new file mode 100644 index 0000000..ff65799 --- /dev/null +++ b/localwiki/Fem-data.svg @@ -0,0 +1,62 @@ + + + + + + + + + + + + image/svg+xml + + + + + [Alexander Gryson] + + + fem-data + 2017-03-11 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/ + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Fem-elmer.svg b/localwiki/Fem-elmer.svg new file mode 100644 index 0000000..5c31380 --- /dev/null +++ b/localwiki/Fem-elmer.svg @@ -0,0 +1,98 @@ + + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Fem-equation-elasticity.svg b/localwiki/Fem-equation-elasticity.svg new file mode 100644 index 0000000..abe47b1 --- /dev/null +++ b/localwiki/Fem-equation-elasticity.svg @@ -0,0 +1,95 @@ + + + + + + + + + + + + + image/svg+xml + + + + + [Alexander Gryson] + + + fem-warp + 2017-03-11 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/ + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + diff --git a/localwiki/Fem-equation-electrostatic.svg b/localwiki/Fem-equation-electrostatic.svg new file mode 100644 index 0000000..3de5b63 --- /dev/null +++ b/localwiki/Fem-equation-electrostatic.svg @@ -0,0 +1,287 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [Alexander Gryson] + + + fem-warp + 2017-03-11 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/ + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Fem-equation-flow.svg b/localwiki/Fem-equation-flow.svg new file mode 100644 index 0000000..0dd0053 --- /dev/null +++ b/localwiki/Fem-equation-flow.svg @@ -0,0 +1,258 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [qingfengxia] + + + fem-constraint-fluid-boundary + 2016-08-10 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/ + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Fem-equation-fluxsolver.svg b/localwiki/Fem-equation-fluxsolver.svg new file mode 100644 index 0000000..4048dfc --- /dev/null +++ b/localwiki/Fem-equation-fluxsolver.svg @@ -0,0 +1,257 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [Alexander Gryson] + + + fem-warp + 2017-03-11 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/ + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Fem-equation-heat.svg b/localwiki/Fem-equation-heat.svg new file mode 100644 index 0000000..c1092a9 --- /dev/null +++ b/localwiki/Fem-equation-heat.svg @@ -0,0 +1,173 @@ + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [vdwalts] + + + fem-constraint-temperature + 2016-08-01 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/ + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Fem-femmesh-boundary-layer.svg b/localwiki/Fem-femmesh-boundary-layer.svg new file mode 100644 index 0000000..75848ec --- /dev/null +++ b/localwiki/Fem-femmesh-boundary-layer.svg @@ -0,0 +1,372 @@ + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Fem-femmesh-clear-mesh.svg b/localwiki/Fem-femmesh-clear-mesh.svg new file mode 100644 index 0000000..0d739c3 --- /dev/null +++ b/localwiki/Fem-femmesh-clear-mesh.svg @@ -0,0 +1,416 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [Bernd Hahnebach] + + + fem-femmesh-clear-mesh + 2016-12-23 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/ + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Fem-femmesh-create-node-by-poly.svg b/localwiki/Fem-femmesh-create-node-by-poly.svg new file mode 100644 index 0000000..ddec642 --- /dev/null +++ b/localwiki/Fem-femmesh-create-node-by-poly.svg @@ -0,0 +1,83 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [Bernd Hahnebach] + + + fem-femmesh-create-node-by-poly + 2016-11-28 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/ + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Fem-femmesh-from-shape.svg b/localwiki/Fem-femmesh-from-shape.svg new file mode 100644 index 0000000..4265f5d --- /dev/null +++ b/localwiki/Fem-femmesh-from-shape.svg @@ -0,0 +1,81 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [Bernd Hahnebach] + + + fem-femmesh-from-shape + 2016-11-28 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/ + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Fem-femmesh-gmsh-from-shape.svg b/localwiki/Fem-femmesh-gmsh-from-shape.svg new file mode 100644 index 0000000..d3c6444 --- /dev/null +++ b/localwiki/Fem-femmesh-gmsh-from-shape.svg @@ -0,0 +1,89 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [Bernd Hahnebach] + + + fem-femmesh-gmsh-from-shape + 2016-11-28 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/ + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Fem-femmesh-netgen-from-shape.svg b/localwiki/Fem-femmesh-netgen-from-shape.svg new file mode 100644 index 0000000..029b843 --- /dev/null +++ b/localwiki/Fem-femmesh-netgen-from-shape.svg @@ -0,0 +1,95 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [Bernd Hahnebach] + + + fem-femmesh-netgen-from-shape + 2016-11-28 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/ + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Fem-femmesh-print-info.svg b/localwiki/Fem-femmesh-print-info.svg new file mode 100644 index 0000000..489ca46 --- /dev/null +++ b/localwiki/Fem-femmesh-print-info.svg @@ -0,0 +1,62 @@ + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [Bernd Hahnebach] + + + fem-femmesh-print-info + 2016-12-23 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/ + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + diff --git a/localwiki/Fem-femmesh-region.svg b/localwiki/Fem-femmesh-region.svg new file mode 100644 index 0000000..9f63c43 --- /dev/null +++ b/localwiki/Fem-femmesh-region.svg @@ -0,0 +1,87 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + [Bernd Hahnebach] + + + fem-femmesh-region + 2016-12-20 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/ + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Fem-femmesh-result.svg b/localwiki/Fem-femmesh-result.svg new file mode 100644 index 0000000..94e6d83 --- /dev/null +++ b/localwiki/Fem-femmesh-result.svg @@ -0,0 +1,448 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [Bernd Hahnebach] + + + fem-femmesh-gmsh-from-shape + 2016-11-28 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/ + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Fem-femmesh-to-mesh.svg b/localwiki/Fem-femmesh-to-mesh.svg new file mode 100644 index 0000000..5e2bd76 --- /dev/null +++ b/localwiki/Fem-femmesh-to-mesh.svg @@ -0,0 +1,92 @@ + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [Bernd Hahnebach] + + + fem-femmesh-to-mesh + 2016-11-25 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/ + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Fem-fluid-section.svg b/localwiki/Fem-fluid-section.svg new file mode 100644 index 0000000..7a95db1 --- /dev/null +++ b/localwiki/Fem-fluid-section.svg @@ -0,0 +1,121 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [kgoao] + + + fem-fluid-section + 2017-02-28 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/ + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Fem-frequency-analysis.svg b/localwiki/Fem-frequency-analysis.svg new file mode 100644 index 0000000..110d97d --- /dev/null +++ b/localwiki/Fem-frequency-analysis.svg @@ -0,0 +1,126 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [Przemo Firszt] + + + fem-frequency-analysis + 2015-09-05 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/ + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + diff --git a/localwiki/Fem-inp-editor.svg b/localwiki/Fem-inp-editor.svg new file mode 100644 index 0000000..0801148 --- /dev/null +++ b/localwiki/Fem-inp-editor.svg @@ -0,0 +1,184 @@ + + + + + + image/svg+xml + + + + + + + + + http://jimmac.musichall.cz + + + + fem-inp-editor + 2015-07-28 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/ + + + FreeCAD LGPL2+ + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Fem-isosurface.svg b/localwiki/Fem-isosurface.svg new file mode 100644 index 0000000..2ea6752 --- /dev/null +++ b/localwiki/Fem-isosurface.svg @@ -0,0 +1,84 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [Alexander Gryson] + + + fem-isosurface + 2017-03-11 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/ + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + diff --git a/localwiki/Fem-linearizedstresses.svg b/localwiki/Fem-linearizedstresses.svg new file mode 100644 index 0000000..8012442 --- /dev/null +++ b/localwiki/Fem-linearizedstresses.svg @@ -0,0 +1,82 @@ + + + + + + + + + + + image/svg+xml + + + + + [mkhizenz] + + + fem-linearizedstresses + 2016-12-20 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/ + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Fem-material-fluid.svg b/localwiki/Fem-material-fluid.svg new file mode 100644 index 0000000..7e4d888 --- /dev/null +++ b/localwiki/Fem-material-fluid.svg @@ -0,0 +1,142 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [qingfengxia] + + + fem-material-fluid + 2017-01-22 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/ + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + diff --git a/localwiki/Fem-material-nonlinear.svg b/localwiki/Fem-material-nonlinear.svg new file mode 100644 index 0000000..1b41f03 --- /dev/null +++ b/localwiki/Fem-material-nonlinear.svg @@ -0,0 +1,143 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [Bernd Hahnebach] + + + fem-material-nonlinear + 2016-09-25 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/ + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + diff --git a/localwiki/Fem-material.svg b/localwiki/Fem-material.svg new file mode 100644 index 0000000..13ae7fd --- /dev/null +++ b/localwiki/Fem-material.svg @@ -0,0 +1,132 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [Przemo Firszt] + + + fem-material + 2015-07-28 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/ + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + diff --git a/localwiki/Fem-plane.svg b/localwiki/Fem-plane.svg new file mode 100644 index 0000000..049d17e --- /dev/null +++ b/localwiki/Fem-plane.svg @@ -0,0 +1,62 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [Stefan Tröger] + + + fem-plane + 2015-11-15 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/ + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + diff --git a/localwiki/Fem-purge-results.svg b/localwiki/Fem-purge-results.svg new file mode 100644 index 0000000..71d2900 --- /dev/null +++ b/localwiki/Fem-purge-results.svg @@ -0,0 +1,130 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [Przemo Firszt] + + + fem-purge-results + 2015-07-28 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/ + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Fem-result.svg b/localwiki/Fem-result.svg new file mode 100644 index 0000000..369b941 --- /dev/null +++ b/localwiki/Fem-result.svg @@ -0,0 +1,114 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [Przemo Firszt] + + + fem-result + 2015-07-28 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/ + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + diff --git a/localwiki/Fem-run-solver.svg b/localwiki/Fem-run-solver.svg new file mode 100644 index 0000000..26e4c73 --- /dev/null +++ b/localwiki/Fem-run-solver.svg @@ -0,0 +1,479 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + + + + + + + + + + + diff --git a/localwiki/Fem-shell-thickness.svg b/localwiki/Fem-shell-thickness.svg new file mode 100644 index 0000000..875d9a8 --- /dev/null +++ b/localwiki/Fem-shell-thickness.svg @@ -0,0 +1,77 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [Bernd Hahnebach] + + + fem-shell-thickness + 2015-09-18 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/ + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Fem-solver.svg b/localwiki/Fem-solver.svg new file mode 100644 index 0000000..c534c45 --- /dev/null +++ b/localwiki/Fem-solver.svg @@ -0,0 +1,61 @@ + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [Author qingfengxia] + + + fem-solver + 2015-11-15 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/ + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + diff --git a/localwiki/Fem-sphere.svg b/localwiki/Fem-sphere.svg new file mode 100644 index 0000000..e19eb08 --- /dev/null +++ b/localwiki/Fem-sphere.svg @@ -0,0 +1,68 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [Stefan Tröger] + + + fem-sphere + 2015-11-15 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/ + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + diff --git a/localwiki/Fem-static-analysis.svg b/localwiki/Fem-static-analysis.svg new file mode 100644 index 0000000..6a818aa --- /dev/null +++ b/localwiki/Fem-static-analysis.svg @@ -0,0 +1,102 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [vdwalts] + + + fem-static-analysis + 2016-08-01 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/ + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Fem-thermomechanical-analysis.svg b/localwiki/Fem-thermomechanical-analysis.svg new file mode 100644 index 0000000..912a854 --- /dev/null +++ b/localwiki/Fem-thermomechanical-analysis.svg @@ -0,0 +1,95 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [vdwalts] + + + fem-thermomechanical-analysis + 2016-08-01 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/ + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + diff --git a/localwiki/Fem-warp.svg b/localwiki/Fem-warp.svg new file mode 100644 index 0000000..51d2f92 --- /dev/null +++ b/localwiki/Fem-warp.svg @@ -0,0 +1,139 @@ + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [Alexander Gryson] + + + fem-warp + 2017-03-11 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/ + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + diff --git a/localwiki/FemWorkbench.jpg b/localwiki/FemWorkbench.jpg new file mode 100644 index 0000000..4b950fa Binary files /dev/null and b/localwiki/FemWorkbench.jpg differ diff --git a/localwiki/FemWorkbench.svg b/localwiki/FemWorkbench.svg new file mode 100644 index 0000000..7b98dca --- /dev/null +++ b/localwiki/FemWorkbench.svg @@ -0,0 +1,1692 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Fem_Preferences.html b/localwiki/Fem_Preferences.html new file mode 100644 index 0000000..414e382 --- /dev/null +++ b/localwiki/Fem_Preferences.html @@ -0,0 +1,44 @@ +Fem Preferences

      Fem Preferences

      + +

      The preferences screen of the Fem wokbench are found in the Preferences window (Menu Edit → Preferences → Fem). +

      + + +

      General

      +
      Preference Fem Tab 01.png
      +
      +

      CalculiX

      +
      Preference Fem Tab 02.png
      +
      +

      Gmsh

      +
      Preference Fem Tab 03.png
      +
      +

      Z88

      +
      Preference Fem Tab 04.png
      +
      +

      Elmer

      +
      Preference Fem Tab 05.png
      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Fem_ResultDisplacement.svg b/localwiki/Fem_ResultDisplacement.svg new file mode 100644 index 0000000..8d2ae98 --- /dev/null +++ b/localwiki/Fem_ResultDisplacement.svg @@ -0,0 +1,181 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + + + + + + + diff --git a/localwiki/Fem_Workbench.html b/localwiki/Fem_Workbench.html new file mode 100644 index 0000000..17ae217 --- /dev/null +++ b/localwiki/Fem_Workbench.html @@ -0,0 +1,135 @@ +Fem Workbench

      Fem Workbench

      (Redirected from Fem Workbench)
      + +

      The FEM Workbench provides modern Finite Element Analysis (FEA) workflow for FreeCAD. Mainly this means all tools to make an Finite Element Analysis are combined in one GUI. +

      FemWorkbench.jpg
      +

      The steps to do a FEA in FreeCAD FEM Workbench GUI are: +

      +
      • Preprocessing +
        • Modeling the geometry, in which FreeCAD is already a nearly full-grown software.
        • +
        • Create an Analysis: +
          • Create an FEM Mesh out of the geometrical model.
          • +
          • Add Constraints such as loads and support fixes to the analysis model.
          • +
          • Add a Material to the analysis model
      • +
      • Solving +
        • Solve the system of equations from within the FreeCAD GUI.
      • +
      • Postprocessing +
        • View Results inside FreeCAD GUI.
      +

      The above mainly describes how a FEA analysis is done inside FreeCAD FEM Workbench. For further documentation refer to the GUI Tools described later here. +

      As of FreeCAD version 0.15 the FEM-Module can be used on Windows, Mac OSX and Linux platforms. Since FEM Workbench makes use of external software, the amount of manual intervention until the FEM workbench is ready to use will depend on the OS that you are using. Check out FEM Install. +

      +

      Tools

      + +


      +

      + +


      +

      + +


      +

      + +


      +

      + +


      +

      +
      • Preferences Menu +
      +

      Tutorials

      +

      Tutorial 1 FEM CalculiX Cantilever 3D +

      Tutorial 2 FEM Tutorial +

      Tutorial 3 FEM Tutorial Python +

      Tutorial 4 FEM Shear of a Composite Block +

      Coupled thermal mechanical analysis tutorials PDF's +

      Video Tutorial 1 Forum post with you tube link +

      Video Tutorial 2 Forum post with you tube link +

      Further video Tutorials Forum post with you tube link +

      + +

      Links

      +

      FEM Install for a detailed description how to set up a working FEM Module. +

      FEM Mesh for further Information about the FEM Mesh in FreeCAD +

      FEM CalculiX for further Information about the interface between FEM Module and the current Solver CalculiX +

      FEM Project for more detailed informations about the Units, Limitations and the Development of FEM Module. +

      + +


      +

      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/FileOpenSavePath.png b/localwiki/FileOpenSavePath.png new file mode 100644 index 0000000..6bc4685 Binary files /dev/null and b/localwiki/FileOpenSavePath.png differ diff --git a/localwiki/FileSaveAs.png b/localwiki/FileSaveAs.png new file mode 100644 index 0000000..3aa6f8a Binary files /dev/null and b/localwiki/FileSaveAs.png differ diff --git a/localwiki/File_Format_FCStd.html b/localwiki/File_Format_FCStd.html new file mode 100644 index 0000000..0023e5f --- /dev/null +++ b/localwiki/File_Format_FCStd.html @@ -0,0 +1,258 @@ +File Format FCStd

      File Format FCStd

      + +

      The FreeCAD Standard file format (.FCStd) is FreeCAD's main file format. It is a compound format, supports compression and embedding of different kinds of data. +

      + + +

      Internals of .FCStd files

      +

      FCStd is a standard zip file, containing one or more files in a specific Structure. As such, it is possible to unpack a FCStd file using a regular zip decompression tool, but care needs to be taken while packing the contents of a FCStd file. FreeCAD contains a "Project Utility" to re-pack FCStd files, it's use is described in #Change the source of the file .FCStd below. +

      +

      Contents

      +

      Document.xml

      +

      This is the main xml file describing all the objects inside a FreeCAD document, that is, only the geometric and parametric definition of the objects, not their visual representation. If FreeCAD is ran in console mode (without the GUI), only this xml document will be used.= +

      +
      Example Document.xml
      +
       <?xml version='1.0' encoding='utf-8'?>
      + <!--
      + FreeCAD Document, see http://free-cad.sourceforge.net for more informations...
      + -->
      + <Document SchemaVersion="4">
      +    <Properties Count="9">
      +       <Property name="Comment" type="App::PropertyString">
      +          <String value=""/>
      +       </Property>
      +       <Property name="Company" type="App::PropertyString">
      +          <String value=""/>
      +       </Property>
      +       <Property name="CreatedBy" type="App::PropertyString">
      +          <String value=""/>
      +       </Property>
      +       <Property name="CreationDate" type="App::PropertyString">
      +          <String value="Fri Jan 29 15:14:38 2010 "/>
      +       </Property>
      +       <Property name="FileName" type="App::PropertyString">
      +          <String value="/tmp/test.FCStd"/>
      +       </Property>
      +       <Property name="Id" type="App::PropertyString">
      +          <String value="201b746f-a1ed-4297-bf3d-65d5ec11abe0"/>
      +       </Property>
      +       <Property name="Label" type="App::PropertyString">
      +          <String value="names"/>
      +       </Property>
      +       <Property name="LastModifiedBy" type="App::PropertyString">
      +          <String value=""/>
      +       </Property>
      +       <Property name="LastModifiedDate" type="App::PropertyString">
      +          <String value="Fri Jan 29 15:15:21 2010 "/>
      +       </Property>
      +    </Properties>
      +    <Objects Count="2">
      +       <Object type="Mesh::Cube" name="Cube" />
      +       <Object type="Part::Box" name="Box" />
      +    </Objects>
      +    <ObjectData Count="2">
      +       <Object name="Cube">
      +          <Properties Count="7">
      +             <Property name="Height" type="App::PropertyFloatConstraint">
      +                <Float value="10"/>
      +             </Property>
      +             <Property name="Label" type="App::PropertyString">
      +                <String value="Cube"/>
      +             </Property>
      +             <Property name="Length" type="App::PropertyFloatConstraint">
      +                <Float value="10"/>
      +             </Property>
      +             <Property name="Mesh" type="Mesh::PropertyMeshKernel">
      +                <Mesh file="MeshKernel.bms"/>
      +             </Property>
      +             <Property name="Placement" type="App::PropertyPlacement">
      +                <PropertyPlacement Px="0" Py="0" Pz="0" Q0="0" Q1="0" Q2="0" Q3="1"/>
      +             </Property>
      +             <Property name="Pos" type="App::PropertyPlacementLink">
      +                <Link value=""/>
      +             </Property>
      +             <Property name="Width" type="App::PropertyFloatConstraint">
      +                <Float value="10"/>
      +             </Property>
      +          </Properties>
      +       </Object>
      +       <Object name="Box">
      +          <Properties Count="7">
      +             <Property name="Height" type="App::PropertyLength">
      +                <Float value="10"/>
      +             </Property>
      +             <Property name="Label" type="App::PropertyString">
      +                <String value="Box2"/>
      +             </Property>
      +             <Property name="Length" type="App::PropertyLength">
      +                <Float value="10"/>
      +             </Property>
      +             <Property name="Placement" type="App::PropertyPlacement">
      +                <PropertyPlacement Px="0" Py="0" Pz="0" Q0="0" Q1="0" Q2="0" Q3="1"/>
      +             </Property>
      +             <Property name="Pos" type="App::PropertyPlacementLink">
      +                <Link value=""/>
      +             </Property>
      +             <Property name="Shape" type="Part::PropertyPartShape">
      +                <Part file="PartShape.brp2"/>
      +             </Property>
      +             <Property name="Width" type="App::PropertyLength">
      +                <Float value="10"/>
      +             </Property>
      +          </Properties>
      +       </Object>
      +    </ObjectData>
      + </Document>
      +

      GuiDocument.xml

      +

      This is the GUI counterpart of the Document.xml file. For each object described in the Document.xml, there is one corresponding object in GuiDocument.xml, describing the visual representation of that object (color, linewidth, etc). +

      +

      Thumbnails/thumbnail.png

      +

      This is a 128x128 pixels thumbnail image of the document, which is a screenshot of the 3D view at save time. Thumbnails are generated only if the corresponding option is enabled in the FreeCAD preferences. +

      +

      Templates/*.svg

      +

      In the Templates folder are stored the template svg files used in Drawing pages. +

      +

      *.brep

      +

      These are the .brep shapes of all objects that have a Part shape in the Document.xml. Each object, even if it is parametric, has its shape stored as an individual .brep file, so it can be accessed by components without the need to recalculate the shape. +

      +

      Structure

      +

      Structure of a typical FCStd file: +

      +
       --File.fcstd
      +  |
      +  --Document.xml
      +  --GuiDocument.xml
      +   |
      +   --Thumbnails
      +    |
      +    --thumbnail.png
      +   |
      +   --Templates
      +    |
      +    --MyPage.svg
      +  --Shape1.brep
      +  --Shape2.brep
      +  --etc...
      +

      Change the source of the file .FCStd

      +
      ATTENTION ALWAYS WORK ON A COPY OF YOUR PROJECT !
      +


      +It is possible to change the source of a file .FCStd but the procedure is not without risk it is for this reason that we need to work on a copy. +

      After having made an copy of your project, follow these steps : +

      Create a new directory and place your copy in that directory (there may be many files in your FCStd). +

      +
      • Go in Menu > tools > Project utility... Project utility
      +

      Project utility en.png +

      +
      • Source : Give your copy to unpack path.
      • +
      • Destination : Give the path to the unzipped files.
      • +
      • Click Extract
      • +
      • Go to your directory and open both files GuiDocument.xml andt Document.xml using Notepad++ (Windows) (Notepad++ to modify a word in all open documents).
      • +
      • GuiDocument.xml : contains all your project information to the interface, display in the Combo view, the configuration of FreeCAD . . . +
        • Example with Text004
      +
      <ViewProvider name="Text004">
      +<Properties Count="9">
      +<Property name="DisplayMode" type="App::PropertyEnumeration">
      +<Integer value="1"/>
      +</Property>
      +<Property name="FontName" type="App::PropertyString">
      +<String value="Arial"/>
      +</Property>
      +<Property name="FontSize" type="App::PropertyFloat">
      +<Float value="5.199999809265"/>
      +</Property>
      +<Property name="Justification" type="App::PropertyEnumeration">
      +<Integer value="0"/>
      +</Property>
      +<Property name="LineSpacing" type="App::PropertyFloat">
      +<Float value="0.600000023842"/>
      +</Property>
      +<Property name="Rotation" type="App::PropertyAngle">
      +<Float value="0.000000000000"/>
      +</Property>
      +<Property name="RotationAxis" type="App::PropertyEnumeration">
      +<Integer value="2"/>
      +</Property>
      +<Property name="TextColor" type="App::PropertyColor">
      +<PropertyColor value="4294901760"/>
      +</Property>
      +<Property name="Visibility" type="App::PropertyBool">
      +<Bool value="true"/>
      +</Property>
      +</Properties>
      +</ViewProvider>
      +
      • Document.xml : contains all information relating to the constituent objects your project. +
        • Example with Text004
      +
      <Object type="App::Annotation" name="Text004" />
      +


      +

      +
      <Object name="Text004">
      +<Properties Count="3">
      +<Property name="Label" type="App::PropertyString">
      +<String value="Text004"/>
      +</Property>
      +<Property name="LabelText" type="App::PropertyStringList">
      +<StringList count="1">
      +<String value="135"/>
      +</StringList>
      +</Property>
      +<Property name="Position" type="App::PropertyVector">
      +<PropertyVector valueX="-30.000000000000" valueY="26.000000000000" valueZ="0.000000000000"/>
      +</Property>
      +</Properties>
      +</Object>
      +
      • Information such as :
      +
      <VectorList file="Points1"/> 
      +<ColorList file="DiffuseColor"/> 
      +<Mesh file="MeshKernel.bms"/> 
      +<Part file="PartShape.brp2"/>
      +. . . .
      +
      • as well as other definitions containers file= relate has a file and if you change example "DiffuseColor" in <ColorList file="DiffuseColor"/> You must also change the name of the file for correspondence.
      • +
      • Once the Word change is identified, search (your Word) and Replace by (your new word) and click on Replace in all open documents and your change will be the same in both files GuiDocument.xml and Document.xml.
      • +
      • When changes are complete, return to the tool Menu > Tools > Project utility... Create project
      • +
      • Source : Give the path of the file that you just changed and that is to restore.
      • +
      • Destination : Give the path of the FCStd file to restore.
      • +
      • Click ... In the new window click on Create a new folder (to avoid errors by rewriting the file) and you post. Click on Create you can check the "Load project file after creation".
      • +
      • If you have checked "Load project file after creation" your project will load in FreeCAD.
      • +
      • PS : It is imperative that it have concordance GuiDocument.xml, Document.xml documents and files without which there will be errors in your .FCStd file. To do this should always work on a copy of your project.
      +

      Other

      +

      Here, a file Converter utility ImageConv. +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/File_browser.png b/localwiki/File_browser.png new file mode 100644 index 0000000..4401785 Binary files /dev/null and b/localwiki/File_browser.png differ diff --git a/localwiki/Filling.svg b/localwiki/Filling.svg new file mode 100644 index 0000000..58fa99e --- /dev/null +++ b/localwiki/Filling.svg @@ -0,0 +1,303 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + diff --git a/localwiki/FitSurface.svg b/localwiki/FitSurface.svg new file mode 100644 index 0000000..da2cb1f --- /dev/null +++ b/localwiki/FitSurface.svg @@ -0,0 +1,419 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + New Document + + + Jakub Steiner + + + http://jimmac.musichall.cz + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/FlamingoBlob.png b/localwiki/FlamingoBlob.png new file mode 100644 index 0000000..ad2ab65 Binary files /dev/null and b/localwiki/FlamingoBlob.png differ diff --git a/localwiki/Flamingo_Workbench.html b/localwiki/Flamingo_Workbench.html new file mode 100644 index 0000000..9fab9fe --- /dev/null +++ b/localwiki/Flamingo_Workbench.html @@ -0,0 +1,347 @@ +Flamingo Workbench

      Flamingo Workbench

      + +
      + +

      Introduction

      +

      "Flamingo tools" is a set of customized FreeCAD commands and objects that help to speed-up the drawing of frames and pipelines, mainly. +

      For convenience Flamingo tools are grouped in three toolbars/menus + one utility set. +

      +
      FlamingoBlob.png
      +
      • Frame tools: that is aimed to arrange frames, trusses and similar in FreeCAD using the Structure objects of Arch module. .../flamingo/tutorials/tutorialFrame.pdf
      • +
      • Pype tools: that's the logical continuation of frame tool since it deals with creating pipelines and tubular structures. It also features its own Python classes to create the piping objects, such as tubes, elbows, flanges etc. .../flamingo/tutorials/tutorialPype2.pdf
      • +
      • Eagle tools: that's basically an addition, and shortcut, to the very professional FreeCAD-PCB workbench (also available in the FreeCAD's add-on repository) to import position of objects from a .brd Eagle's file on a PCB drawn in FreeCAD with the a.m. workbench relating only on their names. It's also the origin, by extension, of the name of the entire workbench. .../flamingo/tutorials/tutorialEagle.pdf
      • +
      • Utilities toolbar provides some functionality to query the objects in the model and their distance, to move/rotate the work plane and a little hack of the DWire creation dialog of Draft module, which allow to change the WP position on-the-fly.
      +

      References

      + +

      FRAME TOOLS

      +
      Flamingos frame2.jpg
      +


      +

      +
      1) Place one-beam over one-edge (class frameIt)
      +

      Given a beam object and an edge in the model, this tool lay down the beam over the edge by selecting them one after the other until ESC is pressed. +

      +
      2) Fill the frame (class fillFrame)
      +

      Dialog to create over multiple edges selected in the viewport the beams of the type of that previously chosen among those present in the model. +

      With the button Select it's possible to change the type of beam. +

      +
      3) alignFlange (class alignFlange)
      +

      Dialog to rotate beams so that their surfaces are parallel to one reference plane. +

      It's possible to preselect the reference face before invoking the command. +

      The three XY, XZ and YZ buttons allow to choose directly the orientation of principal planes as the reference. +

      Finally it's possible to enter directly the new orientation of faces by the three coordinates of the normal and the button Set normal. +

      +
      4) Spin beams by 45 deg. (class spinSect)
      +

      Tool to spin one object around the "Z" axis of its shape by 45 degrees. +

      +
      5) Reverse orientation (class reverseBeam)
      +

      Tool to spin one object around the "X" axis of its shape by 180 degrees. +Notes: if one edge of the object is selected, that is used as the pivot of rotation. +

      +
      6) pivotTheBeam (class pivotBeam)
      +

      Dialog to rotate one beam or other object around one of its edges. +

      Angle textbox to insert the degree of rotation. +

      Reverse button to rotate in the opposite direction, if necessary. +

      OK to perform the action and Cancel to close the dialog. +

      +
      7) Flush the surfaces (class levelBeam)
      +

      Tool to flush the parallel faces of two objects. +Actually the command takes to the same level, respect the position and orientation of the first face selected, the center-of-mass of all faces selected. Thus it translates the objects even if the faces are not parallel. +

      +
      8) Mate the Edges (class alignEdge)
      +

      Tool to mate two parallel edges. +Actually the command moves the objects along the minimum distance of their selected edge to the first one. Thus it translates the object even if edges are not parallel and it's a good way to place objects in desired position. +It is also possible to select two edges of the same objects. With this method is possible to move quickly one object by steps defined on its own geometry. +

      +
      9) Rotate + mate the edges (class rotJoin)
      +

      Tool to translate and rotate the beams to mate two edges. Same as above but it also makes the edges co-linear. +

      +
      10) Shift the beam (class shiftBeam)
      +

      Dialog to translate and copy objects. +

      X, Y and Z textboxes for direct input the amount of translation in each direction. +

      Multiple textbox is the multiple coefficient of the translation amount. +

      Steps textbox is the denominator of the translation amount. It's used when the amount of translation is to be covered in some steps. +

      Get displacement button to take the amount and direction of translation from the distance of selected entities (points, edges, faces) or even from a single edge. In the latter case, a green arrow is displayed to show the direction. +

      OK to perform the action and Cancel to close the dialog. +

      +
      11) Stretch the beam (class stretchBeam)
      +

      Dialog to change the length of beams. +

      In the textbox write the new length that will be applied to selected beams or pipes. +Otherwise Get Length button takes the new length from the selected geometry (either the length of a beam or edge or the distance between geometric entities). +

      With the slider it's possible to change the length wirtten in the text-box from -100% to +100%. +

      Radio buttons Head and Tail allow to choose the side of the beam that will be changed. +

      +
      12) Extend the beam (class extend)
      +

      Dialog to extend one beam to one selected target. +

      If entities are preselected before calling this command, the first entity is automatically taken as target and the object attached to it is removed from the selection set. In any case it's possible to change the target object with the push-button Select. +

      +
      13) Adjust frames' angle (class adjustFrameAngle)
      +

      Tool to adjust the beams at square angles of frames. To understand at best how it works, refer to the previous tutorial. +

      +
      14) Insert a path (class insertPath)
      +

      Tool to create a continuous DWire over the path defined by the edges selected in the viewport, even if these are not touching or are intersecting in the middle or belongs to different objects. The only constraint is that exists the intersection between two subsequent edges, in the order that they were selected. +Also the DWire is given the view-properties of a center-line, i.e. orange and dash-dotted. +

      +
      15) FrameLine manager (class FrameLineManager)
      +

      Same as for "pype-line" objects, this is a dialog to create and change properties of "frame-line" objects. +

      Also similarly to what seen above, the frame-lines are objects that collects properties common to a set of beams (namely the beam's section) which are included in a common group in the tree of the model. +They also have an optional property ".Base", by default set to None, which is the centerline of the beams of the frame. After a path, alias .Base, is defined (a DWire or a Sketch) other beams can be added to the frame-line but they will be deleted when Redraw is invoked. +The dialog provides the following features: +

      +
      • a list of beams' profiles previously included in the model by "Insert Std. Sections" dialog (read further);
      • +
      • a combo-box to select the active FrameLine among those already created or <new> to create a new one;
      • +
      • a text-box where to write the name of the FrameLine that is going to be created; if nothing or "<name>", the FrameLined will be named as default "Telaio00n";
      • +
      • Insert button: creates a new FrameLine object or adds new members to the one selected in the combo-box if edges are selected in the active viewport.
      • +
      • Redraw button: creates new beams and places them over the selected path. New beams will be collected inside the group of the FrameLine. Does not create or update beams added to the FrameLine outside its defined path.
      • +
      • Clear button: deletes all beams in the FrameLine group. It applies also to beams added to the FrameLine outside its defined path.
      • +
      • Get Path button: assigns the Dwire selected to the attribute Path of the FrameLine object.
      • +
      • Get Profile button: changes the Profile attribute of the FrameLine object to the one of the beam selected in the viewport or the one selected in the list.
      • +
      • Copy profile checkbox: if checked generates a new profile object for each beam in order to avoid multiple references in the model.
      • +
      • Move to origin checkbox: if checked, moves the center-of-mass of the profile to the origin of coordinates system: that makes the centerline of the beam coincide with the c.o.m. of the profile.
      +

      If the name of a FrameLine object is modified, also the name of the relevant group will change automatically but not viceversa +

      +
      16) Insert Std. Sections (class insertSection)
      +

      Dialog to create the set of profiles to be used in the model for object FrameLine. +

      +
      • Section list: it includes all the sections defined in the .csv file corresponding to the selected section type.
      • +
      • Section types list: the types of profiles defined with the .csv files included in the folder /tables
      • +
      • Insert button: creates the group "Profiles_set", if not already existing, and adds to it the object of the selected profile.
      +

      Other profiles tables can be created by adding the relevant .csv file in the /tables folder. The rules to create or customize such tables are similar to those for pipe-lines. +

      Other profiles can be drafted in the model and dragged inside the group "Profiles_set". +

      The orientation of the DWires may influence the rendering of beams. +

      +

      PYPE TOOLS

      +
      Flamingos pype2.jpg
      +


      +

      +
      1) Insert a tube
      +

      Opens a dialog to insert tubes. +

      The top-right combo is a common feature for all "Insert ..." dialogs: it lists the pype-line objects defined in the current document: with this it's possible to select to which pype-line to assign the newly created pipes. You can also leave it to <none> so that the object is created on the root line of the part model. +In the top-left corner is printed the currently selected pipe rating, taken from the listbox in the right column. Pipes dimensions for each pipe-rating are defined in .csv files, which is possible to add or modify, with few simple naming rules, according needs. Curves, reductions etc. have the same rules for definition of their tables of dimensions: see files in ../Mod/flamingo/Tables. Read also "tutorialPype.pdf" to know how to customize or create them. +

      To define position and orientation of pipes, following selections are possible: +

      +
      • one or more straight edges
      • +
      • one or more curved edges
      • +
      • one or more vertexes
      • +
      • nothing; in this case the tube will be placed at origin.
      +

      If no length is specified, the default is 200 units (just a convenient length, in mm). +

      Reverse button allow to rotate by 180° the last tube created or those currently selected. +

      Apply button allow to apply a different lenght or Nominal diameter to the tubes currently selected. +

      +
      2) Insert a curve
      +

      Opens a dialog to insert one elbow. +

      Beside the common widgets with other "Insert..." dialogs, the Trim/Extend button allow to adjust the length of selected pipes to the selected edge of the curve. +To define position and orientation following selections are possible: +

      +
      • one vertex,
      • +
      • one circular edge
      • +
      • one pipe at one of its ends; in this case the curve's diameter and thickness will automatically fit those of the selected pipe
      • +
      • a pair of edges or pipes or beams, also not contiguous but intersecting; in this case curve's properties will automatically fit to connect the two selected objects; also selected pipes will be automatically trimmed or extended to the curve's edges
      • +
      • nothing; in this case the curve will be placed at origin.
      +

      If no angle is specified the default is 90 degrees. +

      +
      3) Insert a reduction
      +

      Opens a dialog to insert concentric reductions. +

      To define position and orientation following selections are possible: +two pipes parallel (possibly co-linear) +

      +
      • one pipe at one of its ends
      • +
      • one pipe
      • +
      • one circular edge
      • +
      • one straight edge
      • +
      • one vertex
      • +
      • nothing (created at origin)
      +

      In case one pipe is selected, its properties are applied to the reduction. +

      In case two pipes are selected, the tool will try automatically to connect them with the right major and minor diameter. +

      +
      4) Insert a cap
      +

      Opens dialog to insert caps. +

      To define position and orientation following selections are possible: +one or more curved edges (axis and origin across the center) +one or more vertexes +nothing +If a pipe edge is selected the caps' properties will automatically fit to those of the pipe. +

      +
      5) Insert a flange
      +

      Opens dialog to insert flanges. +To define position and orientation following selections are possible: +

      +
      • one or more circular edges,
      • +
      • one or more vertexes,
      • +
      • nothing.
      +

      In case one pipe is selected, its properties are applied to the flange. +

      +
      6) Insert a U-bolt
      +

      Opens dialog to insert U-bolts. +

      To define position and orientation following selections are possible: +

      +
      • one or more circular edges
      • +
      • one or more pipes
      • +
      • nothing.
      +

      In case one pipe is selected, its properties are aplied to the U-bolt. Moreover it's possible to choose to place the U-bolt at the Head or Tail ends or in the Middle of the pipes by checking the relevant box. +

      With Ref. face button it's possible to select the face of the support to which to orient the U-bolt axis. +

      +
      7) PypeLine Manager
      +

      Before talking about the dialog it's worth to recall what the pype-line object is in the context of Flamingo workbench. +

      This object represent a collection of objects "PType" that are updated with the methods defined in the Python class itself. At present time it creates, with the method "obj.Proxy.update(obj,[edges])", pipes and curves over the given edges and collect them in a group named according the object's obj.Label. +A standard bending radius "3D" (i.e. 1.5xO.D.) is applied for curves. The Bend Radius is a common property of object pype-line, thus it can be changed and then redrawn. +When the Label of the object pype-line is renamed, the name of its group is changed accordingly. +

      The class PypeLine2 has also the optional attribute ".Base", which namely represent the centerline of the piping: +

      +
      • If Base is None, PypeLine2 behaves like a bare container of objects, with possibility to group them automatically, assign one color and extract the part-list.
      • +
      • .Base can be a Wire or a Sketch or any object which has edges in its Shape.
      • +
      • Running "obj.Proxy.update(obj)", without any [edges], the class attempts to render the pypeline (Pipe and Elbow objects) on the "obj.Base" edges: for well defined geometries this usually leads to the desired result. If [edges] are given, pipes and curves will be drawn along them.
      • +
      • Running "obj.Proxy.purge(obj)" deletes from the model all Pipes and Elbows that belongs to the pype-line.
      • +
      • Remember that the object created outside the .Base won't be updated when the .Base is changed and the pypeline is redrawn and (except pipe and curves) won't be deleted if the pype-line is purged.
      +

      This understood, the command opens the dialog to create or modify one pype-line. +

      The dialog is very similar to those for insert other objects seen before. +

      The pipe ratings tables, where the O.D. and thickness are defined, are the same of those for tubes (e.g. Pipe_SCH-STD.csv). +

      When <new> is in the combo and Insert is pressed, a new pype-line object is created in the document with the relevant group. +

      It is possible to create one pypeline in three ways, according to the objects selected in the viewport when Insert is pushed: +

      +
      • nothing is selected. One pype-line is created with property .Base = None and included in its group with the specified name and color (or default values). The piping objects to populate it can be created one-by-one with the commands seen above or alternatively a centerline can be selected afterwards with Get Profile and Redraw buttons.
      • +
      • one DWire object is selected. It is automatically taken as Base and converted in a Path (orange, dash-dotted) and pipes and curves are drawn along it.
      • +
      • a set of edges are selected (even not contiguous but anyway having intersections extending their ends). One Path is created connecting all the edges (see the Path tool in the Frame toolbar) and assigned as .Base to the newly created pype-line. Then pipes and curves are drawn on it as above.
      +

      After that it's still possible to add other objects (such as Flange, Reduct...) using the relevant insertion commands described above. When objects are created within a pype-line they are automatically included in the relevant group of the model and the common properties (i.e. O.D., thickness, color, bending radius etc.) are applied. +

      If at least one pype-line is already in the model, that can be selected from the combo-box: in this case, pushing Insert creates the pipes and curves like described above but, instead of creating a new pype-line object, it adds them to the selected existing pype-line. Beware that the piping created in this way will be deleted at next Redraw. +

      Get Path, Get Profile and Color allow to change the .Base property, the nominal size and color of the object respectively. +

      Redraw re-create tubes and curves along the .Base (if defined) after any modification to the path or the properties of the pype-line. +

      Part list generates a .csv file with the bill of material of the piping object included in the pype-line selected in the combo. +

      +
      8) Break the pipe
      +

      Opens a dialog to break one pipe at a defined point, optionally making a gap between the ends of the two parts. Multiple selection is possible. +

      Insert in the Point text-box the length where the pipe or pipes are going to break: this can be an absolute value or just a percentage of the length (a numeral followed by %). In some case it's quicker to use the slide-bar at the bottom to change this value. +

      The Length button allow to measure the length of the selected pipe and use that as the reference of the slide-bar scale. +

      If it's needed just to break pipes in two, leave the Gap text-box to 0; otherwise define the length of the gap. If a reference length is choosen, also the gap can be defined as a percentage. As seen in the tutorial, it's possible to measure the gap from geometries in the model with the Get gap button: that's the distance between any geometric entity or even the length of a single edge. +

      Pushing on Break performs the action. +

      The Pypeline combo, as usual, allow to choose the group to which to assign the new objects created. +

      +
      9) Rotate by axis
      +

      Opens a dialog that allow to rotate one Part around the axis of its Shape. +

      The axis can be defined directly by input of its coordinates or by selecting one edge + the part to be rotated and pushing Get shape axis. +

      Move/Copy radio buttons allow to choose the corresponding action. Notice that when is Copy is choosen, the original object is the one that is moved while the copy lies in the original position. That may be important in retrieving the object in the model tree. +

      Angle text-box defines the amount of rotation. +

      Finally press OK once or more time to perform the action and Cancel to close the dialog. +

      Reverse makes the rotation the opposite way round. +

      +
      10) Rotate by edge
      +

      Opens a dialog to rotate any object around the axis of one of its circular edges. +

      The behaviour is similar to the command above but the dialog is simpler, since it's only necessary to select the circular edge of one object in the viewport and press OK to perform the action. +

      +
      11) Mate pipes edges.
      +

      When two circular edges belonging to different objects are selected, pressing this button will make the second object move to make the edges concentric and coplanar. +

      This works not only with pipes. +

      It may happen that orientation of second object is not the desired one: in that case it's necessary to reverse it using other placing tools available in the workbench. +

      +
      12) Put in the plane
      +

      (this is work-in-progress: at present time it places a curve at the intersection of two pipes) +

      +
      13) Extend pipes to intersection
      +

      By selecting two pipes, this command extend them both to their intersection point, if exists. +

      +
      14) Extend pipe to intersection
      +

      By selecting two pipes, this command extend the first to the intersection with the other, if exists. +

      +
      15) Lay-down the pipes
      +

      By selecting one face and multiple pipes, this command translates the pipe along the normal of the face in order to make them lie on its plane. +

      +
      16) Raise-up the support
      +

      Similar to the tool above but in this case is the support that is raised or lowered, so that the face is tangent to the pipe. +

      +

      UTILITIES

      +
      Flamingos utils.jpg
      +


      +

      +
      1) Make a polygon
      +

      The first two tools of utils are part of a separate project which aims to create an automatic scanner of rooms with a stepper motor and an ultrasonic distance meter. +This tool creates one regular polygon inside a sketch. +

      +
      2) Polygon from file
      +

      Tool to create any polygon inside a sketch taking vertexes from a .csv file, where they are stored in polar coordinates. +

      +
      3) Query the model
      +

      Tool to get various informations according to the object or objects selected. Beside length or distances, it is specifically suited to give informations related to beams and pipes (length, section, angle-between). +

      +
      4) Align workplane
      +

      Tool to set the position and rotation of working plane according to the selected existing geometry. +

      The normal of WP is defined scanning the elements in the following order: +

      +
      1. the normal of a face
      2. +
      3. the normal of the plane of a curve
      4. +
      5. the normal of the plane containing two segments
      +

      The origin of WP is defined (in order) by +

      +
      1. one vertex
      2. +
      3. the center of curvature of a line
      4. +
      5. the intersection of two lines
      6. +
      7. the center of an edge
      +
      5) Offset workplane
      +

      Shifts the WP along its normal vector. +To show the direction of offset, a temporary green arrow is displayed on the screen. Clearly also negative values are allowed. +

      +
      6) Rotate workplane
      +

      Rotates the WP around one of its axis. +Also in this case a green arrow is displayed in the viewport to identify the present orientation of the WP: the arrow is pointed in the Z direction and the long base of the arrow is layed over the X direction. +

      +
      7) Draw a DWire
      +

      This tool works exactly like the corresponding tool of Draft workbench but with few additional options at the end of the dialog. +As default, the origin of WP is redefined at each point added because this makes simpler to draw segments of known length and orientation using the snap-to-grid option. +Then two push-buttons, invoked also with the short-key Ctrl+Shift+(), allow to rotate and offset the WP as seen above without breaking the DWire object. +The last three buttons allow to quickly change the rotation of WP to be parallel to the principal planes. +

      +
      8) Quick move objects
      +

      To move quickly any part, to access the underlying objects for instance, this tool provides a graphic handle (green arrow) by clicking on which it's possible to displace and rotate the selected objects. +

      +
      9) Pressure loss calculator
      +

      Opens one dialog to calculate the pressure losses across the pype-parts selected in the viewport or across one PypeBranch. +The friction coefficient is calculated for each straight tube and elbow. For other objects the concentrated pressure loss is calculated through the flow factor, provided that the attribute Kv is available and set to a positive value. +

      +

      Installation

      +

      Automatic installation

      +

      See Installing +

      +

      From GitHub

      +

      To install the workbenches, you may copy as usual the files of this repository in a subfolder of \Mod in you FreeCAD installation of your system or use the addons-installer macro. +

      +

      Links to Flamingo WB

      + +

      Other useful links

      + +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Flamingos_frame2.jpg b/localwiki/Flamingos_frame2.jpg new file mode 100644 index 0000000..b499d69 Binary files /dev/null and b/localwiki/Flamingos_frame2.jpg differ diff --git a/localwiki/Flamingos_pype2.jpg b/localwiki/Flamingos_pype2.jpg new file mode 100644 index 0000000..c6b7718 Binary files /dev/null and b/localwiki/Flamingos_pype2.jpg differ diff --git a/localwiki/Flamingos_utils.jpg b/localwiki/Flamingos_utils.jpg new file mode 100644 index 0000000..08b01e6 Binary files /dev/null and b/localwiki/Flamingos_utils.jpg differ diff --git a/localwiki/Flatness.svg b/localwiki/Flatness.svg new file mode 100644 index 0000000..8eba17c --- /dev/null +++ b/localwiki/Flatness.svg @@ -0,0 +1,114 @@ + + + + + Flatness + + + + + + image/svg+xml + + Flatness + + + bavariaSHAPE + + + + + bavariaSHAPE + + + + + bavariaSHAPE + + + 15.10.2016 + Geometric dimensioning and tolerancing symbols +All symbols in this repository are licensed under CC-BY 3.0 + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Flatness_editable.svg b/localwiki/Flatness_editable.svg new file mode 100644 index 0000000..9ad0d66 --- /dev/null +++ b/localwiki/Flatness_editable.svg @@ -0,0 +1,110 @@ + + + + + Flatness + + + + + image/svg+xml + + Flatness + + + bavariaSHAPE + + + + + bavariaSHAPE + + + + + bavariaSHAPE + + + 15.10.2016 + Geometric dimensioning and tolerancing symbols +All symbols in this repository are licensed under CC-BY 3.0 + + + + + + + + + + + + + + + + + + + 0.000 + + + + diff --git a/localwiki/Frame_erxercise_failed_sketch.png b/localwiki/Frame_erxercise_failed_sketch.png new file mode 100644 index 0000000..5387618 Binary files /dev/null and b/localwiki/Frame_erxercise_failed_sketch.png differ diff --git a/localwiki/Frame_erxercise_pad.png b/localwiki/Frame_erxercise_pad.png new file mode 100644 index 0000000..99eb868 Binary files /dev/null and b/localwiki/Frame_erxercise_pad.png differ diff --git a/localwiki/Frame_exercise_dimensions.png b/localwiki/Frame_exercise_dimensions.png new file mode 100644 index 0000000..d8a8c0a Binary files /dev/null and b/localwiki/Frame_exercise_dimensions.png differ diff --git a/localwiki/FramesOn.png b/localwiki/FramesOn.png new file mode 100644 index 0000000..2a88aac Binary files /dev/null and b/localwiki/FramesOn.png differ diff --git a/localwiki/FreeCAD-0.17-missing-Graphviz-error-dialogue.png b/localwiki/FreeCAD-0.17-missing-Graphviz-error-dialogue.png new file mode 100644 index 0000000..31dcb50 Binary files /dev/null and b/localwiki/FreeCAD-0.17-missing-Graphviz-error-dialogue.png differ diff --git a/localwiki/FreeCAD-Ship-AreaCurveIco.png b/localwiki/FreeCAD-Ship-AreaCurveIco.png new file mode 100644 index 0000000..a4ef478 Binary files /dev/null and b/localwiki/FreeCAD-Ship-AreaCurveIco.png differ diff --git a/localwiki/FreeCAD-Ship-HydrostaticsIco.png b/localwiki/FreeCAD-Ship-HydrostaticsIco.png new file mode 100644 index 0000000..75a30a9 Binary files /dev/null and b/localwiki/FreeCAD-Ship-HydrostaticsIco.png differ diff --git a/localwiki/FreeCAD-Ship-Ico.png b/localwiki/FreeCAD-Ship-Ico.png new file mode 100644 index 0000000..e7844b4 Binary files /dev/null and b/localwiki/FreeCAD-Ship-Ico.png differ diff --git a/localwiki/FreeCAD-Ship-LoadIco.png b/localwiki/FreeCAD-Ship-LoadIco.png new file mode 100644 index 0000000..5b508b5 Binary files /dev/null and b/localwiki/FreeCAD-Ship-LoadIco.png differ diff --git a/localwiki/FreeCAD-Ship-OutlineDrawIco.png b/localwiki/FreeCAD-Ship-OutlineDrawIco.png new file mode 100644 index 0000000..512bf82 Binary files /dev/null and b/localwiki/FreeCAD-Ship-OutlineDrawIco.png differ diff --git a/localwiki/FreeCAD-Ship-S60Outline3DSections.png b/localwiki/FreeCAD-Ship-S60Outline3DSections.png new file mode 100644 index 0000000..db6ad74 Binary files /dev/null and b/localwiki/FreeCAD-Ship-S60Outline3DSections.png differ diff --git a/localwiki/FreeCAD-Ship-S60OutlinePlot.png b/localwiki/FreeCAD-Ship-S60OutlinePlot.png new file mode 100644 index 0000000..cd0e5b6 Binary files /dev/null and b/localwiki/FreeCAD-Ship-S60OutlinePlot.png differ diff --git a/localwiki/FreeCAD-Ship-S60ShipCreationFront.png b/localwiki/FreeCAD-Ship-S60ShipCreationFront.png new file mode 100644 index 0000000..34ba257 Binary files /dev/null and b/localwiki/FreeCAD-Ship-S60ShipCreationFront.png differ diff --git a/localwiki/FreeCAD-Ship-S60ShipCreationSide.png b/localwiki/FreeCAD-Ship-S60ShipCreationSide.png new file mode 100644 index 0000000..72fdb45 Binary files /dev/null and b/localwiki/FreeCAD-Ship-S60ShipCreationSide.png differ diff --git a/localwiki/FreeCAD-Ship-S60TankGeometry.png b/localwiki/FreeCAD-Ship-S60TankGeometry.png new file mode 100644 index 0000000..6882b96 Binary files /dev/null and b/localwiki/FreeCAD-Ship-S60TankGeometry.png differ diff --git a/localwiki/FreeCAD-Ship-S60WeightsPreview.png b/localwiki/FreeCAD-Ship-S60WeightsPreview.png new file mode 100644 index 0000000..4f00e34 Binary files /dev/null and b/localwiki/FreeCAD-Ship-S60WeightsPreview.png differ diff --git a/localwiki/FreeCAD-Ship-S60WeightsTanksPreview.png b/localwiki/FreeCAD-Ship-S60WeightsTanksPreview.png new file mode 100644 index 0000000..38a0544 Binary files /dev/null and b/localwiki/FreeCAD-Ship-S60WeightsTanksPreview.png differ diff --git a/localwiki/FreeCAD-Ship-ShipInstance.png b/localwiki/FreeCAD-Ship-ShipInstance.png new file mode 100644 index 0000000..e923dcd Binary files /dev/null and b/localwiki/FreeCAD-Ship-ShipInstance.png differ diff --git a/localwiki/FreeCAD-Ship-SignCriteria.jpg b/localwiki/FreeCAD-Ship-SignCriteria.jpg new file mode 100644 index 0000000..17d70f5 Binary files /dev/null and b/localwiki/FreeCAD-Ship-SignCriteria.jpg differ diff --git a/localwiki/FreeCAD-Ship-TankIco.png b/localwiki/FreeCAD-Ship-TankIco.png new file mode 100644 index 0000000..c6d705d Binary files /dev/null and b/localwiki/FreeCAD-Ship-TankIco.png differ diff --git a/localwiki/FreeCAD-Ship-WeightIco.png b/localwiki/FreeCAD-Ship-WeightIco.png new file mode 100644 index 0000000..84166a9 Binary files /dev/null and b/localwiki/FreeCAD-Ship-WeightIco.png differ diff --git a/localwiki/FreeCAD-Ship_s60_tutorial.html b/localwiki/FreeCAD-Ship_s60_tutorial.html new file mode 100644 index 0000000..e6c9be4 --- /dev/null +++ b/localwiki/FreeCAD-Ship_s60_tutorial.html @@ -0,0 +1,245 @@ +FreeCAD-Ship s60 tutorial

      FreeCAD-Ship s60 tutorial

      + +
      + + + + + + + + + + + + + + + + + + + + + + + + + + + +
      +

      Base ExampleCommandModel.png Tutorial

      +
      Topic +
      Ship Workbench +
      Level +
      Beginner +
      Time to complete +
      +
      Author +
      +
      FreeCAD version +
      +
      Example File(s) +
      +

      + +
      +


      +


      +In this tutorial we will work with Series 60 ship, from the Iowa University. The tutorial is aimed to show how to work with a symmetric monohull ship, but multihull or non symmetric ships can be performed with the same proceeding. +

      You can learn more about FreeCAD-Ship here +

      +

      Loading geometry

      +

      Introduction

      +

      FreeCAD-Ship works over Ship entities, that must be created on top of provided geometry. Geometry must be a solid, or set of solids, following criteria must be taken into account: +

      +
      • All hull geometry must be provided (including symmetric bodies).
      • +
      • Starboard geometry must be included at negatives y domain.
      • +
      • Origin (0,0,0) point is the Midship section (Midpoint between after and forward perpendicular) and base line intersection.
      +
      Schematic view of sign criteria
      +
      FreeCAD-Ship sign criteria
      +

      Loading Series 60 geometry

      +

      In order to help new users FreeCAD-Ship includes a geometries examples loader, with the following to choose from: +

      +
      • Series 60 from Iowa University
      • +
      • Wigley Canonical Ship
      • +
      • Series 60 Catamaran
      • +
      • Wigley Catamaran
      +
      Example ship geometries loader icon.
      +
      Ship Geometries Examples loader icon
      +

      Executing the tool (Ship design/Load an example ship geometry) a task dialogue will shown. Select Series 60 from Iowa University and press Accept. Tool loads new document with s60_IowaUniversity geometry. +

      +
      Warning, before editing anything!
      +
      You are now working with the original example file.
      +
      To preserve the original unedited example, you must first save it as a new file before editing anything.
      +


      +

      +

      Create ship instance

      +

      In order to create a Ship instance select s60 geometry and execute the ship creation tool (Ship design/Create a new ship). +

      +
      Ship creation tool.
      +
      Ship creation tool icon
      +

      Creating ship task dialogue and some annotations at 3D view will shown. The annotations will removed when you close Ship creation tool, so don't worry about this. +

      Most relevant ship data must be introduced (FreeCAD-Ship uses a progressive data introduction system, so basic operations can be performed knowing only basic ship data, more information is needed as the operations become more complex). +

      +

      Ship data

      +

      Main dimensions must be introduced here: +

      +
      • Length: Length between perpendiculars, 25.5 m for this ship.
      • +
      • Beam: Total ship beam, 3.389 m for this ship.
      • +
      • Draft: Design draft, 1.0 m for this ship.
      +
      Front view annotations
      +
      Length annotations.
      +

      Usually the Length between perpendiculars depends on design draft, so if you don't know what is the length of your ship you can set draft, and fit length in order to get bow and draft intersection. +

      +
      Side view annotations
      +
      Beam annotations.
      +

      Same process is valid for Beam fit. Note that requested value is total beam, but annotation is only refered to starboard half ship. +

      When you press Accept button program creates your new Ship instance called Ship at Tags & Attributes dialog. We don't need geometry anymore, so you can hide it. +

      +
      Ship instance icon
      +
      Ship instance icon.
      +

      From here onwards, you must have Ship selected before you execute any FreeCAD-Ship tool. +

      +

      Lines drawing

      +

      FreeCAD-Ship provides a tool that makes it easy to obtain a Lines Plan from the ship lines drawing +

      +
      Outline draw tool.
      +
      Lines drawing tool icon
      +

      Lines drawing is a set of lines from section cuts in all 3 axis, that will eventually show the hull geometry in a Lines Plan. We need to provide the lines for the 3 following views: +

      +
      • Body Plan (using the Transversal Cuts)
      • +
      • Sheer Plan (using the Longitudinals Cuts)
      • +
      • Half-Breadth Plan (using the Waterlines Cuts)
      +


      +

      +

      Transversal cuts

      +

      Usually 21 transversal equidistant sections between perpendiculars must be performed. in order to do it FreeCAD provides an automatic tool in order to do it, simply select Transversal type of sections, go to Auto create box and set 21 sections, then press Create sections. +

      +
      Outline draw transversal sections preview.
      +
      Outline draw transversal sections preview
      +

      Sections table is filled, and sections preview called OutlineDraw shown. Usually more sections was added at bow and stern, where more complex curvatures are registered, in order to do it go to the end of the table, and do double click at empty item in order to edit it, pressing intro to confirm. Add following sections: +

      +
      • X22 = -12.1125 m
      • +
      • X23 = 12.1125 m
      +

      Depending hull geometry complexity, sections preview can take some time. In order to remove a section, just fill it with an empty text and press enter. +

      +

      Longitudinal cuts

      +

      Two longitudinal cuts must be added, so select Longitudinal type of sections, go to Auto create box and set 2 sections, then press Create sections. Sections table is filled, and sections preview updated. +

      +

      Waterlines

      +

      6 Waterlines between base line and design draft must be added, so select Waterlines type of sections, go to Auto create box and set 5 (Z = 0 m will not be considered, add it manually if you need it) sections, then press Create sections. Sections table is filled, and sections preview updated. +

      Several additional waterlines must be added: +

      +
      • Z6 = 1.2 m
      • +
      • Z7 = 1.4 m
      • +
      • Z8 = 1.6 m
      • +
      • Z9 = 1.8 m
      • +
      • Z10 = 2.0 m
      +

      Perform plot

      +

      Select 1:100 scale and press Accept to let the tool to generate the 3D sections in a new object. +

      +
      Resultant sections.
      +
      Resultant sections.
      +

      In order to plot these sections you can use the drawing workbench: +

      +
      Outline draw plot.
      +
      Outline draw plot.
      +

      Transversal areas curve

      +

      One typical ship design hydrodynamic parameter is the transversal areas curve, that retrieves some indicators about the behaviour of the hull (towing resistance, seakeeping, ...). FreeCAD-Ship provides a simple tool in order to perform transversal areas curve. +

      +
      Transversal areas curve tool icon.
      +
      Transversal areas curve tool icon.
      +

      When tool is executed a task dialog is shown, and free surface prewied is created at 3D view (Free surface preview will be removed when tool finished, so don't worry about them). Into task dialog input and output data is present. +

      +

      Input data

      +

      Draft and trim (Hull y edge rotation angle, positive if stern draft may increase) must be provided. Several areas curves may be performed, depending on ship load situations, but two typical plot should be performed: +

      +
      • Design transversal areas curve: Without triming angle and using design draft, 1.0 m in this case.
      • +
      • Maximum draft transversal areas curve: Without trimin angle, and maximum draft allowed, 2.0 m in this case.
      +

      Output data

      +

      Some relevant data is shown at real time: +

      +
      • L: Lenght between perpendiculars, value set at ship instance creation.
      • +
      • B: Beam selected at ship creation.
      • +
      • T: Actual draft amidships.
      • +
      • Trim: Trim angle.
      • +
      • TAP: After perpendicular draft.
      • +
      • TFP: Forward perpendicular draft.
      • +
      • Displacement: Ship displacement (salt water considered, divide by 1.025 in order to know displaced volume).
      • +
      • XCB: Buoyancy centre point X coordinate (relative to midship section).
      +

      When Accept button is pressed a plot is performed (depending on geometry complexity can take some time, you can see progress on terminal, and stop the work pressing Ctrl+C). When the task has finished FreeCAD will generate a Plot (see the plot module documentation) and a SpreadSheet (see the Spreadsheet workbench documentation). +

      +
      Design draft transversal areas curve.
      +
      Design draft transversal areas curve.
      +

      You can perform maximum draft transversal areas curve in order to see the differences (for instance you are noticing that areas curve is passing through length perpendiculars now). +

      +

      Hydrostatics

      +

      Hydrostatics computation is a critical stage at ship design due to know principal stability hull parameters. Hydrostatics are mandatory data in order to classification societies certificates ship, and joined with loading condition data (weights and gravity position) provides essential data about ship stability. FreeCAD-Ship provides a tool to obtain main hydrostatics curves (GZ curves are considered in other tool). +

      +
      Hydrostatics tool icon.
      +
      Hydrostatics tool icon.
      +

      When tool is executed a task dialog is shown. Usually Hydrostatics curves are presented for each trim angle, in this tutorial only upright trimming angle will considered (0º), with an interval around every loading condition draft. Since we don't know what loading conditions we can get, we will consider almost draft possibilities (Usually, in order to get as many resolution as possible, naval architects fits the interval to feasible drafts). +

      So we set following data: +

      +
      • Trim = 0 deg
      • +
      • Minimum Draft = 0.1 m
      • +
      • Maximum Draft = 2.0 m
      • +
      • Number of points = 39. A lot of points or really complex geometries imply long computation times, in this case around 1 minute can be expend.
      +

      When Accept button is pressed plots are performed (see the plot module documentation) and a spreadsheet is generated (see the Spreadsheet workbench documentation). +

      +
      Hydrostatics curves.
      +
      Hydrostatics curves.
      +

      Continue learning FreeCAD-Ship

      +

      Now you are ready to continue learning Ship, here is the second chapter of Series 60 from Iowa university ship. +


      +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/FreeCAD-Ship_s60_tutorial_(II).html b/localwiki/FreeCAD-Ship_s60_tutorial_(II).html new file mode 100644 index 0000000..c13fef6 --- /dev/null +++ b/localwiki/FreeCAD-Ship_s60_tutorial_(II).html @@ -0,0 +1,187 @@ +FreeCAD-Ship s60 tutorial (II)

      FreeCAD-Ship s60 tutorial (II)

      + +
      + + + + + + + + + + + + + + + + + + + + + + + + + + + +
      +

      Base ExampleCommandModel.png Tutorial

      +
      Topic +
      Ship Workbench +
      Level +
      Beginner +
      Time to complete +
      +
      Author +
      +
      FreeCAD version +
      +
      Example File(s) +
      +

      + +
      +


      +


      +Before starting this tutorial, please ensure that you have already performed the first part. +

      You can learn more about FreeCAD-Ship here +

      +
      Windows users
      +
      FreeCAD-Ship have been recently integrated into FreeCAD package, so some bugs can be detected.
      +
      If your Ship module have icons lost, please rename ShipIcons folder at
      +
      C:\Program Files (x86)\FreeCAD0.13\Mod\Ship
      +
      path as Icons folder, and then restart FreeCAD.
      +


      +

      +

      Introduction

      +

      In this tutorial we will work with weights and tanks in order to compute GZ curve, the most important hydrostatic stability parameter. GZ is the static moment generated when the ship takes roll angle, of course, since the GZ arm is positive, the ship has a positive moment, and will try to recover upright position, but when GZ turns on negative numbers ship has not anymore stability, reaching a critical situation. +

      IMO (International Maritime Organization) set following criteria: +

      +
      • GM >= 0.15 m. GM (metacentric height) is the initial tangent of the GZ curve.
      • +
      • Maximum GZ value must be placed over 30 degrees of roll angle.
      • +
      • With 30 degrees roll angle, GZ value must be 0.2 m at least.
      • +
      • Area involved by GZ curve up to 40 degrees of roll angle must be at least 0.090 m · rad.
      • +
      • Area involved by GZ curve up to 30 degrees of roll angle must be at least 0.055 m · rad.
      • +
      • Area involved by GZ curve from 30 to 40 degrees of roll angle must be at least 0.030 m · rad.
      +

      In this tutorial we will set weights and tanks for our series 60 ship, in a unreal situation. +

      +

      Ship weights

      +

      In order to can compute GZ curve we need to know ship weights, and their position at each roll angle, so weights will be divided in two categories: +

      +
      • Fixed weights, that are fully linked to ship movements.
      • +
      • Tanks, where fluid shape changes with the angle, needing center of gravity computation at each position.
      +

      FreeCAD-Ship provides two different tools to generate each instance. +

      +
      Weights definition tool icon.
      +
      Weights definition tool icon.
      +

      Weights definition tool can be used to set first category of weights. When you launch the tool for first time (with ship instance selected), FreeCAD-Ship initialize ship weights with Lightweight ship (equal to ship displacement) that is placed on ship geometry centre of gravity X coordinate, and at design draft height. Usually you have at least, 2 relevant weights: +

      +
      • Structure.
      • +
      • Main engine (or several of them).
      +

      So we will change it. Doing double click over each cell we can edit the value, seting this weights: +

      +
      • Structure, 15000 kg, (-0.1, 0, 1.25) m
      • +
      • Starboard engine, 5000 kg, (-6.5, -0.65, 0.5) m
      • +
      • Port side engine, 5000 kg, (-6.5, 0.65, 0.5) m
      • +
      • Emergency engine, 2500 kg, (0.2, 0, 2.5) m
      +
      Weights definition 3D preview.
      +
      Weights definition 3D preview.
      +

      Weights position are shown at 3D screen view. This annotations will be removed when you ends with the tool, so don't take care about this. When you press Accept weights will stored at your ship instance. +

      +

      Tanks

      +

      Tanks must be created on top of solid geometry, as the ship instance, so first step is create two bow tanks (one per ship side) solid geometries that we will consider (Ussually ships have a lot of tanks for fuel, fresh water, salt water, load, etc). +

      +

      Geometry generation

      +

      In order to generate tanks we load Part module, and create a box solid. +

      We need to edit the box, so we select it at Atributes and tags tree, and change from view to data tab. Uncollapse Placement, and into them Position, and set x to 1.5, and z to -1. We want to change box lenght too changing it for 5.0 (note that units can be in mm, don't take care about this). +

      Tank geometry will be common part of created box and ship geometry, so we can hide Ship instance, and show s60_IowaUniversity geometry. Selecting box and s60_IowaUniversity we can use Common operation generating our starboard tank geometry. +

      +
      Generated tank geometry.
      +
      Generated tank geometry.
      +

      We can perform port side tank selecting our starboard geometry and executing mirror tool, selecting XZ as mirror plane. +

      In order to convert geometry into a ussual solid shape our tanks, and recover our s60_IowaUniversity geometry, we can load Draft module, and with starboard tank geometry selected execute Upgrade, and repeat with port side tank geometry. We can rename geometries as: +

      +
      • StarboardTankGeom
      • +
      • PortTankGeom
      +

      We can delete created Box, that we don't need anymore. +

      +

      Tank intances generation

      +

      If reload FreeCAD-Ship module another time, we can find tank instances generator tool. +

      +
      Tank instance generation tool icon.
      +
      Tank instance generation tool icon.
      +

      Now we can select StarboardTankGeom and execute tank instnace generation tool, where some data must be provided. We will set 40% of filling level, and 925 kg/m<math>\mathrm{m}^{3}</math> (fuel approach). When Accept is clicked a new tank instance called Tank is generated. We can rename it as StarboardTank, and hide StarboardTankGeom. +

      We can repeat the same process in order to generate PortTank. +

      +
      View of generated weights.
      +
      View of generated weights.
      +

      Figure shown our ship result that we will compute. +

      +

      GZ curve computation

      +

      FreeCAD-Ship provide a tool to easily compute a GZ curve. +

      +
      GZ curve computation tool icon.
      +
      GZ curve computation tool icon.
      +

      With Ship instance selected, we can run the tool. The first thing that we can see at opened dialog is a list with all tank instances found at active document. We want to use both of them, so we click over the tanks that are remarked with a diferent background. +

      In order to know the resultant ship displacement and draft we can press Update displacement and draft, taking some time for the computation. We receive following data: +

      +
      • Displacement = 37505.5 kg
      • +
      • Draft = 0.818664 m
      +

      So we are in a unloaded situation, where draft are sightly lower than design draft. Ussually lower drafts imply lower ship stability, the draft depends on loading condition, so if we really expect than ship can be operated in this loading condition we can consider implement ballast tanks. +

      We can also automatically compute ship trim, operation that can take around one minute, retrieving that our ship have 0.95 degrees of trim angle (positive by stern). In this example we will work without trim angle (0 degrees). +

      Tool request roll angles considered too. In this case we want to know all ship behaviour, so we can set: +

      +
      • 0 degrees starting roll angle.
      • +
      • 180 degrees ending roll angle.
      • +
      • 46 points. One for each 2 degrees. GZ computation can take some time, so take care about the number of points requested.
      +

      When we press Accept tool starts the computation. If you runs FreeCAD from terminal you can see work progress. In a couple of seconds we will receive GZ curve. +

      This tool use pyxplot and ghostscript too. You can see where gz.dat output file has been placed at the report view (View/Views/Report view), and load it with datasheet software (for example libreOffice). Nearby data file several auxiliary files has been created too: +

      +
      • gz.dat: Computed GZ curve data.
      • +
      • gz.pyxplot: pyxplot layout in order to plot the curve.
      • +
      • gz.eps: EPS image version.
      • +
      • gz.png: PNG image version.
      +

      This files will be overwritten if you executes the tool another time. +

      +

      Results

      +
      Resultant GZ curve.
      +
      Resultant GZ curve.
      +

      GZ maximum value is placed over 30 degrees (45 degrees), getting 0.25 m at 30 degrees (0.2 m is the minimum). Up to 30 degrees the area below GZ curve is 0.065 m·rad, up to 40 degrees we have 0.092 m·rad, being the area between 30 and 40 degrees of 0.027 m·rad. So our ship don't meets the IMO requeriments. The solution is place ballast tanks. +

      At the other hand the ship, in this bad condition, has positive GZ values up to 95 degrees roll angle, but has not been enoguht for IMO stability requirements, showing the hard cirteria imposed about this item. +

      Of course this example is not real (first for all fuel tanks cannot be placed in the double bottom structure, or using hull side as structure), but is a good example in order to learn to use FreeCAD-Ship. +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/FreeCAD011.png b/localwiki/FreeCAD011.png new file mode 100644 index 0000000..797268d Binary files /dev/null and b/localwiki/FreeCAD011.png differ diff --git a/localwiki/FreeCAD05.png b/localwiki/FreeCAD05.png new file mode 100644 index 0000000..85afa75 Binary files /dev/null and b/localwiki/FreeCAD05.png differ diff --git a/localwiki/FreeCAD05_Tango_Anaglyph.svg b/localwiki/FreeCAD05_Tango_Anaglyph.svg new file mode 100644 index 0000000..01cafac --- /dev/null +++ b/localwiki/FreeCAD05_Tango_Anaglyph.svg @@ -0,0 +1,1878 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/FreeCAD05_Tango_Applications-games.svg b/localwiki/FreeCAD05_Tango_Applications-games.svg new file mode 100644 index 0000000..b9913d3 --- /dev/null +++ b/localwiki/FreeCAD05_Tango_Applications-games.svg @@ -0,0 +1,1916 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/FreeCAD05_Tango_Applications-graphics.svg b/localwiki/FreeCAD05_Tango_Applications-graphics.svg new file mode 100644 index 0000000..ec42d03 --- /dev/null +++ b/localwiki/FreeCAD05_Tango_Applications-graphics.svg @@ -0,0 +1,589 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/FreeCAD05_Tango_Applications-ristretto.svg b/localwiki/FreeCAD05_Tango_Applications-ristretto.svg new file mode 100644 index 0000000..204f984 --- /dev/null +++ b/localwiki/FreeCAD05_Tango_Applications-ristretto.svg @@ -0,0 +1,2289 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/FreeCAD05_Tango_Camera-photo.svg b/localwiki/FreeCAD05_Tango_Camera-photo.svg new file mode 100644 index 0000000..cfb4aa0 --- /dev/null +++ b/localwiki/FreeCAD05_Tango_Camera-photo.svg @@ -0,0 +1,897 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/FreeCAD05_Tango_Camera-video.svg b/localwiki/FreeCAD05_Tango_Camera-video.svg new file mode 100644 index 0000000..4e78e6f --- /dev/null +++ b/localwiki/FreeCAD05_Tango_Camera-video.svg @@ -0,0 +1,1291 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/FreeCAD05_Tango_Dialog-error.svg b/localwiki/FreeCAD05_Tango_Dialog-error.svg new file mode 100644 index 0000000..c0be181 --- /dev/null +++ b/localwiki/FreeCAD05_Tango_Dialog-error.svg @@ -0,0 +1,362 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/FreeCAD05_Tango_Dialog-warning.svg b/localwiki/FreeCAD05_Tango_Dialog-warning.svg new file mode 100644 index 0000000..3eae235 --- /dev/null +++ b/localwiki/FreeCAD05_Tango_Dialog-warning.svg @@ -0,0 +1,403 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/FreeCAD05_Tango_Face-angel.svg b/localwiki/FreeCAD05_Tango_Face-angel.svg new file mode 100644 index 0000000..0fec03f --- /dev/null +++ b/localwiki/FreeCAD05_Tango_Face-angel.svg @@ -0,0 +1,607 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/FreeCAD05_Tango_Face-blush.svg b/localwiki/FreeCAD05_Tango_Face-blush.svg new file mode 100644 index 0000000..d47c95e --- /dev/null +++ b/localwiki/FreeCAD05_Tango_Face-blush.svg @@ -0,0 +1,981 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/FreeCAD05_Tango_Face-crying.svg b/localwiki/FreeCAD05_Tango_Face-crying.svg new file mode 100644 index 0000000..780c03d --- /dev/null +++ b/localwiki/FreeCAD05_Tango_Face-crying.svg @@ -0,0 +1,924 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/FreeCAD05_Tango_Face-devil-grin.svg b/localwiki/FreeCAD05_Tango_Face-devil-grin.svg new file mode 100644 index 0000000..ff35af7 --- /dev/null +++ b/localwiki/FreeCAD05_Tango_Face-devil-grin.svg @@ -0,0 +1,1162 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/FreeCAD05_Tango_Face-glasses.svg b/localwiki/FreeCAD05_Tango_Face-glasses.svg new file mode 100644 index 0000000..dc73c15 --- /dev/null +++ b/localwiki/FreeCAD05_Tango_Face-glasses.svg @@ -0,0 +1,1094 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/FreeCAD05_Tango_Face-grin-braces.svg b/localwiki/FreeCAD05_Tango_Face-grin-braces.svg new file mode 100644 index 0000000..c4bbfc2 --- /dev/null +++ b/localwiki/FreeCAD05_Tango_Face-grin-braces.svg @@ -0,0 +1,1336 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/FreeCAD05_Tango_Face-grin.svg b/localwiki/FreeCAD05_Tango_Face-grin.svg new file mode 100644 index 0000000..b3422de --- /dev/null +++ b/localwiki/FreeCAD05_Tango_Face-grin.svg @@ -0,0 +1,1184 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/FreeCAD05_Tango_Face-kiss.svg b/localwiki/FreeCAD05_Tango_Face-kiss.svg new file mode 100644 index 0000000..325badc --- /dev/null +++ b/localwiki/FreeCAD05_Tango_Face-kiss.svg @@ -0,0 +1,1518 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/FreeCAD05_Tango_Face-plain.svg b/localwiki/FreeCAD05_Tango_Face-plain.svg new file mode 100644 index 0000000..d0f0352 --- /dev/null +++ b/localwiki/FreeCAD05_Tango_Face-plain.svg @@ -0,0 +1,1816 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/FreeCAD05_Tango_Face-sad.svg b/localwiki/FreeCAD05_Tango_Face-sad.svg new file mode 100644 index 0000000..5b13030 --- /dev/null +++ b/localwiki/FreeCAD05_Tango_Face-sad.svg @@ -0,0 +1,1521 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/FreeCAD05_Tango_Face-smile-big.svg b/localwiki/FreeCAD05_Tango_Face-smile-big.svg new file mode 100644 index 0000000..f03edf5 --- /dev/null +++ b/localwiki/FreeCAD05_Tango_Face-smile-big.svg @@ -0,0 +1,1674 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/FreeCAD05_Tango_Face-smile.svg b/localwiki/FreeCAD05_Tango_Face-smile.svg new file mode 100644 index 0000000..2038b1a --- /dev/null +++ b/localwiki/FreeCAD05_Tango_Face-smile.svg @@ -0,0 +1,1556 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/FreeCAD05_Tango_Face-surprise.svg b/localwiki/FreeCAD05_Tango_Face-surprise.svg new file mode 100644 index 0000000..c84e057 --- /dev/null +++ b/localwiki/FreeCAD05_Tango_Face-surprise.svg @@ -0,0 +1,1686 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/FreeCAD05_Tango_Face-wink.svg b/localwiki/FreeCAD05_Tango_Face-wink.svg new file mode 100644 index 0000000..0662591 --- /dev/null +++ b/localwiki/FreeCAD05_Tango_Face-wink.svg @@ -0,0 +1,1799 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/FreeCAD05_Tango_Measure.svg b/localwiki/FreeCAD05_Tango_Measure.svg new file mode 100644 index 0000000..0d8a7b3 --- /dev/null +++ b/localwiki/FreeCAD05_Tango_Measure.svg @@ -0,0 +1,2226 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/FreeCAD05_Tango_Preferences-system.svg b/localwiki/FreeCAD05_Tango_Preferences-system.svg new file mode 100644 index 0000000..ab98011 --- /dev/null +++ b/localwiki/FreeCAD05_Tango_Preferences-system.svg @@ -0,0 +1,968 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/FreeCAD05_Tango_Process-stop.svg b/localwiki/FreeCAD05_Tango_Process-stop.svg new file mode 100644 index 0000000..2d41f3d --- /dev/null +++ b/localwiki/FreeCAD05_Tango_Process-stop.svg @@ -0,0 +1,2304 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/FreeCAD05_Tango_Text-x-python.svg b/localwiki/FreeCAD05_Tango_Text-x-python.svg new file mode 100644 index 0000000..5eb476b --- /dev/null +++ b/localwiki/FreeCAD05_Tango_Text-x-python.svg @@ -0,0 +1,3020 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/FreeCADGui_API.html b/localwiki/FreeCADGui_API.html new file mode 100644 index 0000000..8775a41 --- /dev/null +++ b/localwiki/FreeCADGui_API.html @@ -0,0 +1,200 @@ +FreeCADGui API

      FreeCADGui API

      + +

      This module is the counterpart of the FreeCAD module. It contains everything related to the User interface and the 3D views. Example: +

      +
      import FreeCAD as App
      +import FreeCADGui as Gui
      +
      +# get the 3D model document
      +doc = App.ActiveDocument    
      +
      +# get the visual representation model document
      +gui_doc = Gui.ActiveDocument
      +
      +gui_doc.activateWorkbench("myWorkbench") 
      +


      +

      +
      +
      Method.png activateWorkbench ( string )
      +
      +

      Description: Activates a workbench by name +

      Returns: nothing +

      +
      +
      +


      +

      +
      +
      Method.png activeDocument ( )
      +
      +

      Description: +

      Returns: the active document or None if no one exists +

      +
      +
      +


      +

      +
      +
      Method.png activeWorkbench ( )
      +
      +

      Description: +

      Returns: the active workbench object +

      +
      +
      +


      +

      +
      +
      Method.png addCommand ( string, object )
      +
      +

      Description: Adds a FreeCAD command. String is the name of the command and object is a classname defining the command +

      Returns: +

      +
      +
      +


      +

      +
      +
      Method.png addIcon ( string, string or list )
      +
      +

      Description: Adds an icon as file name or in XPM format to the system +

      Returns: +

      +
      +
      +


      +

      +
      +
      Method.png addIconPath ( string )
      +
      +

      Description: Add a new path to the system where to find icon files +

      Returns: +

      +
      +
      +


      +

      +
      +
      Method.png addPreferencePage ( string,string )
      +
      +

      Description: Adds a UI form to the preferences dialog. The first argument specifies the file name and the second specifies the group name +

      Returns: +

      +
      +
      +


      +

      +
      +
      Method.png addWorkbench ( string, object )
      +
      +

      Description: Adds a workbench under a defined name. The string is the workbench name and the object is a classname defining the workbench +

      Returns: +

      +
      +
      +


      +

      +
      +
      Method.png createDialog ( string )
      +
      +

      Description: Opens a UI file +

      Returns: +

      +
      +
      +


      +

      +
      +
      Method.png getDocument ( string )
      +
      +

      Description: Gets a document by its name +

      Returns: the document +

      +
      +
      +


      +

      +
      +
      Method.png getWorkbench ( string )
      +
      +

      Description: Gets a workbench by its name +

      Returns: the workbench +

      +
      +
      +


      +

      +
      +
      Method.png insert ( string )
      +
      +

      Description: Open a macro, Inventor or VRML file +

      Returns: the document +

      +
      +
      +


      +

      +
      +
      Method.png listWorkbenches ( )
      +
      +

      Description: Shows a list of all workbenches +

      Returns: a list +

      +
      +
      +


      +

      +
      +
      Method.png open ( string )
      +
      +

      Description: Opens a macro, Inventor or VRML file +

      Returns: the openend document +

      +
      +
      +


      +

      +
      +
      Method.png removeWorkbench ( string )
      +
      +

      Description: Removes a workbench by name +

      Returns: +

      +
      +
      +


      +

      +
      +
      Method.png runCommand ( string )
      +
      +

      Description: Runs a FreeCAD command by name +

      Returns: +

      +
      +
      +


      +

      +
      +
      Method.png updateGui ( )
      +
      +

      Description: Updates the main window and all its windows +

      Returns: +

      +
      +
      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/FreeCAD_API.html b/localwiki/FreeCAD_API.html new file mode 100644 index 0000000..27abb15 --- /dev/null +++ b/localwiki/FreeCAD_API.html @@ -0,0 +1,184 @@ +FreeCAD API

      FreeCAD API

      + +

      This is the principal (root) module of FreeCAD. It can also be called by "App" from the FreeCAD interpreter. It contains everything that is needed to manipulate documents and their contents (objects). +

      Example: +

      +
      import FreeCAD
      +print FreeCAD.listDocuments()
      +mydoc = FreeCAD.activeDocument() 
      +


      +

      +
      +
      Method.png ConfigDump ( )
      +
      +

      Description: Prints a dictionary containing all the FreeCAD configuration environment. +

      Returns: +

      +
      +
      +


      +

      +
      +
      Method.png ConfigGet ( [string] )
      +
      +

      Description: Returns the value of the given key. If no key is given, the complete configuration is returned +

      Returns: A string. +

      +
      +
      +


      +

      +
      +
      Method.png ConfigSet ( string, string )
      +
      +

      Description: Set the given key (first string) to the given value (second string). +

      Returns: +

      +
      +
      +


      +

      +
      +
      Method.png Version ( )
      +
      +

      Description: Prints the FreeCAD version. +

      Returns: +

      +
      +
      +


      +

      +
      +
      Method.png activeDocument ( )
      +
      +

      Description: Return the active document or None if there is no active document. +

      Returns: A FreeCAD Document. +

      +
      +
      +


      +

      +
      +
      Method.png addExportType ( string, string )
      +
      +

      Description: Adds a new export file type to FreeCAD. The first string must be formatted like this example: "Word Document (*.doc)". The second string is the name of a python script/module containing an export() function. +

      Returns: +

      +
      +
      +


      +

      +
      +
      Method.png addImportType ( string, string )
      +
      +

      Description: Adds a new import file type to FreeCAD, works the same way as addExportType, the handling python module must contain an open() and/or an import() function. +

      Returns: +

      +
      +
      +


      +

      +
      +
      Method.png closeDocument ( Document name )
      +
      +

      Description: Closes the given document +

      Returns: +

      +
      +
      +


      +

      +
      +
      Method.png getDocument ( Document name )
      +
      +

      Description: Returns a document or raise an exception if there is no document with the given name. +

      Returns: +

      +
      +
      +


      +

      +
      +
      Method.png getExportType ( string )
      +
      +

      Description: Returns the name of the module that can export the specified filetype. +

      Returns: A string. +

      +
      +
      +


      +

      +
      +
      Method.png getImportType ( string )
      +
      +

      Description: Returns the name of the module that can import the specified filetype. +

      Returns: A string. +

      +
      +
      +


      +

      +
      +
      Method.png listDocuments ( )
      +
      +

      Description: Returns a dictionary of names and object pointers of all documents. +

      Returns: A dictionary of names and object pointers. +

      +
      +
      +


      +

      +
      +
      Method.png newDocument ( [string] )
      +
      +

      Description: Creates and returns a new document with a given name. The document name must be unique, which is checked automatically. If no name is supplied, the document will be named "Untitled". +

      Returns: The newly created document. +

      +
      +
      +


      +

      +
      +
      Method.png open ( string )
      +
      +

      Description: See openDocument +

      Returns: +

      +
      +
      +


      +

      +
      +
      Method.png openDocument ( filepath )
      +
      +

      Description: Creates and returns a document and load a project file into the document. The string argument must point to an existing file. If the file doesn't exist or the file cannot be loaded an I/O exception is thrown. In this case the created document is kept, but will be empty. +

      Returns: The opened FreeCAD Document. +

      +
      +
      +


      +

      +
      +
      Method.png setActiveDocument ( Document name )
      +
      +

      Description: Set the active document by its name. +

      Returns: +

      +
      +
      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/FreeCAD_Build_Tool.html b/localwiki/FreeCAD_Build_Tool.html new file mode 100644 index 0000000..92f916d --- /dev/null +++ b/localwiki/FreeCAD_Build_Tool.html @@ -0,0 +1,84 @@ +FreeCAD Build Tool

      FreeCAD Build Tool

      + +

      The FreeCAD build tool or fcbt is a python script located at +

      +
       trunc/src/Tools/fcbt.py
      +

      It can be used to simplify some frequent tasks in building, distributing and extending FreeCAD. +

      + + +

      Usage

      +

      With Python correctly installed, fcbt can be invoked by the command +

      +
       python fbct.py
      +

      It displays a menu, where you can select the task you want to use it for: +

      +
      FreeCAD Build Tool
      + Usage:
      +    fcbt <command name> [command parameter]
      + possible commands are:
      +  - DistSrc         (DS)   Build a source Distr. of the current source tree
      +  - DistBin         (DB)   Build a binary Distr. of the current source tree
      +  - DistSetup       (DI)   Build a Setup Distr. of the current source tree
      +  - DistSetup       (DUI)  Build a User Setup Distr. of the current source tree
      +  - DistAll         (DA)   Run all three above modules
      +  - NextBuildNumber (NBN)  Increase the Build Number of this Version
      +  - CreateModule    (CM)   Insert a new FreeCAD Module in the module directory
      +
      + For help on the modules type:
      +   fcbt <command name> ?
      +
      +

      At the input promt enter the abbreviated command you want to call. For example type "CM" for creating a module. +

      +

      DistSrc

      +

      The command "DS" creates a source distribution of the current source tree. +

      +

      DistBin

      +

      The command "DB" creates a binary distribution of the current source tree. +

      +

      DistSetup

      +

      The command "DI" creates a setup distribution of the current source tree. +

      +

      DistSetup

      +

      The command "DUI" creates a user setup distribution of the current source tree. +

      +

      DistAll

      +

      The command "DA" executes "DS", "DB" and "DI" in sequence. +

      +

      NextBuildNumber

      +

      The "NBN" command increments the build number to create a new release version of FreeCAD. +

      +

      CreateModule

      +

      The "CM" command creates a new application module. +

      + +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/FreeCAD_Community_Portal.html b/localwiki/FreeCAD_Community_Portal.html new file mode 100644 index 0000000..016d0ed --- /dev/null +++ b/localwiki/FreeCAD_Community_Portal.html @@ -0,0 +1,150 @@ +FreeCAD Community Portal

      FreeCAD Community Portal

      + +

      This is the place to put all kind of FreeCAD-related stuff! If you work on something FreeCAD-related, please include it here! +

      + + +

      Places where FreeCAD appears on the net

      + +

      FreeCAD-related projects

      + +

      FreeCAD Community addons

      +

      Community developed workbenches, scripts and addons for FreeCAd are available at +

      + +

      Addons include: +

      + +

      Links provide access to sources/repositories. +

      +

      Scripting, math, vectors, 3d resource & tutorials

      + +

      Publicity

      +

      (From Release process) +

      This is a raw list of sites and blogs that have at some point mentioned FreeCAD. It is mostly harvested from http://forum.freecadweb.org/viewtopic.php?f=8&t=143 (until June 29th 2014). +

      Feel free to add more pages or assign one or more pages to yourself to take care of notifying them about a new release of FreeCAD. +

      +

      Social networks

      + +

      News Sites

      + +

      Other Sites

      + +

      Spanish

      + +

      Blogs

      + +

      French

      + +

      Portugese

      + +

      Spanish

      + +

      Italian

      + +

      Polish

      + +

      Chinese

      + +

      Other resources

      +
      • Interesting links contains some maybe useful links to other FLOSS resources and project in this area.
      +

      You too!

      + +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/FreeCAD_Configuration_Management_Project.html b/localwiki/FreeCAD_Configuration_Management_Project.html new file mode 100644 index 0000000..4f498d2 --- /dev/null +++ b/localwiki/FreeCAD_Configuration_Management_Project.html @@ -0,0 +1,56 @@ +FreeCAD Configuration Management Project

      FreeCAD Configuration Management Project

      + +

      This page is describes a potential 2018 Google Summer of Code project regarding configuration management for the FreeCAD CAE application. +

      + + +

      Outline

      +

      FreeCAD relies on a large number of software packages and is available on most major platforms (Linux, OSX, Windows), each Distro/OS have several distribution methods available (package managers, Libpacks, pip, Conda, AppImages, installers, etc). This makes for a particularly challenging configuration management environment. +

      +

      Details

      +
      1. A clear picture of FreeCAD's dependencies as well as their dependencies is required. This is envisioned as a visual depiction (perhaps a directed graph) and an analysis of conflicting versions.
      2. +
      3. A plan for the partitioning of the FreeCAD functionality into manageable chunks along with smaller sets of dependencies is also required. It's desirable to identify interdependencies and not re-install them.
      +

      Expected Outcome

      +
      1. A concrete/documented view of FreeCD's dependencies (and perhaps the trusted addons)
      2. +
      3. A reduction in manual effort when releasing new versions of FreeCAD
      +

      Future Possibilities

      +

      This work will provide experience in the packaging and distribution of multi-platform, cross-dependency software. +

      +

      Project Properties

      +

      Skills

      +
      • Familiarity with +
        • package managers (Launchpad, pbuilder, gitbuilder, conda, NSIS-installer)
        • +
        • build managers (cMake, make, VS, MSBuild, Nmake)
        • +
        • graph theory (Dependency graph)
      +

      Difficulty

      +

      Medium +

      +

      Additional Information

      + + + +
      + +
      +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/FreeCAD_Howto_Import_Export.html b/localwiki/FreeCAD_Howto_Import_Export.html new file mode 100644 index 0000000..b8151c4 --- /dev/null +++ b/localwiki/FreeCAD_Howto_Import_Export.html @@ -0,0 +1,256 @@ +FreeCAD Howto Import Export

      FreeCAD Howto Import Export

      + +
      This page is WIP. Please do not translate yet. Thank you. R-Frank
      +

      This page attempts to answer the most common questions asked on the FreeCAD forums on import and export of data to/from other programs. If you have a problem or question regarding FreeCAD, check below first. +

      Then, if you cannot find an answer for your specific question, head to the FreeCAD forum! +

      + + +

      Import 2D/3D Data

      +

      Autodesk DWG

      +

      Please refer to the Page FreeCAD and DWG-Import +

      +

      Autodesk DXF

      +

      Please refer to the Page FreeCAD and DXF Import +

      Tutorial: DXF Importer Install +

      +

      BREP Format

      +

      Todo +

      +

      Calculix Result

      +

      Todo +

      +

      Collada

      +

      Importing Collada files requires an external Python module to be installed on your system. This can be easily added by following the directions found on the Extra python modules page under pyCollada in this Wiki. Once the pyCollada Python module is installed, importing Collada files is the same as any standard file import. +

      See also: Importing From Sketchup +

      +

      Common Airfoil Data

      +

      Please refer to the Page Common Airfoil Data Import +

      +

      Drawing

      +

      Todo +

      +

      FEM Formats

      +

      Todo +

      +

      FreeCAD Material Cards

      +

      Is intended to import Material Cards for use in FreeCAD itself and in the FEM-Workbench. +

      Not functional at the moment. +

      +

      IDF emn file

      +

      Todo +

      +

      IGES

      +

      Currently there is no support for text or annotation import with the IGES format due to lack of support with FreeCAD's geometric CAD kernel. +

      +

      Image Formats

      +

      Todo +

      +

      Industry Foundation Classes

      +

      Todo +

      +

      Inventor V2.1

      +

      Todo +

      +

      Mesh Formats

      +

      Please refer to the Page FreeCAD and Mesh Import +

      +

      Open CAD Format

      +

      Todo +

      +

      OpenSCAD CSG Format

      +

      Todo +

      +

      OpenSCAD Format

      +

      Todo +

      +

      Point Formats

      +

      Todo +

      +

      POVRay Format

      +

      Todo +

      +

      Python

      +

      Todo +

      +

      Step with Colors

      +

      Currently there is no support for text or annotation import with the STEP format due to lack of support with FreeCAD's geometric CAD kernel. +

      +

      SVG as geometry

      +

      Todo +

      +

      Spreadsheet

      +

      Todo +

      +

      VRML 2.0

      +

      Todo +

      +

      Export 2D/3D Data

      +

      3D View (SVG)

      +

      Todo +

      +

      Autodesk DWG

      +

      Todo +

      +

      Autodesk DXF

      +

      Todo +

      +

      BREP Format

      +

      Todo +

      +

      Collada

      +

      Todo +

      +

      Drawing

      +

      Todo +

      +

      FEM Formats

      +

      Todo +

      +

      Flattened SVG

      +

      Todo +

      +

      IGES Format

      +
      • From the 3D-View simply select (in the tree-view) the solid(s) to export and select "File -> Export".
      • +
      • Then select your file type (IGES). No need to type in the file extension. FreeCAD will append a ".iges" automatically
      +

      Tip
      +Pressing CTRL-A will select ALL solids in the tree view, even the invisible ones.
      +Make sure to manually select all the solids you want to export.
      +
      +Currently there is no support for text or annotation export with the IGES format due to lack of support with FreeCAD's geometric CAD kernel. +

      +

      Industry Foundation Classes

      +

      Todo +

      +

      Inventor V2.1

      +

      Todo +

      +

      Mesh Formats

      +
      • From the 3D-View simply select (in the tree-view) the solid(s) to export and select "File -> Export".
      • +
      • Then select your file type. Be sure to type in also the file extension. Since these formats are mesh formats, the solids will be exported with a "standard" mesh quality.
      • +
      • Use the Mesh Module to adjust the quality of the mesh if needed.
      +

      Tip
      +Pressing CTRL-A will select ALL solids in the tree view, even the invisible ones.
      +Make sure to manually select all the solids you want to export.
      +

      +

      Open CAD Format

      +

      Todo +

      +

      OpenSCAD CSG Format

      +

      Todo +

      +

      OpenSCAD Format

      +

      Todo +

      +

      Portable Document Format

      +

      Todo +

      +

      Step with Colors

      +

      From the 3D-View simply select (in the tree-view) the solid(s) to export and select "File -> Export". +

      In FreeCAD 0.15 and above, by selecting "Edit -> Preferences" and then "Import-Export" in the left column you should have access to Step-Options such as units, scheme and Header Information. Be aware that Step AP203 does not support assembly structures, while Step AP 214 does. +

      Currently there is no support for text or annotation export with the STEP format due to lack of support with FreeCAD's geometric CAD kernel. +

      +

      Spreadsheet

      +

      Todo +

      +

      TetGen File

      +

      Todo +

      +

      VRML 2.0

      +

      Todo +

      +

      Wavefront OBJ - Arch Module

      +

      Todo +

      +

      WebGL File

      +

      Todo +

      +

      Export Data from third-party programs for import into FreeCAD

      +

      Tips and Tricks with using Third-Party Software +

      +

      Inkscape

      +

      When exporting SVG-Data from Inkscape to FreeCAD be sure to use the file type "plain svg". +

      +

      Sketchup

      +

      Please refer to the Page Importing From Sketchup +

      +
      +


      +

      + + +
      + +
      +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/FreeCAD_Raytracing.jpg b/localwiki/FreeCAD_Raytracing.jpg new file mode 100644 index 0000000..924a8c6 Binary files /dev/null and b/localwiki/FreeCAD_Raytracing.jpg differ diff --git a/localwiki/FreeCAD_Screenshot.png b/localwiki/FreeCAD_Screenshot.png new file mode 100644 index 0000000..d79dc79 Binary files /dev/null and b/localwiki/FreeCAD_Screenshot.png differ diff --git a/localwiki/FreeCAD_Scripting_Basics.html b/localwiki/FreeCAD_Scripting_Basics.html new file mode 100644 index 0000000..369476c --- /dev/null +++ b/localwiki/FreeCAD_Scripting_Basics.html @@ -0,0 +1,140 @@ +FreeCAD Scripting Basics

      FreeCAD Scripting Basics

      + +
      + +

      Python scripting in FreeCAD

      +

      FreeCAD is built from scratch to be totally controlled by Python scripts. Almost all parts of FreeCAD, such as the interface, the scene contents, and even the representation of this content in the 3D views, are accessible from the built-in Python interpreter or from your own scripts. As a result, FreeCAD is probably one of the most deeply customizable engineering applications available today. +

      In its current state however, FreeCAD has very few 'native' commands to interact with your 3D objects, mainly because it is still in the early stages of development, but also because the philosophy behind it is more to provide a platform for CAD development than a specific use application. But the ease of Python scripting inside FreeCAD is a quick way to see new functionality being developed by 'power users', typically users who know a bit of Python programming. Python is one of the most popular interpreted languages, and because it is generally regarded as easy to learn, you too can soon be making your own FreeCAD 'power user' scripts. +

      If you are not familiar with Python, we recommend you search for tutorials on the internet and have a quick look at its structure. Python is a very easy language to learn, especially because it can be run inside an interpreter, where simple commands, right up to complete programs, can be executed on the fly without the need to compile anything. FreeCAD has a built-in Python interpreter. If you don't see the window labeled 'Python console' as shown below, you can activate it under the View -> Panels -> Python console to bring-up the interpreter. +

      +

      The interpreter

      +

      From the interpreter, you can access all your system-installed Python modules, as well as the built-in FreeCAD modules, and all additional FreeCAD modules you installed later. The screenshot below shows the Python interpreter: +

      The FreeCAD Python interpreter +

      From the interpreter, you can execute Python code and browse through the available classes and functions. FreeCAD provides a very handy class browser for exploration of your new FreeCAD world: When you type the name of a known class followed by a period (meaning you want to add something from that class), a class browser window opens, where you can navigate between available subclasses and methods. When you select something, an associated help text (if it exists) is displayed: +

      The FreeCAD class browser +

      So, start here by typing App. or Gui. and see what happens. Another more generic Python way of exploring the content of modules and classes is to use the 'print dir()' command. For example, typing print dir() will list all modules currently loaded in FreeCAD. print dir(App) will show you everything inside the App module, etc. +

      Another useful feature of the interpreter is the possibility to go back through the command history and retrieve a line of code that you already typed earlier. To navigate through the command history, just use CTRL+UP or CTRL+DOWN. +

      By right-clicking in the interpreter window, you also have several other options, such as copy the entire history (useful when you want to experiment with things before making a full script of them), or insert a filename with complete path. +

      +

      Python Help

      +

      In the FreeCAD Help menu, you'll find an entry labeled 'Python help', which will open a browser window containing a complete, realtime-generated documentation of all Python modules available to the FreeCAD interpreter, including Python and FreeCAD built-in modules, system-installed modules, and FreeCAD additional modules. The documentation available there depends on how much effort each module developer put into documenting his code, but usually Python modules have a reputation for being fairly well documented. Your FreeCAD window must stay open for this documentation system to work. +

      +

      Built-in modules

      +

      Since FreeCAD is designed to be run without a Graphical User Interface (GUI), almost all its functionality is separated into two groups: Core functionality, named 'App', and GUI functionality, named 'Gui'. So, our two main FreeCAD built-in modules are called App and Gui. These two modules can also be accessed from scripts outside of the interpreter, by the names 'FreeCAD' and 'FreeCADGui' respectively. +

      +
      • In the App module, you'll find everything related to the application itself, like methods for opening or closing files, and to the documents, like setting the active document or listing their contents.
      +
      • In the Gui module, you'll find tools for accessing and managing Gui elements, like the workbenches and their toolbars, and, more interestingly, the graphical representation of all FreeCAD content.
      +

      Listing all the content of those modules is a bit counter-productive task, since they grow quite fast with FreeCAD development. But the two browsing tools provided (the class browser and the Python help) should give you, at any moment, complete and up-to-date documentation of these modules. +

      +

      The App and Gui objects

      +

      As we said, in FreeCAD, everything is separated between core and representation. This includes the 3D objects too. You can access defining properties of objects (called features in FreeCAD) via the App module, and change the way they are represented on screen via the Gui module. For example, a cube has properties that define it, (like width, length, height) that are stored in an App object, and representation properties, (like faces color, drawing mode) that are stored in a corresponding Gui object. +

      This way of doing things allows a very wide range of uses, like having algorithms work only on the definition part of features, without the need to care about any visual part, or even redirect the content of the document to non-graphical application, such as lists, spreadsheets, or element analysis. +

      For every App object in your document, there exists a corresponding Gui object. Infact the document itself has both App and a Gui objects. This, of course, is only valid when you run FreeCAD with its full interface. In the command-line version no GUI exists, so only App objects are availible. Note that the Gui part of objects is re-generated every time an App object is marked as 'to be recomputed' (for example when one of its parameters changes), so changes you might have made directly to the Gui object may be lost. +

      To access the App part of something, you type: +

      +
      myObject = App.ActiveDocument.getObject("ObjectName") 
      +

      where "ObjectName" is the name of your object. You can also type: +

      +
      myObject = App.ActiveDocument.ObjectName 
      +

      To access the Gui part of the same object, you type: +

      +
      myViewObject = Gui.ActiveDocument.getObject("ObjectName") 
      +

      where "ObjectName" is the name of your object. You can also type: +

      +
      myViewObject = App.ActiveDocument.ObjectName.ViewObject 
      +

      If we have no GUI (for example we are in command-line mode), the last line will return 'None'. +

      +

      The Document objects

      +

      In FreeCAD all your work resides inside Documents. A document contains your geometry and can be saved to a file. Several documents can be opened at the same time. The document, like the geometry contained inside, has App and Gui objects. App object contains your actual geometry definitions, while the Gui object contains the different views of your document. You can open several windows, each one viewing your work with a different zoom factor or point of view. These views are all part of your document's Gui object. +

      To access the App part the currently open (active) document, you type: +

      +
      myDocument = App.ActiveDocument 
      +

      To create a new document, type: +

      +
      myDocument = App.newDocument("Document Name") 
      +

      To access the Gui part the currently open (active) document, you type: +

      +
      myGuiDocument = Gui.ActiveDocument 
      +

      To access the current view, you type: +

      +
      myView = Gui.ActiveDocument.ActiveView 
      +

      Using additional modules

      +

      The FreeCAD and FreeCADGui modules are solely responsibles for creating and managing objects in the FreeCAD document. They don't actually do anything such as creating or modifying geometry. That is because that geometry can be of several types, and so it is managed by additional modules, each responsible for managing a certain geometry type. For example, the Part Module uses the OpenCascade kernel, and therefore is able to create and manipulate B-rep type geometry, which is what OpenCascade is built for. The Mesh Module is able to build and modify mesh objects. That way, FreeCAD is able to handle a wide variety of object types, that can all coexist in the same document, and new types could be added easily in the future. +

      +

      Creating objects

      +

      Each module has its own way to treat its geometry, but one thing they usually all can do is create objects in the document. But the FreeCAD document is also aware of the available object types provided by the modules: +

      +
      FreeCAD.ActiveDocument.supportedTypes() 
      +

      will list you all the possible objects you can create. For example, let's create a mesh (treated by the mesh module) and a part (treated by the part module): +

      +
      myMesh = FreeCAD.ActiveDocument.addObject("Mesh::Feature","myMeshName")
      +myPart = FreeCAD.ActiveDocument.addObject("Part::Feature","myPartName") 
      +

      The first argument is the object type, the second the name of the object. Our two objects look almost the same: They don't contain any geometry yet, and most of their properties are the same when you inspect them with dir(myMesh) and dir(myPart). Except for one, myMesh has a "Mesh" property and "Part" has a "Shape" property. That is where the Mesh and Part data are stored. For example, let's create a Part cube and store it in our myPart object: +

      +
      import Part
      +cube = Part.makeBox(2,2,2)
      +myPart.Shape = cube 
      +

      You could try storing the cube inside the Mesh property of the myMesh object, it will return an error complaining of the wrong type. That is because those properties are made to store only a certain type. In the myMesh's Mesh property, you can only save stuff created with the Mesh module. Note that most modules also have a shortcut to add their geometry to the document: +

      +
      import Part
      +cube = Part.makeBox(2,2,2)
      +Part.show(cube) 
      +

      Modifying objects

      +

      Modifying an object is done the same way: +

      +
      import Part
      +cube = Part.makeBox(2,2,2)
      +myPart.Shape = cube 
      +

      Now let's change the shape by a bigger one: +

      +
      biggercube = Part.makeBox(5,5,5)
      +myPart.Shape = biggercube 
      +

      Querying objects

      +

      You can always look at the type of an object like this: +

      +
      myObj = FreeCAD.ActiveDocument.getObject("myObjectName")
      +print myObj.TypeId 
      +

      or know if an object is derived from one of the basic ones (Part Feature, Mesh Feature, etc): +

      +
      print myObj.isDerivedFrom("Part::Feature") 
      +

      Now you can really start playing with FreeCAD! To look at what you can do with the Part Module, read the Part scripting page, or the Mesh Scripting page for working with the Mesh Module. Note that, although the Part and Mesh modules are the most complete and widely used, other modules such as the Draft Module also have scripting APIs that can be useful to you. For a complete list of each modules and their available tools, visit the Category:API section. +

      + +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/FreeCAD_and_DWG_Import.html b/localwiki/FreeCAD_and_DWG_Import.html new file mode 100644 index 0000000..ca7d11e --- /dev/null +++ b/localwiki/FreeCAD_and_DWG_Import.html @@ -0,0 +1,106 @@ +FreeCAD and DWG Import

      FreeCAD and DWG Import

      + +
      + +

      Why Can't I Import DWG Files into FreeCAD?

      +

      The DWG format is a closed source binary file format that is not directly supported by FreeCAD. It requires an external 3rd party file converter to first convert then import the conversion into FreeCAD for use. +

      Note that at this time, it is not possible to import 3D DWG in FreeCAD. 3D data is embedded as binary .SAT (ACIS) data, a proprietary and undocumented format. +

      +

      What Do I Need To Be Able To Import DWG Files?

      +

      Teigha Converter

      + +

      The Teigha Converter is a small freely available utility that allows to convert between several versions of DWG and DXF files. FreeCAD can use it to offer DWG import and export, by converting DWG files to the DXF format under the hood,then using its standard DXF importer to import the file contents. The restrictions of the DXF importer apply. +

      +

      Installation

      +

      On all platforms, only by installing the appropriate package from https://www.opendesign.com/guestfiles/teigha_file_converter . After installation, if the utility is not found automatically by FreeCAD, you might need to set the path to the converter executable manually. Change workbench to "Draft", than in the menu Edit -> Preferences -> Import/Export -> DWG and fill "Path to Teigha File Converter" appropriately. +

      For more detailed instruction see this tutorial. +

      +

      Usage

      +

      The program may be used with the command line interface or the graphical interface. +Be sure to convert the dwg-files to an ASCII-Format. +

      Command Line Format is: +

      +
      1. Quoted Input Folder
      2. +
      3. Quoted Output Folder
      4. +
      5. Output_version {"ACAD9","ACAD10","ACAD12", "ACAD13","ACAD14", "ACAD2000","ACAD2004", "ACAD2007","ACAD2010"}
      6. +
      7. Output File type {"DWG","DXF","DXB"}
      8. +
      9. Recurse Input Folder {"0","1"}
      10. +
      11. Audit each file {"0","1"}
      12. +
      13. [optional] Input file filter (default:"*.DWG;*.DXF")
      +

      Example for Linux
      +TeighaFileConverter "/home/dwg-data" "/home/dxf-data" "ACAD2010" "DXF" "0" "1" "test.dwg" +The second number (audit) needs to be 1 otherwise it fails +

      Example for Windows
      +"C:\Program Files\ODA\Teigha File Converter 3.08.2\TeighaFileConverter.exe" "Path-To-Input-Directory" "Path-To-Output-Directory" "ACAD2010" "DXF" "0" "1" "Name-Of-A-Test-File.dwg" +

      +

      What Are The Alternatives?

      +

      DraftSight

      +

      There is a free commercial program called Draft Sight (http://www.3ds.com/products-services/draftsight/overview/) that can import most DWG files and can save and export in formats that are friendly to FreeCAD. +Draftsight runs on +

      +
      • Windows 32 bit
      • +
      • Windows 64 bit
      • +
      • Mac OS X
      • +
      • Linux Fedora
      • +
      • Linux Ubuntu
      +

      A free registration is required for activation of the program. +

      +

      DoubleCAD XT

      +

      There is also DoubleCAD XT (https://www.turbocad.com/content/doublecad-xt-v5) . +The program is free for personal and commercial use. +It requires a free sign-up to receive an activation code via E-Mail. +This Program is windows-only. +

      +

      Export Your AutoCAD files in Friendly Format

      +

      Exporting your AutoCAD files in a more FreeCAD friendly format, like DXF R12 or R14, SVG, and if version supports it, IGES. All are better alternatives to the DWG format when using FreeCAD. +

      It is important to know that, contrarily to popular belief, there is no difference between the contents of a file saved in DWG or DXF formats, provided it is the same version (ex. DWG 2014 vs. DXF 2014). Both formats are maintained by Autodesk, and they both support exactly the same features. The difference is that DWG is closed (machine-encoded) while DXF is open. +

      +

      What Can I Do To Help?

      +

      Promote the use of alternative formats

      +

      Simply put, stop accepting work done in DWG format. In practice, this is often easier said than done. Still, it would not be bad practice for users and supporters of FreeCAD to avoid and reject the DWG format whenever possible. +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/FreeCAD_and_DXF_Import.html b/localwiki/FreeCAD_and_DXF_Import.html new file mode 100644 index 0000000..3fa44f3 --- /dev/null +++ b/localwiki/FreeCAD_and_DXF_Import.html @@ -0,0 +1,75 @@ +FreeCAD and DXF Import

      FreeCAD and DXF Import

      + +
      + +

      Legal Notice

      +

      To be able to import DXF-Files you have to manually install several files. Why this? These libraries are published with another license than FreeCAD, so the developers of FreeCAD would not have them being bundled with the FreeCAD-Application. +

      +

      How to install

      +

      To install Draft-dxf-importer: +

      +
      1. Go to Yorik's Github account and download these files (on the right side you can choose "download as ZIP").
      2. +
      3. Put the files in your macro folder.
      +
      • In Ubuntu, this is normally
      +
      /home/your_user_name/.FreeCAD 
      +
      +

      The directory is hidden. You may need to unhide it to make it visible. +

      +
      • In Windows, your (standard) macro directory is
      +
      C:\Users\your_user_name\AppData\Roaming\FreeCAD
      +
      +

      If you are unsure of where your macro-directory is, +

      +
      1. open FreeCAD and go to "Edit → Preferences",
      2. +
      3. select "General" in the left column and select category "Macro" on the top right corner of the preferences-window. There sould be a field named "Macro Path".
      +

      Tutorial: Dxf Importer Install +

      +

      Setting Options

      +

      You can set several import options for DWG/DXF. Depending on your version you have to use a different method. +

      +
      • FreeCAD 0.14 and older
      +
      1. Open FreeCAD.
      2. +
      3. Switch to the Draft Workbench. (Otherwise you won't see the options)
      4. +
      5. Go to "Edit → Preferences" and select "Draft" in the left column.
      6. +
      7. Select "DXF / DWG-Options" in the top right corner of the preferences-window.
      +
      • FreeCAD 0.15 and above
      +
      1. Open FreeCAD.
      2. +
      3. Switch to the Draft Workbench. (Otherwise you won't see the options)
      4. +
      5. Go to "Edit → Preferences".
      6. +
      7. Now you shoould see an icon labeled "Import-Export" in the left column. Select that.
      +

      Tips and Tricks

      +

      Sometimes DXF Files don't seem to import although they open up in 2D-DXF-CAD-Programs without problems.
      +You can try:
      +

      +
      1. Go to Edit → Preferences → Import/Export → DXF/DWG and untick the option "join geometry" and try again.
      2. +
      3. Remember that maybe now you won't have coincident end-of-line-points. You will have to make them coincident yourself.
      4. +
      5. You can do this with the command "Close Shape" in the sketcher workbench (needs version 0.15) or you can apply the constraints manually
      +

      You can also try:
      +

      +
      1. Go to Edit → Preferences → Draf → General and adjust the value of "Tolerance" (default: 0,05)
      2. +
      3. Try again
      +

      Good luck on importing. +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/FreeCAD_and_Mesh_Import.html b/localwiki/FreeCAD_and_Mesh_Import.html new file mode 100644 index 0000000..888f904 --- /dev/null +++ b/localwiki/FreeCAD_and_Mesh_Import.html @@ -0,0 +1,53 @@ +FreeCAD and Mesh Import

      FreeCAD and Mesh Import

      + +
      + +

      Operations after Import

      +

      After import the model is (for FreeCAD) just an assembly of faces. You might want to convert the model into a shape FreeCAD can recognize and that could be altered in FreeCAD. +

      To do this: +

      +
      • Switch to the Part workbench
      • +
      • Select the mesh, and go to the Part menu --> Create shape from mesh
      • +
      • Click OK to the dialog
      • +
      • Select the newly created shape
      • +
      • Go to Part --> Convert to solid
      • +
      • Select the newly created solid
      • +
      • Go to Part --> Refine shape
      +

      The last step is not necessary, but it will clean the solid of most of its residual edges on planar and cylindrical surfaces. +

      +

      I get the error message "cannot convert because shape is not a shell" ! What now ?

      +

      Well, your shell seems to have errors, maybe it is not closed (has holes). Since the capabilities of the mesh workbench in FreeCAD are a little limited at the moment, you might want to try examining and repairing of your model with third-party software. After doing that, you may try importing and converting of your model again. +

      +

      Which programs can I use for examining/repairing of my mesh model ?

      +
      • Meshlab +
        • License: Open Source (GPL V2)
        • +
        • Runs on Windows 32/64 bit, Linux and Mac OS X
      +
      • netFabb basic +
        • License: Freeware
        • +
        • Runs on Windows XP/7/8, Linux and Mac OS X
      +

      Tutorials

      + +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/FreeCAD_development_model.html b/localwiki/FreeCAD_development_model.html new file mode 100644 index 0000000..ff7e327 --- /dev/null +++ b/localwiki/FreeCAD_development_model.html @@ -0,0 +1,19 @@ +FreeCAD development model

      FreeCAD development model

      + +

      This is the documentation of the FreeCAD development model. +

      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/FreeCAD_development_model_project.html b/localwiki/FreeCAD_development_model_project.html new file mode 100644 index 0000000..2b6400b --- /dev/null +++ b/localwiki/FreeCAD_development_model_project.html @@ -0,0 +1,89 @@ +FreeCAD development model project

      FreeCAD development model project

      + +

      This page is toward the transition of the FreeCAD code in a GIT repository and a more capable development model. It follows the rules of the Getting things done process. The projects are collected in the Development roadmap. +

      + + +

      Purpose and principles

      +

      This project aims to define a new development and governance model for FreeCAD. +We come to point where one SVN repository is hard to govern. Working with patches +is annoying and complicated for people willing to contribute code. +To give everyone write access to the SVN repo dangerous. People can +unintentional break something in the base system or force tasty decisions. +

      So I look at the Linux development process, which is maybe at the moment +too big for our shoes, but never the less! Which means Git as distributed +version control system (DVCS), mailing lists and submaintainers (lieutenants). +

      +

      Outcome

      +

      Brainstorming

      +

      Git

      +
      • Using Git as new version control system
      • +
      • Keeping SVN (at least for while) +
        • use it as some kind of release repository to keep the ppa work flows and the nice revision numbers
        • +
        • restrict SVN writes to Werner, Yorik and Jurgen (official tree)
        • +
        • all other things, like development, branches, experiments go into Git!
        • +
        • Option: switch completely to Git +
          • would give some collaterals in version numbering and ppa builds....
      • +
      • give write rights (push) to everyone interested in
      +

      Development mailing list

      +

      The forum has its limitation, I would use the one or more mailing lists to +manage branches and pull requests. That has advantages: +

      +
      • can work off-line
      • +
      • use powerful search of the mail client
      • +
      • no restrictions in attachments and sizes
      +

      Clarify responsibilities

      +

      We will soon become more and more developers and user will have conflicting feature requests. +We have to have structure and responsibilities to filter and decide such requests and incoming +code. +

      +

      Step ups

      +
      Adrian Przekwas:
      +Publicity - G+, Youtube,
      +Tutorials - http://freecad-tutorial.blogspot.com
      +Translation (unsure) - Polish (Wiki, Crowdin)
      +
      +
      Yorik van Havre:
      +Software: arch module, draft module, artwork
      +Documentation: general wiki organization and design
      +Translation: french, dutch, brazilian portuguese
      +Publicity: articles on http://yorik.uncreated.net/guestblog.php, G+, facebook
      +
      +

      Organizing

      +

      Decided rules and information goes to the FreeCAD development model document. +

      +

      Next actions

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/FreeCAD_start_center.jpg b/localwiki/FreeCAD_start_center.jpg new file mode 100644 index 0000000..f12bb78 Binary files /dev/null and b/localwiki/FreeCAD_start_center.jpg differ diff --git a/localwiki/FreeCAD_vector_math_library.html b/localwiki/FreeCAD_vector_math_library.html new file mode 100644 index 0000000..56a5e86 --- /dev/null +++ b/localwiki/FreeCAD_vector_math_library.html @@ -0,0 +1,85 @@ +FreeCAD vector math library

      FreeCAD vector math library

      + +

      This is a python file containing a couple of useful functions to manipulate freecad vectors. Just paste the following code in a python file, and import that file in your python script in order to use them. This library is included in the Draft Module and can be accessed like this from the python interpreter: +

      +
      import DraftVecUtils
      +
      +

      Vectors are the building bricks of almost all 3D geometric operations, so it is useful to know a bit about them to understand how these functions can be useful to you. A couple of good pages to learn the basics of vector math: +

      + +
      + "Vector math library for FreeCAD"
      +
      + import math,FreeCAD
      + 
      + def add(first, other):
      + "add(Vector,Vector) - adds two vectors"
      + if isinstance(first,FreeCAD.Vector) and isinstance(other,FreeCAD.Vector):
      + return FreeCAD.Vector(first.x+other.x, first.y+other.y, first.z+other.z)
      + 
      + def sub(first, other): 
      + "sub(Vector,Vector) - subtracts second vector from first one"
      + if isinstance(first,FreeCAD.Vector) and isinstance(other,FreeCAD.Vector):
      + return FreeCAD.Vector(first.x-other.x, first.y-other.y, first.z-other.z)
      + 
      + def scale(first,scalar):
      + "scale(Vector,Float) - scales (multiplies) a vector by a factor"
      + if isinstance(first,FreeCAD.Vector):
      + return FreeCAD.Vector(first.x*scalar, first.y*scalar, first.z*scalar)
      + 
      + def length(first):
      + "lengh(Vector) - gives vector length"
      + if isinstance(first,FreeCAD.Vector):
      + return math.sqrt(first.x*first.x + first.y*first.y + first.z*first.z)
      + 
      + def dist(first, other):
      + "dist(Vector,Vector) - returns the distance between both points/vectors"
      + if isinstance(first,FreeCAD.Vector) and isinstance(other,FreeCAD.Vector):
      + return length(sub(first,other))
      + 
      + def normalized(first):
      + "normalized(Vector) - returns a unit vector"
      + if isinstance(first,FreeCAD.Vector):
      + l=length(first)
      + return FreeCAD.Vector(first.x/l, first.y/l, first.z/l)
      + 
      + def dotproduct(first, other):
      + "dotproduct(Vector,Vector) - returns the dot product of both vectors"
      + if isinstance(first,FreeCAD.Vector) and isinstance(other,FreeCAD.Vector):
      + return (first.x*other.x + first.y*other.y + first.z*other.z)
      + 
      + def crossproduct(first, other=FreeCAD.Vector(0,0,1)):
      + "crossproduct(Vector,Vector) - returns the cross product of both vectors. 
      + If only one is specified, cross product is made with vertical axis, thus returning its perpendicular in XY plane"
      + if isinstance(first,FreeCAD.Vector) and isinstance(other,FreeCAD.Vector):
      + return FreeCAD.Vector(first.y*other.z - first.z*other.y, first.z*other.x - first.x*other.z, first.x*other.y - first.y*other.x)
      + 
      + def angle(first, other=FreeCAD.Vector(1,0,0)):
      + "angle(Vector,Vector) - returns the angle in radians between the two vectors. 
      + If only one is given, angle is between the vector and the horizontal East direction"
      + if isinstance(first,FreeCAD.Vector) and isinstance(other,FreeCAD.Vector):
      + return math.acos(dotproduct(normalized(first),normalized(other)))
      + 
      + def project(first, other):
      + "project(Vector,Vector): projects the first vector onto the second one"
      + if isinstance(first,FreeCAD.Vector) and isinstance(other,FreeCAD.Vector):
      + return scale(other, dotproduct(first,other)/dotproduct(other,other))
      +
      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Freecad-doc.png b/localwiki/Freecad-doc.png new file mode 100644 index 0000000..900cb8b Binary files /dev/null and b/localwiki/Freecad-doc.png differ diff --git a/localwiki/Freecad-doc.svg b/localwiki/Freecad-doc.svg new file mode 100644 index 0000000..4a43066 --- /dev/null +++ b/localwiki/Freecad-doc.svg @@ -0,0 +1,403 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Freecad-solar-diagram.jpg b/localwiki/Freecad-solar-diagram.jpg new file mode 100644 index 0000000..aef22d0 Binary files /dev/null and b/localwiki/Freecad-solar-diagram.jpg differ diff --git a/localwiki/Freecad-vista01.jpg b/localwiki/Freecad-vista01.jpg new file mode 100644 index 0000000..8f3840a Binary files /dev/null and b/localwiki/Freecad-vista01.jpg differ diff --git a/localwiki/Freecad-vista02.jpg b/localwiki/Freecad-vista02.jpg new file mode 100644 index 0000000..ee101d3 Binary files /dev/null and b/localwiki/Freecad-vista02.jpg differ diff --git a/localwiki/Freecad.svg b/localwiki/Freecad.svg new file mode 100644 index 0000000..5fde369 --- /dev/null +++ b/localwiki/Freecad.svg @@ -0,0 +1,256 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + diff --git a/localwiki/Freecad010.png b/localwiki/Freecad010.png new file mode 100644 index 0000000..b167ff1 Binary files /dev/null and b/localwiki/Freecad010.png differ diff --git a/localwiki/Freecad09.jpg b/localwiki/Freecad09.jpg new file mode 100644 index 0000000..b7cbad1 Binary files /dev/null and b/localwiki/Freecad09.jpg differ diff --git a/localwiki/Freecad16.svg b/localwiki/Freecad16.svg new file mode 100644 index 0000000..28d7e0e --- /dev/null +++ b/localwiki/Freecad16.svg @@ -0,0 +1,159 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + + + + + + + + + diff --git a/localwiki/Freecadsplash016.png b/localwiki/Freecadsplash016.png new file mode 100644 index 0000000..64f2c7a Binary files /dev/null and b/localwiki/Freecadsplash016.png differ diff --git a/localwiki/Freecadsplash017.png b/localwiki/Freecadsplash017.png new file mode 100644 index 0000000..bf97a9d Binary files /dev/null and b/localwiki/Freecadsplash017.png differ diff --git a/localwiki/Freecadsplash14.png b/localwiki/Freecadsplash14.png new file mode 100644 index 0000000..f1d1ef5 Binary files /dev/null and b/localwiki/Freecadsplash14.png differ diff --git a/localwiki/Freecadsplash15.png b/localwiki/Freecadsplash15.png new file mode 100644 index 0000000..77a9001 Binary files /dev/null and b/localwiki/Freecadsplash15.png differ diff --git a/localwiki/FromShape_image_0.png b/localwiki/FromShape_image_0.png new file mode 100644 index 0000000..bdb944e Binary files /dev/null and b/localwiki/FromShape_image_0.png differ diff --git a/localwiki/GGTuto1_0.PNG b/localwiki/GGTuto1_0.PNG new file mode 100644 index 0000000..116ffaa Binary files /dev/null and b/localwiki/GGTuto1_0.PNG differ diff --git a/localwiki/GGTuto1_1.PNG b/localwiki/GGTuto1_1.PNG new file mode 100644 index 0000000..a317cc1 Binary files /dev/null and b/localwiki/GGTuto1_1.PNG differ diff --git a/localwiki/GGTuto1_10.PNG b/localwiki/GGTuto1_10.PNG new file mode 100644 index 0000000..295ec7b Binary files /dev/null and b/localwiki/GGTuto1_10.PNG differ diff --git a/localwiki/GGTuto1_11.PNG b/localwiki/GGTuto1_11.PNG new file mode 100644 index 0000000..fed7231 Binary files /dev/null and b/localwiki/GGTuto1_11.PNG differ diff --git a/localwiki/GGTuto1_12.PNG b/localwiki/GGTuto1_12.PNG new file mode 100644 index 0000000..8b4b745 Binary files /dev/null and b/localwiki/GGTuto1_12.PNG differ diff --git a/localwiki/GGTuto1_2.PNG b/localwiki/GGTuto1_2.PNG new file mode 100644 index 0000000..95463f0 Binary files /dev/null and b/localwiki/GGTuto1_2.PNG differ diff --git a/localwiki/GGTuto1_3.PNG b/localwiki/GGTuto1_3.PNG new file mode 100644 index 0000000..24366db Binary files /dev/null and b/localwiki/GGTuto1_3.PNG differ diff --git a/localwiki/GGTuto1_4.PNG b/localwiki/GGTuto1_4.PNG new file mode 100644 index 0000000..22afb0b Binary files /dev/null and b/localwiki/GGTuto1_4.PNG differ diff --git a/localwiki/GGTuto1_5.PNG b/localwiki/GGTuto1_5.PNG new file mode 100644 index 0000000..9c941cf Binary files /dev/null and b/localwiki/GGTuto1_5.PNG differ diff --git a/localwiki/GGTuto1_6.PNG b/localwiki/GGTuto1_6.PNG new file mode 100644 index 0000000..e92fb25 Binary files /dev/null and b/localwiki/GGTuto1_6.PNG differ diff --git a/localwiki/GGTuto1_7.PNG b/localwiki/GGTuto1_7.PNG new file mode 100644 index 0000000..dfe6d1c Binary files /dev/null and b/localwiki/GGTuto1_7.PNG differ diff --git a/localwiki/GGTuto1_8.PNG b/localwiki/GGTuto1_8.PNG new file mode 100644 index 0000000..cd55a08 Binary files /dev/null and b/localwiki/GGTuto1_8.PNG differ diff --git a/localwiki/GGTuto1_9.PNG b/localwiki/GGTuto1_9.PNG new file mode 100644 index 0000000..480a309 Binary files /dev/null and b/localwiki/GGTuto1_9.PNG differ diff --git a/localwiki/GGTuto1_Vue.PNG b/localwiki/GGTuto1_Vue.PNG new file mode 100644 index 0000000..51275ef Binary files /dev/null and b/localwiki/GGTuto1_Vue.PNG differ diff --git a/localwiki/GW_Dim.png b/localwiki/GW_Dim.png new file mode 100644 index 0000000..5b58c58 Binary files /dev/null and b/localwiki/GW_Dim.png differ diff --git a/localwiki/Geneva.png b/localwiki/Geneva.png new file mode 100644 index 0000000..1a63062 Binary files /dev/null and b/localwiki/Geneva.png differ diff --git a/localwiki/Geofeaturegroup.svg b/localwiki/Geofeaturegroup.svg new file mode 100644 index 0000000..fffcdcc --- /dev/null +++ b/localwiki/Geofeaturegroup.svg @@ -0,0 +1,258 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + Path-Stock + 2015-07-04 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Path/Gui/Resources/icons/Path-Stock.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + diff --git a/localwiki/GeometryCheck_Errors.jpg b/localwiki/GeometryCheck_Errors.jpg new file mode 100644 index 0000000..1013106 Binary files /dev/null and b/localwiki/GeometryCheck_Errors.jpg differ diff --git a/localwiki/Getting_started.html b/localwiki/Getting_started.html new file mode 100644 index 0000000..81c28cb --- /dev/null +++ b/localwiki/Getting_started.html @@ -0,0 +1,188 @@ +Getting started

      Getting started

      + +
      + +

      What's new

      + +

      Foreword

      +

      FreeCAD is a 3D CAD/CAE parametric modeling application. It is primarily made for mechanical design, but also serves all other uses where you need to model 3D objects with precision and control over modeling history. +

      FreeCAD is still in the early stages of development, so, although it already offers you a large (and growing) list of features, much is still missing, specially comparing it to commercial solutions, and you might not find it developed enough yet for use in production environment. Still, there is a fast-growing community of enthusiastic users, and you can already find many examples of quality projects developed with FreeCAD. +

      Like all open-source projects, the FreeCAD project is not a one-way work delivered to you by its developers. It depends much on its community to grow, gain features, and stabilize (get bugs fixed). So don't forget this when starting to use FreeCAD, if you like it, you can directly influence and help the project! +

      +

      Installing

      +

      First of all (if not done already) download and install FreeCAD. See the Download page for information about current versions and updates, and the Installing page for information about how to install FreeCAD. There are install packages ready for Windows (.msi), Ubuntu & Debian (.deb) openSUSE (.rpm) and Mac OSX. As FreeCAD is open-source, if you are adventurous, but want to have a look at the brand-new features being developed right now, you can also grab the source code and compile FreeCAD yourself. +

      +

      Exploring FreeCAD

      +
      Freecad-interface.jpg
      +


      +

      +
      1. The 3D view, showing the contents of your document
      2. +
      3. The tree view, which shows the hierarchy and construction history of all the objects in your document
      4. +
      5. The properties editor, which allows you to view and modify properties of the selected object(s)
      6. +
      7. The report view (or output window), which is where FreeCAD prints messages, warnings and errors
      8. +
      9. The python console, where all the commands executed by FreeCAD are printed, and where you can enter python code
      10. +
      11. The workbench selector, where you select the active workbench
      +


      +The main concept behind the FreeCAD interface is that it is separated into workbenches. A workbench is a collection of tools suited for a specific task, such as working with meshes, or drawing 2D objects, or constrained sketches. You can switch the current workbench with the workbench selector (6). You can customize the tools included in each workbench, add tools from other workbenches or even self-created tools, that we call macros. Widely used starting points are the PartDesign Workbench and Part Workbench +

      When you start FreeCAD for the first time, you are presented with the start center: +


      +

      +
      Startcenter.jpg
      +


      +The Start Center allows you to quickly jump to one of the most common workbenches, open one of the recent files, or see the latest news from the FreeCAD world. You can change the default workbench in the preferences. +

      +

      Navigating in the 3D space

      +

      FreeCAD has several different navigation modes available, that change the way you use your mouse to interact with the objects in the 3D view and the view itself. One of them is specifically made for touchpads, where the middle mouse button is not used. The following table describes the default mode, called CAD Navigation (You can quickly change the current navigation mode by right-clicking on an empty area of the 3D view): +


      +

      + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
      Select +Pan +Zoom +Rotate View +Rotate View +

      Alternate Method +

      +
      Hand cursor.png +Pan cursor.png +Zoom cursor.png +Rotate cursor.png +Rotate cursor.png +
      to Select +to Pan +to Zoom in or out +to Rotate view +to Rotate view +
      Press the left mouse button over an object you want to select. Holding down ctrl allows the selection of multiple objects. +Click the middle mouse button and move the object around to pan +Use the mouse wheel to zoom in and out. Clicking the middle mouse button re-centers the view to the location of the cursor. +Click first with the middle mouse button, hold it down, and then click the left mouse button and drag the mouse in the desired direction. The cursor location at the middle mouse button click determines the center of rotation. Rotation works like spinning a ball which rotates around its center. If the buttons are released before you stop the mouse motion, the object continues spinning, if this is enabled. A double click with the middle mouse button sets a new center of rotation. +Click first with the middle mouse button, hold it down, and then click the right mouse button and drag the mouse in the desired direction. This method works just like the previously described Rotate View that uses Middle Mouse Button + Left Mouse Button, except that the middle mouse button may be released after the right mouse button is pressed. Users who use the mouse with their right hand may find this Rotate View method easier than the previous method. +
      +to Pan +to Zoom +to rotate + +
      +For the Pan mode, press the Ctrl key and press the right mouse button to pan (rev 0.17) +For the Zoom mode, press the Ctrl and Shift key and press the right mouse button to Zoom (rev 0.17) +For the Rotate mode, press the Shift key and press the right mouse button to rotate (rev 0.17) + +
      +


      +

      You also have several view presets (top view, front view, etc) available in the View menu and on the View toolbar, and by numeric shortcuts (1, 2, etc...), and by right-clicking on an object or on an empty area of the 3D view, you have quick access to some common operations, such as setting a particular view, or locating an object in the Tree view. +

      +

      First steps with FreeCAD

      +

      FreeCAD's focus is to allow you to make high-precision 3D models, to keep tight control over those models (being able to go back into modelling history and change parameters), and eventually to build those models (via 3D printing, CNC machining or even construction worksite). It is therefore very different from some other 3D applications made for other purposes, such as animation film or gaming. Its learning curve can be steep, specially if this is your first contact with 3D modeling. If you are struck at some point, don't forget that the friendly community of users on the FreeCAD forum might be able to get you out in no time. +

      The workbench you will start using in FreeCAD depends on the type of job you need to do: If you are going to work on mechanical models, or more generally any small-scale objects, you'll probably want to try the PartDesign Workbench. If you will work in 2D, then switch to the Draft Workbench, or the Sketcher Workbench if you need constraints. If you want to do BIM, launch the Arch Workbench. If you are working with ship design, there is a special Ship Workbench for you. And if you come from the OpenSCAD world, try the OpenSCAD Workbench. +

      You can switch workbenches at any time, and also customize your favorite workbench to add tools from other workbenches. +

      +

      Working with the PartDesign and Sketcher workbenches

      +

      The PartDesign Workbench is specially made to build complex objects, starting from simple shapes, and adding or removing pieces (that we call "features"), until you get to your final object. All the features you applied during the modelling process are stored in a separate view called the tree view, which also contains the other objects in your document. You can think of a PartDesign object as a succession of operations, each one applied to the result of the preceding one, forming one big chain. In the tree view, you see your final object, but you can expand it and retrieve all preceding states, and change any of their parameter, which automatically updates the final object. +

      The PartDesign workbench makes heavy use of another workbench, the Sketcher Workbench. The sketcher allows you to draw 2D shapes, which are defined by applying Constraints to the 2D shape. For example, you might draw a rectangle and set the size of a side by applying a length constraint to one of the sides. That side then cannot be resized anymore (unless the constraint is changed). +

      Those 2D shapes made with the sketcher are used a lot in the PartDesign workbench, for example to create 3D volumes, or to draw areas on the faces of your object that will then be hollowed from its main volume. This is a typical PartDesign workflow: +

      +
      1. Create a new sketch
      2. +
      3. Draw a closed shape (make sure all points are joined)
      4. +
      5. Close the sketch
      6. +
      7. Expand the sketch into a 3D solid by using the pad tool
      8. +
      9. Select one face of the solid
      10. +
      11. Create a second sketch (this time it will be drawn on the selected face)
      12. +
      13. Draw a closed shape
      14. +
      15. Close the sketch
      16. +
      17. Create a pocket from the second sketch, on the first object
      +

      Which gives you an object like this: +

      +
      Partdesign example.jpg
      +

      At any moment, you can select the original sketches and modify them, or change the extrusion parameters of the pad or pocket operations, which will update the final object. +

      +

      Working with the Draft and Arch workbenches

      +

      The Draft Workbench and Arch Workbench behave a bit differently than the other workbenches above, although they follow the same rules, which are common to all of FreeCAD. In short, while the Sketcher and PartDesign are made primarily to design single pieces, Draft and Arch are made to ease your work when working with several, simpler objects. +

      The Draft Workbench offers you 2D tools a bit similar to what you can find in traditional 2D CAD applications such as AutoCAD. However, 2D drafting being far away from the scope of FreeCAD, don't expect to find there the full array of tools that these dedicated applications offer. Most of the Draft tools work not only in a 2D plane but also in the full 3D space, and benefit from special helper systems such as Work planes and object snapping. +

      The Arch Workbench adds BIM tools to FreeCAD, allowing you to build architectural models with parametric objects. The Arch workbench relies much on other modules such as Draft and Sketcher. All the Draft tools are also present in the Arch workbench, and most Arch tools make use of the Draft helper systems. +

      A typical workflow with Arch and Draft workbenches might be: +

      +
      1. Draw a couple of lines with the Draft Line tool
      2. +
      3. Select each line and press the Wall tool to build a wall on each of them
      4. +
      5. Join the walls by selecting them and pressing the Arch Add tool
      6. +
      7. Create a floor object, and move your walls in it from the Tree view
      8. +
      9. Create a building object, and move your floor in it from the Tree view
      10. +
      11. Create a window by clicking the Window tool, select a preset in its panel, then click on a face of a wall
      12. +
      13. Add dimensions by first setting the working plane if necessary, then using the Draft Dimension tool
      +

      Which will give you this: +

      Arch workflow example.jpg +

      More on the Tutorials page. +

      +

      Scripting

      +

      And finally, one of the most powerful features of FreeCAD is the scripting environment. From the integrated python console (or from any other external Python script), you can gain access to almost any part of FreeCAD, create or modify geometry, modify the representation of those objects in the 3D scene or access and modify the FreeCAD interface. Python scripting can also be used in macros, which provide an easy method to create custom commands. +


      +

      + +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Git.svg b/localwiki/Git.svg new file mode 100644 index 0000000..2e42bc7 --- /dev/null +++ b/localwiki/Git.svg @@ -0,0 +1,15 @@ + + + + + + + + diff --git a/localwiki/GitKraken-Clone-Repo-dialogue.png b/localwiki/GitKraken-Clone-Repo-dialogue.png new file mode 100644 index 0000000..2e12e9e Binary files /dev/null and b/localwiki/GitKraken-Clone-Repo-dialogue.png differ diff --git a/localwiki/GitKraken-Main-Screen-sm.jpg b/localwiki/GitKraken-Main-Screen-sm.jpg new file mode 100644 index 0000000..7ebc0a7 Binary files /dev/null and b/localwiki/GitKraken-Main-Screen-sm.jpg differ diff --git a/localwiki/GitKraken-Rebasing.gif b/localwiki/GitKraken-Rebasing.gif new file mode 100644 index 0000000..304d939 Binary files /dev/null and b/localwiki/GitKraken-Rebasing.gif differ diff --git a/localwiki/Gitkraken-add-remote.gif b/localwiki/Gitkraken-add-remote.gif new file mode 100644 index 0000000..c0dedcc Binary files /dev/null and b/localwiki/Gitkraken-add-remote.gif differ diff --git a/localwiki/Glossary.html b/localwiki/Glossary.html new file mode 100644 index 0000000..0d8beee --- /dev/null +++ b/localwiki/Glossary.html @@ -0,0 +1,558 @@ +Glossary

      Glossary

      + +

      This page is a glossary of common FreeCAD terms and definitions. +

      Jump to letter: A B C D E F G H I J K L M N O P Q R S T U V W X Y Z +


      +

      +

      A

      +
      +
      Arc +
      A portion or segment of a circle. + +
      Arch +
      An abbreviation for the Architectural workbench which is used primarily for modelling buildings and structures. Closely related to the Draft Workbench. + +
      Assembly +
      1.  A set of parts that have defined positions in relation to each other. + +
      2.  A workbench which aims to facilitate the creation of assemblies. It is currently in development and not yet part of FreeCAD. + +
      Axis +
      An imaginary line through the origin of the workspace. There are 3 normal axes. They have the classic names of X, Y and Z. X is side to side. Y is up and down. Z is in and out of the page/screen. + +
      +

      B

      +
      +
      Backtrace +
      Output from a debugging program that displays the series of instructions FreeCAD followed before a problem occurred. + +
      Bezier Curve +
      A type of parametric curve. See Bezier Curve + +
      Blueprint +
      Old term used for drawing, and coined for its original reproduction process. + +
      Body +
      A type of container used in the PartDesign workbench that groups a sequence of operations (sketches, construction geometry and features) to create a single contiguous solid. (Introduced in FreeCAD V0.17.) + +
      Boolean Logic +
      A method of data manipulation by using of the operands: And, Or, Not. + +
      Boolean Operation +
      A method of manipulating objects by using Boolean Logic. In FreeCAD, the Boolean Operations are: Union (Fuse), Difference (Cut), Intersection, and Section. + +
      Boolean OPerations check +
      See BOPcheck. + +
      BOPcheck +
      A setting that allows the Check Geometry tools in the Part WB and OpenSCAD WB to also check geometry made from Boolean logic. The default setting is "false" (or off) but the user can enable it to provide more accuracy when running a Check Geometry, but this is at the expense of longer Check Geometry processing times. The setting is enabled by navigating to Tools > Edit Parameters > Preferences folder > Mod folder > Part folder > Check geometry folder, then double-clicking "false" in the right pane, changing the value to "true", clicking the "OK" button, clicking the "Save to disk" button, then clicking the "Close" button. A corresponding screen grab and description of how to enable BOPCheck is in this forum post. + +
      brep +
      Native file format for Open CASCADE and shared by a few applications. FreeCAD can save in *.brep format. + +
      B-rep +
      Stands for boundary representation, which is one of two types of 3D models that FreeCAD supports (the other being mesh). + +
      B-spline +
      A type of parametric curve. See B-spline + +
      +

      C

      +
      +
      Callout +
      String of text connected to a line pointing to an object in a drawing. + +
      Chamfer +
      The cutting off of an edge, at an angle, to get rid of its sharpness; a beveled edge. + +
      Clipping Plane +
      The clipping plane is used to cut away at the model in the 3D view. It is just a visual aid and does not actually cut the model. + +
      Clone +
      A copy of an object whereby the copy remains parametric. When the original object is changed the Clone(s) also change to show modifications made to the original object. + +
      Coin +
      Also called Coin3D. Third-party software library used for 3D representation by FreeCAD. + +
      COLLADA +
      An interchange file format for mesh models. File extension is *.dae. + +
      Command +
      An action invoked from the Gui when you press a toolbar button or type a keyboard shortcut or type into the python console. + +
      Compound +
      Groups objects together without fusing them like a boolean union would. + +
      CompSolid +
      Set of solids connected by their faces. CompSolids are needed in FEM, where more than one material is used in one FEM-mesh. + +
      Constraint +
      A restriction on the geometric relationship between primitives in a Sketch. If a constraint has a numerical value, it is referred to as Datum (e.g., a distance constraint has a numerical value - the length of an imaginary line connecting the two points). A constraint that has no numerical value (e.g., a Horizontal constraint) is sometimes referred to as Geometric Constraint. + +
      Constructive Solid Geometry +
      A solid modeling method for creating shapes by using boolean operations on primitives. + +
      Coordinate +
      A number which defines the position of an object in space in reference to a coordinate system. + +
      Coplanar +
      Existing on the same plane. + +
      CSG +
      Short for Constructive Solid Geometry. + +
      Cut +
      Applying a boolean difference between shapes. + +
      +

      D

      +
      +
      DAG +
      See Directed Acyclic Graph. + +
      Degrees Of Freedom (abbreviated as "DOF") +
      The number of ways geometry in a Sketch may vary. For example, if we have a Sketch consisting of only one point, and the point has no Constraints applied to it, the point has two DOF because it is free to move both vertically and horizontally. Similarly, a Sketch consisting of only a single unconstrained circle has three DOF because the circle can move vertically and horizontally and, additionally, the radius is not defined. It is good practice to constrain a Sketch until it has no DOF remaining, in which case it is said to be Fully Constrained. + +
      Dependency Graph +
      A third-party graphing tool used to show how objects in a FreeCAD model use or are related to one another. For more information, refer to the Dependency Graph Wiki page + +
      Difference +
      1.  The result of, or remainder of, a subtraction. + +
      2.  A Boolean Operation in the Part Workbench which is used to subtract one geometry from another; it results in a Cut. + +
      Directed Acyclic Graph (abbreviated as "DAG") +
      A type of Dependency Graph where the relationship of objects flows in a generally linear direction from start to end with no circular dependencies. When following a DAG there is no flow from one object A to any other objects and then back to that same object A again. In FreeCAD, a graph of the model must always be a DAG. + +
      Draft +
      1.  A FreeCAD Workbench used primarily for 2 dimensional work. + +
      2.  A relief angle on a mold to allow removal of the finished product. See PartDesign Draft. + +
      Drawing +
      1.  A FreeCAD Workbench used to generate 2D representations of a model, also called drawings. + +
      2.  Describes a representation of geometry through the use of two-dimensional views. Also called plan. + +
      +

      E

      +
      +
      Edge +
      1.  A segment joining two vertices. This segment can be a straight line or a curve. The CAD kernel defines it as: One-dimensional shape corresponding to a curve and bounded by a vertex at each extremity. A closed circle has therefore only one vertex, where it starts and ends. [see Profile: Defining the Topology]. + +
      2.  The joining line between two faces. It can be curved or straight. + +
      Element +
      An item of Sketcher geometry such as a point, a line segment, an arc, a circle, etc. + +
      Extrude +
      A general term for extending a 2D object into 3D along 1 direction. See also Pad. + +
      +

      F

      +
      +
      Face +
      A 2 dimensional topological construct. For example, a cube has 6 Faces. A face can be curved, like in case of a sphere, which has one face in FreeCAD. The CAD kernel defines it as: Part of a surface bounded by a closed wire(s). [see Profile: Defining the Topology]. + +
      Facet +
      Often used to describe planar faces on a mesh. + +
      FC +
      Short for FreeCAD. + +
      FCStd +
      FreeCAD native file format. File extension *.fcstd, *.FCStd + +
      Feature +
      A step in a 3d part's evolution in the Part Design Workbench workflow. Examples are Pad, Pocket, Groove, Fillet, etc. As we create a model in the Part Design Workbench, each feature takes the shape of the last one and adds or removes something. Hence a "Pocket" feature is not only the pocketed hole itself, but the whole part with the pocket feature. + +
      FEM +
      Finite Element Method, a workbench used to solve engineering and mathematical physics problems associated with parts, assemblies and structures. + +
      Fillet +
      A rounded relief or cut at an edge added for a finished appearance and to break sharp edges. See Part Fillet and PartDesign Fillet. + +
      Fork +
      See Forked Model. + +
      Forked Model +
      A modeling method, usually accidental and incorrect in FreeCAD, that creates two or more versions of a model from a previous item. (Not to be confused with intentional operations like Array, Clone, PolarPattern, etc.) + +
      Frenet +
      When Sweeping a profile along a 3D path, the Frenet parameter controls the orientation of the profile as it travels along the path. If Frenet is true, the profiles are oriented using the Frenet Frame (tangent, binormal, normal) of the path. If Frenet is false the profile's rotation is not restricted. [1] + +
      FreeType +
      A freely available software library used to extract information from font definition files. + +
      Frustum +
      The portion of a solid that lies between two parallel planes cutting it. Used in computer graphics to describe the three-dimensional region which is visible on the screen, the "viewing frustum" + +
      Fully Constrained +
      In Sketcher, when a Sketch has no Degrees Of Freedom, the Sketch is said to be "fully constrained" by the applied Constraints. + +
      Fuse +
      Term commonly used in FreeCAD to refer to a boolean union of shapes. + +
      +

      G

      +
      +
      GDB or gdb +
      GNU Project DeBugger, a debugging program used on Unix and other 'nix operating systems in order to get a backtrace. "gdb" (without the quotation marks) is also the first part of the command used to start the GDB program itself. An example of how to use GDB with FreeCAD is in this forum post + +
      Geometric modeling kernel +
      Also called CAD kernel. A set of complex software libraries responsible for the creation of 3D shapes. All operations on objects (extrude, boolean operations, chamfer, fillet) rely on the geometric modeling kernel. + +
      Git +
      Distributed revision control system used by FreeCAD to host and manage its code base. + +
      Group +
      Used to organize elements in the Model tree. + +
      GUI +
      Graphical User Interface. Allows users to interact with FreeCAD through graphical icons and the mouse pointer. + +
      +

      H

      +
      +
      Half Space +
      When a plane completely divides a 3D Euclidian space, the plane forms two half spaces. + +
      +

      I

      +
      +
      IGES +
      A file format for the exchange of product data models. Files extensions are *.iges, *.igs. See also STEP. + +
      Intersection +
      That portion of two or more geometric entities that is common to all. For example, the intersection of two lines is a point. + +
      +

      J

      +
      +
      JT +
      A proprietary 3D data format developed by Siemens PLM Software. FreeCAD has no support for JT at this time. + +
      +

      K

      +
      +
      Kernel +
      See Geometric modeling kernel. + +
      KML +
      Keyhole Markup Language - an XML-based geospatial 3D data definition file used by Google Earth. FreeCAD has no support for KML at this time. + +
      +

      L

      +
      +
      Label +
      1.  A user defined property of an object; used to make the model tree easier to understand by humans. + +
      2.  A string of descriptive text added to a drawing (see Draft Label). + +
      Contrast with Name. + +
      Line +
      A straight path between two points. + +
      Lock +
      Constraint Lock + +
      Loft +
      A topological form created by linking consecutive profiles with a surface. Similar to the process used to make fabric covered aeroplanes or boats. Also the FreeCAD function for creating such a form. + +
      +

      M

      +
      +
      Macro +
      A saved sequence of FreeCAD instructions, often written by end users. + +
      Manifold +
      Said of a shape that forms a perfectly enclosed volume. A familiar synonym that gives a good description is "watertight". To generate a solid, a shell must be manifold. + +
      Mantis +
      Bug tracking system used by the FreeCAD project. + +
      Mesh +
      Type of object that can be imported or created by FreeCAD. See Polygon mesh for more details. + +
      Model +
      Also called 3D model. Computer representation of a three-dimensional part or assembly. + +
      MultiTransform +
      Stands for multiple transformation. A feature from the PartDesign workbench that applies a series of chained transformations (linear and circular pattern, mirrored) to selected features. + +
      +

      N

      +
      +
      Name +
      An unique identifier for a FreeCAD document object. Once assigned by the program, the Name can not be easily changed. Contrast with Label. + +
      Non-manifold +
      Non-manifold topology, also called zero-thickness, is two distinct solid bodies connected at a theoretical vertex or edge. It is an unsupported type of shape (not always detected by FreeCAD) that should be avoided, as it can cause trouble with further steps and export. + +
      Null Shape +
      A Shape property that has not been initialized by a program/macro. Usually an error condition. + +
      +

      O

      +
      +
      OCC +
      Acronym for Open CASCADE. Prior to being open sourced, it used to be named CAS.CADE (abbreviated from Computer Aided Software for Computer Aided Design and Engineering). + +
      OCE +
      Open CASCADE Community Edition. It provides patches, improvements and experiments contributed by users over the official Open CASCADE library. FreeCAD is known to work on either OCC or OCE. + +
      OCCT +
      Open CASCADE Technology. See OCC. + +
      Open CASCADE +
      The geometric modeling kernel (software library) underlying FreeCAD. Also called OCC or OCCT (for Open CASCADE Technology). See also OCE. + +
      OpenSCAD +
      Name of a script-only based CAD program as well as a workbench in FreeCAD. The OpenSCAD workbench provides an interface for import/export of *.scad and *.csg models, as well as a some utility tools. + +
      Origin +
      The center of the coordinate system. Everything goes out from here in either the positive or negative directions. As is our view of the universe with Earth being the “origin”. + +
      Orthographic +
      See Orthographic projection and Multiview orthographic projection. + +
      +

      P

      +
      +
      Pad +
      An extension of a Sketch in a direction perpendicular to the plane of the Sketch. See also Extrude. + +
      Part +
      1.  A FreeCAD Workbench primarily used for a Constructive Solid Geometry workflow. + +
      2.  A unibody solid. The lowest level component in an assembly. + +
      3.  A container which groups any type of FreeCAD object and has a placement. (Introduced in FreeCAD V0.17.) + +
      PartDesignNext +
      Nickname used over the forums to distinguish the PartDesign workbench in the FreeCAD 0.17 release version from the one in v0.16 and earlier, because of the vast changes introduced. + +
      PD +
      Abbreviation of PartDesign, a FreeCAD workbench. + +
      PDN +
      Abbreviation of PartDesignNext. + +
      Perspective +
      Perspective projection + +
      Pivy +
      A software library that allows Python to use Coin. + +
      Placement +
      Set of properties of an object that defines its coordinates and orientation in space. See Placement. + +
      Planar +
      Said of geometry of which elements all lie on a same plane. + +
      Plane +
      1.  A flat, two-dimensional surface that extends infinitely far. + +
      2.  A primitive two-dimensional object created in the Part workbench. + +
      Plot +
      <To be added.> + +
      Pocket +
      A feature that removes material from a solid based on a Sketch. + +
      Point +
      An item used to reference a single area in the 3D workspace. A “point” is dimensionless. It has a dimension on the screen, usually represented by a “dot” only so we can see where it is. See also Vertex. + +
      Polygon mesh +
      See Polygonal_mesh + +
      Polyline +
      A series of connected line or arc segments. + +
      POV-Ray +
      POV-Ray + +
      PPA +
      An acronym that stands for Personal Package Archive. It's a type of software repository exclusive to the Ubuntu Linux operating system. The FreeCAD project offers the latest release as well as development versions through two PPA repositories. Updates are managed by the host system's update manager. + +
      Primitive +
      A basic shape used in the construction of models. Some 2D primitives are: point, line, polygon, circle, ellipse, spiral, helix. 3D primitives are: box, cylinder, cone, torus, sphere, ellipsoid, prism. + +
      PySide +
      A freely available software library that allows Python to use QT. + +
      Python +
      A programming language used in the development of FreeCAD as well as in user-written macros or scripts. + +
      +

      Q

      +
      +
      Qt +
      A cross-platform application and user interface framework. Also Qt4. + +
      +

      R

      +
      +
      Raytracing +
      Ray tracing + +
      Revolve +
      A tool in the Part workbench. See Part Revolve. + +
      Robot +
      Industrial robot + +
      Rotate +
      Action to spin an object unto an axis to change its orientation in space. + +
      +

      S

      +
      +
      Section +
      Cross section (geometry) + +
      Self Intersection +
      A condition where a curve crosses over itself (ex.'8','&'). This confuses geometric kernel algorithms and generally produces an error condition. + +
      Shape +
      Generic term used in FreeCAD to describe most elements (except for meshes). + +
      Shell +
      Shape made of two or more contiguous faces. A manifold (enclosed) shell can be converted into a solid. + +
      Sketch +
      A constrained 2D depiction of an object fixed to a plane or a Face. In FreeCAD a Sketch is always a 2-dimensional object somewhere in the 3D space. + +
      Sketcher +
      A workbench used to create 2D geometry by use of elements and constraints. + +
      Sketcher Solver +
      The internal FreeCAD mechanism that calculates interdependencies and effects of adding, deleting, and modifying geometry and associated constraints in each Sketch. Sketcher Solver also calculates the arrangement of all geometry in each Sketch so it can be displayed correctly. + +
      Smooth Line +
      In a Drawing, a line indicating a change between tangent surfaces, as in the transition from a flat surface to a fillet. Also "tangent edge". See Drawing View + +
      Solid +
      Part of 3D space bounded by Shells. A solid has a volume and other properties related to objects with a mass. + +
      Solver +
      See Sketcher Solver. + +
      Stable +
      A nickname for the last general release version of the FreeCAD software. This is typically the version available from sources other than the FreeCAD project. Compare with Unstable. + +
      STL +
      STereoLithography, also known as Standard Tessellation Language. A mesh file format defining only the surface of a 3D object. File extensions is *.stl + +
      STEP +
      An ISO standard (ISO 10303) for the exchange of 3D data and product manufacturing information. It replaces IGES. File extensions are *.step, *.stp. + +
      SVG +
      Scalable Vector Graphics. A vector graphics file format. + +
      Sweep +
      A 3D shape generated from at least one 2D cross-section that traces along a trajectory (path). Commonly used to define the tool as well as the created shape. See Solid modeling + +
      +

      T

      +
      +
      Task panel +
      See Tasks tab. + +
      Tasks tab +
      A control panel in FreeCAD that displays content specific to the task at hand. It can show available tools in the active workbench or prompt for values and options while a command is active. + +
      Tessellation +
      A tessellation of a surface is the tiling of the surface using one or more geometric shapes, called tiles, with no overlaps and no gaps. In FreeCAD it is needed to display the geometric shapes in the 3D-view. The tessellation relative to the dimensions of a shape can be set in the preferences to get a smoother view of round surfaces at the cost of computation time. See Preferences Editor. + +
      Thickness +
      1.  A measure of how thick a shape is. + +
      2.  A Part Workbench tool to hollow out a solid and leave a defined uniform thickness. + +
      Toggle +
      A setting that can be changed between two options, for example between True or False or between Off and On. + +
      Topological Naming +
      A scheme whereby an edge or face, once created, is assigned a permanent name. Internally, FreeCAD identifies edges and faces on a solid by numbering them such as: Edge1, Edge2, Face1, Face2, etc. The problem is that these IDs are somewhat randomly applied, and they will change after something is done to the model that changes the amount of edges and faces. For example, if the model is revised an item linked to a Face2 could later erroneously become linked to a different face (which was renamed to become the new Face2), causing the user unwanted results. As of the FreeCAD 0.16 release Topological Naming has not yet been implemented, and so if an object is modified such that the number of edges or faces changes, the names of the edges or faces of that object might change too. + +
      Torus +
      A primitive shape. + +
      Tracker +
      Short for bug tracker, the online software application used to keep track of reported bugs or feature requests. See also Mantis. + +
      +

      U

      +
      +
      Union +
      A Part workbench tool that operates a Boolean operation on selected shapes. + +
      Unstable +
      A nickname for a very recent version of the FreeCAD software. This version will contain many changes recently implemented by the developers. It does not typically fail or produce wrong results, but it has not completed testing. + +
      Upgrade +
      A Draft workbench tool. See Draft Upgrade. + +
      +

      V

      +
      +
      Vector +
      A magnitude with a direction. Often represented graphically as an arrow in 2 or 3 dimensions. For example, "fifty paces north", "9.8 m/s^2 down", and "(3,5,6) units in the x, y, z, direction, respectively" are all vectors. In FreeCAD, they are most often denoted as ordered pairs (x, y) or ordered triples (x, y, z). + +
      Vertex +
      A lone point in space, or the corner of a shape where edges meet. The open Cascade Technology defines it, as a zero dimensional shape corresponding to a point in geometry. [see OCCT Profile: Defining the topology] + +
      +

      W

      +
      +
      WB +
      Short for workbench. + +
      Wire +
      1.  A sequence of connected edges by vertices. The term wire is used in this sense mainly by Open Cascade Technology [[2]]and therefore also inside of FreeCAD. + +
      2.  A Draft workbench command that creates a parametric wire. + +
      Workbench +
      Also called module, the workbench groups a set of tools dedicated for a specific task. + +
      +

      X

      +
      +
      X +
      Commonly refers to the X axis. + +
      +

      Y

      +
      +
      Y +
      Commonly refers to the Y axis. + +
      +

      Z

      +
      +
      Z +
      Commonly refers to the Z axis. + +
      +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Goldener_Schnitt_Konstr_beliebt.svg b/localwiki/Goldener_Schnitt_Konstr_beliebt.svg new file mode 100644 index 0000000..bb8a84d --- /dev/null +++ b/localwiki/Goldener_Schnitt_Konstr_beliebt.svg @@ -0,0 +1,56 @@ + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + + + + + A + D + S + B + C + + + 1. + + + + 3. + + + + 2. + + + + + + + + + + + \ No newline at end of file diff --git a/localwiki/Google_Summer_of_Code.html b/localwiki/Google_Summer_of_Code.html new file mode 100644 index 0000000..6f791a6 --- /dev/null +++ b/localwiki/Google_Summer_of_Code.html @@ -0,0 +1,138 @@ +Google Summer of Code

      Google Summer of Code

      (Redirected from Google Summer of Code)
      + +

      FreeCAD started participating to the Google student coding program (GSoC) in 2016. We participate through a combined effort of many CAx organisations. Due to the combined application at GSoC many links will lead from here to the BRLcad wiki, which is used as single place for everything. +

      + + +

      How it works

      +
      • The student writes a project proposal for FreeCAD. +
        • Sometimes their project idea caters to something that the open source organization suggests and sometimes it's an idea entirely of the student's conception.
      • +
      • Proposals are reviewed, evaluated, and ranked by the open source organization's mentors.
      • +
      • Google allocates a certain number of slots to each participating organization +
        • That, in turn, determines how many student developers work with that organization.
      +

      If you want to get involved have a look at the getting started checklist. Whether you're applying or accepted, we've itemized everything you need to do in this list. We're here to help you become new open source developers, so don't be shy if you have any questions. +

      +

      The Selection Process

      +

      GSoC is about getting people involved and contributing to open source over the long-term. As such, we heavily weight our application selection process towards students that are interested in remaining involved in FreeCAD and open source software development long after GSoC has ended. GSoC is not a job. If you think this is just a summer job, then GSoC is probably not for you. It's only like a job in terms of planning your time commitment over the summer. +

      Additionally, submissions are graded based on perception of the submitter's abilities to complete the task within the program timeframe, general consensus on the technical approach being proposed, and overall interest in having such modifications made to FreeCAD. Particular notice is made of students that are responsive to questions and readily interactive in the IRC channel or on the forum. Communication is a great thing. +

      Just about every GSoC organization receives considerably more project proposals than can be accepted. Every application gets read multiple times and reviewed in detail. Of those applications, only a small subset are selected so keep in mind that the selection process is rather competitive and difficult. +

      Whether or not you are accepted, contributing to open source outside of GSoC is one of the main goals of the program and is the best way to be noticed and get your proposal accepted. Keep that in mind. Thanks for your interest and we look forward to working with new FreeCAD developers! +

      +

      Available Slots

      +

      FreeCAD will be allocated a maximum of (tbd) slots in this year's GSoC. To increase your chances of earning a slot, get to know us early and start fixing bugs before GSoC starts, this always helps to build trust and will convince us of your dedication. +

      +

      Possible Mentors

      +

      Bernd, Yorik, sgrogan, wandererfan, Amritpal : +The best way to contact us is through the FreeCAD forums. You can also look on the IRC channel. +

      +

      Implementation Ideas

      +

      The ideas listed here have a high chance of being accepted as project proposal. Note that for students already longer involved in FreeCAD, and which already contributed code, own ideas in their line of work are also welcome. Feel free to contact us on IRC, the forum or the mailing list for further discussions about the listed projects. +The topics priority shows you how important the work on the ideas is for the mentors, and hence choosing a high priority topic will give you an advantage if there are more applications than slots for FreeCAD. +

      + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
      Topic + Language + Difficulty + Priority + Contact +
      FreeCAD Configuration Management Project: Streamline the configuration and distribution of FreeCAD software package +Launchpad, pbuilder, gitbuilder, conda, NSIS-installer +Medium +High +sgrogan +
      TechDraw Enhancement Project: Add new functionality to the Technical Drawing Workbench +C++ +Medium +Medium +wandererfan +
      FEM_GSOC_Project: FEM Workbench ... +Python +Medium +Medium +bernd +
      Path_GSOC_Project: Path Workbench... +Python +Medium +Medium +sliptonic +
      Arch Workbench: Extend the Reinforcement bar tools (last year's GSoC) to make it possible to produce complete sheets/drawings (see Bernd's example attachment in this thread). Project detail +Python +Medium +Medium +Amritpal +
      Swept-path Analysis GSoC Project: Add functionality to FreeCAD analyze the path a vehicle takes as it turns a corner. +Python +Medium +Medium +Joel_graff microelly2 +
      +

      These are new suggestions for this year. Don't forget to look at the last year ideas too, most of them are still valid! +

      Best of luck to all applicants! +

      + + +
      + +
      +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Google_Summer_of_Code_2018.html b/localwiki/Google_Summer_of_Code_2018.html new file mode 100644 index 0000000..c0e6047 --- /dev/null +++ b/localwiki/Google_Summer_of_Code_2018.html @@ -0,0 +1,138 @@ +Google Summer of Code 2018

      Google Summer of Code 2018

      + +

      FreeCAD started participating to the Google student coding program (GSoC) in 2016. We participate through a combined effort of many CAx organisations. Due to the combined application at GSoC many links will lead from here to the BRLcad wiki, which is used as single place for everything. +

      + + +

      How it works

      +
      • The student writes a project proposal for FreeCAD. +
        • Sometimes their project idea caters to something that the open source organization suggests and sometimes it's an idea entirely of the student's conception.
      • +
      • Proposals are reviewed, evaluated, and ranked by the open source organization's mentors.
      • +
      • Google allocates a certain number of slots to each participating organization +
        • That, in turn, determines how many student developers work with that organization.
      +

      If you want to get involved have a look at the getting started checklist. Whether you're applying or accepted, we've itemized everything you need to do in this list. We're here to help you become new open source developers, so don't be shy if you have any questions. +

      +

      The Selection Process

      +

      GSoC is about getting people involved and contributing to open source over the long-term. As such, we heavily weight our application selection process towards students that are interested in remaining involved in FreeCAD and open source software development long after GSoC has ended. GSoC is not a job. If you think this is just a summer job, then GSoC is probably not for you. It's only like a job in terms of planning your time commitment over the summer. +

      Additionally, submissions are graded based on perception of the submitter's abilities to complete the task within the program timeframe, general consensus on the technical approach being proposed, and overall interest in having such modifications made to FreeCAD. Particular notice is made of students that are responsive to questions and readily interactive in the IRC channel or on the forum. Communication is a great thing. +

      Just about every GSoC organization receives considerably more project proposals than can be accepted. Every application gets read multiple times and reviewed in detail. Of those applications, only a small subset are selected so keep in mind that the selection process is rather competitive and difficult. +

      Whether or not you are accepted, contributing to open source outside of GSoC is one of the main goals of the program and is the best way to be noticed and get your proposal accepted. Keep that in mind. Thanks for your interest and we look forward to working with new FreeCAD developers! +

      +

      Available Slots

      +

      FreeCAD will be allocated a maximum of (tbd) slots in this year's GSoC. To increase your chances of earning a slot, get to know us early and start fixing bugs before GSoC starts, this always helps to build trust and will convince us of your dedication. +

      +

      Possible Mentors

      +

      Bernd, Yorik, sgrogan, wandererfan, Amritpal : +The best way to contact us is through the FreeCAD forums. You can also look on the IRC channel. +

      +

      Implementation Ideas

      +

      The ideas listed here have a high chance of being accepted as project proposal. Note that for students already longer involved in FreeCAD, and which already contributed code, own ideas in their line of work are also welcome. Feel free to contact us on IRC, the forum or the mailing list for further discussions about the listed projects. +The topics priority shows you how important the work on the ideas is for the mentors, and hence choosing a high priority topic will give you an advantage if there are more applications than slots for FreeCAD. +

      + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
      Topic + Language + Difficulty + Priority + Contact +
      FreeCAD Configuration Management Project: Streamline the configuration and distribution of FreeCAD software package +Launchpad, pbuilder, gitbuilder, conda, NSIS-installer +Medium +High +sgrogan +
      TechDraw Enhancement Project: Add new functionality to the Technical Drawing Workbench +C++ +Medium +Medium +wandererfan +
      FEM_GSOC_Project: FEM Workbench ... +Python +Medium +Medium +bernd +
      Path_GSOC_Project: Path Workbench... +Python +Medium +Medium +sliptonic +
      Arch Workbench: Extend the Reinforcement bar tools (last year's GSoC) to make it possible to produce complete sheets/drawings (see Bernd's example attachment in this thread). Project detail +Python +Medium +Medium +Amritpal +
      Swept-path Analysis GSoC Project: Add functionality to FreeCAD analyze the path a vehicle takes as it turns a corner. +Python +Medium +Medium +Joel_graff microelly2 +
      +

      These are new suggestions for this year. Don't forget to look at the last year ideas too, most of them are still valid! +

      Best of luck to all applicants! +

      + + +
      + +
      +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Green_tones.PNG b/localwiki/Green_tones.PNG new file mode 100644 index 0000000..3e8b643 Binary files /dev/null and b/localwiki/Green_tones.PNG differ diff --git a/localwiki/Grid.svg b/localwiki/Grid.svg new file mode 100644 index 0000000..c0e153a --- /dev/null +++ b/localwiki/Grid.svg @@ -0,0 +1,153 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [Jose Luis Cercos Pita] + + + Grid + 2012-11-02 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Plot/resources/icons/Grid.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Group.svg b/localwiki/Group.svg new file mode 100644 index 0000000..1ebd008 --- /dev/null +++ b/localwiki/Group.svg @@ -0,0 +1,67 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/GuiCommand_model.html b/localwiki/GuiCommand_model.html new file mode 100644 index 0000000..30a7c54 --- /dev/null +++ b/localwiki/GuiCommand_model.html @@ -0,0 +1,113 @@ +GuiCommand model

      GuiCommand model

      + +

      + + + + + + + + + + + + + + + + + + + +
      +

      Base ExampleCommandModel.png Base ExampleCommandModel

      +
      Menu location +
      Sample → Command +
      Workbenches +
      +
      Default shortcut +
      +
      See also +
      +

      + +
      +


      +

      +

      Description

      +

      Insert here a short description of what the command does. +

      FreeCAD05.png image +

      +

      How to use

      +
      1. Press the Std Close.png Command name button.
      2. +
      3. Detailed steps as needed.
      4. +
      5. Set options and press OK.
      +

      Options

      +

      Part Box.png Create Geometry

      +
      {{TitleTasks|[[Image:Icon.png|24]] + Text}} (Code for the main title Tasks)
      +
      +
      • TASKS Tasks : Tasks
      +
      {{PropertyTasks|Tasks}} (Code of title Tasks)
      +
      +
      • Options
      +

      Properties

      +

      Base +

      +
      {{TitleProperty|Base}}  (Code for the main title Properties)
      +
      +
      • DATAProperties: Properties
      +
      {{PropertyData|Properties}} (Code of title Data)
      +
      +
      • VIEWProperties: Properties
      +
      {{PropertyView|Properties}} (Code of title View)
      +
      +

      Example

      +

      Optional +

      +

      Scripting

      +

      The ExampleCommandModel tool can by used in macros and from the python console by using the following function: +

      +
      makeExampleCommandModel (Data, Data)
      +
      +
      • Creates a CommandModel using Data.
      • +
      • Returns the newly created object.
      +

      Example: +

      +
      import FreeCAD, Base
      +Base.makeExampleCommandModel(FreeCAD.Data,FreeCAD.Data)
      +
      +

      Other

      +

      Optional +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Gui_Command.html b/localwiki/Gui_Command.html new file mode 100644 index 0000000..1729e9b --- /dev/null +++ b/localwiki/Gui_Command.html @@ -0,0 +1,83 @@ +Gui Command

      Gui Command

      + +

      The GuiCommand is one of the most important functions of FreeCAD +in the main interaction point of the user. Every time the user +selects a menu item or presses a toolbar button it activates a +GuiCommand. Some of the attributes of a GuiCommand are: +

      +
      • Defines a name
      • +
      • Contains an icon
      • +
      • Defines the scope for an undo/redo
      • +
      • Has a help page
      • +
      • Opens and controls dialogs
      • +
      • Macro recording
      • +
      • and so forth...
      + + +

      Naming

      +

      The GuiCommand is named in a certain way: ModuleName_CommandName +e.g "Base_Open" this is the Open Gui Command in the Base system. +The GuiCommand in a certain module is named with the module name +in front e.g. "Part_Cylinder". +

      If the docu is not finished use Template:UnfinishedDocu +

      +

      Help page

      +

      Every GuiCommand has to have a help page. The help page is hosted on the +FreeCAD docu wiki. The article has the same name as the GuiCommand, e.g. Draft ShapeString. +

      To create your own help pages you can use the template: +GuiCommand model +

      Example: +

      + +

      Icons

      +
      Tango-Palette.png
      +

      Every GuiCommand has to have an icon. We use the Tango icon set and its guidelines. On the right side you see +the tango color palette. +

      Preferable all Icons are drafted with SVG with e.g. Inkscape. +This makes it easier to apply changes and derive +additional Icons in the same application space. +

      icons color coding chart +

      Colorchart.png +

      We try as much as possible to respect this chart, so the color of the icons has a direct meaning. +

      +

      Quality requirements

      +

      There are a lot of GuiCommands (Features) in FreeCAD which are experimental +or used shortly for implementation purposes. These GuiCommands are mostly in +the dedicated workbenches like Part, Mesh or Cam. +To ensure a good user experience the workbench Complete was created. This +workbench incorporates all GuiCommands +which meet certain Quality requirements which are described here: +

      +
      • The Command/Feature has to be finished. No work in progress!
      • +
      • Has to have a help page like Draft ShapeString +
        • All the fields in Template:GuiCommand have to filled in
        • +
        • A picture of the dialogs the command eventually yield
        • +
        • detailed description of the command and all its parameters and settings
        • +
        • Description of the related python interfaces and classes with example code
      • +
      • Set up a proper Icon and menu position
      +

      Hopefully this becomes true for all GuiCommands in the List of Commands. +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Half_turn_stairs.png b/localwiki/Half_turn_stairs.png new file mode 100644 index 0000000..2a15fa7 Binary files /dev/null and b/localwiki/Half_turn_stairs.png differ diff --git a/localwiki/Hand_cursor.png b/localwiki/Hand_cursor.png new file mode 100644 index 0000000..cd957dc Binary files /dev/null and b/localwiki/Hand_cursor.png differ diff --git a/localwiki/Hbone.svg b/localwiki/Hbone.svg new file mode 100644 index 0000000..7c90449 --- /dev/null +++ b/localwiki/Hbone.svg @@ -0,0 +1,367 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + Pablo Gil + + + + + SVG + template + + + + + + + + + + + + + + diff --git a/localwiki/Help-browser.svg b/localwiki/Help-browser.svg new file mode 100644 index 0000000..1c6f525 --- /dev/null +++ b/localwiki/Help-browser.svg @@ -0,0 +1,242 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + Help Browser + 2005-11-06 + + + Tuomas Kuosmanen + + + + + help + browser + documentation + docs + man + info + + + + + + Jakub Steiner, Andreas Nilsson + + + http://tigert.com + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Help-btn.png b/localwiki/Help-btn.png new file mode 100644 index 0000000..b17e10f Binary files /dev/null and b/localwiki/Help-btn.png differ diff --git a/localwiki/Help_FreeCAD.html b/localwiki/Help_FreeCAD.html new file mode 100644 index 0000000..1a9779d --- /dev/null +++ b/localwiki/Help_FreeCAD.html @@ -0,0 +1,87 @@ +Help FreeCAD

      Help FreeCAD

      + +

      If you like FreeCAD and would like to help in its development, there are many things you can do, even if you are not a programmer. Actually, there are things to do for everyone: users, power users and developers: +

      + + +

      Work on the documentation

      +

      Help us to build, correct and extend this documentation. Correct mistakes, extend or correct pages that are unclear, create new pages if a topic is missing, etc. Contributing to FreeCAD Wiki is easy, at WikiPages you can find the FreeCAD Wiki rules and the help needed to to get you started. To edit the wiki, you will need a FreeCAD Wiki account (the wiki is write-protected to avoid spamming). You can ask for an account on the forum or on the irc channel. Please note that the IRC channel may not be as responsive as the forum. +

      A couple of areas that would welcome your work: +

      +
      • The Command_Reference page lists and documents all of the FreeCAD commands. Most of them contain little to no information at all. Please refer to WikiPages for good examples of what command documentation pages should look like.
      • +
      • The Tutorials section is still very poor. If you developed something cool with FreeCAD, why not document how you did it for posterity?
      • +
      • There are open tickets on the FreeCAD bugtracker tagged 'documentation' that could use some love.
      +

      Share your FreeCAD knowledge

      +

      The users community around FreeCAD is still small, but already includes several advanced users who do a very important job in showing to newcomers how to use the software. If you begin to feel comfortable with FreeCAD, your knowledge could be very valuable to others, and you might +contribute with important assets, like: +

      +
      • Showing the work you do with FreeCAD on the Users Showcase forum. You can post screenshots, and, even better, attach the FreeCAD files so other people can examine it and understand how you did it.
      • +
      • Recording videos showing how you did something interesting in FreeCAD. These videos usually do a great job in showing new features.
      • +
      • Write tutorials describing or teaching something interesting. You can write tutorials on your own blog, directly on our wiki, or even on the forum.
      • +
      • Post on the FreeCAD Google Plus or Facebook community.
      +

      Translate FreeCAD

      +

      Translate FreeCAD in your own language. All text of the FreeCAD interface can be easily translated in other languages. All we need is someone who know that other language and is willing to help! All the translations are done online on crowdin. +

      For details on translation, see FreeCAD Wiki Translation Process under Localisation. +

      +

      Translate the documentation

      +

      Translating is easy, the FreeCAD wiki supports a Translation plugin which allows to manage translations between pages. +

      For details on translation, see FreeCAD Wiki Translation Process under Localisation#Translating_the_wiki. +

      Please be sure to be familiar with the WikiPages style guide, which includes rules for good translations. +

      The Help Editing page provides some information on editing. +

      +

      Help others to know FreeCAD

      +
      • Talk about FreeCAD to other people who might be interested
      • +
      • Find interesting uses for FreeCAD, and document it, for example with screenshots. FreeCAD is very young, and not many people see what they can do with it. If you are a FreeCAD fan already, you surely know some cool thing FreeCAD can do. Help us to show that to others!
      • +
      • Hang on the forum, and help newcomers to solve basic questions
      • +
      • Write tutorials, record videos, etc... showing what you do with FreeCAD
      • +
      • Contribute with files, drawings, etc... We still lack good example files of what can be done with FreeCAD
      • +
      • Help to promote FreeCAD on GitHub by 'Starring' and 'Watching' the FreeCAD repository github
      +

      Report bugs and ask for interesting features

      +
      Bugreport-workflow.png
      +

      Although the place to report confirmed bugs and suggest new features is eventually the FreeCAD Tracker, please always post bug reports and feature requests to the Help forum first. In order to save developers time (triaging and handling hard to understand bugs can be very time consuming), and avoid frustrations because your issue was not handled the way you would like, please read the following: +

      +
      • Bugs and features requests are handled in the same tracker. Just mark your issue as "bug" (something that doesn't work as it should) or "feature" (something that is not there but you think it would be good to have)
      • +
      • Although originally you could submit issues anonymously, unfortunately this had to be cancelled due to spam. Now if you would like to create/edit tickets you will have to create an account. You will then by default be notified when someone adds notes to the issue. In many cases, the person who will handle the bug will need more information from you.
      • +
      • When reporting a bug, the most important point is to allow developers to reproduce it. Be sure to include the exact steps needed to make the bug happen, so another person can do the same and see the bug happen on his machine too. If the developer cannot see the bug, he cannot solve it either.
      • +
      • Also include information that can help developers to situate the problem, like the operating system you are running FreeCAD on, the exact version of FreeCAD and the relevant libraries. Please post all the data by using the "copy to clip board" button in the Help (menu) -> about FreeCAD dialogue, and do this from the Part or PartDesign workbench.
      • +
      • No matter how sure you are that you have found a bug, please always discuss bugs first in the Help forum.
      • +
      • Before submitting a feature request, always discuss it with other users first on the Open discussion forum, so you might end up with a more solid proposal, with more chances to interest a developer to implement it.
      • +
      • Remember that FreeCAD is developed by volunteers who use their free time to work on it. Although everyone tries his best to make the best possible application, your bug report might be treated with low priority, or cancelled if you cannot give sufficient information, and your feature request might be postponed or even refused if no developer has interest in implement it or if that would request unrealistic amount of work.
      +

      Design artwork

      +

      See the Artwork page for guidelines about designing icons for FreeCAD. +

      +

      Program!

      +

      Writing code for FreeCAD is not hard, and you don't need any permission, you can start right now to work on something you want, then submit a patch on the tracker or request a merge from a git branch. But to avoid some headache you should meet the following prerequisites first: +

      +
      • FreeCAD goes at its own pace, and has a very small team of developers. We have not as much time as we would like to dedicate to FreeCAD, and things are not planned ahead, they are done when some developer sees it fit and when he finds time to do it. So we don't maintain a list of tasks to be done. It is up to you to find something you would like to do, for example a defect you would like to correct, or a small feature you think is missing. The tracker also contains some items that are not yet assigned to anybody.
      • +
      • Before you start to code for FreeCAD, you must know well how FreeCAD works. This seems obvious, but if you don't know how it is supposed to work you won't know what to do internally or how to do it.
      • +
      • Almost everything can be done either in python or C++. The internals work almost the same in both languages. We suggest you read through the Power users hub pages, even if you're going to code in C++, since it will give you a good overview of the internals.
      • +
      • If you are going to work in C++, make sure you can compile FreeCAD without problems first.
      • +
      • Present yourself to other developers. FreeCAD is before anything a social project, we discuss a lot of things on the forum before implementing it, and it's always best to discuss your ideas and tell people what you are planning to do before actually doing it. We also have an IRC channel, but the forum is the one and only place where you can meet all the developers.
      • +
      • Since 2016, FreeCAD is also participating to the Google Summer of Code. Be sure to check our ideas there if you are interested in participating in a next edition.
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Hexaedres.gif b/localwiki/Hexaedres.gif new file mode 100644 index 0000000..983a5b6 Binary files /dev/null and b/localwiki/Hexaedres.gif differ diff --git a/localwiki/HighlightDifference.png b/localwiki/HighlightDifference.png new file mode 100644 index 0000000..520bc97 Binary files /dev/null and b/localwiki/HighlightDifference.png differ diff --git a/localwiki/Hing_00.gif b/localwiki/Hing_00.gif new file mode 100644 index 0000000..a6283cc Binary files /dev/null and b/localwiki/Hing_00.gif differ diff --git a/localwiki/History.html b/localwiki/History.html new file mode 100644 index 0000000..8aa81c2 --- /dev/null +++ b/localwiki/History.html @@ -0,0 +1,235 @@ +History

      History

      + +
      + +

      History

      +
      Early FreeCAD version unknown
      +
      FreeCAD version 0.7 from 2009
      +

      FreeCAD history began in January 2001 when Jürgen Riegel started working on the Cas.CADE project, a commercial software development framework including a geometric modeling kernel (or CAD kernel) that in 2000 had been released under an open source license and renamed as Open Cascade. This made the realization of an open source 3D CAD program possible, as having to program a CAD kernel from scratch would have required a huge amount of work. +

      In Jürgen's own words: +

      +
      The FreeCAD project was started by me in January 2001, as a so called GOM (Graphical Object Modeler), with the idea to use Qt, Python and Cas.CADE, an commercial CAD-Kernel that time I used in Daimler's projects. Cas.CADE gone open source shortly before, so the time seemed right to try a move in the, at that time, empty space of open source CAD. I had a two year experience with OpenCascade in a project called QSpect in which, at the end, I was the main software designer. I learned a lot about 3D and CAD programming. I also was influenced by Catia V5 and its very special user and programming interface… In March 17 2002, within the OpenCascade Project, I registered the software as FreeCAD. I couldn't think of a better name, I'm very bad on names… In April 2003, Werner Meyer, one of the colleges in the QSpect project, switched to a company called Imetric. The contact to Imetric resulted very promising since they searched for a new 3D software platform for their 3D sensors. In 2005, Imetric donated most of its Mesh Module to FreeCAD and the Open Source community, and since then they used FreeCAD as basis for their sensor system software. Since that time, Werner Meyer is a very active developer of FreeCAD. In 2005, after one year of struggle, I decided to rip of the OpenCascade document framework and replace it with an own implementation. So, at the end, we only use the CAD kernel of OpenCascade and not the rest of its Framework. 2007 was another interesting milestone. We switched to QT4 and, therefore, to the LGPL. At that time we did much work, mainly Werner. +
      +

      The project was announced to the general public on the OpenCascade Forum in 2003. Again, in Jürgen's words: +

      +
      Hi together, my name is Juergen Riegel and today I want announce an OpenCasCade project, FreeCAD. It is an Open Source CAx RAD based on OpenCasCade, QT and Python. It features some key concepts like Macro Recording, Workbenches, ability to run as a server and as a dynamically loadable applications' extension, and it is designed to be platform independent… Although it is in an early stage and not usable for users nor developers—the first user release is planned for the end of 2003—, I would like to get some feedback on the direction and design of FreeCAD. The GUI is nearly finished and now we, my co-developer Werner Mayer and me, have started adding the first CAD functions. FreeCAD can be seen as a general purpose mechanical CAD system, but its first audience, I think, will be CAx developers which need groundwork for own development. +
      +


      +Eventually, the project gained traction, and saw the addition of new key contributors in the community. +

      Yorik van Havre joined the project in 2008 and started work on the Draft Module. Before that point, there was no way to create 2D geometry through the GUI. This module was programmed entirely in Python rather than in C++, the core programming language used in FreeCAD. This proved that Python integration was a success and could be used to extend or customize FreeCAD's capabilities. In addition to his work on the Draft module, Yorik worked on expanding the FreeCAD documentation, and became FreeCAD's de facto "Art director", creating many icons for FreeCAD's GUI and defining its style. +

      Version 0.7 of FreeCAD released in April 2009 was the first to include the Draft module. The Part module provided a simple CSG workflow with creation of primitive shapes and boolean operations accessible through the Part menu. Extrusion of 2D profiles and filleting was also possible. +

      Version 0.8 released in July 2009 saw some more work in the Draft module, including a new Dimension tool. The Part module benefited from a new toolbar along with new tools, Revolve and Section. +

      By the end of 2009, FreeCAD was accepted as a Debian package in the Debian repositories. FreeCAD was added to the Ubuntu 10.04 repositories in 2010. +

      Version 0.10 released on July 2010 introduced the Sketcher Workbench, based on Sketchsolve, a constraint-based solver to create 2D geometry. The first version was limited to creation of rectangles and lines. +

      In early 2011, taking the opportunity given by the Launchpad online platform, the FreeCAD Maintainers team was created to provide fresh stable releases along with daily build packages of FreeCAD to users of the Ubuntu operating system. +

      Version 0.11 released in May 2011 introduced the new Part Design workbench which included tools such as Pad, Pocket, Fillet and Chamfer. The Draft workbench received enhancements and new tools, like BSpline. The Robot workbench featured more GUI tools. +

      Version 0.12 released in January 2012 featured a more complete Sketcher workbench. It included a totally rewritten solver, FreeGCS. It was the result of months of work by the main FreeCAD developers along with newcomers logari81 (who programmed the solver) and mrlukeparry. More tools were added to the PartDesign workbench. +

      +

      Release history

      +
      • Overview
      + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
      Version + Release date + Informations +
      0.18 + + Current Developer Release +
      0.17 + 2018-04-06 + Release notes 0.17 +
      0.16 + 2016-04-18 + Release notes 0.16 +
      0.15 + 2015-04-08 + Release notes 0.15 +
      0.14 + 2014-07-01 + Release notes 0.14 +
      0.13 + 2013-01-29 + Release notes 0.13 +
      0.12 + 2011-12-20 + Release notes 0.12 +
      0.11 + 2011-05-03 + Release notes 0.11 +
      0.10 + 2010-07-24 + +
      0.9 + 2010-01-16 + +
      0.8 + 2009-07-10 + +
      0.7 + 2009-04-24 + +
      0.6 + 2007-02-27 +
      0.5 + 2006-10-05 + +
      0.4 + 2006-01-15 + +
      0.3 + 2005-10-31 + +
      0.2 + 2005-08-09 + +
      0.1 + 2003-01-27 + +
      0.0.1 + 2002-10-29 + Initial Upload --> The birth of FreeCAD +
      +


      +

      +
      • Legend
      + + + + + + + + + + + + + + + + + + + + +
      Color + Version Type +
      + Future release +
      + Latest preview version +
      + Latest version +
      + Older version, still supported +
      + Old version +
      +
      • Commit history
      +

      An overview about the commit history can be found in the following Forum post: https://forum.freecadweb.org/viewtopic.php?f=8&t=23695#p184940 +

      +

      Links

      + +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Hole_Pad002.png b/localwiki/Hole_Pad002.png new file mode 100644 index 0000000..d5f799d Binary files /dev/null and b/localwiki/Hole_Pad002.png differ diff --git a/localwiki/HorizontalSample.png b/localwiki/HorizontalSample.png new file mode 100644 index 0000000..ecf69a5 Binary files /dev/null and b/localwiki/HorizontalSample.png differ diff --git a/localwiki/How_to_install_additional_workbenches.html b/localwiki/How_to_install_additional_workbenches.html new file mode 100644 index 0000000..60d3e89 --- /dev/null +++ b/localwiki/How_to_install_additional_workbenches.html @@ -0,0 +1,148 @@ +How to install additional workbenches

      How to install additional workbenches

      + +
      + + + + + + + + + + + + + + + + + + + + + + + + + + + +
      +

      Base ExampleCommandModel.png Tutorial

      +
      Topic +
      Programming +
      Level +
      Medium programmer +
      Time to complete +
      15 minutes +
      Author +
      r-frank +
      FreeCAD version +
      All +
      Example File(s) +
      None +

      + +
      +


      +

      +

      Description

      +

      Power users have extended FreeCAD with various custom external workbenches, that are not integrated into the FreeCAD source code (yet!), +but are easy to install on an existing FreeCAD installation. Here we will cover the installation methods for the different operating systems. +

      Note Starting from version 0.17, FreeCAD features an addons manager in the Tools menu, that allows to easily install a series of external workbenches. The instructions below are only necessary if you are running an earlier version, or if you want to install a workbench that is not in the list offered by the addons manager. +

      +

      Installing on Windows

      +

      Recommended installation method +

      Use the addons-installer from Github.
      +During Google Summer of Code 2016 student Mandeep Singh started work on an improved
      +version (available here) but that version needs further work before it can be fully integrated in FreeCAD.
      +

      Alternative installation method “manual install” +

      +
      • download the workbench from github by clicking on the button “clone or download” on the github page (upper right corner) and choosing "Download ZIP"
      • +
      • unpack the downloaded archive on your local hard disk
      • +
      • within FreeCAD, locate the macro path by choosing “Edit > Preferences > General > Macro” and look for the ”Macro path”
      • +
      • supposed your Windows-Login is “User-Name” the default macro path is “C:\User-Name\Appdata\Roaming\FreeCAD”
      • +
      • within the macro-directory create (if not already present) a folder called “Mod”
      • +
      • within the folder mod create a folder with the name of the workbench, for example “Assembly2”
      • +
      • now move the unpacked files and sub-folders of the workbench to the just created workbench-folder
      • +
      • after restart of FreeCAD you should now have an entry in the workbench-pulldown-menu
      +

      Additional Recommendation for upating workbenches +

      On windows, when updating an already installed workbench, Windows keeps the old .py files as .pyc.
      +Since this may lead to trouble, it is recommended to uninstall the workbench, restart FreeCAD and install
      +the new version of the workbench. +


      +

      +

      Installing on Linux (Ubuntu/Mint)

      +

      Recommended installation method +

      Adding the community-ppa within the ppa-manager.
      +Installing the workbenches via synaptic packet manager. +

      Alternative installation method “Installing via Git” +

      +
      $ sudo apt-get install git python-numpy python-pyside
      +$ mkdir ~/.FreeCAD/Mod
      +$ cd ~/.FreeCAD/Mod
      +$ git clone https://github.com/hamish2014/FreeCAD_assembly2.git 
      +

      FreeCAD you will now have a new workbench-entry called "Assembly 2". Once installed, use git to upgrade to the latest version through BASH as follows +

      +
      $ cd ~/.FreeCAD/Mod/FreeCAD_assembly2
      +$ git pull
      +$ rm *.pyc 
      +

      Alternative installation method “manual install” +

      +
      • download the workbench from github by clicking on the button “clone or download” on the github page (upper right corner) and choosing "Download ZIP"
      • +
      • unpack the downloaded archive on your local hard disk
      • +
      • within FreeCAD, locate the macro path by choosing “Edit > Preferences > General > Macro” and look for the ”Macro path”
      • +
      • by default, the macro directory is the (hidden) "/.FreeCAD"-directory in your home-directory
      • +
      • within the macro-directory create (if not already present) a folder called “Mod”
      • +
      • within the folder "mod" create a folder with the name of the workbench, for example “Assembly2”
      • +
      • now move the unpacked files and sub-folders of the workbench to the just created workbench-folder
      • +
      • after restart of FreeCAD you should now have an entry in the workbench-pulldown-menu
      +

      Installing on Mac

      +

      Recommended installation method +


      +Alternative installation method “manual install” - here a description for the workbench "assembly2" +

      +
      • download the git repository as ZIP
      • +
      • assuming FreeCAD is installed in "/Applications/FreeCAD/v0.15", go to "/Applications/FreeCAD/v0.15" in the Browser, and select FreeCAD.app
      • +
      • right-click and select "Show Package Contents", a new window will appear with a folder named "Contents"
      • +
      • single-click on the folder "Contents" and select the folder "Mod"
      • +
      • in the folder "Mod" create a new folder named "assembly2"
      • +
      • unzip downloaded repository in the folder "Contents/Mod/assembly2"
      +


      +Copy or unzip the drawing dimensioning folder to the directory FreeCAD.app/Contents/Mod +where FreeCAD.app is the folder where FreeCAD is installed. +

      +

      General troubleshooting

      +
      • Don’t use special characters (for example german umlauts) in your windows user name, otherwise FreeCAD will not recognize files and folders in the macro path
      • +
      • If you have already set up a user name with special characters either create a new user name or point the macro path to a directory not using special characters
      • +
      • Workbench still not showing up ? In FreeCAD, choose “Tools > Customize > Workbenches” and make sure it is not set to invisible
      • +
      • Notes for users with 32-bit system and FreeCAD 0.16.6706 . After attempts to install, the additional Workbenches may not be available. In this case +
      +


      +

      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/How_to_install_macros.html b/localwiki/How_to_install_macros.html new file mode 100644 index 0000000..eb4e1ad --- /dev/null +++ b/localwiki/How_to_install_macros.html @@ -0,0 +1,313 @@ +How to install macros

      How to install macros

      + +
      + + + + + + + + + + + + + + + + + + + + + + + + + + + +
      +

      Base ExampleCommandModel.png Tutorial

      +
      Topic +
      Programming +
      Level +
      Medium programmer +
      Time to complete +
      15 minutes +
      Author +
      Mario52 +
      FreeCAD version +
      All +
      Example File(s) +
      None +

      + +
      +


      +

      +

      Description

      +

      This short tutorial will show you how to install and use FreeCAD Macros. +

      This tutorial was made on the Windows platform so a small adjustment may be necessary for other systems. +It was updated to cover the Macintosh platform. +

      +

      Python

      +

      Python is a programming language which is very simple to use and very fast to learn. +

      Python files have a file extension of .py while FreeCAD macros (which are also Python files) use the file extension .FCMacro. The Macro facility of FreeCAD can also execute files with the extension .py. Python was invented by Guido Van Rossun +

      +

      The Macro Menu and Toolbar Icons

      +

      record Launch Record +stop Stop Record +open editor Open Menu macro +execute Execute +start Debug Macro +stop Stop +

      +

      Location and destination of macros

      +

      This section shows you how to locate the folder containing your FreeCAD macros. +

      1 : click Menu > Macro > Macros (which has the icon Std DlgMacroExecuteDirect.svg and the tool tip "Open a dialog to let you execute a recorded macro") +

      +
      Dxf Importer Install 01.png
      +

      2 : This will open a dialog box +

      3 : The address of "Macro destination" (C:\Users\your_user_name\AppData\Roaming\FreeCAD\ in the screen snapshot below) +

      +
      • Windows: the form is usually drive:\Users\your_user_name\AppData\Roaming\FreeCAD\
      • +
      • Ubuntu: the form is usually /home/your_user_name/.FreeCAD
      • +
      • Macintosh: the form is usually "/Users/your_user_name/Library/Preferences/FreeCAD"
      +

      4 : copy the address of "Macro destination" (here C:\Users\your_user_name\AppData\Roaming\FreeCAD\) +

      +
      Dxf Importer Install 02.png
      +

      5 : View the macro folder by: +

      +
      • Windows: paste the address into your File explorer and confirm
      • +
      • Macintosh: locate the folder in the Finder or paste the address into a File explorer (remember the "file:///" prefix in the File explorer for a file on disk)
      +
      Dxf Importer Install 03.png
      +

      6 : Access the files by: +

      +
      • Windows: leave open the file explorer
      • +
      • Macintosh: either leave a Finder window open, or bookmark the location in your File explorer, or set up an Alias to point to it, or drag the folder into the SideBar of the Finder so it is there to use from other programs such as text editors etc. (Note: version 0.14 of FreeCAD does not support Aliases but does support the SideBar)
      +
      Dxf Importer Install 04.png
      +
      +


      +

      Section to read if you are not familiar with Python programming (common mistakes copy/paste). +

      +
      +

      The indentation errors examples wrong code

      +
      +

      The indentation in the python programming is very important and integral part of the code, a space or an inappropriate shift causes an indentation error ex : +

      +<unknown exception traceback><type 'exceptions.IndentationError'>: ('expected an indented block', ('C:/Users/d/AppData/Roaming/FreeCAD/Macro_Apothem_Based_Prism_GUI.FCMacro', 21, 3, 'def priSm(self):\n')) + +

      gives the error returned 'expected an indented block' block indentation expected to line 21, 3, normal after a class p (): must be the next line an indentation at least one space. +

      1 : In this example, the code was stuck without any indentation and of course does not work! here definitely a programmer error when pasting the code on the page as it would have never known it to work. +

      +
      the code was stuck without any indentation
      +

      2 : the code was correct indentations in the right place. +

      +
      the code was correct indentations in the right place
      +

      3 : we select the code, and we see that the selection is at the edge of the code, the macro must works so good +

      +
      the macro must works so good
      +

      4 : Here additional space is selected (it can happen) then you need to copy the code into a word processor to remove one space all lines +

      +
      remove one space all lines
      +

      5 : Here the code has been copied in a forum window with the Select all button apparently the selection is good +

      +
      Here the code has been copied in a forum
      +

      6 : But the selection pasted into the FreeCAD editor gives a surprise, an indent of four spaces has been added by the system ? the code is not good +

      +
      But the selection pasted into the FreeCAD editor gives a surprise
      +

      7 : You must delete all the extra space that is four spaces on each line, for Windows word processing notepad-plus-plus enables vertical selection with a combination of buttons Alt + Mouse dragging or Menu> Edit> Indent> Decrease the indentation +

      +
      You must delete all the extra space
      +

      8 : Here the selection also take the column numbers which will also give an error +

      +
      Here the selection also take the column numbers
      +

      9 : Perfect code. +

      +
      Perfect code
      +


      +

      +
      +
      +

      Method 1: +

      +
      +

      Method copy the code in one window and paste in the FreeCAD editor

      +
      +

      For example we will copy the macro Part Prism Apothem.svg Macro_Apothem_Based_Prism_GUI +

      If there are one or more icon (s) download also position your mouse over the icon, click the right mouse button and click "Save image as ..." the icon or icons are placed in the macro directory and one of these icons serve as a shortcut icon to place on the toolbar. +

      +
      Download icon
      +

      After copying your code we will paste the code in FreeCAD editor. +

      1 : Open FreeCAD and open the editor in FreeCAD +

      +
      Dxf Importer Install 01.png
      +

      2 : The window macros file opens, click Create button +

      +
      The window macros file opens
      +

      3 : A new window opens, enter the macro name (here "Macro_Apothem_Based_Prism_GUI")and click the create Ok button +

      +
      enter the macro name
      +

      4 : The editing window FreeCAD macros is now available and has the name of our future macro. +

      +
      The editing window FreeCAD macros
      +

      5 : Paste your code in the macro editor window and click the little cross to close the window. +

      +
      close the window
      +

      6 : A warning window appears asking for confirmation of save code, click on Yes +

      PS: For the change silk consideration must save the macro and reopen it and just run it. +

      +
      A warning window appears asking for confirmation of save code
      +

      7 : Repeat the number 1 : , Click on your new macro and button Execute +

      +
      Click on your new macro and button Execute
      +

      8 : The macro runs, complete the fields with your values and click the OK button +

      +
      The macro runs, complete the fields
      +

      9 : The macro returns an error ! we do not have to open document, open a document Document-new.svg and repeat the operation 7 and 8. Some macros open a new document if it does not find one. +

      +
      The macro returns an error!
      +

      10 : Here is your prism +

      +
      your prism
      +

      11 : You can also open your macro in the editor to run or modify, click the Edit button +

      +
      You can also open your macro in the editor
      +

      12: The macro is now in the FreeCAD editor you can run through the menu "Macro Run Macro" or by clicking on the triangle Macro-execute.svg green in the macros toolsbar +

      +
      The macro is now in the FreeCAD editor
      +
      +
      +

      Method 2: +

      +
      +

      Method macro in a compressed .ZIP file

      +
      +

      Download the file compressed here (example) Macro_screw_maker 1.7. (the page Macro_screw_maker) +

      Free for Windows 7-zip ou L-Zarc ou quickzip +

      For Linux use this on the terminal +

      +
      unzip your_file.zip -d your_directory 
      +

      you must unzip the zip and copy the file (or all the files and folders) in your macro directory. +

      Process +

      1 : Download your file in your local folder here the folder Temp +

      +
      Download your file in your local folder here the folder Temp
      +

      2 : Unzip your file in the folder. +

      +
      Unzip your file in the folder.
      +

      3 : The decompressor finished his work and created a new folder with the unpacked file +

      +
      The decompressor finished his work and created a new folder with the unpacked file
      +

      4 : Enter in the newly created directory, move about the file, click the right mouse button and click on Cut. +

      +
      Enter in the newly created directory
      +

      5 : Return to your File explorer remained open in the macro location (here C:\Users\your_user_name\AppData\Roaming\FreeCAD\) and close the File explorer. +

      +
      Return to your File explorer remained open
      +

      6 : Open FreeCAD click Menu > Macro > Macros or the click the bottom Std DlgMacroExecuteDirect.svg "Open a dialog to let you execute a macro Recorded" +

      +
      Open FreeCAD
      +

      7 : The macros window open , select your macro and click the button Execute +

      +
      The macros window open
      +

      8 : Your macro is executed enter the data and click the Create button +

      +
      Your macro is executed
      +

      9 : Whaouu +

      +
      Whaouu
      +
      +
      +

      Section if the text are not display: +

      +
      +

      For those who see no information is displayed.

      +
      +

      Some macros display information on the screen in general they are displayed in the report view. +

      FreeCAD use two methods to display the information in the window view report. +

      1 : Commands +

      +
      App = FreeCAD
      +App.Console.PrintMessage ("Hello World ! \n")
      +App.Console.PrintError ("Hello World ! \n")
      +App.Console.PrintWarning ("Hello World ! \n") 
      +

      or +

      +
      FreeCAD.Console.PrintMessage ("Hello World ! \n")
      +FreeCAD.Console.PrintError ("Hello World ! \n")
      +FreeCAD.Console.PrintWarning ("Hello World ! \n") 
      +

      or +

      +
      print "Hello World !" 
      +

      To see the information displayed in the console you should: +

      1 : Open FreeCAD +

      +
      Open FreeCAD
      +

      2 : Click the View menu and Views +

      +
      Click the View menu and Views
      +

      3 : Check Report View and Python Console +

      +
      Check Report View and Python Console
      +

      4 : the windows are enabled and available commands like "App.Console.PrintMessage" is configured to the "Report View" +

      +
      Hello World!
      +


      +2 : command "print" which is a Python command. +

      It is possible that this command does not display the expected string. +

      For information to be displayed in the window do this : +

      1 : Click the Edit menu and then Preferences +

      +
      Edit menu
      +

      2 : In the new window, click General, and select the Output window tab +

      +
      General
      +

      3 : check both boxes: +

      Case a cocher O.png Redirect internal Python output to Report view +

      Case a cocher O.png Redirect internal Python errors to Report view +

      and click the OK button +

      +
      Redirect internal
      +

      4 : the setup is complete you should see all. +

      +
      the setup is complete
      +
      +
      +

      End tutorial good job. +

      +

      Links

      +

      Macro addons_installer.FCMacro for easy install the macro +

      Other easy macro installer freecad-pluginloader +

      The Macros recipes page +

      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Hull_example.jpg b/localwiki/Hull_example.jpg new file mode 100644 index 0000000..61b4d4c Binary files /dev/null and b/localwiki/Hull_example.jpg differ diff --git a/localwiki/IFC.svg b/localwiki/IFC.svg new file mode 100644 index 0000000..73a4113 --- /dev/null +++ b/localwiki/IFC.svg @@ -0,0 +1,83 @@ + + + + + + + + + + image/svg+xml + + + + + + + + + + + + + diff --git a/localwiki/Icon.svg b/localwiki/Icon.svg new file mode 100644 index 0000000..f512f06 --- /dev/null +++ b/localwiki/Icon.svg @@ -0,0 +1,148 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [Jose Luis Cercos Pita] + + + Icon + 2012-11-02 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Plot/resources/icons/Icon.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/IconSize.png b/localwiki/IconSize.png new file mode 100644 index 0000000..2b2a9e4 Binary files /dev/null and b/localwiki/IconSize.png differ diff --git a/localwiki/Icone01.png b/localwiki/Icone01.png new file mode 100644 index 0000000..53e2998 Binary files /dev/null and b/localwiki/Icone01.png differ diff --git a/localwiki/Icone02.png b/localwiki/Icone02.png new file mode 100644 index 0000000..d5a6912 Binary files /dev/null and b/localwiki/Icone02.png differ diff --git a/localwiki/Icone03.png b/localwiki/Icone03.png new file mode 100644 index 0000000..1b44a1e Binary files /dev/null and b/localwiki/Icone03.png differ diff --git a/localwiki/Image-import.svg b/localwiki/Image-import.svg new file mode 100644 index 0000000..ec7d5bd --- /dev/null +++ b/localwiki/Image-import.svg @@ -0,0 +1,335 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/ImageConv.html b/localwiki/ImageConv.html new file mode 100644 index 0000000..50115d6 --- /dev/null +++ b/localwiki/ImageConv.html @@ -0,0 +1,29 @@ +ImageConv

      ImageConv

      + +

      ImageConv is a program used to convert images from various formats to the XPM-format, that can be compiled into FreeCAD. +

      +

      Building

      +

      ImageConv is located in the source tree of FreeCAD: +

      +
       /trunk/src/Tools/ImageTools/ImageConv
      +

      Building is easy with the Makefile or the VisualStudio-Project. +

      +

      Usage

      +

      ImageConv is a command line tool. +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/ImageWorkbench.svg b/localwiki/ImageWorkbench.svg new file mode 100644 index 0000000..e7a0a50 --- /dev/null +++ b/localwiki/ImageWorkbench.svg @@ -0,0 +1,243 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + + + + + + + + + diff --git a/localwiki/Image_Import.html b/localwiki/Image_Import.html new file mode 100644 index 0000000..4e3441c --- /dev/null +++ b/localwiki/Image_Import.html @@ -0,0 +1,79 @@ +Image Import

      Image Import

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Image Import.png Image Import

      +
      Menu location +
      Toolsbar → Create a planar image in the 3D space +
      Workbenches +
      Image +
      Default shortcut +
      +
      See also +
      +

      + +
      +


      +

      +

      Description

      +

      Imports an image for display on one of the main planes (including offset). +

      +

      Use

      +

      Click on Image Import.png.
      +A dialogue box will open asking you for the file name.
      +Afterwards you will be presented with the standard-FreeCAD-dialogue asking for the orientation of the image. +

      +

      Limitations

      +


      +

      +

      Notes

      +

      Selecting the image in the tree view and activating its data-tab in the property view lets you select size
      +and orientation of the image. +Specifying a small offset of 0,1 mm on import will make it easier to trace the image. +
      +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Image_Module.html b/localwiki/Image_Module.html new file mode 100644 index 0000000..87e1991 --- /dev/null +++ b/localwiki/Image_Module.html @@ -0,0 +1,42 @@ +Image Module

      Image Module

      + +

      The image module manages different types of bitmap images, and lets you open them in FreeCAD.
      +
      +Currently, the modules lets you open .bmp, .jpg, .png and .xpm file formats in a separate viewer window. +

      The image workbenches also allows you to import an image on a plane in the 3D-space of FreeCAD. This function is available via the second button of the image workbench. Image Import.png. +
      +The imported image can be attached like a sketch to one of the main three planes (XY/XZ/YZ) with positive or negativ offset. +
      +This function is only available if you have opened a FreeCAD document. +

      The image can be moved in 3D-space by editing the placement in the Property editor. +
      +The major use is tracing over the image, in order to generate a new part at using the image as template. +

      The image is imported with 1 pixel = 1mm. +Therefore it is recommended to have the imported image in a reasonable resolution. +The image can be scaled by editing the "XSize" and "YSize" values in the Property editor. +The image can be also moved by editing the X/Y/Z-values in the Placement-Tab. +The image can also be rotated around any axis by using the placement-dialogue. +

      Tip:
      +Tracing with sketcher elements over an image works best if the image has a small (negative) offset to the sketch plane. +
      +You can set an offset of -0,1 mm at import or later by editing the placement of the image. +

      Tools +

      Image Import.png Image Import +

      + +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Import_Export.html b/localwiki/Import_Export.html new file mode 100644 index 0000000..9b69112 --- /dev/null +++ b/localwiki/Import_Export.html @@ -0,0 +1,592 @@ +Import Export

      Import Export

      + +

      This page gathers the different file formats that can be imported or exported from FreeCAD. Most of these file formats are implemented by a specific module. This module doesn't need to be loaded in order to import or export to that format, but must be loaded to display the corresponding preferences page. +

      + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
      Format + Description + Import + Export + Module + Preferences page +
      FCStd + FreeCAD's native file format + yes + yes + Built-in + no +
      FCMat + FreeCAD Material Card + yes + yes + Built-in + no +
      FCMacro + FreeCAD Macro + yes + yes + Built-in + no +
      STEP + One of the most widely used exchange format for engineering models + yes + yes + Part + yes +
      STPZ + Compressed version of STEP exchange format for engineering models + yes + yes + Part + yes +
      IGES + A bit older but still much in use solid-based format + yes + yes + Part + yes +
      BREP + OpenCasCade's native format + yes + yes + Part + no +
      DXF + Autodesk Exchange Format. Only 2D geometry is supported + yes + yes + Draft + yes +
      DWG + Autocad main format. Only 2D geometry is supported. Requires the installation of external software. + yes + yes + Draft + yes +
      SVG + 2D format widely used for vector graphics + yes + yes + Draft / Drawing + yes +
      OCA + Open CAD Format (obsolete, 2D-only format) + yes + yes + Draft + yes +
      IFC + Industry Foundation Classes, used to exchange BIM models. Requires the installation of external software. + yes + yes + Arch + yes +
      DAE + Collada format, used for exchange of mesh geometry + yes + yes + Arch + yes +
      OBJ + Mesh exchange format + yes + yes + Arch / Mesh + no +
      STL + Mesh exchange format mostly used for 3D printing + yes + yes + Mesh + no +
      BMS + Binary mesh exchange format + yes + yes + Mesh + no +
      AST + Mesh exchange format + yes + yes + Mesh + no +
      OFF + Mesh exchange format + yes + yes + Mesh + no +
      PLY + Mesh exchange format / Points cloud + yes + yes + Mesh / Points + no +
      INP + Abaqus format + yes + yes + FEM + no +
      POLY + Tetgen format + no + yes + FEM + no +
      UNV + FEM exchange format + yes + yes + FEM + no +
      MED + FEM exchange format + yes + yes + FEM + no +
      DAT + FEM exchange format (FEM) or 2D airfoil profile (Draft) + yes + yes + FEM / Draft + no +
      BDF + FEM exchange format + yes + no + FEM + no +
      FRD + CalculiX result format + yes + no + FEM + no +
      NC + G-Code file format + yes + yes + Path + no +
      GC + G-Code file format + yes + yes + Path + no +
      NCC + G-Code file format + yes + yes + Path + no +
      NGC + G-Code file format + yes + yes + Path + no +
      CNC + G-Code file format + yes + yes + Path + no +
      TAP + G-Code file format + yes + yes + Path + no +
      GCODE + G-Code file format + yes + yes + Path + no +
      EMN + IDF file format + yes + no + Idf + no +
      IV + OpenInventor file format + yes + yes + Built-in + no +
      VRML + Web 3D format + yes + yes + Built-in + no +
      WebGL (HTML) + Web 3D format + no + yes + Arch + no +
      SCAD + OpenSCAD file format + yes + yes + OpenSCAD + no +
      CSG + OpenSCAD Constructive Solid Geometry + yes + yes + OpenSCAD + no +
      ASC + Points cloud format + yes + no + Points + no +
      POV + Povray format + no + yes + Raytracing + no +
      CSV + Comma-separated values spreadsheet + yes + yes + Spreadsheet + no +
      PDF + Adobe portable document format + no + yes + Built-in + no +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Import_Export_Preference.html b/localwiki/Import_Export_Preference.html new file mode 100644 index 0000000..f78e89a --- /dev/null +++ b/localwiki/Import_Export_Preference.html @@ -0,0 +1,66 @@ +Import Export Preference

      Import Export Preference

      + +
      + +

      Preference DXF

      +

      The DXF settings configure how DXF files must be imported (FreeCAD_and_DXF_Import). +

      +
      Preference Import Export Tab 01.png
      +
      +

      Preference DWG

      +

      teighafileconverter must be download on teighafileconverter page +

      +
      Preference Import Export Tab 02.png
      +
      +

      Preference SVG

      +

      The SVG settings configure how SVG files must be imported. +

      +
      Preference Import Export Tab 03.png
      +
      +

      Preference OCA

      +

      The OCA settings configure how OCA files must be imported. +

      +
      Preference Import Export Tab 04.png
      +
      +

      Preference IFC

      +
      Preference Import Export Tab 05.png
      +
      +

      Preference DAE

      +
      Preference Import Export Tab 06.png
      +
      +

      Preference IGES

      +
      Preference Import Export Tab 07.png
      +
      +

      Preference STEP

      +
      Preference Import Export Tab 08.png
      +
      +

      Preference Mesh Format

      +
      Preference Import Export Tab 09.png
      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Import_OpenSCAD_code.html b/localwiki/Import_OpenSCAD_code.html new file mode 100644 index 0000000..5687c59 --- /dev/null +++ b/localwiki/Import_OpenSCAD_code.html @@ -0,0 +1,102 @@ +Import OpenSCAD code

      Import OpenSCAD code

      + +
      + + + + + + + + + + + + + + + + + + + + + + + + + + + +
      +

      Base ExampleCommandModel.png Tutorial

      +
      Topic +
      Import OpenSCAD code +
      Level +
      Beginner +
      Time to complete +
      30 minutes +
      Author +
      r-frank +
      FreeCAD version +
      0.16.6704 +
      Example File(s) +
      +

      + +
      +


      +

      +

      Introduction

      +

      OpenSCAD, like FreeCAD, is an open source 3D CAD program. But while FreeCAD uses a visual approach, OpenSCAD uses a programming interface to perform 3D operations. The OpenSCAD workbench can be used to import OpenSCAD object code and to have access to some of the mesh operations possible with OpenSCAD. +

      +

      Installing OpenSCAD

      +

      Mac Users could download the binaries from the OpenSCAD homepage.
      +Linux Ubuntu/Mint users can install from the system repositories or from the OpenSCAD homepage.
      +Windows users can download the program from the OpenSCAD homepage.
      +Since only the OpenSCAD executable is needed by FreeCAD, Windows users can install the portable version if they like.
      +

      +

      Configuring OpenSCAD workbench in FreeCAD

      +
      • Open FreeCAD
      • +
      • Switch to OpenSCAD workbench
      • +
      • Choose Edit > Preferences > OpenSCAD from the Top menu +
        • Point FreeCAD to the OpenSCAD executable (section: General OpenSCAD settings)
        • +
        • all the other values on the settings-page could be left at default
      +

      The sample model

      +

      Here we will use the example005.scad-file from the (old) OpenSCAD-examples, but feel free to use any scad-file of your liking.
      +TutorialOpenSCAD SampleFile.jpg +

      +

      Importing the model in FreeCAD

      +
      • In FreeCAD just choose File Open and choose the .scad-File you want to import.
      • +
      • It is not important which workbench is activated, the OpenSCAD workbench itself is only needed when applying special features to your model
      • +
      • FreeCAD will import the OpenSCAD-File and build up a tree with primitives and boolean operations
      • +
      • Tutorial finished
      +


      +TutorialOpenSCAD ImportFile.jpg +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Import_from_STL_or_OBJ.html b/localwiki/Import_from_STL_or_OBJ.html new file mode 100644 index 0000000..12ae3e3 --- /dev/null +++ b/localwiki/Import_from_STL_or_OBJ.html @@ -0,0 +1,174 @@ +Import from STL or OBJ

      Import from STL or OBJ

      + +
      + + + + + + + + + + + + + + + + + + + + + + + + + + + +
      +

      Base ExampleCommandModel.png Tutorial

      +
      Topic +
      Import from STL or OBJ +
      Level +
      Beginner +
      Time to complete +
      30 minutes +
      Author +
      r-frank +
      FreeCAD version +
      0.16.6703 +
      Example File(s) +
      +

      + +
      +


      +

      +

      Introduction

      +

      In this tutorial we will cover how to import STL/OBJ files in FreeCAD. +Since the mesh-format STL/OBJ is dimensionless, FreeCAD will assume on import that the units used in the model are mm. +If this is not the case you have to scale your model either in the application it was created with (before exporting it) or you +have to scale your model in FreeCAD after import and conversion to a solid. +

      +

      Sample part

      +

      For this tutorial you can use your own STL file or create a demo file by doing this: +

      +
      • Open FreeCAD
      • +
      • Create a new document
      • +
      • Switch to the mesh workbench
      • +
      • Insert a torus by clicking on MeshesMesh RegularSolid.png Regular solid... , choosing settings like: +
        • Radius1: 10 mm
        • +
        • Radius2: 2 mm
        • +
        • Sampling: 50
      • +
      • Click on Create and then on Close
      • +
      • Save your file with File Save to get a FreeCAD-File containing a mesh object
      +


      +For importing a STL or OBJ file into FreeCAD, create a new FreeCAD document und choose + File Import from the top menu. +

      +

      Cleaning and repairing the STL/OBJ-File for preparing import

      +

      Basically, FreeCAD would import any STL/OBJ-File. +But our goal is to have a solid which can be measured and changed (adding pads/pockets ..). +For a successful conversion from mesh to solid we need to make sure that the mesh is “water-tight” +(has no holes) or doesn’t have any other errors. +
      +FreeCAD’s aim is not to be a good mesh modeler, it is designed to be a solid modeler. +FreeCAD has some capabilities for mesh operation in mesh workbench and OpenSCAD workbench +(some operations need OpenSCAD to be installed and configured in the FreeCAD-preferences). +
      +Some users like to use third-party software for cleaning and repairing meshes, for example +

      +
      • Netfabb Basic (Windows/Linux/Mac) - free for personal use (automatic mesh repair available)
      • +
      • Meshlab (Windows/Linux/Mac) - Open Source
      +


      +In this tutorial we will use the mesh workbench within FreeCAD to clean/repair/verify the mesh of our sample file. +

      +

      Automatic testing and repairing

      +
      • Open FreeCAD and the sample FreeCAD file containing the mesh object
      • +
      • Switch to mesh workbench
      • +
      • Make sure that your mesh object is selected in the tree view
      • +
      • Choose Meshes Analyze Evaluate & Repair mesh... from the top menu
      • +
      • Make sure the pull down menu on the top right corner displays the name of your mesh object
      • +
      • With the last point in the list reading "All above tests together" click on Analyze
      • +
      • The texts beside the tick boxes will change to reflect results of the different tests
      • +
      • If errors had been detected the corresponding check-boxes will be ticked and you will be able to select Repair
      • +
      • Choose Close to close the menu
      +

      Harmonizing normals

      +

      Harmonizing normals of a mesh object can be done by +

      +
      • Selecting your mesh object in the tree view
      • +
      • Choose MeshesMesh HarmonizeNormals.png Harmonize normals from the top menu.
      +

      Tip: +By choosing the mesh object in the tree view, going to the view tab in the property view and changing "Lighting" from +"Two Side" to "One Side" you can identify triangles with flipped normals. +If the normals point into the mesh the triangle will be shown in black. +

      +

      Closing holes

      +

      You can also manually close holes in your mesh object by +

      +
      • Selecting your mesh object in the tree view
      • +
      • Choose Meshes Fill holes... from the top menu
      • +
      • Specify maximum number of edges to be filled (3 is default)
      • +
      • Since STL and OBJ are meshes consisting of triangles the default number of edges should be sufficient
      +


      +Another method of manually closing holes in your mesh object would be +

      +
      • Selecting your mesh object in the tree view
      • +
      • Choose MeshesMesh FillInteractiveHole.png Close hole from the top menu
      • +
      • Select one of the edges of the hole in the mesh object in the 3D view
      • +
      • Right-Click in 3D view and choose Leave hole-filling mode to exit the command
      +

      Conversion mesh to solid

      +
      • Switch to part workbench
      • +
      • Make sure your mesh object is selected in the tree view, otherwise select it
      • +
      • Choose PartPart ShapeFromMesh.png Create shape from mesh ... from top menu
      • +
      • Specify tolerance for sewing shape (0,1 is default)
      • +
      • A new object will be created in the tree view (with blue shape icon, instead of green mesh icon)
      • +
      • Select the newly created object in the tree view
      • +
      • Choose PartPart RefineShape.png Refine shape from the top menu
      • +
      • A new object will be created in the tree view and the previous one will be made invisible
      • +
      • Select the newly created object in the tree view
      • +
      • Choose Part Convert to solid from the top menu
      • +
      • A new object will be created in the tree view, bearing "(Solid)" in its name, to indicate it is a solid
      +


      +Since the created solid has no history and no editable features (like a simple copy in FreeCAD) +you could delete all previous objects from the tree view. +This would keep your file size small ... +

      +

      Links

      + +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Import_text_and_geometry_from_Inkscape.html b/localwiki/Import_text_and_geometry_from_Inkscape.html new file mode 100644 index 0000000..3d0a23f --- /dev/null +++ b/localwiki/Import_text_and_geometry_from_Inkscape.html @@ -0,0 +1,108 @@ +Import text and geometry from Inkscape

      Import text and geometry from Inkscape

      + +
      + + + + + + + + + + + + + + + + + + + + + + + + + + + +
      +

      Base ExampleCommandModel.png Tutorial

      +
      Topic +
      Import text and geometry from Inkscape +
      Level +
      Beginner +
      Time to complete +
      30 minutes +
      Author +
      r-frank +
      FreeCAD version +
      0.16.6704 +
      Example File(s) +
      +

      + +
      +


      +

      +

      Introduction

      +

      This tutorial is supposed to show how to import text or geometry created with inkscape via svg-format into FreeCAD.
      +Inkscape 0.91 and FreeCAD 0.16.6704 on Windows are used for these operations.
      +

      +

      General tips for importing from inkscape

      +
      • the svg-import in FreeCAD cannot handle a svg file with a resolution of more than 45 dpi, so check the settings in inkscape
      • +
      • when importing path objects which show up in the 3D view in FreeCAD not very smooth it may be a matter of the FreeCAD-settings for the shape view. +
        • in FreeCAD choose Edit Preferences Part Design Shape View
        • +
        • as for "Tesselation", the "Maximum deviation depending on the model bounding box" the default value is "0,5 %"
        • +
        • setting this to a lower value will increase smoothness of the model in the 3D view (and use more PC performance)
        • +
        • don't use values lower than "0,01 %", this will most likely crash FreeCAD
        • +
        • in that case deleting "system.cfg" and "user.cfg" in your FreeCAD-user-directory will solve this problem
      +

      Importing text from inkscape

      +
      • after inserting text in inkscape (and perhaps applying effects like bending or something else to it) make sure to +
        • select your text and choose Path Object to path
        • +
        • ungroup your objects
        • +
        • save as "Plain SVG (*.svg)" file format
      • +
      • open the file in FreeCAD, choosing the option "SVG as geometry (importSVG)"
      • +
      • a path object for each letter/number/sign will be created in the tree view
      • +
      • use draft upgrade on each path object to create faces
      • +
      • use pad or extrude on the faces to get solids
      • +
      • you can fuse your objects or use compound on them depending on your intended further work
      +

      Importing geometry from inkscape

      +

      Since inkscape and FreeCAD seem to have different approaches on how to apply dimensions on svg-object, the recommended workflow seems to be: +

      +
      • ungroup all objects in inkscape
      • +
      • select all objects in inkscape
      • +
      • apply a stroke style with a width of 0 mm (yes, that is zero millimeter) to all objects
      • +
      • save as "Inkscape SVG (*.svg)" or "Plain SVG (*.svg)" file format
      • +
      • open the file in FreeCAD, choosing the option "SVG as geometry (importSVG)"
      • +
      • the dimensions of the objects in inkscape and in FreeCAD should now be identical
      +

      Credits

      +

      Thanks to users "freecad-heini-1" and "herbk" for testing and providing valuable feedback. +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Importing_From_Sketchup.html b/localwiki/Importing_From_Sketchup.html new file mode 100644 index 0000000..ece676e --- /dev/null +++ b/localwiki/Importing_From_Sketchup.html @@ -0,0 +1,39 @@ +Importing From Sketchup

      Importing From Sketchup

      + +
      + +

      Best Method

      +

      From experience, currently the best method to import a file from Sketchup is to use the Collada (*.dae) format. FreeCAD does not natively support the Collada format. To have this functionality in FreeCAD, the user needs to install a Python module for importing and exporting the format. It's a relatively easy task to perform and instructions can be found on the Extra python modules page. The direct link to the instructions is - Extra python modules: pyCollada. +

      +

      Importing Collada (*.dae) files

      +

      Providing the pyCollada module has been installed, you can open or import Collada files just like any other. Select the File menu and then pick either Open or Import. Select your Collada file and click Open. You can filter the file type by selecting the Files of type pull down in the Open or Import dialog and select Collada (*.dae) from the list. +

      +

      Alternatives

      +

      Using a Sketchup STL export plugin, you may also chose to use that format that FreeCAD supports natively. There are a number of these plugins available for Sketchup and some work better than others. Some research my be requires of the user to determine which one will best serve their needs. +

      +

      Notes

      +

      Both Collada (*.dae) and STL are mesh formats. To use these files within FreeCAD, which works primarily with solids, additional work to the objects imported using these formats will in most cases be required. +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Inkscape_Template_tut_2.png b/localwiki/Inkscape_Template_tut_2.png new file mode 100644 index 0000000..73473be Binary files /dev/null and b/localwiki/Inkscape_Template_tut_2.png differ diff --git a/localwiki/Inkscape_Template_tut_3.png b/localwiki/Inkscape_Template_tut_3.png new file mode 100644 index 0000000..42b79a2 Binary files /dev/null and b/localwiki/Inkscape_Template_tut_3.png differ diff --git a/localwiki/Inkscape_Template_tut_4.png b/localwiki/Inkscape_Template_tut_4.png new file mode 100644 index 0000000..e88919e Binary files /dev/null and b/localwiki/Inkscape_Template_tut_4.png differ diff --git a/localwiki/Inkscape_Template_tut_5.png b/localwiki/Inkscape_Template_tut_5.png new file mode 100644 index 0000000..ca601e6 Binary files /dev/null and b/localwiki/Inkscape_Template_tut_5.png differ diff --git a/localwiki/Inkscape_Template_tut_6.png b/localwiki/Inkscape_Template_tut_6.png new file mode 100644 index 0000000..d84e127 Binary files /dev/null and b/localwiki/Inkscape_Template_tut_6.png differ diff --git a/localwiki/InputField.html b/localwiki/InputField.html new file mode 100644 index 0000000..0842b41 --- /dev/null +++ b/localwiki/InputField.html @@ -0,0 +1,28 @@ +InputField

      InputField

      + +
      +

      This documentation is not finished. Please help and contribute documentation. +

      See Draft ShapeString for good documented Command. Gui Command gives an overview over commands. And see List of Commands for other commands. +

      Go to Help FreeCAD to contribute. +

      +
      +


      +

      This is the documentation of the FreeCAD 'InputField' widgets, which get used in most of the dialogs handling parameter with units. +

      ToDo... +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Inspect_pipette.svg b/localwiki/Inspect_pipette.svg new file mode 100644 index 0000000..d83fa47 --- /dev/null +++ b/localwiki/Inspect_pipette.svg @@ -0,0 +1,253 @@ + + + + + mesh_pipette + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + mesh_pipette + + + + FreeCAD LGPL2+ + + + + + FreeCAD + + + FreeCAD/src/Mod/Mesh/Gui/Resources/icons/mesh_pipette.svg + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + pipette + eyedropper + sample + + + Pipette or eyedropper lit from above + + + [agryson] Alexander Gryson + + + Sat Feb 8 16:10:16 2014 +0100 + + + [wmayer] + + + + + + + + + + + + + + + + + diff --git a/localwiki/InspectionEx.png b/localwiki/InspectionEx.png new file mode 100644 index 0000000..a9390cf Binary files /dev/null and b/localwiki/InspectionEx.png differ diff --git a/localwiki/InspectionWorkbench.svg b/localwiki/InspectionWorkbench.svg new file mode 100644 index 0000000..d83fa47 --- /dev/null +++ b/localwiki/InspectionWorkbench.svg @@ -0,0 +1,253 @@ + + + + + mesh_pipette + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + mesh_pipette + + + + FreeCAD LGPL2+ + + + + + FreeCAD + + + FreeCAD/src/Mod/Mesh/Gui/Resources/icons/mesh_pipette.svg + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + pipette + eyedropper + sample + + + Pipette or eyedropper lit from above + + + [agryson] Alexander Gryson + + + Sat Feb 8 16:10:16 2014 +0100 + + + [wmayer] + + + + + + + + + + + + + + + + + diff --git a/localwiki/Inspection_Workbench.html b/localwiki/Inspection_Workbench.html new file mode 100644 index 0000000..d48fa96 --- /dev/null +++ b/localwiki/Inspection_Workbench.html @@ -0,0 +1,30 @@ +Inspection Workbench

      Inspection Workbench

      + +

      The Inspection Workbench is made to give you specific tools for examination of shapes. +It is still in development. +

      Intended Workflow: +

      +
      • Visual Inspection can be done via the pull-down-menu in the top row.
      • +
      • Select two shapes to be compared and select Inspection > Visual Inspection from the menu.
      • +
      • The shapes should intersect as much as possible.
      • +
      • You will get a colored image showing the deviation between the two shapes.
      +

      InspectionEx.png +

      Alternatively you could also use the macro HighlightDifference to compare two shapes. +

      + +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Install_on_Mac.html b/localwiki/Install_on_Mac.html new file mode 100644 index 0000000..7755ed4 --- /dev/null +++ b/localwiki/Install_on_Mac.html @@ -0,0 +1,38 @@ +Install on Mac

      Install on Mac

      + +

      FreeCAD can be installed on Mac OS X in one step using the Installer. +

      Mac.png Mac 10.9 Mavericks 64-bit +


      +This page describes the usage and features of the FreeCAD installer. It also includes uninstallation instructions. +Once installed, you can get started! +

      +

      Simple Installation

      +

      The FreeCAD installer is provided as a app package (.app) enclosed in a disk image file. +

      You can download the latest installer from the Download page. After downloading the file, just mount the disk image, then drag it to the Application folder or a folder of your choice. +

      Mac installer 1.png +

      That's it.Just click on the app to launch FreeCAD. If you have this message "FreeCAD can't be open as it is from unidentified developer. " Open the folder (Application) and right click on the app then click open and accept to open the application. +


      +

      +

      Uninstallation

      +

      There currently isn't an uninstaller for FreeCAD. To completely remove FreeCAD and all installed components, drag the following files and folders to the Trash: +

      +
      • In /Applications: +
        • FreeCAD
      +

      That's it. +

      + +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Install_on_Unix.html b/localwiki/Install_on_Unix.html new file mode 100644 index 0000000..316083d --- /dev/null +++ b/localwiki/Install_on_Unix.html @@ -0,0 +1,121 @@ +Install on Unix

      Install on Unix

      + +

      The installation of FreeCAD on the most well-known linux systems has been now endorsed by the community, and FreeCAD should be directly available via the package manager available on your distribution. The FreeCAD team also provides a couple of "official" packages when new releases are made, and a couple of experimental PPA repositories for testing bleeding-edge features. +

      Once you've got FreeCAD installed, it's time to get started! +

      + + +

      Ubuntu and Ubuntu-based systems

      +

      Many Linux distributions are based on Ubuntu and share its repositories. Besides official variants (Kubuntu, Lubuntu and Xubuntu), there are non official distros such as Linux Mint, Voyager and others. The installation options below should be compatible to these systems. +

      +

      Official Ubuntu repository

      +

      FreeCAD is available from Ubuntu repositories and can be installed via the Software Center or with this command in a terminal: +

      +
      sudo apt-get install freecad 
      +

      But chances are this stable version will be outdated, and not have the latest features. To get the last release version, please use the PPA. +

      +

      Stable PPA with GUI

      +

      To install FreeCAD using the PPA, from the graphical interface, please follow those instructions. The FreeCAD community provides a PPA repository on Launchpad with the latest stable FreeCAD version. +

      You need to add to your system's Software Sources the following PPA. To do that navigate to Ubuntu Software Centre > Edit > Software Sources > Other Software. Click on add and copy and past the code below: +

      +
      ppa:freecad-maintainers/freecad-stable 
      +

      Refresh your software sources, if asked. Now, you can find and install the last stable FreeCAD version on the Ubuntu Software Center. +

      For more information on PPA, click here: Definition of PPA (Personal Package Archive) on help.ubuntu.com. +

      +

      Stable PPA with console

      +

      Type, or copy-paste, these commands in a console to add the PPA: +

      For the "stable" PPA +

      +
      sudo add-apt-repository ppa:freecad-maintainers/freecad-stable 
      +

      Don't forget to retrieve the updated the package lists: +

      +
      sudo apt-get update 
      +

      Update synchronizes your list of available packages with the servers. +

      Then, install FreeCAD along with the documentation: +

      +
      sudo apt-get install freecad freecad-doc && sudo apt-get upgrade 
      +

      Upgrade downloads and installs the newest packages version of the installed programs. It will be applied to all the softwares installed on your computer. +

      Execute this command to open the stable version of FreeCAD: +

      +
      freecad 
      +

      Daily PPA with console

      +

      If you want to install the last unstable version of FreeCAD, please use the PPA named "freecad-daily" PPA repository on Launchpad. This way you can access the bleeding edge of FreeCAD development. This PPA is automatically compiled daily from the official FreeCAD's master branch repository. It will usually contain numerous bug fixes and feature updates. +

      For the daily PPA: +

      +
      sudo add-apt-repository ppa:freecad-maintainers/freecad-daily
      +sudo apt-get update
      +sudo apt-get install freecad-daily && sudo apt-get upgrade 
      +

      Execute this command to open the daily build of FreeCAD: +

      +
      freecad-daily 
      +

      Debian and other debian-based systems

      +

      Since Debian Lenny, FreeCAD is available directly from the Debian software repositories and can be installed via synaptic or simply with: +

      +
      sudo apt-get install freecad 
      +

      OpenSUSE

      +

      FreeCAD is typically installed with: +

      +
      zypper install FreeCAD 
      +

      Gentoo

      +

      FreeCAD can be built/installed simply by issuing: +

      +
      emerge freecad 
      +

      Other

      +

      If you find out that your system features FreeCAD but is not documented in this page, please tell us on the forum! +

      Many alternative, non-official FreeCAD packages are available on the net, for example for systems like slackware or fedora. A search on the net can quickly give you some results. +

      +

      Manual install on .deb based systems

      +

      If for some reason you cannot use one of the above methods, you can always download one of the .deb packages available on the Download page.
      +Linux.png Ubuntu 32/64bit +AppImage-logo.png AppImage 64bit +


      +Once you downloaded the .deb corresponding to your system version, if you have the Gdebi package installed (usually it is), you just need to navigate to where you downloaded the file, and double-click on it. The necessary dependencies will be taken care of automatically by your system package manager. +Alternatively you can also install it from the terminal, navigating to where you downloaded the file, and type: +

      +
      sudo dpkg -i Name_of_your_FreeCAD_package.deb 
      +

      changing Name_of_your_FreeCAD_package.deb by the name of the file you downloaded. +

      After you installed FreeCAD, a startup icon will be added in the "Graphic" section of your Start Menu. +

      +

      Installing on other Linux/Unix systems

      +

      Unfortnately, at the moment, no precompiled package is available for other Linux/Unix systems,so you will need to compile FreeCAD yourself. +

      +

      Installing Windows Version on Linux

      +

      See the Install on Windows page. +

      + +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Install_on_Windows.html b/localwiki/Install_on_Windows.html new file mode 100644 index 0000000..2b10447 --- /dev/null +++ b/localwiki/Install_on_Windows.html @@ -0,0 +1,145 @@ +Install on Windows

      Install on Windows

      + +

      The easiest way to install FreeCAD on Windows is to download the installer below. +

      Windows.png Windows 32 bits +

      Windows.png Windows 64 bits +


      +After downloading the .msi (Microsoft Installer) file, just double-click on it to start the installation process. +

      Below is more information about technical options. If it looks daunting, don't worry! Most Windows users will not need anything more than the .msi to install FreeCAD and Get started! +


      +

      + + +

      Simple Microsoft Installer Installation

      +

      The easiest way to install FreeCAD on Windows is by using the installer above. This page describes the usage and the features of the Microsoft Installer for more installation options. +

      If you would like to download either a 64 bit or unstable development version, see the Download page. +


      +

      +

      Command Line Installation

      +

      With the msiexec.exe command line utility, additional features are available, like non-interactive installation and administrative installation. +

      +

      Non-interactive Installation

      +

      With the command line +

      +
       msiexec /i FreeCAD<version>.msi
      +
      +

      installation can be initiated programmatically. Additional parameters can be passed at the end of this command line, like +

      +
      msiexec /i FreeCAD-2.5.msi TARGETDIR=r:\FreeCAD25 
      +

      Limited user interface

      +

      The amount of user interface that installer displays can be controlled with /q options, in particular: +

      +
      • /qn - No interface
      • +
      • /qb - Basic interface - just a small progress dialog
      • +
      • /qb! - Like /qb, but hide the Cancel button
      • +
      • /qr - Reduced interface - display all dialogs that don't require user interaction (skip all modal dialogs)
      • +
      • /qn+ - Like /qn, but display "Completed" dialog at the end
      • +
      • /qb+ - Like /qb, but display "Completed" dialog at the end
      +

      Target directory

      +

      The property TARGETDIR determines the root directory of the FreeCAD installation. For example, a different installation drive can be specified with +

      +
      TARGETDIR=R:\FreeCAD25 
      +

      The default TARGETDIR is [WindowsVolume\Programm Files\]FreeCAD<version>. +

      +

      Installation for All Users

      +

      Adding +

      +
      ALLUSERS=1 
      +

      causes an installation for all users. By default, the non-interactive installation install the package just for the current user, and the interactive installation offers a dialog which defaults to "all users" if the user is sufficiently privileged. +

      +

      Feature Selection

      +

      A number of properties allow selection of features to be installed, reinstalled, or removed. The set of features for the FreeCAD installer is +

      +
      • DefaultFeature - install the software proper, plus the core libraries
      • +
      • Documentation - install documentation
      • +
      • Source code - install the sources
      • +
      • ... ToDo
      +

      In addition, ALL specifies all features. All features depend on DefaultFeature, so installing any feature automatically installs the default feature as well. The following properties control features to be installed or removed +

      +
      • ADDLOCAL - list of feature to be installed on the local machine
      • +
      • REMOVE - list of features to be removed
      • +
      • ADDDEFAULT - list of features added in their default configuration (which is local for all FreeCAD features)
      • +
      • REINSTALL - list of features to be reinstalled/repaired
      • +
      • ADVERTISE - list of feature for which to perform an advertise installation
      +

      There are a few additional properties available; see the MSDN documentation for details. +

      With these options, adding +

      +
      ADDLOCAL=Extensions 
      +

      installs the interpreter itself and registers the extensions, but does not install anything else. +

      +

      Uninstallation

      +

      With +

      +
      msiexec /x FreeCAD<version>.msi 
      +

      FreeCAD can be uninstalled. It is not necessary to have the MSI file available for uninstallation; alternatively, the package or product code can also be specified. You can find the product code by looking at the properties of the Uninstall shortcut that FreeCAD installs in the start menu. +

      +

      Administrative installation

      +

      With +

      +
      msiexec /a FreeCAD<version>.msi 
      +

      an "administrative" (network) installation can be initiated. The files get unpacked into the target directory (which should be a network directory), but no other modification is made to the local system. In addition, another (smaller) msi file is generated in the target directory, which clients can then use to perform a local installation (future versions may also offer to keep some features on the network drive altogether). +

      Currently, there is no user interface for administrative installations, so the target directory must be passed on the command line. +

      There is no specific uninstall procedure for an administrative install - just delete the target directory if no client uses it anymore. +

      +

      +

      With +

      +
      msiexec /jm FreeCAD<version>.msi 
      +

      it would be possible, in principle, to "advertise" FreeCAD to a machine (with /ju to a user). This would cause the icons to appear in the start menu, and the extensions to become registered, without the software actually being installed. The first usage of a feature would cause that feature to be installed. +

      The FreeCAD installer currently supports just advertisement of start menu entries, but no advertisement of shortcuts. +

      +

      Automatic Installation on a Group of Machines

      +

      With Windows Group Policy, it is possible to automatically install FreeCAD an a group of machines. To do so, perform the following steps: +

      +
      1. Log on to the domain controller
      2. +
      3. Copy the MSI file into a folder that is shared with access granted to all target machines.
      4. +
      5. Open the MMC snapin "Active Directory users and computers"
      6. +
      7. Navigate to the group of computers that need FreeCAD
      8. +
      9. Open Properties
      10. +
      11. Open Group Policies
      12. +
      13. Add a new policy, and edit it
      14. +
      15. In Computer Configuration/Software Installation, choose New/Package
      16. +
      17. Select the MSI file through the network path
      18. +
      19. Optionally, select that you want the FreeCAD to be deinstalled if the computer leaves the scope of the policy.
      +

      Group policy propagation typically takes some time - to reliably deploy the package, all machines should be rebooted. +

      +

      Installation on Linux using Crossover Office

      +

      You can install the windows version of FreeCAD on a Linux system using CXOffice 5.0.1. Run msiexec from the CXOffice command line, assuming that the install package is placed in the "software" directory which is mapped to the drive letter "Y:": +

      +
      msiexec /i Y:\\software\\FreeCAD<version>.msi 
      +

      FreeCAD is running, but it has been reported that the OpenGL display does not work, like with other programs running under Wine i.e. Google SketchUp. +

      + +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Installing.html b/localwiki/Installing.html new file mode 100644 index 0000000..f492ddb --- /dev/null +++ b/localwiki/Installing.html @@ -0,0 +1,78 @@ +Installing

      Installing

      + +
      + +

      Choose Your Operating System

      +

      FreeCAD is a truly multi-platform application, developed with the world-renowned Qt framework. What that means is that FreeCAD looks and acts the same on Windows, Linux and Mac. However, the installation procedure is a little different for each Operating system. Choose your Operating system below for more details about how to install FreeCAD. +

      + + + + + + + + +
      'Windows' +'Linux' +'Mac' +
      Install on Windows + Install on Linux/Unix +Install on Mac +
      +

      Installing additional contents

      +

      The offline documentation is not shipped with all installers and available as a separate package. See here for Installing a helpfile. +

      Apart from the default workbenches bundled with FreeCAD, there is a growing collection of useful additional workbenches and modules made by community members available on the web. Several efforts are in progress to gather them and make them available to you in a convenient way. They are listed below. +

      Since these workbenches are not part of the official FreeCAD package and not supported by the FreeCAD team, you should read the information provided on each of the addons page above before installing any of them, to make sure you know what you are installing. Also, bug reports and feature requests should be made directly on each addon page. +

      +

      The FreeCAD-addons repository

      +

      This is a gathering of useful workbenches, using the git submodules system, which allows to keep constantly updated contents. The FreeCAD-addons repository can be found at https://github.com/FreeCAD/FreeCAD-addons . This repository features an installer macro that can be launched from inside FreeCAD, that will list, download and install any of the addons automatically. To install the installer macro: +

      +
      1. Right-click on addons_installer.FCMacro and choose Save as...
      2. +
      3. Place the downloaded macro in your FreeCAD Macros folder. The FreeCAD Macros folder location is indicated in menu Macros -> Macros -> User macros location:
      +

      Macro installer 01.jpg +

      +
      1. Restart FreeCAD. The addons installer will now be listed in menu Macro -> Macros and can be launched by selecting it then clicking the Execute button:
      +

      Macro installer 02.jpg +

      +

      The pluginloader addon

      +

      The plugin loader is a much more elaborate way to install and manage additional content for freecad. Install it with the method above, or following the instructions on the pluginloader page. +

      +

      Manual install

      +

      External workbenches, when they are fully programmed in python (which is the case of all of them at the moment of writing) can always easily be installed manually, simply by downloading them (usually clicking the **Download ZIP** button found on top of each addon page when they are hosted on github), and placing them in your user's FreeCAD/Mod folder (or in the Macros folder if they are macros). Refer to the instructions on each addon page for complete instructions. +

      +

      Notes for users with 32-bit system and FreeCAD 0.16.6706

      +

      After attempts to install, the additional Workbenches may not be available. In this case +

      + +


      +

      + +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Installing_Helpfile.html b/localwiki/Installing_Helpfile.html new file mode 100644 index 0000000..c4729bc --- /dev/null +++ b/localwiki/Installing_Helpfile.html @@ -0,0 +1,57 @@ +Installing Helpfile

      Installing Helpfile

      + +
      + +

      FreeCAD Helpfiles

      +

      The FreeCAD offline documentation is created with scripts from the FreeCAD-Wiki. It has actual grown to a file size of more than 100 megabyte. These big files are not part of development installers and executables of FreeCAD. But the offline documentation can be installed separately, which is explained here. +

      The offline documentation has now also made been available in French and Italian. (Check for other languages.) These files are not part of the official installers of FreeCAD but available as separate packages. +


      +

      +

      Download Helpfiles

      +

      A working offline documentation consist of at least two files: "freecad.qhc" the Qt-helpfile-configuration and "freecad.qch" the compressed Qt-helpfile. They are put together in a ZIP-archive. +

      The helpfiles can be downloaded here: https://github.com/FreeCAD/FreeCAD/releases/tag/0.18_pre +

      As a future option they can be installed from within FreeCAD with the Addon manager. +

      The help files do always have the same names: "freecad.qhc" and "freecad.qch". In order to have different version of the helpfiles, these need to be installed in different directories. In case of a manual download, just store the zip-file locally and extract the archive into the wanted directory. +

      +

      Register the Documentation

      +

      The actual organization of the offline help does allow only one helpfile to be active. It is therefore not possible to have helpfiles in different languages accessible from FreeCAD at the same time. +

      In order to make another FreeCAD documentation active the following steps have to be applied: +

      +
      • Click inside FreeCAD in the Help menu on the Help item. The program Qt-assistant should open.
      • +
      • In Qt-assistant click in the menu Edit on preferences.
      • +
      • In the preferences dialog click on the tab Documentation.
      • +
      • In the list registered documentation select org.freecad.usermanual and click on the button "Remove".
      • +
      • Close the dialog with ok, but do not close the Qt-assistant. This is important as otherwise another helpfile will not be registered.
      • +
      • Open again the preferences dialog via the menu Edit/Preferences.
      • +
      • Select the tab documentation and click the button Add...
      • +
      • In the filedialog navigate to your new helpfile and select freecad.qch
      • +
      • close the filedialog by confirming your selection. The Documentation tab in the preferences should now have again a line with org.freecad.usermanual.
      • +
      • Close the Preferences with Ok.
      • +
      • You should now have the new documentation available in the Qt-assistant, which is accessible from within FreeCAD.
      +

      Additional Notes

      +

      In case your operation system has no Qt-Assistant and it is not delivered with FreeCAD, it will be necessary to install one. +


      +

      + +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Installing_more_workbenches.html b/localwiki/Installing_more_workbenches.html new file mode 100644 index 0000000..4f81796 --- /dev/null +++ b/localwiki/Installing_more_workbenches.html @@ -0,0 +1,34 @@ +Installing more workbenches

      Installing more workbenches

      + +

      Outside the standard workbenches that are bundled with every FreeCAD installation, it is very easy to add other workbenches that extend FreeCAD functionality. At the moment, since FreeCAD is very young, there is almost no other workbench availible. But FreeCAD has been made extensible right from the start, so adding new workbenches is very easy, and in the future several new workbench should appear. +

      Extra workbenches are delivered in a folder, that must simply be copied into one of FreeCAD's Mod directory. The Mod directories are scanned everytime FreeCAD is started and the availible workbenches automatically added. There are two ways of installing: +

      +

      Installing system-wide

      +

      Extra workbenches, or modules, can be installed inside your FreeCAD installation directory, so they will be availible to all users. Depending on your system, you might need administrator or superuser privileges to access the FreeCAD installation directory. +

      Copy or move the folder containing your workbench to the "Mod" directory that lies inside your FreeCAD installation directory. On Windows, it will probably be something like C:\Program Files\FreeCAD\Mod, on Debian-based systems something like /usr/lib/FreeCAD/Mod +

      +

      Installing user-wide

      +

      Workbenches installed that way will be availible only to you, and not to the other users of your system. But it will not require any administrator or superuser privileges. +

      Copy or move the folder containing your workbench to the "Mod" directory that lies inside your FreeCAD user directory. On Windows, it will be something like C:\Users\your_user_name\Application Data\FreeCAD\Mod, on Linux systems it will be ~/.FreeCAD/Mod where ~ is your user's home directory. On Mac OSX the "Mod" directory should be ~/Library/Preferences/FreeCAD/Mod. One way to get to the FreeCAD preferences directory on Mac is to use the Finder menu item Go->Go to Folder... and then enter "~/Library/Preferences/FreeCAD". +


      +

      Extra information about how to create a custom workbench can be found on the Developer hub and on the Power users hub. +

      +

      Tutorials

      +

      How to install additional workbenches +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Interface_Customization.html b/localwiki/Interface_Customization.html new file mode 100644 index 0000000..606f44b --- /dev/null +++ b/localwiki/Interface_Customization.html @@ -0,0 +1,45 @@ +Interface Customization

      Interface Customization

      + +

      Since FreeCAD interface is based on the modern Qt toolkit, it has a state-of-the-art organization. Widgets, menus, toolbars and other tools can be modified, moved, shared between workbenches, keyboard shortcuts can be set, modified, and macros can be recorded and played. The customization window is accessed from the Tools -> Customize menu: +

      Screenshot-customize.jpg +

      The Commands tab lets you browse all available FreeCAD commands, organized by their category. +

      In Keyboard, you can see the keyboard shortcuts associated with every FreeCAD command, and if you want, modify or assign new shortcut to any command. This is where to come if you use a particular workbench often, and would like to speed up its use by using the keyboard. +

      The Toolbars and Toolbox bars tabs let you modify existing toolbars, or create your own custom toolbars. +

      The Macros tab lets you manage your saved Macros. +

      Create your Toolbars for your macro Customize Toolbars +

      In 0.16 version is available a new tool that lets you manage your workbenches +

      CustomizeWorkbenches.png +

      For an example workflow lets suppose we want to have the "Measure Linear" tool also show up in a custom toolbar in draft workbench. +

      +
      • in FreeCAD choose "Tools -> Customize" from the top menu
      • +
      • select the "Toolbars" tab
      • +
      • on the left side choose "Part" in the pull down menu
      • +
      • on the left side in the lower window scroll down to the "Measure Linear" entry and select it
      • +
      • on the right side choose "Draft" in the pull down menu
      • +
      • click on "New..." to create a new toolbar and choose a name for it
      • +
      • now select your destination toolbar in the right lower window (only needed if you have more than one toolbar)
      • +
      • by clicking on the blue "Arrow right" (top icon in the middle row) you will add your selected entry to the selected toolbar
      +

      Remarks: +

      +
      • when selecting "Global" in the pull down menu on the right side you will create a toolbar which will be visible in all workbenches
      • +
      • for adding an installed macro to a toolbar you must +
        • select "Macros" in the pull down menu on the left side
        • +
        • have assigned menu text, icon (Pixmap) and so on using the "Tools -> Customize -> Macros" menu
      +


      +

      + +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Interface_screenshot.jpg b/localwiki/Interface_screenshot.jpg new file mode 100644 index 0000000..4261c7d Binary files /dev/null and b/localwiki/Interface_screenshot.jpg differ diff --git a/localwiki/Internet-web-browser.svg b/localwiki/Internet-web-browser.svg new file mode 100644 index 0000000..553ddf6 --- /dev/null +++ b/localwiki/Internet-web-browser.svg @@ -0,0 +1,3085 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + Globe + + + Jakub Steiner + + + + + Tuomas Kuosmanen + + + + http://jimmac.musichall.cz + + + globe + international + web + www + internet + network + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Introduction_to_Python.html b/localwiki/Introduction_to_Python.html new file mode 100644 index 0000000..57e4812 --- /dev/null +++ b/localwiki/Introduction_to_Python.html @@ -0,0 +1,328 @@ +Introduction to Python

      Introduction to Python

      + +

      This is a short tutorial for those new to Python. Python is an open-source, multiplatform programming language. Python has several features that make it very different than other common programming languages, and very accessible to new users like yourself: +

      +
      • It has been designed specially to be easy to read by human beings, and so it is very easy to learn and understand.
      • +
      • It is interpreted, that is, unlike compiled languages like C, your program doesn't need to be compiled before it is executed. The code you write can be immediately executed, line by line if you wish. Because you can go slowly, step-by-step, it is extremely easy to learn and to find errors in your code.
      • +
      • It can be embedded in other programs to be used as scripting language. FreeCAD has an embedded Python interpreter; you can write Python code in FreeCAD, that will manipulate parts of FreeCAD, for example to create geometry. This is extremely powerful, instead of just clicking a button labeled "create sphere", that some programmer has coded; you have the freedom to easily build your own tool, creating exactly the geometry you want, in a manner or shape that the programmer may not foresee.
      • +
      • It is extensible, you can easily plug new modules in your Python installation and extend its functionality. For example, you have modules that allow Python to read and write jpg images, to communicate with twitter, to schedule tasks to be performed by your operating system, etc.
      +

      We strongly encourage you to enter the code snippets below into a Python interpreter. For many of our discussions, the important point is the line after the snippet is run, the reveal. Not running the code would be all build up, without a punch line. So, hands on! The following is a very simple introduction, and by no means a complete tutorial. But our hope is that this will provide enough basics to explore deeper into the FreeCAD mechanisms. +

      + + +

      The interpreter

      +

      Usually, when writing computer programs, you simply open a text editor or your special programming environment, (which is usually a text editor with several additional tools) write your program, then compile and execute. Usually, one or more errors were made during entry, so your program won't work. You may even get an error message telling you what went wrong. Then you go back to your text editor, correct the mistakes, run again, repeating until your program works as intended. +

      That whole process, in Python, can be done transparently inside the Python interpreter. The interpreter is a Python window with a command prompt, where you can simply type Python code. If you install Python on your computer (download it from the Python website if you are on Windows or Mac, install it from your package repository if you are on GNU/Linux), you will have a Python interpreter in your start menu. But FreeCAD also has a Python interpreter in its lower window: +

      Screenshot pythoninterpreter.jpg +

      (If you don't have it, click on View --> Panels --> Python console.) +

      The interpreter shows the Python version, then a >>> symbol, which is the command prompt, that is, where you enter Python code. Writing code in the interpreter is simple: one line is one instruction. When you press Enter, your line of code will be executed (after being instantly and invisibly compiled). For example, try writing this: +

      +
      print "hello" 
      +

      print is a special Python keyword that means, obviously, to print something on the screen. When you press Enter, the operation is executed, and the message "hello" is printed. If you make an error, for example let's write: +

      +
      print hello 
      +

      Python will tell us that it doesn't know what hello is. The " characters specify that the content is a string, which is simply, in programming jargon, a piece of text. Without the ", the print command believed hello was not a piece of text but a special Python keyword. The important thing is, you immediately get notified that you made an error. By pressing the up arrow (or, in the FreeCAD interpreter, CTRL+up arrow), you can go back to the last command you wrote and correct it. +

      The Python interpreter also has a built-in help system. Try typing: +

      +
      help 
      +

      or, for example, let's say we don't understand what went wrong with our print hello command above, we want specific information about the "print" command: +

      +
      help("print") 
      +

      You'll get a long and complete description of everything the print command can do. +

      Now that we totally dominate our interpreter, we can begin with the serious stuff. +

      +

      Variables

      +

      Of course, printing "hello" is not very interesting. More interesting is printing stuff you didn't know before, or let Python find for you. That's where the concept of the variable comes in. A variable is simply a value that you store under a name. For example, type this: +

      +
      a = "hello"
      +print a 
      +

      I guess you understood what happened, we "saved" the string "hello" under the name "a." Now, "a" is not an unknown name any more! We can use it anywhere, for example in the print command. We can use any name we want, just follow some simple rules, like not using spaces or punctuation. For example, we could write: +

      +
      hello = "my own version of hello"
      +print hello 
      +

      See? now hello is not an undefined word any more. What if, by terrible bad luck, we choose a name that already exists in Python? Let's say we want to store our string under the name "print": +

      +
      print = "hello" 
      +

      Python is very intelligent and will tell us that this is not possible. It has some "reserved" keywords that cannot be modified. But our variables can be modified any time, that's why they are called variables, the contents can vary. For example: +

      +
      myVariable = "hello"
      +print myVariable
      +myVariable = "good bye"
      +print myVariable 
      +

      We changed the value of myVariable. We can also copy variables: +

      +
      var1 = "hello"
      +var2 = var1
      +print var2 
      +

      Note that it is important to give meaningful names to your variables. After a while you won't remember what your variable named "a" represents. But if you named it, for example myWelcomeMessage, you'll easily remember its purpose. Plus your code is a step closer to being self-documenting. +

      Case is very important. myVariable is not the same as myvariable, the difference in the upper/lower case v. If you were to enter print myvariable it would come back with an error as not defined. +

      +

      Numbers

      +

      Of course you must know that programming is useful to treat all kinds of data, and especially numbers, not only text strings. One thing is important, Python must know what kind of data it is dealing with. We saw in our print hello example, that the print command recognized our "hello" string. That is because by using the ", we told specifically the print command what follows next is a text string. +

      We can always check the data type of a variable with the special Python keyword type: +

      +
      myVar = "hello"
      +type(myVar) 
      +

      It will tell us the contents of myVar is 'str', short for string in Python jargon. We have also other basic types of data, such as integer and float numbers: +

      +
      firstNumber = 10
      +secondNumber = 20
      +print firstNumber + secondNumber
      +type(firstNumber) 
      +

      This is much more interesting, isn't it? Now we have a powerful calculator! Look at how well it worked, Python knows that 10 and 20 are integer numbers. So they are stored as "int", and Python can do with them everything it can do with integers. Look at the results of this: +

      +
      firstNumber = "10"
      +secondNumber = "20"
      +print firstNumber + secondNumber 
      +

      See? We forced Python to consider that our two variables are not numbers but mere pieces of text. Python can add two pieces of text together, but it won't try to find out any sum. But we were talking about integer numbers. There are also float numbers. The difference is that integer numbers don't have decimal part, while float numbers can have a decimal part: +

      +
      var1 = 13
      +var2 = 15.65
      +print "var1 is of type ", type(var1)
      +print "var2 is of type ", type(var2) 
      +

      Int and Floats can be mixed together without problem: +

      +
      total = var1 + var2
      +print total
      +print type(total) 
      +

      Of course the total has decimals, right? Then Python automatically decided that the result is a float. In several cases such as this one, Python automatically decides what type to use. In other cases it doesn't. For example: +

      +
      varA = "hello 123"
      +varB = 456
      +print varA + varB 
      +

      This will give us an error, varA is a string and varB is an int, and Python doesn't know what to do. However, we can force Python to convert between types: +

      +
      varA = "hello"
      +varB = 123
      +print varA + str(varB) 
      +

      Now both are strings, the operation works! Note that we "stringified" varB at the time of printing, but we didn't change varB itself. If we wanted to turn varB permanently into a string, we would need to do this: +

      +
      varB = str(varB) 
      +

      We can also use int() and float() to convert to int and float if we want: +

      +
      varA = "123"
      +print int(varA)
      +print float(varA) 
      +

      Note on Python commands +

      You must have noticed that in this section we used the print command in several ways. We printed variables, sums, several things separated by commas, and even the result of other Python command such as type(). Maybe you also saw that doing those two commands, +

      +
      type(varA)
      +print type(varA) 
      +

      have exactly the same result. That is because we are in the interpreter, and everything is automatically printed. When we write more complex programs that run outside the interpreter, they won't print automatically, so we'll need to use the print command. From now on, let's stop using it here, it'll go faster. So we can simply write: +

      +
      myVar = "hello friends"
      +myVar 
      +

      You must have seen that most of the Python commands (or keywords) type(), int(), str(), etc. have parenthesis to limit the command contents. The only exception is the print command, which in fact is not really an exception, as it also works normally: print("hello"). However, since it is used often, the Python designers allowed a simpler version. +

      +

      Lists

      +

      Another interesting data type is a list. A list is simply a collection of other data. The same way that we define a text string by using " ", we define a list by using [ ]: +

      +
      myList = [1,2,3]
      +type(myList)
      +myOtherList = ["Bart", "Frank", "Bob"]
      +myMixedList = ["hello", 345, 34.567] 
      +

      You see that it can contain any type of data. Lists are very useful because you can group variables together. You can then do all kinds of things within that group, for example counting them: +

      +
      len(myOtherList) 
      +

      or retrieving one item of a list: +

      +
      myName = myOtherList[0]
      +myFriendsName = myOtherList[1] 
      +

      You see that while the len() command returns the total number of items in a list, their "position" in the list begins with 0. The first item in a list is always at position 0, so in our myOtherList, "Bob" will be at position 2. We can do much more with lists, you can read here, such as sorting contents, removing or adding elements. +

      A funny and interesting thing: a text string is very similar to a list of characters! Try doing this: +

      +
      myvar = "hello"
      +len(myvar)
      +myvar[2] 
      +

      Usually, what you can do with lists can also be done with strings. In fact both lists and strings are sequences. +

      Outside strings, ints, floats and lists, there are more built-in data types, such as dictionaries, or you can even create your own data types with classes. +

      +

      Indentation

      +

      One big cool use of lists is also browsing through them and do something with each item. For example look at this: +

      +
      alldaltons = ["Joe", "William", "Jack", "Averell"]
      +for dalton in alldaltons:
      +   print dalton + " Dalton" 
      +

      We iterated (programming jargon) through our list with the "for ... in ..." command and did something with each of the items. Note the special syntax: the for command terminates with : indicating the following will be a block of one of more commands. In the interpreter, immediately after you enter the command line ending with :, the command prompt will change to ... which means Python knows that a colon (:) ended line has happened and more is coming. +

      How will Python know how many of the next lines will be to be executed inside the for...in operation? For that, Python uses indentation. That is, your next lines won't begin immediately. You will begin them with a blank space, or several blank spaces, or a tab, or several tabs. Other programming languages use other methods, like putting everything inside parenthesis, etc. +As long as you write your next lines with the same indentation, they will be considered part of the for-in block. If you begin one line with 2 spaces and the next one with 4, there will be an error. +When you finished, just write another line without indentation, or simply press Enter to come back from the for-in block +

      Indentation is cool because it aids in program readability. If you use large indentations (for example use tabs instead of spaces because it's larger), when you write a big program you'll have a clear view of what is executed inside what. We'll see that commands other than for-in, can have indented blocks of code too. +

      For-in commands can be used for many things that must be done more than once. It can, for example, be combined with the range() command: +

      +
      serie = range(1,11)
      +total = 0
      +print "sum"
      +for number in serie:
      +   print number
      +   total = total + number
      +print "----"
      +print total 
      +

      (If you have been running the code examples in an interpreter by Copying and Pasting, you will find the previous block of text will throw an error. Instead, copy to the end of the indented block, i.e. the end of the line total = total + number and then paste to the interpreter. In the interpreter issue an <enter> until the three dot prompt disappears and the code runs. Then copy the final two lines into the interpreter followed by one or more <enter> The final answer should appear.) +

      If you would type into the interpreter help(range) you would see: +

      +
      range(...)
      +    range(stop) -> list of integers
      +    range(start, stop[, step]) -> list of integers 
      +

      Here the square brackets denote an optional parameter. However all are expected to be integers. Below we will force the range parameters to be an integer using int() +

      +
      decimales = 1000                     # for 3 decimales 
      +#decimales = 10000                   # for 4 decimales ...
      +for i in range(int(0 * decimales),int(180 * decimales),int(0.5 * decimales)):
      +    print float(i) / decimales 
      +

      Or more complex things like this: +

      +
      alldaltons = ["Joe", "William", "Jack", "Averell"]
      +for n in range(4):
      +   print alldaltons[n], " is Dalton number ", n 
      +

      You see that the range() command also has that strange particularity that it begins with 0 (if you don't specify the starting number) and that its last number will be one less than the ending number you specify. That is, of course, so it works well with other Python commands. For example: +

      +
      alldaltons = ["Joe", "William", "Jack", "Averell"]
      +total = len(alldaltons)
      +for n in range(total):
      +   print alldaltons[n] 
      +

      Another interesting use of indented blocks is with the if command. If executes a code block only if a certain condition is met, for example: +

      +
      alldaltons = ["Joe", "William", "Jack", "Averell"]
      +if "Joe" in alldaltons:
      +   print "We found that Dalton!!!" 
      +

      Of course this will always print the first sentence, but try replacing the second line by: +

      +
      if "Lucky" in alldaltons: 
      +

      Then nothing is printed. We can also specify an else: statement: +

      +
      alldaltons = ["Joe", "William", "Jack", "Averell"]
      +if "Lucky" in alldaltons:
      +   print "We found that Dalton!!!"
      +else:
      +   print "Such Dalton doesn't exist!" 
      +

      Functions

      +

      There are few standard Python commands. In the current version of Python, there are about 30, and we already know several of them. But imagine if we could invent our own commands? Well, we can, and it's extremely easy. In fact, most the additional modules that you can plug into your Python installation do just that, they add commands that you can use. A custom command in Python is called a function and is made like this: +

      +
      def printsqm(myValue):
      +   print str(myValue)+" square meters"
      + 
      +printsqm(45) 
      +

      (Another copy and paste error, only copy through the end of the indented section i.e. " square meters" Paste to the interpreter, and issue <enter> until the three dot prompt goes a way, then copy and paste the final line.) +

      Extremely simple: the def() command defines a new function. You give it a name, and inside the parenthesis you define arguments that we'll use in our function. Arguments are data that will be passed to the function. For example, look at the len() command. If you just write len() alone, Python will tell you it needs an argument. That is, you want len() of something, right? Then, for example, you'll write len(myList) and you'll get the length of myList. Well, myList is an argument that you pass to the len() function. The len() function is defined in such a way that it knows what to do with what is passed to it. Same as we did here. +

      The "myValue" name can be anything, and it will be used only inside the function. It is just a name you give to the argument so you can do something with it, but it also serves to tell the function how many arguments to expect. For example, if you do this: +

      +
      printsqm(45,34) 
      +

      There will be an error. Our function was programmed to receive just one argument, but it received two, 45 and 34. We could instead do something like this: +

      +
      def sum(val1,val2):
      +   total = val1 + val2
      +   return total
      +
      +sum(45,34)
      +myTotal = sum(45,34) 
      +

      We made a function that receives two arguments, sums them, and returns that value. Returning something is very useful, because we can do something with the result, such as store it in the myTotal variable. Of course, since we are in the interpreter and everything is printed, doing: +

      +
      sum(45,34) 
      +

      will print the result on the screen, but outside the interpreter, since there is no print command inside the function, nothing would appear on the screen. You would need to: +

      +
      print sum(45,34) 
      +

      to have something printed. Read more about functions here. +

      +

      Modules

      +

      Now that we have a good idea of how Python works, we'll need one last thing: How to work with files and modules. +

      Until now, we wrote Python instructions line by line in the interpreter, right? What if we could write several lines together, and have them executed all at once? It would certainly be handier for doing more complex things. And we could save our work too. Well, that too, is extremely easy. Simply open a text editor (such as the windows notepad, Linux gedit, emacs, or vi), and write all your Python lines, the same way as you write them in the interpreter, with indentations, etc. Then, save that file somewhere, preferably with a .py extension. That's it, you have a complete Python program. Of course, there are much better editors than notepad, but it is just to show you that a Python program is nothing else than a text file. +

      To make Python execute that program, there are hundreds of ways. In windows, simply right-click your file, open it with Python, and execute it. But you can also execute it from the Python interpreter itself. For this, the interpreter must know where your .py program is. In FreeCAD, the easiest way is to place your program in a place that FreeCAD's Python interpreter knows by default, such as FreeCAD's bin folder, or any of the Mod folders. (In Linux, you probably have a directory /home/<username>/.FreeCAD/Mod, let's add a subdirectory to that called scripts where we will put the text file.) Suppose we write a file like this: +

      +
      def sum(a,b):
      +    return a + b
      +
      +print "myTest.py succesfully loaded" 
      +

      and we save it as myTest.py in our FreeCAD/bin directory (or on Linux to /home/<username>/.FreeCAD/Mod/scripts.) Now, let's start FreeCAD, and in the interpreter window, write: +

      +
      import myTest 
      +

      without the .py extension. This will simply execute the contents of the file, line by line, just as if we had written it in the interpreter. The sum function will be created, and the message will be printed. There is one big difference: the import command is made not only to execute programs written in files, like ours, but also to load the functions inside, so they become available in the interpreter. Files containing functions, like ours, are called modules. +

      Normally when we write a sum() function in the interpreter, we execute it simply like that: +

      +
      sum(14,45) 
      +

      Like we did earlier. When we import a module containing our sum() function, the syntax is a bit different. We do: +

      +
      myTest.sum(14,45) 
      +

      That is, the module is imported as a "container", and all its functions are inside. This is extremely useful, because we can import a lot of modules, and keep everything well organized. So, basically, everywhere you see something.somethingElse, with a dot in between, that means somethingElse is inside something. +

      We can also import our sum() function directly into the main interpreter space, like this: +

      +
      from myTest import *
      +sum(12,54) 
      +

      Basically all modules behave like that. You import a module, then you can use its functions: module.function(argument). Almost all modules do that: they define functions, new data types and classes that you can use in the interpreter or in your own Python modules, because nothing prevents you from importing other modules inside your module! +

      One last extremely useful thing. How do we know what modules we have, what functions are inside and how to use them (that is, what kind of arguments they need)? We saw already that Python has a help() function. Doing: +

      +
      help()
      +modules 
      +

      Will give us a list of all available modules. We can now type q to get out of the interactive help, and import any of them. We can even browse their content with the dir() command +

      +
      import math
      +dir(math) 
      +

      We'll see all the functions contained in the math module, as well as strange stuff named __doc__, __file__, __name__. The __doc__ is extremely useful, it is a documentation text. Every function of (well-made) modules has a __doc__ that explains how to use it. For example, we see that there is a sin function in side the math module. Want to know how to use it? +

      +
      print math.sin.__doc__ 
      +

      (It may not be evident, but on either side of doc are two underscore characters.) +

      And finally one last little goodie: When we work on a new or existing module, it's best to replace the file extension with py such as: myModule.FCMacro => myModule.py. We often want to test it so we will load it as above. +

      +
      import myModule
      +myModule.myTestFunction() 
      +

      But what if we see that myTestFunction() doesn't work correctly? We go back to our editor and make changes. Then, instead of closing and reopening the python interpreter, we can simply update the module like this: +

      +
      reload(myModule) 
      +

      This file renaming is because Python doesn't know about the extension FCMacro. +

      However, there are two alternates: Inside the one macro use Python's exec or execfile functions. +

      +
      f = open("myModule","r")
      +d = f.read()
      +exec d 
      +

      or +

      +
      execfile "myModule" 
      +

      To share code across macros, you can access the FreeCAD or FreeCADGui module (or any other Python module) and set any attribute to it. This should survive the execution of the macro. +

      +
      import FreeCAD
      +if hasattr(FreeCAD,"macro2_executed"):
      +    ...
      +else:
      +    FreeCAD.macro2_executed = True # you can assign any value because we only check for the existence of the attribute
      +    ... execute macro2 
      +

      Starting with FreeCAD

      +

      Well, I think you now have a good idea of how Python works, and you can start exploring what FreeCAD has to offer. FreeCAD's Python functions are all well organized in different modules. Some of them are already loaded (imported) when you start FreeCAD. So, just do +

      +
      dir() 
      +

      and read on to FreeCAD Scripting Basics... +

      Of course, we saw here only a very small part of the Python world. There are many important concepts that we didn't mention. There are three very important Python reference documents on the net: +

      + +

      Be sure to bookmark them! +


      +

      + +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Job_1.jpg b/localwiki/Job_1.jpg new file mode 100644 index 0000000..93399de Binary files /dev/null and b/localwiki/Job_1.jpg differ diff --git a/localwiki/Job_2.jpg b/localwiki/Job_2.jpg new file mode 100644 index 0000000..61945dc Binary files /dev/null and b/localwiki/Job_2.jpg differ diff --git a/localwiki/Job_3.jpg b/localwiki/Job_3.jpg new file mode 100644 index 0000000..576f40f Binary files /dev/null and b/localwiki/Job_3.jpg differ diff --git a/localwiki/Job_4.jpg b/localwiki/Job_4.jpg new file mode 100644 index 0000000..3c61716 Binary files /dev/null and b/localwiki/Job_4.jpg differ diff --git a/localwiki/Job_5.jpg b/localwiki/Job_5.jpg new file mode 100644 index 0000000..47c9fe1 Binary files /dev/null and b/localwiki/Job_5.jpg differ diff --git a/localwiki/JoinFeatures_dropdownToolbarButton.png b/localwiki/JoinFeatures_dropdownToolbarButton.png new file mode 100644 index 0000000..6638a38 Binary files /dev/null and b/localwiki/JoinFeatures_dropdownToolbarButton.png differ diff --git a/localwiki/JschremppFCADEdit1.png b/localwiki/JschremppFCADEdit1.png new file mode 100644 index 0000000..f9a66a7 Binary files /dev/null and b/localwiki/JschremppFCADEdit1.png differ diff --git a/localwiki/JschremppFCADEdit2.png b/localwiki/JschremppFCADEdit2.png new file mode 100644 index 0000000..8df74bf Binary files /dev/null and b/localwiki/JschremppFCADEdit2.png differ diff --git a/localwiki/JschremppFCADEdit3.png b/localwiki/JschremppFCADEdit3.png new file mode 100644 index 0000000..b4ef6d8 Binary files /dev/null and b/localwiki/JschremppFCADEdit3.png differ diff --git a/localwiki/JschremppFCADEdit4.png b/localwiki/JschremppFCADEdit4.png new file mode 100644 index 0000000..a39b865 Binary files /dev/null and b/localwiki/JschremppFCADEdit4.png differ diff --git a/localwiki/Kate1.png b/localwiki/Kate1.png new file mode 100644 index 0000000..9c13f80 Binary files /dev/null and b/localwiki/Kate1.png differ diff --git a/localwiki/Kate2.png b/localwiki/Kate2.png new file mode 100644 index 0000000..e538946 Binary files /dev/null and b/localwiki/Kate2.png differ diff --git a/localwiki/Kate2a.png b/localwiki/Kate2a.png new file mode 100644 index 0000000..b1c0cdf Binary files /dev/null and b/localwiki/Kate2a.png differ diff --git a/localwiki/Kate3.png b/localwiki/Kate3.png new file mode 100644 index 0000000..459dff4 Binary files /dev/null and b/localwiki/Kate3.png differ diff --git a/localwiki/Kate4.png b/localwiki/Kate4.png new file mode 100644 index 0000000..2e2bf5c Binary files /dev/null and b/localwiki/Kate4.png differ diff --git a/localwiki/Kate5.png b/localwiki/Kate5.png new file mode 100644 index 0000000..697d3b5 Binary files /dev/null and b/localwiki/Kate5.png differ diff --git a/localwiki/KicadStepUp_Workbench.html b/localwiki/KicadStepUp_Workbench.html new file mode 100644 index 0000000..7623d7f --- /dev/null +++ b/localwiki/KicadStepUp_Workbench.html @@ -0,0 +1,32 @@ +KicadStepUp Workbench

      KicadStepUp Workbench

      + +

      Introduction

      +

      FreeCAD kicad StepUp WorkBench

      +

      kicad StepUp WB is aimed to help KiCad and FreeCAD users in ECAD and MCAD collaboration. +

      Features: +

      kicad StepUp is a set of tools to help in ECAD MCAD collaboration and design. +

      Help and howto: +

      kicad StepUp cheat sheet +

      +

      References

      + +


      +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/KukaAxisData.jpg b/localwiki/KukaAxisData.jpg new file mode 100644 index 0000000..45e3c6b Binary files /dev/null and b/localwiki/KukaAxisData.jpg differ diff --git a/localwiki/KukaAxisPosition.jpg b/localwiki/KukaAxisPosition.jpg new file mode 100644 index 0000000..de081f3 Binary files /dev/null and b/localwiki/KukaAxisPosition.jpg differ diff --git a/localwiki/KukaBase.jpg b/localwiki/KukaBase.jpg new file mode 100644 index 0000000..568af43 Binary files /dev/null and b/localwiki/KukaBase.jpg differ diff --git a/localwiki/KukaKR16.jpg b/localwiki/KukaKR16.jpg new file mode 100644 index 0000000..ed3b003 Binary files /dev/null and b/localwiki/KukaKR16.jpg differ diff --git a/localwiki/KukaKR16FreeCAD.jpg b/localwiki/KukaKR16FreeCAD.jpg new file mode 100644 index 0000000..801bb5c Binary files /dev/null and b/localwiki/KukaKR16FreeCAD.jpg differ diff --git a/localwiki/KukaParts.jpg b/localwiki/KukaParts.jpg new file mode 100644 index 0000000..2a23373 Binary files /dev/null and b/localwiki/KukaParts.jpg differ diff --git a/localwiki/KukaSegment1.jpg b/localwiki/KukaSegment1.jpg new file mode 100644 index 0000000..96b5a5a Binary files /dev/null and b/localwiki/KukaSegment1.jpg differ diff --git a/localwiki/KukaSegment2.jpg b/localwiki/KukaSegment2.jpg new file mode 100644 index 0000000..09db8e4 Binary files /dev/null and b/localwiki/KukaSegment2.jpg differ diff --git a/localwiki/KukaSegment3.jpg b/localwiki/KukaSegment3.jpg new file mode 100644 index 0000000..d7b518a Binary files /dev/null and b/localwiki/KukaSegment3.jpg differ diff --git a/localwiki/KukaSegment4.jpg b/localwiki/KukaSegment4.jpg new file mode 100644 index 0000000..4fc7cac Binary files /dev/null and b/localwiki/KukaSegment4.jpg differ diff --git a/localwiki/KukaSegment5.jpg b/localwiki/KukaSegment5.jpg new file mode 100644 index 0000000..727413e Binary files /dev/null and b/localwiki/KukaSegment5.jpg differ diff --git a/localwiki/KukaSegment6.jpg b/localwiki/KukaSegment6.jpg new file mode 100644 index 0000000..4ccb4c3 Binary files /dev/null and b/localwiki/KukaSegment6.jpg differ diff --git a/localwiki/Labels.svg b/localwiki/Labels.svg new file mode 100644 index 0000000..ea9dbc6 --- /dev/null +++ b/localwiki/Labels.svg @@ -0,0 +1,163 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [Jose Luis Cercos Pita] + + + Labels + 2012-11-02 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Plot/resources/icons/Labels.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Land_Survey_Workbench_Blueprint.html b/localwiki/Land_Survey_Workbench_Blueprint.html new file mode 100644 index 0000000..9943569 --- /dev/null +++ b/localwiki/Land_Survey_Workbench_Blueprint.html @@ -0,0 +1,81 @@ +Land Survey Workbench Blueprint

      Land Survey Workbench Blueprint

      + +

      This page lists the requirements and implementation for a new workbench usable in the field of Land Survey. The page is a bit outdated. Find the latest informations for FreeCAD in this regard on a HUGE forum thread: http://forum.freecadweb.org/viewtopic.php?f=8&t=6973 +


      +

      + + +

      Rectangle selection

      +
      +

      A new mouse mode may be required: +

      +
      • left-click on an object selects the object
      • +
      • left-click in empty space - begin selection action; click again - end selection action, add to selection set +
        • CTRL - exclude from already selected set
      • +
      • press and hold middle button to pan
      • +
      • contextual menu on right click
      • +
      • wheel up/down - zoom
      +
      +


      +

      +

      Layers

      +
      • Object properties such as color, line weight, visibility, print-ability can be set on a per-object basis or may be inherited from the parent layer.
      • +
      • Each object has a parent layer / an object may be part of a layer or not.
      +

      Blocks

      +

      Blocks are objects that behave in most circumstances as a single object. The objects do not loose their individuality inside the block. +

      +
      +

      Since there is a Upgrade/Downgrade, this functionality may already be present. +

      +
      +

      Dynamic attributes

      +

      Variables. Components of the block that may be changed without changing the definition of the block. Position inside the block is one such attribute. +

      +
      +

      This feature will integrate well if expressed as properties. +

      +
      +

      Points

      +

      In land survey the points are usually associated with numbers, description and other characteristics. +

      +
      +

      The blocks with dynamic properties should do it. +

      +
      +

      Querry tools for 2 and a half system

      +

      The planar position is usually decoupled (especially in cadastre applications) from the height. When you want to know the distance between two points you actually want to know the distance in horizontal projection. The horizontal plane is XY, with Y pointing toward north. Z points upward (positive altitude). +

      +

      Rich text; Tables

      +

      General support for rich text. +


      +Note: the information in this page is based on a shallow understanding of FreeCAD's internals. Once it deepens the requirements and implementation may be adjusted. Contributions are welcomed! --Xtnickx 11:00, 26 January 2013 (UTC) +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Legend.svg b/localwiki/Legend.svg new file mode 100644 index 0000000..b741e32 --- /dev/null +++ b/localwiki/Legend.svg @@ -0,0 +1,184 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [Jose Luis Cercos Pita] + + + Legend + 2012-11-02 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Plot/resources/icons/Legend.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Licence.html b/localwiki/Licence.html new file mode 100644 index 0000000..a63b74a --- /dev/null +++ b/localwiki/Licence.html @@ -0,0 +1,93 @@ +Licence

      Licence

      + +
      + +

      Statement of the main developer

      +

      I know that the discussion on the "right" licence for open source occupied a significant portion of internet bandwidth and so is here the reason why, in my opinion, FreeCAD should have this one. +

      I chose the LGPL for the project and I know the pro and cons about the LGPL and will give you some reasons for that decision. +

      FreeCAD is a mixture of a library and an application, so the GPL would be a little bit strong for that. It would prevent writing commercial modules for FreeCAD because it would prevent linking with the FreeCAD base libs. You may ask why commercial modules at all? Therefore Linux is good example. Would Linux be so successful when the GNU C Library would be GPL and therefore prevent linking against non-GPL applications? And although I love the freedom of Linux, I also want to be able to use the very good NVIDIA 3D graphic driver. I understand and accept the reason NVIDIA does not wish to give away driver code. We all work for companies and need payment or at least food. So for me, a coexistence of open source and closed source software is not a bad thing, when it obeys the rules of the LGPL. I would like to see someone writing a Catia import/export processor for FreeCAD and distribute it for free or for some money. I don't like to force him to give away more than he wants to. That wouldn't be good neither for him nor for FreeCAD. +

      Nevertheless this decision is made only for the core system of FreeCAD. Every writer of an application module may make his own decision. +

      +

      Licences used in FreeCAD

      +

      FreeCAD uses two different licenses, one for the application itself, and one for the documentation: +

      +
      Lesser General Public Licence, version 2 or superior (LGPL2+)
      +
      For the core libs as stated in the .h and .cpp files in src/App src/Gui src/Base and all modules in src/Mod and for the executable as stated in the .h and .cpp files in src/main. The icons and other graphic parts are also LGPL.
      +
      Open Publication Licence
      +
      For the documentation on http://www.freecadweb.org when not marked differently by the author
      +


      +See FreeCAD's debian copyright file for more details about the licenses used by the different components found in FreeCAD +

      +

      Impact of the licences

      +

      Private users

      +

      Private users can use FreeCAD free of charge and can do basically whatever they want to do with it: use it, copy it, modify it, redistribute it. +They are always master of their data, they are not forced to update FreeCAD, change their usage of FreeCAD. Using FreeCAD doesn't bind them to any kind of contract or obligation. +

      +

      Professional users

      +

      Can use FreeCAD freely, for any kind of private or professional work. They can customize the application as they wish. They can write open or closed source extensions to FreeCAD. They are always master of their data, they are not forced to update FreeCAD, change their usage of FreeCAD. Using FreeCAD doesn't bind them to any kind of contract or obligation. +

      +

      Open Source developers

      +

      Can use FreeCAD as the groundwork for own extension modules for special purposes. They can choose either the GPL or the LGPL to allow the use of their work in proprietary software or not. +

      +

      Commercial developers

      +

      Commercial developers can use FreeCAD as the groundwork for their own extension modules for special purposes and are not forced to make their modules open source. They can use all modules which use the LGPL. They are allowed to distribute FreeCAD along with their proprietary software. They will get the support of the author(s) as long as it is not a one way street. +

      +

      OpenCasCade License side effects (for FreeCAD version 0.13 and older)

      +

      The following is no more applicable since version 0.14, since both FreeCAD and OpenCasCade are now fully LGPL. +


      +Up to Version 0.13 FreeCAD is delivered as GPL2+, although the source itself is under LGPL2+. Thats because of linkage of Coin3D (GPL2) and PyQt(GPL). Starting with 0.14 we will be completely GPL free. PyQt will be replaced by PySide, and Coin3D was re-licensed under BSD. One problem, we still have to face, license-wise, the OCTPL (Open CASCADE Technology Public License). Its a License mostly LGPL similar, with certain changes. On of the originators, Roman Lygin, elaborated on the License on his Blog. The home-brew OCTPL license leads to all kind of side effects for FreeCAD, which where widely discussed on different forums and mailing lists, e.g. on OpenCasCade forum itself. I will link here some articles for the biggest problems. +

      +

      GPL2/GPL3/OCTLP incompatibility

      +

      We first discovered the problem by a discussion on the FSF high priority project discussion list. It was about a library we look at, which was licensed with GPL3. Since we linked back then with Coin3D, with GPL2 only, we was not able to adopt that lib. Also the +OCTPL is considered GPL incompatible. This Libre Graphics World article "LibreDWG drama: the end or the new beginning?" shows up the drama of LibreDWG project not acceptably in FreeCAD or LibreCAD. +

      +

      Debian

      +

      The incompatibility of the OCTPL was discussed on the debian legal list and lead to a bug report on the FreeCAD package which prevent (ignor-tag) the transition from debian-testing to the main distribution. But its also mentioned thats a FreeCAD, which is free of GPL code and libs, would be acceptably. With a re-licensed Coin3D V4 and a substituted PyQt we will hopefully reach GPL free with the 0.14 release. +

      +

      Fedora/RedHat non-free

      +

      In the Fedora project OpenCasCade is listed "non-free". This means basically it won't make it into Fedora or RedHat. This means also FreeCAD won't make it into Fedora/RedHat until OCC is changing its license. Here the links to the license evaluation: +

      + +

      The main problem they have AFIK is that the OCC license demand non discriminatory support fees if you want to do paid support. It has nothing to do with "free" or OpenSource, its all about RedHat's business model! +

      + +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Line.png b/localwiki/Line.png new file mode 100644 index 0000000..99b0cc2 Binary files /dev/null and b/localwiki/Line.png differ diff --git a/localwiki/Line.svg b/localwiki/Line.svg new file mode 100644 index 0000000..ecc47cf --- /dev/null +++ b/localwiki/Line.svg @@ -0,0 +1,95 @@ + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Line_drawing_function.html b/localwiki/Line_drawing_function.html new file mode 100644 index 0000000..3283af4 --- /dev/null +++ b/localwiki/Line_drawing_function.html @@ -0,0 +1,171 @@ +Line drawing function

      Line drawing function

      + +

      This page shows how advanced functionality can easily be built in Python. In this exercise, we will be building a new tool that draws a line. This tool can then be linked to a FreeCAD command, and that command can be called by any element of the interface, like a menu item or a toolbar button. +

      + + +

      The main script

      +

      First we will write a script containing all our functionality. Then, we will save this in a file, and import it in FreeCAD, so all classes and functions we write will be availible to FreeCAD. So, launch your favorite text editor, and type the following lines: +

      +
      import FreeCADGui, Part
      +from pivy.coin import *
      + 
      +class line:
      +    "this class will create a line after the user clicked 2 points on the screen"
      +    def __init__(self):
      +        self.view = FreeCADGui.ActiveDocument.ActiveView
      +        self.stack = []
      +        self.callback = self.view.addEventCallbackPivy(SoMouseButtonEvent.getClassTypeId(),self.getpoint)  
      +
      +    def getpoint(self,event_cb):
      +        event = event_cb.getEvent()
      +        if event.getState() == SoMouseButtonEvent.DOWN:
      +            pos = event.getPosition()
      +            point = self.view.getPoint(pos[0],pos[1])
      +            self.stack.append(point)
      +            if len(self.stack) == 2:
      +                l = Part.Line(self.stack[0],self.stack[1])
      +                shape = l.toShape()
      +                Part.show(shape)
      +                self.view.removeEventCallbackPivy(SoMouseButtonEvent.getClassTypeId(),self.callback) 
      +

      Detailed explanation

      +
      import Part, FreeCADGui
      +from pivy.coin import * 
      +

      In Python, when you want to use functions from another module, you need to import it. In our case, we will need functions from the Part Module, for creating the line, and from the Gui module (FreeCADGui), for accessing the 3D view. We also need the complete contents of the coin library, so we can use directly all coin objects like SoMouseButtonEvent, etc... +

      +
      class line: 
      +

      Here we define our main class. Why do we use a class and not a function? The reason is that we need our tool to stay "alive" while we are waiting for the user to click on the screen. A function ends when its task has been done, but an object (a class defines an object) stays alive until it is destroyed. +

      +
      "this class will create a line after the user clicked 2 points on the screen" 
      +

      In Python, every class or function can have a description string. This is particularly useful in FreeCAD, because when you'll call that class in the interpreter, the description string will be displayed as a tooltip. +

      +
      def __init__(self): 
      +

      Python classes can always contain an __init__ function, which is executed when the class is called to create an object. So, we will put here everything we want to happen when our line tool begins. +

      +
      self.view = FreeCADGui.ActiveDocument.ActiveView 
      +

      In a class, you usually want to append self. before a variable name, so it will be easily accessible to all functions inside and outside that class. Here, we will use self.view to access and manipulate the active 3D view. +

      +
      self.stack = [] 
      +

      Here we create an empty list that will contain the 3D points sent by the getpoint function. +

      +
      self.callback = self.view.addEventCallbackPivy(SoMouseButtonEvent.getClassTypeId(),self.getpoint) 
      +

      This is the important part: Since it is actually a coin3D scene, the FreeCAD uses coin callback mechanism, that allows a function to be called everytime a certain scene event happens. In our case, we are creating a callback for SoMouseButtonEvent events, and we bind it to the getpoint function. Now, everytime a mouse button is pressed or released, the getpoint function will be executed. +

      Note that there is also an alternative to addEventCallbackPivy() called addEventCallback() which dispenses the use of pivy. But since pivy is a very efficient and natural way to access any part of the coin scene, it is much better to use it as much as you can! +

      +
      def getpoint(self,event_cb): 
      +

      Now we define the getpoint function, that will be executed when a mouse button is pressed in a 3D view. This function will receive an argument, that we will call event_cb. From this event callback we can access the event object, which contains several pieces of information (mode info here). +

      +
      if event.getState() == SoMouseButtonEvent.DOWN: 
      +

      The getpoint function will be called when a mouse button is pressed or released. But we want to pick a 3D point only when pressed (otherwise we would get two 3D points very close to each other). So we must check for that here. +

      +
      pos = event.getPosition() 
      +

      Here we get the screen coordinates of the mouse cursor +

      +
      point = self.view.getPoint(pos[0],pos[1]) 
      +

      This function gives us a FreeCAD vector (x,y,z) containing the 3D point that lies on the focal plane, just under our mouse cursor. If you are in camera view, imagine a ray coming from the camera, passing through the mouse cursor, and hitting the focal plane. There is our 3D point. If we are in orthogonal view, the ray is parallel to the view direction. +

      +
      self.stack.append(point) 
      +

      We add our new point to the stack +

      +
      if len(self.stack) == 2: 
      +

      Do we have enough points already? if yes, then let's draw the line! +

      +
      l = Part.Line(self.stack[0],self.stack[1]) 
      +

      Here we use the function Line() from the Part Module that creates a line from two FreeCAD vectors. Everything we create and modify inside the Part module, stays in the Part module. So, until now, we created a Line Part. It is not bound to any object of our active document, so nothing appears on the screen. +

      +
      shape = l.toShape() 
      +

      The FreeCAD document can only accept shapes from the Part module. Shapes are the most generic type of the Part module. So, we must convert our line to a shape before adding it to the document. +

      +
      Part.show(shape) 
      +

      The Part module has a very handy show() function that creates a new object in the document and binds a shape to it. We could also have created a new object in the document first, then bound the shape to it manually. +

      +
      self.view.removeEventCallbackPivy(SoMouseButtonEvent.getClassTypeId(),self.callback) 
      +

      Since we are done with our line, let's remove the callback mechanism, that consumes precious CPU cycles. +

      +

      Testing & Using the script

      +

      Now, let's save our script to some place where the FreeCAD python interpreter will find it. When importing modules, the interpreter will look in the following places: the python installation paths, the FreeCAD bin directory, and all FreeCAD modules directories. So, the best solution is to create a new directory in one of the FreeCAD Mod directories, and to save our script in it. For example, let's make a "MyScripts" directory, and save our script as "exercise.py". +

      Now, everything is ready, let's start FreeCAD, create a new document, and, in the python interpreter, issue: +

      +
      import exercise 
      +

      If no error message appear, that means our exercise script has been loaded. We can now check its contents with: +

      +
      dir(exercise) 
      +

      The command dir() is a built-in python command that lists the contents of a module. We can see that our line() class is there, waiting for us. Now let's test it: +

      +
      exercise.line() 
      +

      Then, click two times in the 3D view, and bingo, here is our line! To do it again, just type exercise.line() again, and again, and again... Feels great, no? +

      +

      Registering the script in the FreeCAD interface

      +

      Now, for our new line tool to be really cool, it should have a button on the interface, so we don't need to type all that stuff everytime. The easiest way is to transform our new MyScripts directory into a full FreeCAD workbench. It is easy, all that is needed is to put a file called InitGui.py inside your MyScripts directory. The InitGui.py will contain the instructions to create a new workbench, and add our new tool to it. Besides that we will also need to transform a bit our exercise code, so the line() tool is recognized as an official FreeCAD command. Let's start by making an InitGui.py file, and write the following code in it: +

      +
      class MyWorkbench (Workbench): 
      +   MenuText = "MyScripts"
      +   def Initialize(self):
      +       import exercise
      +       commandslist = ["line"]
      +       self.appendToolbar("My Scripts",commandslist)
      +Gui.addWorkbench(MyWorkbench()) 
      +

      By now, you should already understand the above script by yourself, I think: We create a new class that we call MyWorkbench, we give it a title (MenuText), and we define an Initialize() function that will be executed when the workbench is loaded into FreeCAD. In that function, we load in the contents of our exercise file, and append the FreeCAD commands found inside to a command list. Then, we make a toolbar called "My Scripts" and we assign our commands list to it. Currently, of course, we have only one tool, so our command list contains only one element. Then, once our workbench is ready, we add it to the main interface. +

      But this still won't work, because a FreeCAD command must be formatted in a certain way to work. So we will need to transform a bit our line() tool. Our new exercise.py script will now look like this: +

      +
      import FreeCADGui, Part
      +from pivy.coin import *
      +class line:
      + "this class will create a line after the user clicked 2 points on the screen"
      + def Activated(self):
      +   self.view = FreeCADGui.ActiveDocument.ActiveView
      +   self.stack = []
      +   self.callback = self.view.addEventCallbackPivy(SoMouseButtonEvent.getClassTypeId(),self.getpoint) 
      + def getpoint(self,event_cb):
      +   event = event_cb.getEvent()
      +   if event.getState() == SoMouseButtonEvent.DOWN:
      +     pos = event.getPosition()
      +     point = self.view.getPoint(pos[0],pos[1])
      +     self.stack.append(point)
      +     if len(self.stack) == 2:
      +       l = Part.Line(self.stack[0],self.stack[1])
      +       shape = l.toShape()
      +       Part.show(shape)
      +       self.view.removeEventCallbackPivy(SoMouseButtonEvent.getClassTypeId(),self.callback)
      + def GetResources(self): 
      +     return {'Pixmap' : 'path_to_an_icon/line_icon.png', 'MenuText': 'Line', 'ToolTip': 'Creates a line by clicking 2 points on the screen'} 
      +FreeCADGui.addCommand('line', line()) 
      +

      What we did here is transform our __init__() function into an Activated() function, because when FreeCAD commands are run, they automatically execute the Activated() function. We also added a GetResources() function, that informs FreeCAD where it can find an icon for the tool, and what will be the name and tooltip of our tool. Any jpg, png or svg image will work as an icon, it can be any size, but it is best to use a size that is close to the final aspect, like 16x16, 24x24 or 32x32. +Then, we add the line() class as an official FreeCAD command with the addCommand() method. +

      That's it, we now just need to restart FreeCAD and we'll have a nice new workbench with our brand new line tool! +

      +

      So you want more?

      +

      If you liked this exercise, why not try to improve this little tool? There are many things that can be done, like for example: +

      +
      • Add user feedback: until now we did a very bare tool, the user might be a bit lost when using it. So we could add some feedback, telling him what to do next. For example, you could issue messages to the FreeCAD console. Have a look in the FreeCAD.Console module
      • +
      • Add a possibility to type the 3D points coordinates manually. Look at the python input() function, for example
      • +
      • Add the possibility to add more than 2 points
      • +
      • Add events for other things: Now we just check for Mouse button events, what if we would also do something when the mouse is moved, like displaying current coordinates?
      • +
      • Give a name to the created object
      +

      Don't hesitate to write your questions or ideas on the forum! +

      + +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Linearpattern_parameters.png b/localwiki/Linearpattern_parameters.png new file mode 100644 index 0000000..d6365b7 Binary files /dev/null and b/localwiki/Linearpattern_parameters.png differ diff --git a/localwiki/Linearpattern_parameters_v017.png b/localwiki/Linearpattern_parameters_v017.png new file mode 100644 index 0000000..9696bbd Binary files /dev/null and b/localwiki/Linearpattern_parameters_v017.png differ diff --git a/localwiki/Linux.png b/localwiki/Linux.png new file mode 100644 index 0000000..2c5e0a5 Binary files /dev/null and b/localwiki/Linux.png differ diff --git a/localwiki/List-add.svg b/localwiki/List-add.svg new file mode 100644 index 0000000..cea01fc --- /dev/null +++ b/localwiki/List-add.svg @@ -0,0 +1,213 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [wmayer] + + + Arch_Add + 2011-10-10 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Arch/Resources/icons/Arch_Add.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + diff --git a/localwiki/List-remove.svg b/localwiki/List-remove.svg new file mode 100644 index 0000000..fe55655 --- /dev/null +++ b/localwiki/List-remove.svg @@ -0,0 +1,213 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [wmayer] + + + Arch_Remove + 2011-10-10 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Arch/Resources/icons/Arch_Remove.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + diff --git a/localwiki/List_of_Commands.html b/localwiki/List_of_Commands.html new file mode 100644 index 0000000..3f14301 --- /dev/null +++ b/localwiki/List_of_Commands.html @@ -0,0 +1,221 @@ +List of Commands

      List of Commands

      (Redirected from List of Commands)
      + +

      This category contains the help pages of each of FreeCAD Command. +

      + + +
      + +
      +

      Pages in category "Command Reference"

      +

      The following 200 pages are in this category, out of 956 total. +

      (previous page) (next page)

      A

      +
      (previous page) (next page) +
      +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Loading.png b/localwiki/Loading.png new file mode 100644 index 0000000..0365086 Binary files /dev/null and b/localwiki/Loading.png differ diff --git a/localwiki/LocalZAfter2.png b/localwiki/LocalZAfter2.png new file mode 100644 index 0000000..d19734c Binary files /dev/null and b/localwiki/LocalZAfter2.png differ diff --git a/localwiki/LocalZBefore2.png b/localwiki/LocalZBefore2.png new file mode 100644 index 0000000..75897a7 Binary files /dev/null and b/localwiki/LocalZBefore2.png differ diff --git a/localwiki/Localisation.html b/localwiki/Localisation.html new file mode 100644 index 0000000..c756c4d --- /dev/null +++ b/localwiki/Localisation.html @@ -0,0 +1,126 @@ +Localisation

      Localisation

      + +

      Localisation is in general the process of providing a Software with a multiple language user interface. In FreeCAD you can set the language of the user interface under Edit→Preferences→Application. FreeCAD uses Qt to enable multiple language support. On Unix/Linux systems, FreeCAD uses the current locale settings of your system by default. +

      + + +

      Helping to translate FreeCAD

      +

      One of the very important things you can do for FreeCAD if you are not a programmer, is to help to translate the program in your language. To do so is now easier than ever, with the use of the Crowdin collaborative on-line translation system. +

      +

      How to Translate

      +
      • Go to the FreeCAD translation project page on Crowdin;
      • +
      • Login by creating a new profile, or using a third-party account like your GMail address;
      • +
      • Click on the language you wish to work on;
      • +
      • Start translating by clicking on the Translate button next to one of the files. For example, FreeCAD.ts contains the text strings for the FreeCAD main GUI.
      • +
      • You can vote for existing translations, or you can create your own.
      +
      Note: If you are actively taking part in translating FreeCAD and want to be 
      +informed before next release is ready to be launched, 
      +so there is time to review your translation, please subscribe 
      +to this issue: http://www.freecadweb.org/tracker/view.php?id=137
      +
      +

      Preparing your FreeCAD/master modules for translation

      +

      These are the parts to the FreeCAD translation process: +

      +
      • extract text strings from source code into *.ts files
      • +
      • load *.ts files into FreeCAD Crowdin.
      • +
      • translation of strings within Crowdin
      • +
      • extract modified/new *.ts files from Crowdin
      • +
      • convert *.ts files into *.qm files and update each module's *.qrc file
      • +
      • update FreeCAD master
      +

      All of the above steps are performed by the "translation scripts" which are run by an administrator periodically. +

      Preparing your module for translation is quite easy. First, you need to ensure that you have a "translations" directory in myModule/Gui/Resources. Then open a terminal window (or Windows/OSX equivalent) in your "translations" directory and enter the following command: +

      +
      lupdate -ts myModule.ts 
      +

      This creates an empty translation file. Once this is done, you need to ensure that the translation scripts are updated as in this pull request. +

      Everything after this is automatic as far as a developer is concerned. The administrator will extract the text strings, the translators will translate them, then the administrator will extract the translations and update FreeCAD/master. +

      +

      Preparing your 3rd party module or macro for translation

      +

      3rd party modules or macros are translated in much the same fashion, except that you must do some of the work yourself. +This forum discussion describes the details . +

      +

      Older module translation techniques

      +

      Localization Older Methods describes the use of translation tools such as Qt Linguist, lupdate, lrelease, pylupdate4, etc in detail. Most of this is no longer required for FreeCAD/master modules, but may be helpful preparing and updating 3rd party modules. +

      +

      Translating the wiki

      +

      This wiki is hosting a lot of contents, the majority of which build up the manual. You can browse the documentation starting from the Main Page, or have a look at the User's manual Online Help Toc. +

      +

      Translation plugin

      +

      When the Wiki moved away from SourceForge, Yorik installed a Translation plugin which allows to ease translations between pages. For example, the page title can now be translated. Other advantages of the Translation plugin are that it keeps track of translations, notifies if the original page has been updated, and maintains translations in sync with the original English page. +

      The tool is documented in Extension:Translate, and is part of a Language Extension Bundle. +

      To quickly get started on preparing a page for translation and activating the plugin, please read the Page translation example. +

      To see an example of how the Translation tool works once the translation plugin is activated on a page, you can visit the Main Page. You will see a new language menu bar at the bottom. It is automatically generated. Click for instance on the German link, it will get you to Main Page/de. Right under the title, you can read "This page is a translated version of a page Main Page and the translation is xx% complete." (xx being the actual percentage of translation). Click on the "translated version" link to start translation, or to update or correct the existing translation. +

      You will notice that you cannot directly edit a page anymore once it's been marked as a translation. You have to go through the translation utility. +

      When adding new content, the English page should be created first, then translated into another language. If someone wants to change/add content in a page, he should do the English one first. +

      It is recommended to have basic knowledge of wiki style formatting and general guidelines of the FreeCAD wiki, because you will have to deal with some tags while translating. You can find this information on WikiPages. +

      The sidebar (navigation menu on the left) is also translatable. Please follow dedicated instructions on Localisation Sidebar page. +

      REMARK: The first time you switch a page to the new translation system, it looses all its old 'manual' translations. To recover the translation, you need to open an earlier version from the history, and copy/paste manually the paragraphs to the new translation system. +

      Remark: to be able to translate in the wiki, you must of course gain wiki edit permission. +


      +If you are unsure how to proceed, don't hesitate to ask for help in the forum. +

      +

      Old translation instructions

      + + + + +
      These instructions are for historical background only, while the pages are being passed to the new translation plugin. +
      +

      So the first step is to check if the manual translation has already been started for your language (look in the left sidebar, under "manual").
      +If not, head to the forum and say that you want to start a new translation, we'll create the basic setup for the language you want to work on.
      +You must then gain wiki edit permission.
      +If your language is already listed, see what pages are still missing a translation (they will be listed in red). The technique is simple: go into a red page, and copy/paste the contents of the corresponding English page, and start translating.
      +Do not forget to include all the tags and templates from the original English page. Some of those templates will have an equivalent in your language (for example, there is a French Docnav template called Docnav/fr). You should use a slash and your language code in almost all the links. Look at other already translated pages to see how they did it.
      +Add a slash and your language code in the categories, like [[Category:Developer Documentation/fr]]
      +And if you are unsure, head to the forums and ask people to check what you did and tell you if it's right or not.
      +Four templates are commonly used in manual pages. These 4 templates have localized versions (Template:Docnav/fr, Template:fr, etc...) +

      +
      • Template:GuiCommand : is the Gui Command information block in upper-right of command documentation.
      • +
      • Template:Docnav : it is the navigation bar at the bottom of the pages, showing previous and next pages.
      +

      Page Naming Convention
      +Please take note that, due to limitations in the Sourceforge implementation of the MediaWiki engine, we require that your pages all keep their original English counterpart's name, appending a slash and your language code. For example, the translated page for About FreeCAD should be About Freecad/es for Spanish, About FreeCAD/pl for polish, etc. The reason is simple: so that if translators go away, the wiki's administrators, who do not speak all languages, will know what these pages are for. This will facilitate maintenance and avoid lost pages.
      +If you want the Docnav template to show linked pages in your language, you can use redirect pages. They are basically shortcut links to the actual page. Here is an example with the French page for About FreeCAD.
      +

      +
      • The page About FreeCAD/fr is the page with content
      • +
      • The page À propos de FreeCAD contains this code:
      +
      #REDIRECT [[About FreeCAD/fr]]
      +
      +
      • In the About FreeCAD/fr page, the Docnav code will look like this:
      +
      {{docnav/fr|Bienvenue sur l'aide en ligne|Fonctionnalités}}
      +
      +

      The page "Bienvenue sur l'aide en ligne" redirects to Online Help Startpage/fr, and the page "Fonctionnalités" redirects to Feature list/fr. +

      +
      + +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Localisation_Sidebar.html b/localwiki/Localisation_Sidebar.html new file mode 100644 index 0000000..90a44f0 --- /dev/null +++ b/localwiki/Localisation_Sidebar.html @@ -0,0 +1,36 @@ +Localisation Sidebar

      Localisation Sidebar

      + +

      Localisation is in general the process of providing a Software with a multiple language user interface. +

      The Sidebar is an important navigation tool in the wiki world, as documented here. +

      +

      Translate the sidebar

      +

      The sidebar is now fully translatable with the Translation plugin usable for all the pages in the wiki. +

      This feature is a bit of an hack, so if you want some technical details on the way it has been implemented, you can refer to this post. +

      +

      Instructions

      +

      You can go to the special page : Special:Translate/wiki-sidebar to begin translation. +

      There is a bug with the Download page. You can't redirect the link to "Download/lang". Instead, the link will point to the actual translation of "Download" in your language. The best way to deal with it is to create this new page and do a redirection to the right page. More about redirection on Help:Editing. +

      +

      Be carefull

      +

      You will find most of the time 2 strings for each item in the menu. One represent the text who is displayed in the sidebar, and the other is the target of the link. +

      You can see the difference between the two by looking on the top of the 'translate box' where the name of the variable is displayed. +When the variable name ends with "-target", it mean that you are translating a target link. It's made to allow the allow the translator to redirect the items to the translated pages (by adding "/fr" after the name page for french translation for exemple). +

      DO NOT add the "/lang" if the translate page doesn't exists in you langage, it will broke the link. DO NOT write anything else than the name of the page or it will broke the link. +

      +
      Where to look
      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Localization_Older_Methods.html b/localwiki/Localization_Older_Methods.html new file mode 100644 index 0000000..dc68211 --- /dev/null +++ b/localwiki/Localization_Older_Methods.html @@ -0,0 +1,145 @@ +Localization Older Methods

      Localization Older Methods

      + +

      This is a collection of old localization techniques used by FreeCAD in the past. They show some of the internals of the processs, but the techniques on the Localisation page should be used from now on. +

      + + +

      Translating with Qt-Linguist (old way)

      +

      The following information doesn't need to be used anymore and will likely become obsolete. +It is being kept here so that programmers may familiarize themselves with how it works. +- +

      +
      • Open all of the language folders of FreeCAD shown below
      • +
      • Verify that a .ts file with your language code doesn't exist ("fr" for french, "de" for german, etc...)
      • +
      • If it exists, you can download that file, if you want to modify/review/better the translation (click the file, then download)
      • +
      • If it doesn't exist, download the .ts file without language code (or any other .ts available, it will work too)
      • +
      • Rename that file with your language code
      • +
      • Open it with the Qt-Linguist program
      • +
      • Start translating (Qt Linguist is very easy to use)
      • +
      • Once it's completely done, save your file
      • +
      • send the files to us so we can include them in the freecad source code so they benefit other users too.
      +

      Available translation files
      +

      + +

      Preparing your own modules/applications for translation

      +

      Prerequisites

      +

      To localise your application module your need to helpers that come with Qt. You can download them from the Trolltech-Website, but they are also contained in the LibPack: +

      +
      qmake
      +
      Generates project files
      +
      lupdate
      +
      Extracts or updates the original texts in your project by scanning the source code
      +
      Qt-Linguist
      +
      The Qt-Linguist is very easy to use and helps you translating with nice features like a phrase book for common sentences.
      +

      Project Setup

      +

      To start the localisation of your project go to the GUI-Part of you module and type on the command line: +

      +
      +qmake -project
      +
      +

      This scans your project directory for files containing text strings and creates a project file like the following example: +

      +
      + ######################################################################
      + # Automatically generated by qmake (1.06c) Do 2. Nov 14:44:21 2006
      + ######################################################################
      + 
      + TEMPLATE = app
      + DEPENDPATH += .\Icons
      + INCLUDEPATH += .
      + 
      + # Input
      + HEADERS += ViewProvider.h Workbench.h
      + SOURCES += AppMyModGui.cpp \
      +            Command.cpp \
      +            ViewProvider.cpp \
      +            Workbench.cpp
      + TRANSLATIONS += MyMod_de.ts
      +
      +

      You can manually add files here. The section TRANSLATIONS contains a list of files with the translation for each language. In the above example MyMod_de.ts is the german translation. +

      Now you need to run lupdate to extract all string literals in your GUI. Running lupdate after changes in the source code is allways safe since it never deletes strings from your translations files. It only adds new strings. +

      Now you need to add the .ts-files to your VisualStudio project. Specifiy the following custom build method for them: +

      +
      python ..\..\..\Tools\qembed.py "$(InputDir)\$(InputName).ts"
      +                 "$(InputDir)\$(InputName).h" "$(InputName)" 
      +

      Note: Enter this in one command line, the line break is only for layout purpose. +

      By compiling the .ts-file of the above example, a header file MyMod_de.h is created. The best place to include this is in App<Modul>Gui.cpp. In our example this would be AppMyModGui.cpp. There you add the line +

      +
      new Gui::LanguageProducer("Deutsch", <Modul>_de_h_data, <Modul>_de_h_len); 
      +

      to publish your translation in the application. +

      +

      Setting up python files for translation

      +

      To ease localization for the py files you can use the tool "pylupdate4" which accepts one or more py files. With the -ts option you can prepare/update one or more .ts files. For instance to prepare a .ts file for French simply enter into the command line: +

      +
      +pylupdate4 *.py -ts YourModule_fr.ts 
      +
      +

      the pylupdate tool will scan your .py files for translate() or tr() functions and create a YourModule_fr.ts file. That file can the be translated with QLinguist and a YourModule_fr.qm file produced from QLinguist or with the command +

      +
      +lrelease YourModule_fr.ts
      +
      +

      Beware that the pylupdate4 tool is not very good at recognizing translate() functions, they need to be formatted very specifically ( see the Draft module files for examples). Inside your file, you can then setup a translator like this (after loading your QApplication but BEFORE creating any qt widget): +

      +
      +translator = QtCore.QTranslator()
      +translator.load("YourModule_"+languages[ln])
      +QtGui.QApplication.installTranslator(translator)
      +
      +

      Optionally, you can also create the file XML Draft.qrc with this content: +

      +
        
      +<RCC>
      +<qresource prefix="/translations" > 
      +<file>Draft_fr.qm</file> 
      +</qresource> 
      +</RCC> 
      +
      +

      and running pyrcc4 Draft.qrc -o qrc_Draft.py creates a big Python containing all resources. BTW this approach also works to put icon files in one resource file +

      + +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/LockConstraint5.png b/localwiki/LockConstraint5.png new file mode 100644 index 0000000..6303c42 Binary files /dev/null and b/localwiki/LockConstraint5.png differ diff --git a/localwiki/Lou_papet.png b/localwiki/Lou_papet.png new file mode 100644 index 0000000..4e6b763 Binary files /dev/null and b/localwiki/Lou_papet.png differ diff --git a/localwiki/LuxRenderExecPath.png b/localwiki/LuxRenderExecPath.png new file mode 100644 index 0000000..023e984 Binary files /dev/null and b/localwiki/LuxRenderExecPath.png differ diff --git a/localwiki/LuxRenderOutput.png b/localwiki/LuxRenderOutput.png new file mode 100644 index 0000000..40b4cc0 Binary files /dev/null and b/localwiki/LuxRenderOutput.png differ diff --git a/localwiki/MEPlan.png b/localwiki/MEPlan.png new file mode 100644 index 0000000..9e7b5b4 Binary files /dev/null and b/localwiki/MEPlan.png differ diff --git a/localwiki/MEPlanD.png b/localwiki/MEPlanD.png new file mode 100644 index 0000000..26813b4 Binary files /dev/null and b/localwiki/MEPlanD.png differ diff --git a/localwiki/MEPlanF.png b/localwiki/MEPlanF.png new file mode 100644 index 0000000..4e2df66 Binary files /dev/null and b/localwiki/MEPlanF.png differ diff --git a/localwiki/MEPlanFC.png b/localwiki/MEPlanFC.png new file mode 100644 index 0000000..73f7725 Binary files /dev/null and b/localwiki/MEPlanFC.png differ diff --git a/localwiki/MEPlanI.png b/localwiki/MEPlanI.png new file mode 100644 index 0000000..16cc506 Binary files /dev/null and b/localwiki/MEPlanI.png differ diff --git a/localwiki/MEPlanPY.png b/localwiki/MEPlanPY.png new file mode 100644 index 0000000..c1c1497 Binary files /dev/null and b/localwiki/MEPlanPY.png differ diff --git a/localwiki/MEPlanT.png b/localwiki/MEPlanT.png new file mode 100644 index 0000000..0bf77e1 Binary files /dev/null and b/localwiki/MEPlanT.png differ diff --git a/localwiki/MEpipe01.png b/localwiki/MEpipe01.png new file mode 100644 index 0000000..5df1cc4 Binary files /dev/null and b/localwiki/MEpipe01.png differ diff --git a/localwiki/MEpipe02.png b/localwiki/MEpipe02.png new file mode 100644 index 0000000..e0c1fda Binary files /dev/null and b/localwiki/MEpipe02.png differ diff --git a/localwiki/MIBA.html b/localwiki/MIBA.html new file mode 100644 index 0000000..8ad430c --- /dev/null +++ b/localwiki/MIBA.html @@ -0,0 +1,43 @@ +MIBA

      MIBA

      + +

      Introduction

      +

      Miba is a way to embed information about the 3D space into a 2D image. This makes it often possible to use the 2D picture instead of a 3D viewer. By the Miba information you're able to calculate the position of a 3D location in the 2D image. That allows you to decorate the image later with arbitrary 3D information. You can take the picture in an early state (design) and use it later (e.g. Production). You do not need to know the kind of 3D data or the positions when you take the picture. So the picture is completely separated from the 3D data. +

      A detailed specification you can find here: http://miba.juergen-riegel.net/ +

      +

      Miba in FreeCAD

      +

      If you choose a file format which has an comment ability ( JPG and PNG) you can choose to write a comment or insert the MIBA information in the comment fileds (default): +

      Save picture.png +

      +

      Making Miba pictures by script

      +
       import Part,PartGui
      + # loading test part
      + Part.open("C:/Documents and Settings/jriegel/My Documents/Projects/FreeCAD/data/Blade.stp")
      + OutDir = 'c:/temp/'
      + Gui.ActiveDocument.ActiveView.setAnimationEnabled(False)
      + 
      + # creating images with different Views, Cameras and sizes
      + for p in ["PerspectiveCamera","OrthographicCamera"]:
      +   Gui.SendMsgToActiveView(p)
      +   for f in ["ViewAxo","ViewFront","ViewTop"]:
      +     Gui.SendMsgToActiveView(f)
      +     for x,y in [[500,500],[1000,3000],[3000,1000],[3000,3000],[8000,8000]]:
      +       Gui.ActiveDocument.ActiveView.saveImage(OutDir + "Blade_" + p +"_" + f + "_" + `x` + "_" + `y` + ".jpg",x,y,"White")
      +       Gui.ActiveDocument.ActiveView.saveImage(OutDir + "Blade_" + p +"_" + f + "_" + `x` + "_" + `y` + ".png",x,y,"Transparent")
      + 
      + # close active document
      + App.closeDocument(App.ActiveDocument.Name)
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Mac.png b/localwiki/Mac.png new file mode 100644 index 0000000..b2fe578 Binary files /dev/null and b/localwiki/Mac.png differ diff --git a/localwiki/Mac_installer_1.png b/localwiki/Mac_installer_1.png new file mode 100644 index 0000000..5ae97fd Binary files /dev/null and b/localwiki/Mac_installer_1.png differ diff --git a/localwiki/Macro-execute.svg b/localwiki/Macro-execute.svg new file mode 100644 index 0000000..494dab5 --- /dev/null +++ b/localwiki/Macro-execute.svg @@ -0,0 +1,387 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + Lapo Calamandrei + + + + + + play + media + music + video + player + + + + + Jakub Steiner + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Macro-record.svg b/localwiki/Macro-record.svg new file mode 100644 index 0000000..7d508fc --- /dev/null +++ b/localwiki/Macro-record.svg @@ -0,0 +1,588 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + + + + + + + diff --git a/localwiki/Macro-stop.svg b/localwiki/Macro-stop.svg new file mode 100644 index 0000000..763ff1f --- /dev/null +++ b/localwiki/Macro-stop.svg @@ -0,0 +1,650 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + Lapo Calamandrei + + + + + + media + stop + playback + video + music + + + + + Jakub Steiner + + + + + + + + + + + + + + + + + + diff --git a/localwiki/MacroEditor.svg b/localwiki/MacroEditor.svg new file mode 100644 index 0000000..fbae575 --- /dev/null +++ b/localwiki/MacroEditor.svg @@ -0,0 +1,116 @@ + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + + + + + + + + + diff --git a/localwiki/MacroVariableWatcherGui1.jpg b/localwiki/MacroVariableWatcherGui1.jpg new file mode 100644 index 0000000..a3c3bc8 Binary files /dev/null and b/localwiki/MacroVariableWatcherGui1.jpg differ diff --git a/localwiki/Macro_3D_Parametric_Curve.html b/localwiki/Macro_3D_Parametric_Curve.html new file mode 100644 index 0000000..c153581 --- /dev/null +++ b/localwiki/Macro_3D_Parametric_Curve.html @@ -0,0 +1,255 @@ +Macro 3D Parametric Curve

      Macro 3D Parametric Curve

      + +
      + + + + + + + + + + + + + + + + + + + + + + + + + + +
      +

      Text-x-python.png Macro 3D Parametric Curve

      +
      Description +
      Draw a function described by parametric equations x(t), y(t) and z(t) With the possibility to choose between b-spline and polyline for the type of line between points. +
      Author +
      Lucio Gomez (psicofil) +
      Links +
      Macros recipes
      How to install macros
      How to customize toolbars +
      Version +
      2.0 +
      Date last modification +
      2015-03-06 +
      +

      + +
      +


      +

      +

      Description

      +

      This macro creates a curve described by parametric equations x(t), y(t) and z(t). With the possibility to choose between b-spline and polyline for the type of line between points. +

      Example Epicycloid curve‎ +

      +

      Original Script

      +

      You can find the updated code (13/05/2015) on the following Github repository: +Get the code here! +

      +

      Modified Script

      +

      Example Epicycloid curve‎ +

      Macro 3D Parametric Curve.FCMacro +

      +
      # -*- coding: utf-8 -*-
      +# Create a 3D parametric Curve.
      +# Author: Gomez Lucio
      +# Modified by Laurent Despeyroux on 9th feb 2015
      +#   - 3 helping variables added a, b and c
      +#   - enlarged GUI
      +#   - more flexible GUI
      +#   - basic error mangement
      + 
      +import FreeCAD
      +from PySide import QtGui,QtCore
      +import Part
      +import Draft
      +from math import *
      + 
      +class ParamCurv(QtGui.QWidget):
      +    def __init__(self):
      +        super(ParamCurv, self).__init__()
      +        self.initUI()
      +    def initUI(self):
      +        self.t0 = QtGui.QLabel("Equation :",self)
      +        self.ta = QtGui.QLabel("    a(t) ",self)
      +        self.la = QtGui.QLineEdit(self)
      +        self.la.setText("37")
      +        self.tb = QtGui.QLabel("    b(a,t) ",self)
      +        self.lb = QtGui.QLineEdit(self)
      +        self.lb.setText("1")
      +        self.tc = QtGui.QLabel("    c(a,b,t) ",self)
      +        self.lc = QtGui.QLineEdit(self)
      +        self.lc.setText("(a+cos(a*t)*2)*b")
      +        self.t1 = QtGui.QLabel("    X(a,b,c,t) ",self)
      +        self.l1 = QtGui.QLineEdit(self)
      +        self.l1.setText("cos(t)*c")
      +        self.t2 = QtGui.QLabel("    Y(a,b,c,t) ",self)
      +        self.l2 = QtGui.QLineEdit(self)
      +        self.l2.setText("sin(t)*c")
      +        self.t3 = QtGui.QLabel("    Z(a,b,c,t) ",self)
      +        self.l3 = QtGui.QLineEdit(self)
      +        self.l3.setText("0")
      +        self.t31 = QtGui.QLabel("Parameters :",self)
      +        self.t4 = QtGui.QLabel("    Min t ",self)
      +        self.l4 = QtGui.QLineEdit(self)
      +        self.l4.setText("0")
      +        self.t5 = QtGui.QLabel("    Max t ",self)
      +        self.l5 = QtGui.QLineEdit(self)
      +        self.l5.setText("6.283185")
      +        self.t6 = QtGui.QLabel("    Interval ",self)
      +        self.l6 = QtGui.QLineEdit(self)
      +        self.l6.setText("0.01")
      +        self.t7 = QtGui.QLabel("Type of Line :",self)
      +        self.op1 = QtGui.QCheckBox("    Polyline",self)
      +        self.poly = False
      +        self.op1.stateChanged.connect(self.polyState)
      +        self.op1.setCheckState(QtCore.Qt.Checked)
      +        self.op2 = QtGui.QCheckBox("    Bspline",self)
      +        self.bsline = False
      +        self.op2.stateChanged.connect(self.bsplineState)
      +        self.t8 = QtGui.QLabel("    Closed Curve",self)
      +        self.op3 = QtGui.QCheckBox("",self)
      +        self.cclose = False
      +        self.op3.stateChanged.connect(self.ccloseState)
      +        self.createbutt = QtGui.QPushButton("Create Curve",self)
      +        self.exitbutt = QtGui.QPushButton("Close",self)
      +        layout = QtGui.QGridLayout()
      +        self.resize(420, 380)
      +        self.setWindowTitle("Parametric Curve ")
      +        i = 0
      +        layout.addWidget(self.t0, i, 0)
      +        i = i+1
      +        layout.addWidget(self.ta, i, 0)
      +        layout.addWidget(self.la, i, 1)
      +        i = i+1
      +        layout.addWidget(self.tb, i, 0)
      +        layout.addWidget(self.lb, i, 1)
      +        i = i+1
      +        layout.addWidget(self.tc, i, 0)
      +        layout.addWidget(self.lc, i, 1)
      +        i = i+1
      +        layout.addWidget(self.t1, i, 0)
      +        layout.addWidget(self.l1, i, 1)
      +        i = i+1
      +        layout.addWidget(self.t2, i, 0)
      +        layout.addWidget(self.l2, i, 1)
      +        i = i+1
      +        layout.addWidget(self.t3, i, 0)
      +        layout.addWidget(self.l3, i, 1)
      +        i = i+1
      +        layout.addWidget(self.t31, i, 0)
      +        i = i+1
      +        layout.addWidget(self.t4, i, 0)
      +        layout.addWidget(self.l4, i, 1)
      +        i = i+1
      +        layout.addWidget(self.t5, i, 0)
      +        layout.addWidget(self.l5, i, 1)
      +        i = i+1
      +        layout.addWidget(self.t6, i, 0)
      +        layout.addWidget(self.l6, i, 1)
      +        i = i+1
      +        layout.addWidget(self.t8, i, 0)
      +        layout.addWidget(self.op3, i, 1)
      +        i = i+1
      +        layout.addWidget(self.t7, i, 0)
      +        i = i+1
      +        layout.addWidget(self.op1, i, 0)
      +        layout.addWidget(self.op2, i, 1)
      +        i = i+1
      +        layout.addWidget(self.createbutt, i, 0)
      +        layout.addWidget(self.exitbutt, i, 1)
      +        self.setLayout(layout)
      +        self.show()
      +        QtCore.QObject.connect(self.createbutt, QtCore.SIGNAL("pressed()"),self.draw)
      +        QtCore.QObject.connect(self.exitbutt, QtCore.SIGNAL("pressed()"),self.close)
      +    def ccloseState(self, state):
      +        if state == QtCore.Qt.Checked:
      +            self.cclose = True
      +        else:
      +            self.cclose = False
      +    def bsplineState(self, state):
      +        if state == QtCore.Qt.Checked:
      +            self.bsline = True
      +            self.op1.setCheckState(QtCore.Qt.Unchecked)
      +        else:
      +            self.bsline = False
      +    def polyState(self, state):
      +        if state == QtCore.Qt.Checked:
      +            self.poly = True
      +            self.op2.setCheckState(QtCore.Qt.Unchecked)
      +        else:
      +            self.poly = False
      +    def draw(self):
      +        msgBox = QtGui.QMessageBox()
      +        fa = str(self.la.text())
      +        fb = str(self.lb.text())
      +        fc = str(self.lc.text())
      +        fx = str(self.l1.text())
      +        fy = str(self.l2.text())
      +        fz = str(self.l3.text())
      +        t = float(str(self.l4.text()))
      +        tf = float(self.l5.text())
      +        intv = float(str(self.l6.text()))
      +        d=(tf-t)/intv
      +        matriz = []
      +        for i in range(int(d)):
      +            try:
      +              value="a"
      +              a=eval(fa)
      +              value="b"
      +              b=eval(fb)
      +              value="c"
      +              c=eval(fc)
      +              value="X"
      +              fxx=eval(fx)
      +              value="Y"
      +              fyy=eval(fy)
      +              value="Z"
      +              fzz=eval(fz)
      +            except ZeroDivisionError:
      +              msgBox.setText("Error division by zero in calculus of "+value+"() for t="+str(t)+" !")
      +              msgBox.exec_()
      +            except:
      +              msgBox.setText("Error in the formula of "+value+"() !")
      +              msgBox.exec_()
      +            matriz.append(FreeCAD.Vector(fxx,fyy,fzz))
      +            t+=intv
      +        curva = Part.makePolygon(matriz)
      +        if self.bsline == True:
      +            Draft.makeBSpline(curva,closed=self.cclose,face=False)
      +        if self.poly == True:
      +            Draft.makeWire(curva,closed=self.cclose,face=False)
      +    def close(self):
      +        self.hide()
      + 
      +ParamCurv() 
      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Macro_3d_Printer_Slicer.html b/localwiki/Macro_3d_Printer_Slicer.html new file mode 100644 index 0000000..8138a4b --- /dev/null +++ b/localwiki/Macro_3d_Printer_Slicer.html @@ -0,0 +1,134 @@ +Macro 3d Printer Slicer

      Macro 3d Printer Slicer

      + +
      + + + + + + + + + + + + + + + + + + + + + + + + + + +
      +

      Text-x-python.png Macro_3d_Printer_Slicer

      +
      Description +
      Export to slicing software for 3D printers. Exports stl file in the same directory as original design file, then opens it in slicing software. +
      Author +
      cae2100 +
      Links +
      Macros recipes
      How to install macros
      How to customize toolbars +
      Version +
      1.0 +
      Date last modification +
      2013-10-10 +
      +

      + +
      +


      +

      This code, when run, will export the currently open design to STL file, and open it in the slicing software that you use. This example is for KISSlicer, but can be modified to use Slic3r, Cura, or any other 3d printer software. It can also be modified slightly to open up CAM software for CNC machines. +

      It is best used by creating a link to the macro on the toolbar, and when your ready to slice the object, just click it and your object, as it appears on the screen in FreeCAD will appear on your slicing software's interface, ready to slice. It will also create an STL file with the same filename as the design file in the same directory as the design file as a backup. +


      +Macro 3d Printer Slicer 00.png +

      +
      +


      +

      +

      Script

      +

      The SLICER variable can be changed to any slicing software of your choosing, just make sure to set it before you try running it or it'll flag an error with the script. +

      Macro_3d_Printer_Slicer.py +

      +
      import FreeCAD
      +import Mesh
      +import sys
      +import math
      +import os
      +import subprocess
      +# some fuctions
      +def getPlacement(quat,vect,obj):
      +  if quat[3] > -1  and quat[3] < 1:
      +    delta = math.acos(quat[3])*2.0
      +    scale = math.sin(delta/2)
      +    rx = quat[0]/scale
      +    ry = quat[1]/scale
      +    rz = quat[2]/scale
      +  else:
      +    delta = 0
      +    rx = 0
      +    ry = 0
      +    rz = 1
      +  info0 = "translation "+str(vect.x)+" "+str(vect.y)+" "+str(vect.z)
      +  info1 = "rotation "+str(rx)+" "+str(ry)+" "+str(rz)+" "+str(delta)
      +  return info0+" "+info1
      +# some definitions
      +placement = App.Placement(App.Vector(0,0,0),App.Rotation(0,0,0,1))
      +# user need to set this directory where slicing software is located
      +OutDir = FreeCAD.ActiveDocument.FileName.replace(FreeCAD.ActiveDocument.Label + ".fcstd", "")
      +visible_objs = []
      +SLICER = "/kisslicer location/"                          # Put your Slicer program location here
      +os.chdir(SLICER)
      +# Get Objects in document
      +doc = App.ActiveDocument
      +objs = doc.Objects
      +# hide all
      +for obj in objs:
      +   if obj.ViewObject.isVisible():
      +      visible_objs.append(obj)
      +for obj in visible_objs:
      +  # get volume
      +  volume = obj.Shape.Volume
      +  # get Rotation and translation of volume
      +  quat = obj.Placement.Rotation.Q
      +  vect = obj.Placement.Base
      +  pinfo = getPlacement(quat,vect,obj)
      +  # reset placement, export it and set at original placement
      +  oldPlacement = obj.Placement
      +  obj.Placement = placement
      +  obj.Placement = oldPlacement   
      +stlFile = OutDir+str(doc.Label)+".stl"
      +Mesh.export(visible_objs,stlFile)
      +subprocess.Popen([SLICER + "KISSlicer", stlFile]) 
      +

      Credits

      +

      Thanks to Wmayer for his help in writing this script.
      +Original forum topic: http://forum.freecadweb.org/viewtopic.php?f=10&t=4686 +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Macro_Airfoil_Import_%26_Scale.html b/localwiki/Macro_Airfoil_Import_%26_Scale.html new file mode 100644 index 0000000..bdd76a7 --- /dev/null +++ b/localwiki/Macro_Airfoil_Import_%26_Scale.html @@ -0,0 +1,420 @@ +Macro Airfoil Import %26 Scale

      Macro Airfoil Import %26 Scale

      + +
      + + + + + + + + + + + + + + + + + + + + + + + + + + +
      +

      Text-x-python.png Macro Airfoil Import & Scale

      +
      Description +
      Trace the perimeter of a Airfoil from a .dat file. +
      Author +
      quick61 +
      Links +
      Macros recipes
      How to install macros
      How to customize toolbars +
      Version +
      1.5 , 2.0 and 2.1 +
      Date last modification +
      2014-10-02 +
      +

      + +
      +


      +

      This Macro, when run, will first provide the user with a file browser to locate and select a .dat airfoil text file. Once selected, a chord length is entered and upon pressing the OK button, a properly scaled airfoil is produced. There are two versions provided here. Version 1.5 should work on FreeCAD versions, 0.13 stable as well as all 0.14 versions. Version 2 should only be used with FreeCAD versions equal to or greater than 0.14 3077 and will work best with versions built with OCE/OCC versions 6.7 or greater. +

      See also Common Airfoil Data Import +


      +Macro Airfoil Import & Scale 00.png +

      +
      +


      +

      +

      How To Use - Version 1.5

      +

      Select The File

      +

      Running the Macro will first present the user with a file browser that will allow you to select the desired airfoil .dat file. Browse to where you have saved the airfoil file, select it and press Open. +

      +
      File browser window for importing .dat airfoil files
      +

      Enter Chord Length

      +

      Once the airfoil file has been selected, a new dialog will appear asking for a chord length. Any length may be entered, in millimeters. Once your desired length is entered, the Macro will produce a Draft Wire (DWire) following the points described in the previously selected .dat airfoil file at the scale you entered for the chord length. +

      +
      Chord length dialog for import and scale macro v1.5
      +

      The Airfoil, properly scaled, should now be ready for use in your project. +

      +

      How To Use - Version 2

      +

      File selection is the same as version 1.5. With version 2 you now have the choice to either have the resulting airfoil made with a Draft Wire (DWire) or a Basic Spline (BSpline). As with version 1.5, you enter the desired chord length. Additionally you can now select which type of foil you want. Simply click on the BSpline radio button or leave as is for for the default DWire. +

      +
      Version 2 Airfoil Import and scale dialog with choice of DWire or BSpline
      +

      Editing The Default Selection

      +

      If you primarily wish to have your imported and scaled airfoils made with BSplines rather than DWires, the Marco may be edited to default to the Bspline. This is done by editing the line - +

      +
      ##exampleCode##
      +self.radio1.setChecked(True) 
      +


      +- and changing it to -
      +

      +
      ##exampleCode##
      +self.radio2.setChecked(True) 

      +

      A note on this is included within the text of the macro. +

      +

      The Macros

      +

      Version 1.5

      +
      # # # #
      +#
      +# AIRFOIL IMPORT & SCALE v1.5
      +# 
      +# Imports and scales an Airfoil in the form of a Draft Wire (DWire) 
      +#
      +# # # #
      +
      +
      +from PySide import QtCore, QtGui
      +from PySide.QtGui import QLineEdit
      +import FreeCAD, FreeCADGui, Draft
      +import importAirfoilDAT
      +
      +# Select .dat airfoil data file to be imported
      +
      +filename = QtGui.QFileDialog.getOpenFileName(QtGui.qApp.activeWindow(),'Open An Airfoil File','*.dat')
      +
      +class p():
      +
      +    def proceed(self):
      +            try:
      +                
      +                # This produces a scaled Airfoil with a DWire
      +
      +                scalefactor=float(self.s1.text())
      +                f1=str(filename)
      +                importAirfoilDAT.insert(f1,"Unnamed")
      +                Draft.scale(App.ActiveDocument.ActiveObject,delta=App.Vector(scalefactor,scalefactor,scalefactor),center=App.Vector(0,0,0),legacy=True)
      +            
      +            except:
      +                FreeCAD.Console.PrintError("Error, not a valid .dat file\n")
      +
      +            self.close()
      +
      +    def close(self):
      +        self.dialog.hide()
      +
      +    def __init__(self):
      +        self.dialog = None
      +        self.s1 = None
      +
      +        # Make dialog box and get the scale size
      +
      +        self.dialog = QtGui.QDialog()
      +        self.dialog.resize(350,100)
      +        self.dialog.setWindowTitle("Airfoil Import & Scale")
      +        la = QtGui.QVBoxLayout(self.dialog)
      +        t1 = QtGui.QLabel("Chord Length")
      +        la.addWidget(t1)
      +        self.s1 = QtGui.QLineEdit()
      +        la.addWidget(self.s1)
      +
      +        # Add OK / Cancel buttons
      +
      +#ori        okbox = QtGui.QDialogButtonBox(self.dialog)
      +#ori        okbox.setOrientation(QtCore.Qt.Horizontal)
      +#ori        okbox.setStandardButtons(QtGui.QDialogButtonBox.Cancel -PIPE- QtGui.QDialogButtonBox.Ok)
      +#        modify original code for install with addon-install cause -PIPE- 05-12-2016 FC 0.16
      +
      +        okbox = QtGui.QDialogButtonBox(self.dialog)
      +        okbox.setOrientation(QtCore.Qt.Horizontal)
      +        okbox.setStandardButtons(QtGui.QDialogButtonBox.Ok)
      +
      +        cancelbox = QtGui.QDialogButtonBox(self.dialog)
      +        cancelbox.setOrientation(QtCore.Qt.Horizontal)
      +        cancelbox.setStandardButtons(QtGui.QDialogButtonBox.Cancel)
      +        cancelbox.move(0,62)
      +
      +        la.addWidget(okbox)
      +        QtCore.QObject.connect(okbox, QtCore.SIGNAL("accepted()"), self.proceed)
      +        QtCore.QObject.connect(cancelbox, QtCore.SIGNAL("rejected()"), self.close)
      +        QtCore.QMetaObject.connectSlotsByName(self.dialog)
      +        self.dialog.show()
      +        self.dialog.exec_()
      +
      +p() 
      +

      Version 2

      +
      Warning - Using this Macro with versions of FreeCAD lesser than 0.14, revision 3077 will not produce the expected results when using the BSpline option and can result in FreeCAD crashing and loss of unsaved data!
      +
      +# # # #
      +#
      +# AIRFOIL IMPORT & SCALE v2.
      +# 
      +# Imports and scales an Airfoil in the form of a Draft Wire (DWire) or Basic Spline (BSpline)
      +#
      +# For FreeCAD Versions = or > 0.14 Revision 3077
      +#
      +# Works best with OCC/OCE = or > 6.7
      +#
      +# # # #
      +
      +
      +from PyQt4 import QtCore, QtGui
      +from PyQt4.QtGui import QLineEdit, QRadioButton
      +import FreeCAD, FreeCADGui, Draft
      +import importAirfoilDAT
      +
      +# Select .dat airfoil data file to be imported
      +
      +filename = QtGui.QFileDialog.getOpenFileName(QtGui.qApp.activeWindow(),'Open An Airfoil File','*.dat')
      +
      +class p():
      +
      +    def proceed(self):
      +        if self.radio1.isChecked():
      +            try:
      +                
      +                # This produces a scaled Airfoil with a DWire
      +
      +                scalefactor=float(self.s1.text())
      +                f1=str(filename)
      +                importAirfoilDAT.insert(f1,"Unnamed")
      +                Draft.scale(App.ActiveDocument.ActiveObject,delta=App.Vector(scalefactor,scalefactor,scalefactor),center=App.Vector(0,0,0),legacy=True)
      +            
      +            except:
      +                FreeCAD.Console.PrintError("Error, not a valid .dat file\n")
      +
      +            self.close()
      +
      +        if self.radio2.isChecked():
      +            try:
      +
      +                # This produces a scaled Airfoil with a BSpline
      +
      +                scalefactor=float(self.s1.text())
      +                f1=str(filename)
      +                importAirfoilDAT.insert(f1,"Unnamed")
      +                points = FreeCAD.ActiveDocument.ActiveObject.Points
      +                Draft.makeBSpline(points, closed=True)
      +                Draft.scale(App.ActiveDocument.ActiveObject,delta=App.Vector(scalefactor,scalefactor,scalefactor),center=App.Vector(0,0,0),legacy=True)
      +                App.getDocument("Unnamed").removeObject("DWire")
      +
      +            except:
      +                FreeCAD.Console.PrintError("Error, not a valid .dat file\n")
      +
      +            self.close()
      +
      +    def close(self):
      +        self.dialog.hide()
      +
      +
      +    def __init__(self):
      +        self.dialog = None
      +        self.s1 = None
      +
      +
      +        # Make dialog box and get the scale size
      +
      +        self.dialog = QtGui.QDialog()
      +        self.dialog.resize(350,100)
      +        self.dialog.setWindowTitle("Airfoil Import & Scale")
      +        la = QtGui.QVBoxLayout(self.dialog)
      +        t1 = QtGui.QLabel("Chord Length")
      +        la.addWidget(t1)
      +        self.s1 = QtGui.QLineEdit()
      +        la.addWidget(self.s1)
      +
      +        # Add radio buttons to select between DWire and BSpline
      +
      +        self.radio1 = QRadioButton("Make DWire")
      +        self.radio2 = QRadioButton("Make BSpline")
      +
      +            # set default to DWire & make radio buttons - Change self.radio1.setChecked(True) to
      +            # self.radio2.setChecked(True) to set BSpline as default
      +
      +        self.radio1.setChecked(True)
      +        la.addWidget(self.radio1)
      +        la.addWidget(self.radio2)
      +
      +        # Add OK / Cancel buttons
      +
      +        okbox = QtGui.QDialogButtonBox(self.dialog)
      +        okbox.setOrientation(QtCore.Qt.Horizontal)
      +        okbox.setStandardButtons(QtGui.QDialogButtonBox.Cancel|QtGui.QDialogButtonBox.Ok)
      +        la.addWidget(okbox)
      +        QtCore.QObject.connect(okbox, QtCore.SIGNAL("accepted()"), self.proceed)
      +        QtCore.QObject.connect(okbox, QtCore.SIGNAL("rejected()"), self.close)
      +        QtCore.QMetaObject.connectSlotsByName(self.dialog)
      +        self.dialog.show()
      +        self.dialog.exec_()
      +
      +p()
      +
      +

      Version 2.1

      +

      Updated by mangtronix to use PySide instead of PyQt (used in older versions of FreeCAD) +

      +
      +# # # #
      +#
      +# AIRFOIL IMPORT & SCALE v2.1
      +# 
      +# Imports and scales an Airfoil in the form of a Draft Wire (DWire) or Basic Spline (BSpline)
      +#
      +# For FreeCAD Versions = or > 0.14 Revision 3703
      +#
      +# Works best with OCC/OCE = or > 6.7
      +#
      +# # # #
      + 
      + 
      +from PySide import QtCore, QtGui
      +from PySide.QtGui import QLineEdit, QRadioButton
      +import FreeCAD, FreeCADGui, Draft
      +import importAirfoilDAT
      + 
      +# Select .dat airfoil data file to be imported
      + 
      +# PySide returns a tuple (filename, filter) instead of just a string like in PyQt
      +filename, filefilter = QtGui.QFileDialog.getOpenFileName(QtGui.qApp.activeWindow(),'Open An Airfoil File','*.dat')
      +
      +class p():
      + 
      +    def proceed(self):
      +        global filename
      +        if self.radio1.isChecked():
      +            #if True:
      +            try:
      + 
      +                # This produces a scaled Airfoil with a DWire
      + 
      +                scalefactor=float(self.s1.text())
      +                f1=str(filename)
      +                importAirfoilDAT.insert(f1,"Unnamed")
      +                Draft.scale(App.ActiveDocument.ActiveObject,delta=App.Vector(scalefactor,scalefactor,scalefactor),center=App.Vector(0,0,0),legacy=True)
      + 
      +            except Exception, e:
      +                FreeCAD.Console.PrintError("Error, not a valid .dat file\n")
      + 
      +            self.close()
      + 
      +        if self.radio2.isChecked():
      +            try:
      + 
      +                # This produces a scaled Airfoil with a BSpline
      + 
      +                scalefactor=float(self.s1.text())
      +                f1=str(filename)
      +                importAirfoilDAT.insert(f1,"Unnamed")
      +                points = FreeCAD.ActiveDocument.ActiveObject.Points
      +                Draft.makeBSpline(points, closed=True)
      +                Draft.scale(App.ActiveDocument.ActiveObject,delta=App.Vector(scalefactor,scalefactor,scalefactor),center=App.Vector(0,0,0),legacy=True)
      +                App.getDocument("Unnamed").removeObject("DWire")
      + 
      +            except:
      +                FreeCAD.Console.PrintError("Error, not a valid .dat file\n")
      + 
      +            self.close()
      + 
      +    def close(self):
      +        self.dialog.hide()
      + 
      + 
      +    def __init__(self):
      +        self.dialog = None
      +        self.s1 = None
      + 
      + 
      +        # Make dialog box and get the scale size
      + 
      +        self.dialog = QtGui.QDialog()
      +        self.dialog.resize(350,100)
      +        self.dialog.setWindowTitle("Airfoil Import & Scale")
      +        la = QtGui.QVBoxLayout(self.dialog)
      +        t1 = QtGui.QLabel("Chord Length")
      +        la.addWidget(t1)
      +        self.s1 = QtGui.QLineEdit()
      +        la.addWidget(self.s1)
      + 
      +        # Add radio buttons to select between DWire and BSpline
      + 
      +        self.radio1 = QRadioButton("Make DWire")
      +        self.radio2 = QRadioButton("Make BSpline")
      + 
      +            # set default to DWire & make radio buttons - Change self.radio1.setChecked(True) to
      +            # self.radio2.setChecked(True) to set BSpline as default
      + 
      +        self.radio1.setChecked(True)
      +        la.addWidget(self.radio1)
      +        la.addWidget(self.radio2)
      + 
      +        # Add OK / Cancel buttons
      + 
      +        okbox = QtGui.QDialogButtonBox(self.dialog)
      +        okbox.setOrientation(QtCore.Qt.Horizontal)
      +        okbox.setStandardButtons(QtGui.QDialogButtonBox.Cancel|QtGui.QDialogButtonBox.Ok)
      +        la.addWidget(okbox)
      +        QtCore.QObject.connect(okbox, QtCore.SIGNAL("accepted()"), self.proceed)
      +        QtCore.QObject.connect(okbox, QtCore.SIGNAL("rejected()"), self.close)
      +        QtCore.QMetaObject.connectSlotsByName(self.dialog)
      +        self.dialog.show()
      +        self.dialog.exec_()
      + 
      +p()
      +
      +

      Link

      +

      Discussion on Forum +

      UIUC Applied Aerodynamics Group Departement of Aerospace Engineering +

      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Macro_Alias_Manager.html b/localwiki/Macro_Alias_Manager.html new file mode 100644 index 0000000..fa6d988 --- /dev/null +++ b/localwiki/Macro_Alias_Manager.html @@ -0,0 +1,449 @@ +Macro Alias Manager

      Macro Alias Manager

      + +
      + + + + + + + + + + + + + + + + + + + + + + + + + + +
      +

      Aliasmanager icon.png Alias Manager

      +
      Description +
      This macro helps managing aliases inside FreeCAD Spreadsheet workbench. It is able to create, delete, move aliases and create a 'part family' group of files. +
      Author +
      pablogil & tahari +
      Links +
      Macros recipes
      How to install macros
      How to customize toolbars +
      Version +
      1.0 +
      Date last modification +
      2016-11-20 +
      +

      + +
      Aliasmanager icon.png This macro helps managing aliases inside FreeCAD Spreadsheet workbench. It is able to: +
      • create aliases based on first column (A column)
      • +
      • delete aliases placed on a column
      • +
      • move aliases from one column to another one
      • +
      • create a "part family", that's it, create different files for each column in a range. It will add to the original name a suffix based on first row (1)
      +

      More information might be found on FreeCAD forums: Macro for Spreadsheet Alias setup and Part Family Generation +

      And most updated versions of the macro can be downloaded from GitHub: https://github.com/pgilfernandez/FreeCAD_AliasManager +

      Aliasmanager screenshot.png +

      +

      How to use

      +

      - pending - +

      +

      Limitations

      +

      - pending - +

      +

      The script

      +
      +
      +# ============================================================================================================
      +# ============================================================================================================
      +# ==                                                                                                        ==
      +# ==                                           alias Manager                                                ==
      +# ==                                                                                                        ==
      +# ============================================================================================================
      +# ============================================================================================================
      +# ABOUT
      +# ============================================================================================================
      +# version v1.0
      +# Macro developed for FreeCAD (http://www.freecadweb.org/).
      +# This macro helps managing aliases inside FreeCAD Spreadsheet workbench. It is able to:
      +#        - create aliases based on first column (A column)
      +#        - delete aliases placed on a column
      +#        - move aliases from one column to other one
      +#        - create a "part family", that's it, create different files for each column in a range. It will add
      +#          to the original name a suffix based on first row (1)
      +# More information might be found on FreeCAD forums: http://forum.freecadweb.org/
      +#
      +#
      +# LICENSE
      +# ============================================================================================================
      +# Original work done by tarihatari (https://github.com/tarihatari/FreeCAD_Macros)
      +# Improved by Pablo Gil Fernandez
      +#
      +# Copyright (c) 2016 tarihatari & Pablo Gil Fernandez
      +#
      +# This work is licensed under GNU Lesser General Public License (LGPL).
      +# To view a copy of this license, visit https://www.gnu.org/licenses/lgpl-3.0.html.
      +#
      +# ============================================================================================================
      +__title__   = "alias manager"
      +__author__  = "Pablo Gil Fernandez"
      +__version__ = "01.00"
      +__date__    = "20/11/2016"
      + 
      +__Comment__ = "This macro helps managing aliases inside FreeCAD Spreadsheet workbench. It is able to create, delete, move aliases and create a 'part family' group of files"
      + 
      +__Wiki__ = "https://github.com/pgilfernandez/FreeCAD_AliasManager"
      +__Help__ = "https://github.com/pgilfernandez/FreeCAD_AliasManager"
      +__Status__ = "stable"
      +__Requires__ = "FreeCAD 0.16"
      +
      +from PySide import QtGui, QtCore
      +from FreeCAD import Gui
      +import os
      +import string
      +App = FreeCAD
      +Gui = FreeCADGui
      +
      +# ========================================================
      +# ===== Info popup window ================================
      +# ========================================================
      +class infoPopup(QtGui.QDialog):
      +    def __init__(self, parent=None):
      +        self.dialog = None
      +        self.dialog = QtGui.QDialog()
      +        self.dialog.resize(360,400)
      +        self.dialog.setWindowTitle("About...")
      +
      +        info = QtGui.QTextEdit("<h2>INFORMATION</h2><hr><br>This macro helps managing aliases inside FreeCAD Spreadsheet workbench. It is able to create, delete, move aliases and create a 'part family' group of files.<br><h2>USAGE</h2><hr><ul><li><b>set aliases</b>: based on first column (A column), it will create aliases for the range given. If an alias is already set for any other cell the command won't work, it will be needed to clear them before setting them again.</li><li><b>Clear aliases</b>: it will clear all aliases inside the given range of cells (only one column).</li><li><b>Move aliases</b>: it will clear and set aliases <b>from</b> a given column <b>to</b> a new one.</li><li><b>Generate part family</b>: it will create different files for each column in a range. It will add to the original name a suffix based on first row. If an alias is already set for any other cell the command won't work, it will be needed to clear them before running the command.</li></ul><h2>LICENCE</h2><hr>Original work done by <b>tarihatari</b> (<a href='https://github.com/tarihatari/FreeCAD_Macros'>https://github.com/tarihatari/FreeCAD_Macros</a>)<br>Improved by <b>Pablo Gil Fernandez</b><br><br>Copyright (c) 2016 tarihatari & Pablo Gil Fernandez<br><br>This work is licensed under GNU Lesser General Public License (LGPL).<br>To view a copy of this license, visit <a href='https://www.gnu.org/licenses/lgpl-3.0.html'>https://www.gnu.org/licenses/lgpl-3.0.html</a>.<br>")
      +        info.setReadOnly(True)
      +        info.setAlignment(QtCore.Qt.AlignLeft | QtCore.Qt.AlignTop)
      +
      +        okbox = QtGui.QDialogButtonBox(self.dialog)
      +        okbox.setOrientation(QtCore.Qt.Horizontal)
      +        okbox.setStandardButtons(QtGui.QDialogButtonBox.Close)
      +        okbox.setFocus()
      +
      +        grid2 = QtGui.QGridLayout()
      +        grid2.setSpacing(10)
      +        grid2.addWidget(info, 0, 0)
      +        grid2.addWidget(okbox, 1, 0)
      +
      +        self.dialog.setLayout(grid2)
      +
      +        QtCore.QObject.connect(okbox, QtCore.SIGNAL("rejected()"), self.close)
      +        QtCore.QMetaObject.connectSlotsByName(self.dialog)
      +        self.dialog.show()
      +        self.dialog.exec_()
      +
      +    def close(self):
      +        self.dialog.close()
      +
      +
      +# ========================================================
      +# ===== Main code ========================================
      +# ========================================================
      +
      +
      +# ===== Global variables ==============================================
      +alphabet_list = list(string.ascii_uppercase)
      +
      +class p():
      +    def aliasManager(self):
      +        try:
      +
      +# ===== Variables ==============================================
      +            mode = self.d1.currentText()
      +            column_from = self.d2.currentText()
      +            column_to = self.d3.currentText()
      +            row_from = self.d4.value()
      +            row_to = self.d5.value()
      +
      +
      +# ===== Mode - Set ==============================================
      +            if mode == "Set aliases":
      +                for i in range(row_from,row_to+1):
      +                    cell_from = 'A' + str(i)
      +                    cell_to = str(column_from) + str(i)
      +                    App.ActiveDocument.Spreadsheet.setAlias(cell_to, '')
      +                    App.ActiveDocument.Spreadsheet.setAlias(cell_to, App.ActiveDocument.Spreadsheet.getContents(cell_from))
      +                    App.ActiveDocument.recompute()
      +
      +                FreeCAD.Console.PrintMessage("\nAliases set\n")
      +
      +
      +# ===== Mode - Clear ==============================================
      +            elif mode == "Clear aliases":
      +                for i in range(row_from,row_to+1):
      +                    cell_to = str(column_from) + str(i)
      +                    App.ActiveDocument.Spreadsheet.setAlias(cell_to, '')
      +                    App.ActiveDocument.recompute()
      +
      +                FreeCAD.Console.PrintMessage("\nAliases cleared\n")
      +
      +
      +# ===== Mode - Move ==============================================
      +            elif mode == "Move aliases":
      +
      +                self.d3.setDisabled(False)
      +                for i in range(row_from,row_to+1):
      +                    cell_reference = 'A'+ str(i)                        
      +                    cell_from = column_from + str(i)
      +                    cell_to = column_to + str(i)
      +                    App.ActiveDocument.Spreadsheet.setAlias(cell_from, '')
      +                    App.ActiveDocument.recompute()
      +                    App.ActiveDocument.Spreadsheet.setAlias(cell_to, App.ActiveDocument.Spreadsheet.getContents(cell_reference))
      +                    App.ActiveDocument.recompute()
      +                FreeCAD.Console.PrintMessage("\nAliases moved\n")
      +
      +
      +# ===== Mode - Generate part family ==============================================
      +            elif mode == "Generate part family":
      +                doc = FreeCAD.ActiveDocument    
      +                if not doc.FileName:
      +                    FreeCAD.Console.PrintError('\nMust save project first\n')
      +                    
      +                docDir, docFilename = os.path.split(doc.FileName)
      +                filePrefix = os.path.splitext(docFilename)[0]
      +
      +                def char_range(c1, c2):
      +                    """Generates the characters from `c1` to `c2`, inclusive."""
      +                    for c in xrange(ord(c1), ord(c2)+1):
      +                        yield str.capitalize(chr(c))
      +
      +                fam_range = []
      +                for c in char_range(str(column_from), str(column_to)):
      +                    fam_range.append(c)
      +
      +                for index in range(len(fam_range)):
      +                    # set aliases
      +                    for i in range(row_from,row_to+1):
      +                        cell_reference = 'A' + str(i)
      +                        cell_from = str(fam_range[index-1]) + str(i)
      +                        cell_to = str(fam_range[index]) + str(i)
      +                        App.ActiveDocument.Spreadsheet.setAlias(cell_from, '')
      +                        App.ActiveDocument.recompute()
      +                        App.ActiveDocument.Spreadsheet.setAlias(cell_to, App.ActiveDocument.Spreadsheet.getContents(cell_reference))
      +                        App.ActiveDocument.recompute()
      +                        sfx = str(fam_range[index]) + '1'
      +
      +                    # save file
      +                    suffix = App.ActiveDocument.Spreadsheet.getContents(sfx)
      +                    filename = filePrefix + '_' + suffix + '.fcstd'
      +                    filePath = os.path.join(docDir, filename)
      +                
      +                    FreeCAD.Console.PrintMessage("\nSaving view to %s\n" % filePath)
      +                    App.getDocument(filePrefix).saveAs(filePath)
      +
      +                # Clear last aliases created:
      +                for j in range(row_from,row_to+1):
      +                    cell_to = str(column_to) + str(j)
      +                    App.ActiveDocument.Spreadsheet.setAlias(cell_to, '')
      +                App.ActiveDocument.recompute()
      +
      +                # Turn working file to original naming:
      +                filename = filePrefix + '.fcstd'
      +                filePath = os.path.join(docDir, filename)
      +                FreeCAD.Console.PrintMessage("\nSaving original view to %s\n" % filePath)
      +                App.getDocument(filePrefix).saveAs(filePath)
      +                FreeCAD.Console.PrintMessage("\nPart family files generated\n")
      +
      +
      +
      +# ===== If errors ==============================================
      +            else:
      +                FreeCAD.Console.PrintError("\nError or 'TODO'\n")
      +
      +
      +        except:
      +            FreeCAD.Console.PrintError("\nUnable to complete task\n")
      + 
      +            self.close()
      + 
      +
      +    def close(self):
      +        self.dialog.hide()
      +
      +
      +# ========================================================
      +# ===== GUI menu ========================================
      +# ========================================================
      +    def __init__(self):
      +        infoIcon = ['16 16 3 1',
      +                '   c None',
      +                '+  c #444444',
      +                '.  c #e6e6e6',
      +                '     ......    ',
      +                '   ..........  ',
      +                '  ......++.... ',
      +                ' .......++.....',
      +                ' ..............',
      +                '.....+++++......',
      +                '....+++++.......',
      +                '.......++.......',
      +                '.......++.......',
      +                '.......+........',
      +                '......++........',
      +                ' .....++.+.....',
      +                ' .....++++.....',
      +                '  .....++..... ',
      +                '   ..........  ',
      +                '     ......    ']
      +
      +        # Hide/show "to column" label and spinbox based on mode type
      +        def disableWidget(currentIndex):
      +            if self.d1.currentText() == "Set aliases":
      +                iN3.hide()
      +                self.d3.setEnabled(False)
      +                self.d3.hide()
      +            elif self.d1.currentText() == "Clear aliases":
      +                iN3.hide()
      +                self.d3.setEnabled(False)
      +                self.d3.hide()
      +            else:
      +                iN3.show()
      +                self.d3.setEnabled(True)
      +                self.d3.show()
      +
      +
      +
      +
      +        self.dialog = None
      +        
      +        self.dialog = QtGui.QDialog()
      +        self.dialog.resize(400,140)
      +        
      +        self.dialog.setWindowTitle("Alias manager")
      + 
      +        iN1 = QtGui.QLabel("mode:")
      +        iN1.setAlignment(QtCore.Qt.AlignRight | QtCore.Qt.AlignVCenter)
      +        self.d1 = QtGui.QComboBox()
      +        self.d1.addItem("Set aliases")
      +        self.d1.addItem("Clear aliases")
      +        self.d1.addItem("Move aliases")
      +        self.d1.addItem("Generate part family")
      +        self.d1.setCurrentIndex(0) # set default item
      +        self.d1.currentIndexChanged['QString'].connect(disableWidget)
      + 
      +        iN2a = QtGui.QLabel("column:")
      +        iN2a.setAlignment(QtCore.Qt.AlignRight | QtCore.Qt.AlignVCenter)
      +        iN2b = QtGui.QLabel("from")
      +        iN2b.setAlignment(QtCore.Qt.AlignCenter | QtCore.Qt.AlignVCenter)
      +        self.d2 = QtGui.QComboBox()
      +        for i in range(0,26):
      +            self.d2.addItem(alphabet_list[i])
      +        for i in range(0,26):
      +            for j in range(0,26):
      +                self.d2.addItem(alphabet_list[i] + alphabet_list[j])
      +        self.d2.setCurrentIndex(1) # set default item
      +
      +        iN3 = QtGui.QLabel("to")
      +        iN3.setAlignment(QtCore.Qt.AlignCenter | QtCore.Qt.AlignVCenter)
      +        iN3.hide() # set initial state hidden
      +        self.d3 = QtGui.QComboBox()
      +        for i in range(0,26):
      +            self.d3.addItem(alphabet_list[i])
      +        for i in range(0,26):
      +            for j in range(0,26):
      +                self.d3.addItem(alphabet_list[i] + alphabet_list[j])
      +        self.d3.setCurrentIndex(2) # set default item
      +        self.d3.setEnabled(False) # set initial state to not editable
      +        self.d3.hide() # set initial state hidden
      +
      +        iN4 = QtGui.QLabel("from row:")
      +        iN4.setAlignment(QtCore.Qt.AlignRight | QtCore.Qt.AlignVCenter)
      +        self.d4 = QtGui.QSpinBox()
      +        self.d4.setValue(2.0) # set default item
      +        self.d4.setSingleStep(1.0)
      +        self.d4.setMinimum(1.0)
      +
      +        iN5 = QtGui.QLabel("to row:")
      +        iN5.setAlignment(QtCore.Qt.AlignRight | QtCore.Qt.AlignVCenter)
      +        self.d5 = QtGui.QSpinBox()
      +        self.d5.setValue(4.0) # set default item
      +        self.d5.setSingleStep(1.0)
      +        self.d5.setMinimum(1.0)
      +
      +        # Info button
      +        self.d6 = QtGui.QPushButton("")
      +        self.d6.setFixedWidth(40)
      +        self.d6.setIcon(QtGui.QIcon(QtGui.QPixmap(infoIcon)))
      +        self.d6.clicked.connect(self.popup)
      +
      +        okbox = QtGui.QDialogButtonBox(self.dialog)
      +        okbox.setOrientation(QtCore.Qt.Horizontal)
      +        okbox.setStandardButtons(QtGui.QDialogButtonBox.Ok|QtGui.QDialogButtonBox.Close)
      +
      +        grid = QtGui.QGridLayout()
      +        grid.setSpacing(10)
      +
      +        # Mode
      +        grid.addWidget(self.d1, 0, 0, 1, 3)
      +        # column, column from
      +        grid.addWidget(iN2a,    2, 0, 1, 1)
      +        grid.addWidget(iN2b,    1, 1, 1, 1)
      +        grid.addWidget(self.d2, 2, 1, 1, 1)
      +        # column to
      +        grid.addWidget(iN3,     1, 2, 1, 1)
      +        grid.addWidget(self.d3, 2, 2, 1, 1)
      +        # from row
      +        grid.addWidget(iN4,     3, 0, 1, 1)
      +        grid.addWidget(self.d4, 3, 1, 1, 1)
      +        # to row
      +        grid.addWidget(iN5,     4, 0, 1, 1)
      +        grid.addWidget(self.d5, 4, 1)
      +        # + info
      +        grid.addWidget(self.d6, 6, 0, 1, 1)
      +        # cancel, OK
      +        grid.addWidget(okbox,   6, 1, 1, 2)
      +
      +        self.dialog.setLayout(grid)
      +
      +        # # Set Tab order (not needed anymore because of enabling/disabling spinboxes)
      +        # self.dialog.setTabOrder(self.d3, self.d1)
      +        # self.dialog.setTabOrder(self.d1, self.d2)
      +        # self.dialog.setTabOrder(self.d2, self.d4)
      +        # self.dialog.setTabOrder(self.d4, self.d5)
      +        # self.dialog.setTabOrder(self.d5, self.d3)
      + 
      +        QtCore.QObject.connect(okbox, QtCore.SIGNAL("rejected()"), self.close)
      +        QtCore.QObject.connect(okbox, QtCore.SIGNAL("accepted()"), self.aliasManager)
      +        QtCore.QMetaObject.connectSlotsByName(self.dialog)
      +        self.dialog.show()
      +        self.dialog.exec_()
      +
      +
      +    def popup(self):
      +        self.dialog2 = infoPopup()
      +        self.dialog2.exec_()
      +p()
      +
      +
      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Macro_Align_Camera_to_Working_Plane.html b/localwiki/Macro_Align_Camera_to_Working_Plane.html new file mode 100644 index 0000000..93c8378 --- /dev/null +++ b/localwiki/Macro_Align_Camera_to_Working_Plane.html @@ -0,0 +1,83 @@ +Macro Align Camera to Working Plane

      Macro Align Camera to Working Plane

      + +
      + + + + + + + + + + + + + + + + + + + + + + + + + + +
      +

      Text-x-python.png Macro Align Camera to Working Plane

      +
      Description +
      This macro aligns the camera to the current Draft Working Plane +
      Author +
      yorik +
      Links +
      Macros recipes
      How to install macros
      How to customize toolbars +
      Version +
      0.1 +
      Date last modification +
      2017-03-16 +
      +

      + +
      +


      +

      +

      Description

      +

      This macro aligns the camera to the current Draft Working Plane +

      +

      How to use

      + +

      Script

      +

      Macro Align Camera to Working Plane.FCMacro +

      +
      import FreeCAD,FreeCADGui
      +c = FreeCADGui.ActiveDocument.ActiveView.getCameraNode()
      +r = FreeCAD.DraftWorkingPlane.getRotation().Rotation.Q
      +c.orientation.setValue(r) 
      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Macro_Align_Face_Object_to_View.html b/localwiki/Macro_Align_Face_Object_to_View.html new file mode 100644 index 0000000..030c1e0 --- /dev/null +++ b/localwiki/Macro_Align_Face_Object_to_View.html @@ -0,0 +1,101 @@ +Macro Align Face Object to View

      Macro Align Face Object to View

      + +
      + + + + + + + + + + + + + + + + + + + + + + + + + + +
      +

      Text-x-python.png Macro Align Face Object to View

      +
      Description +
      This macro directs the face of the object on the side of the ActiveView. +
      Author +
      Mario52 +
      Links +
      Macros recipes
      How to install macros
      How to customize toolbars +
      Version +
      0.1 +
      Date last modification +
      2015-01-16 +
      +

      + +
      +


      +

      +

      Description

      +

      This macro directs the face of the object on the side of the ActiveView (camera). +In the case of the face of a borehole (or internal or cylinder) face drilling facing the screen +

      +

      How to use

      +
      • Select your object and run the macro
      • +
      • Your object will be of the camera
      +

      Script

      +

      Macro_Align_Face_Object_to_View.FCMacro +

      +
      # This macro directs the face of the object on the side of the ActiveView (camera)
      +# extact
      +# 16/01/2015
      +
      +__title__="FCCamera"
      +__author__ = "Mario52"
      +
      +import pivy
      +from pivy import coin
      +
      +try:
      +    v=Gui.Selection.getSelectionEx()[0].SubObjects[0].Surface.Axis    # to Axis
      +#    v = Gui.Selection.getSelectionEx()[0].SubObjects[0].normalAt(0,0) # normalAt
      +    r=App.Rotation(App.Vector(0,0,1),v)
      +    Gui.ActiveDocument.ActiveView.setCameraOrientation(r.Q)
      +except Exception:
      +    App.Console.PrintError("Select a face and run the macro"+"\n") 
      +

      Links

      +

      Original macro by wmayer Looking for some helpful GUI-commands +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Macro_Align_Object_to_View.html b/localwiki/Macro_Align_Object_to_View.html new file mode 100644 index 0000000..bc4c01d --- /dev/null +++ b/localwiki/Macro_Align_Object_to_View.html @@ -0,0 +1,140 @@ +Macro Align Object to View

      Macro Align Object to View

      + +
      + + + + + + + + + + + + + + + + + + + + + + + + + + +
      +

      Text-x-python.png Macro Align Object to View

      +
      Description +
      This macro aligns the selected object to the current View. +
      Author +
      Mario52 +
      Links +
      Macros recipes
      How to install macros
      How to customize toolbars +
      Version +
      0.1 +
      Date last modification +
      2015-01-16 +
      +

      + +
      +


      +

      +

      Description

      +

      This macro aligns and Position the selected object to the current View. +

      +

      How to use

      +
      • Direct your view, select your object and run the macro
      • +
      • Your object will be the placement of the camera coordinates
      +

      Script

      +

      Macro Align Object to View.FCMacro +

      +
      # This macro place your object selected to the position ActiveView (camera)
      +# extact
      +# 16/01/2015
      +
      +__title__="FCCamera"
      +__author__ = "Mario52"
      +
      +import pivy
      +from pivy import coin
      +
      +sel = FreeCADGui.Selection.getSelection()
      +Nameelement = sel[0].Name
      +App.Console.PrintMessage(str(Nameelement)+"\n")
      +
      +pl = FreeCAD.Placement()
      +pl.Rotation = FreeCADGui.ActiveDocument.ActiveView.getCameraOrientation()
      +pl.Base = FreeCAD.Vector(0.0,0.0,0.0)
      +
      +App.ActiveDocument.getObject(Nameelement).Placement=pl 
      +

      Example

      +
      + +
      +
      + +
      +

      Credits

      +

      Tanks Simplified code to rentlau_64 +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Macro_Align_View_to_Face.html b/localwiki/Macro_Align_View_to_Face.html new file mode 100644 index 0000000..2e271db --- /dev/null +++ b/localwiki/Macro_Align_View_to_Face.html @@ -0,0 +1,121 @@ +Macro Align View to Face

      Macro Align View to Face

      + +
      + + + + + + + + + + + + + + + + + + + + + + + + + + +
      +

      Text-x-python.png Macro Align View to Face

      +
      Description +
      This macro aligns the current view to a selected face +
      Author +
      Rockn +
      Links +
      Macros recipes
      How to install macros
      How to customize toolbars +
      Version +
      1.0 +
      Date last modification +
      2014-03-12 +
      +

      + +
      +


      +

      +

      Description

      +

      This macro rotates the current view to point perpendicularly at a selected face of an existing object. +

      +

      How to use

      +
      1. Select a face on an object
      2. +
      3. Run the macro
      +

      Script

      +
      # -*- coding: utf-8 -*-
      +# Set the current view perpendicular to the selected face
      +# Place la vue perpendiculairement à la face selectionnee
      +# 2013 Jonathan Wiedemann, 2016 Werner Mayer
      +
      +from pivy import coin
      +
      +def pointAt(normal, up):
      +    z = normal
      +    y = up
      +    x = y.cross(z)
      +    y = z.cross(x)
      +   
      +    rot = App.Matrix()
      +    rot.A11 = x.x
      +    rot.A21 = x.y
      +    rot.A31 = x.z
      +   
      +    rot.A12 = y.x
      +    rot.A22 = y.y
      +    rot.A32 = y.z
      +   
      +    rot.A13 = z.x
      +    rot.A23 = z.y
      +    rot.A33 = z.z
      +
      +    return App.Placement(rot).Rotation
      +
      +s=Gui.Selection.getSelectionEx()
      +obj=s[0]
      +faceSel = obj.SubObjects[0]
      +dir = faceSel.normalAt(0,0)
      +cam = FreeCADGui.ActiveDocument.ActiveView.getCameraNode()
      +
      +if dir.z == 1 :
      +    rot = pointAt(dir, App.Vector(0.0,1.0,0.0))
      +elif dir.z == -1 :
      +    rot = pointAt(dir, App.Vector(0.0,1.0,0.0))
      +else :
      +    rot = pointAt(dir, App.Vector(0.0,0.0,1.0))
      +
      +cam.orientation.setValue(rot.Q)
      +Gui.SendMsgToActiveView("ViewSelection") 
      +


      +

      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Macro_Align_Working_Plane_to_Camera.html b/localwiki/Macro_Align_Working_Plane_to_Camera.html new file mode 100644 index 0000000..d6ce3af --- /dev/null +++ b/localwiki/Macro_Align_Working_Plane_to_Camera.html @@ -0,0 +1,84 @@ +Macro Align Working Plane to Camera

      Macro Align Working Plane to Camera

      + +
      + + + + + + + + + + + + + + + + + + + + + + + + + + +
      +

      Text-x-python.png Macro Align Working Plane to Camera

      +
      Description +
      This macro moves the current Draft Working Plane to the center of the current view +
      Author +
      yorik +
      Links +
      Macros recipes
      How to install macros
      How to customize toolbars +
      Version +
      1.0 +
      Date last modification +
      2017-05-10 +
      +

      + +
      +


      +

      +

      Description

      +

      This macro moves the current Draft Working Plane to the center of the current view. It is useful when you are working quite far from the grid center. +

      +

      How to use

      +
      • Move the view to the zone where you want to look at
      • +
      • Run the macro
      +

      Script

      +

      Macro Align Working Plane to Camera.FCMacro +

      +
      import FreeCAD,FreeCADGui
      +cam = FreeCAD.Vector(FreeCADGui.ActiveDocument.ActiveView.getCameraNode().position.getValue().getValue())
      +pos = FreeCAD.DraftWorkingPlane.projectPoint(cam)
      +FreeCAD.DraftWorkingPlane.position = pos
      +FreeCADGui.Snapper.setGrid() 
      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Macro_Animated_Constrain.html b/localwiki/Macro_Animated_Constrain.html new file mode 100644 index 0000000..2ba44d6 --- /dev/null +++ b/localwiki/Macro_Animated_Constrain.html @@ -0,0 +1,79 @@ +Macro Animated Constrain

      Macro Animated Constrain

      + +
      + + + + + + + + + + + + + + + + + + + + + + + + + + +
      +

      Text-x-python.png Animated Constrain

      +
      Description +
      Animate Constrain within sketch in FreeCAD +
      Author +
      psicofil +
      Links +
      Macros recipes
      How to install macros
      How to customize toolbars +
      Version +
      1.0 +
      Date last modification +
      2015-05-20 +
      +

      + +
      +


      +

      Simple macro to animate angles constraints in the sketcher.
      +Based on the work of @microelly.
      +Animate a constraint and review the resulting effects.
      +

      +

      Use

      +

      The macro you can find in the following github repository: Animated Constrain Macro +

      +

      Link

      +

      The page discussion Animated Constrain Macro +

      See the animation on YouTube. +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Macro_Apothem_Based_Prism_GUI.html b/localwiki/Macro_Apothem_Based_Prism_GUI.html new file mode 100644 index 0000000..d6f8513 --- /dev/null +++ b/localwiki/Macro_Apothem_Based_Prism_GUI.html @@ -0,0 +1,179 @@ +Macro Apothem Based Prism GUI

      Macro Apothem Based Prism GUI

      + +
      + + + + + + + + + + + + + + + + + + + + + + + + + + +
      +

      Part Prism Apothem.png Apothem Based Prism

      +
      Description +
      A GUI dialog that creates an Apothem, (inradius) Based Prism from user input. +
      Author +
      Quick61 +
      Links +
      Macros recipes
      How to install macros
      How to customize toolbars +
      Version +
      1.0 +
      Date last modification +
      2014-12-31 +
      +

      + +
      +


      +

      +

      Part Prism Apothem.svgApothem Based Prism

      +

      About

      +

      This macro will present the user with a dialog to provide the distance between centers, the number of sides, and height and will create a prism based on the apothem, or inradius of a polygon. This can be extremely handy when one only knows the distance between flats. An example of this would be hexagonal stock of plastics or metal provided by vendors. Most vendors define such stock by the distance between flats. If one is using such stock in their projects, this Macro can be a real time saver. +

      +

      How To Use

      +

      Copy the Macro into your FreeCAD Macro directory. Then either run the macro from the Execute Macro dialog or create a shortcut to use from your custom toolbar. +

      When run, the Macro wil present the user with a dialog like seen below. First enter the desired distance between flats. This can be any number and can include a decimal value, it will not take fractional input. Next enter the number of sides. This number is a whole number and should be an even number as well for proper results. Lastly enter the height you wish the prism to be. Again, this can be any number and can include a decimal value. Click OK and the prism will be created in your document. +

      +
      ABP Screenshot.png
      +

      The Macro

      +
      # # # # # # # # # # #
      +#
      +# Apothem Based Prism
      +#
      +# This script will take the input of the distance between flats, (apothem, aka inradius), 
      +# and the number of sidesfor a regular polygon along with a height and produce a 
      +# correctly sized prism derived from the circumradius.
      +#
      +# # # # # # # # # # #
      + 
      +import FreeCAD, FreeCADGui, Part, PartGui, math
      +from FreeCAD import Base
      +from PySide import QtGui, QtCore
      +from math import cos, radians
      +App = FreeCAD
      +Gui = FreeCADGui
      + 
      +class p():
      + 
      + 
      +    def priSm(self):
      + 
      +        try:
      +            dbf = float(self.d1.text())
      +            nos = int(self.d2.text())
      +            hth = float(self.d3.text())
      +            aR = dbf / 2
      +            op1 = 180/float(nos)
      +            coS = cos(math.radians(op1))
      +            cR = aR / coS
      +            prism=App.ActiveDocument.addObject("Part::Prism","Prism")
      +            prism.Polygon=nos
      +            prism.Circumradius=cR
      +            prism.Height=hth
      +            prism.Placement=Base.Placement(Base.Vector(0.00,0.00,0.00),Base.Rotation(0.00,0.00,0.00,1.00))
      +            prism.Label='Prism'
      +            App.ActiveDocument.recompute()
      +            Gui.SendMsgToActiveView("ViewFit")
      +        except:
      +            FreeCAD.Console.PrintError("Unable to complete task")
      + 
      +            self.close()
      + 
      +    def close(self):
      +        self.dialog.hide()
      + 
      + 
      +#
      +# Make dialog box and get input for distance between flats, number of sides, and height
      +#
      + 
      +    def __init__(self):
      +        self.dialog = None
      + 
      +        self.dialog = QtGui.QDialog()
      +        self.dialog.resize(280,110)
      + 
      +        self.dialog.setWindowTitle("Apothem Based Prism")
      +        la = QtGui.QVBoxLayout(self.dialog)
      + 
      +        iN1 = QtGui.QLabel("Distance Between Flats")
      +        la.addWidget(iN1)
      +        self.d1 = QtGui.QLineEdit()
      +        la.addWidget(self.d1)
      + 
      +        iN2 = QtGui.QLabel("Number Of Sides (Best results - use even numbers)")
      +        la.addWidget(iN2)
      +        self.d2 = QtGui.QLineEdit()
      +        la.addWidget(self.d2)
      + 
      +        iN3 = QtGui.QLabel("Prism Height")
      +        la.addWidget(iN3)
      +        self.d3 = QtGui.QLineEdit()
      +        la.addWidget(self.d3)
      + 
      +        okbox = QtGui.QDialogButtonBox(self.dialog)
      +        okbox.setOrientation(QtCore.Qt.Horizontal)
      +        okbox.setStandardButtons(QtGui.QDialogButtonBox.Cancel|QtGui.QDialogButtonBox.Ok)
      +        la.addWidget(okbox)
      +        QtCore.QObject.connect(okbox, QtCore.SIGNAL("accepted()"), self.priSm)
      +        QtCore.QObject.connect(okbox, QtCore.SIGNAL("rejected()"), self.close)
      +        QtCore.QMetaObject.connectSlotsByName(self.dialog)
      +        self.dialog.show()
      +        self.dialog.exec_()
      + 
      +p() 
      +

      Additions

      +

      SVG icon for use in custom toolbar shortcut. +

      Part Prism Apothem.svg +

      +

      Acknowledgements

      +

      A thanks to FreeCAD main developer shoogen and FreeCAD programmer wandererfan for their invaluable help and advice in constructing this Macro. +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Macro_Arch_Axis_System_Repartition.html b/localwiki/Macro_Arch_Axis_System_Repartition.html new file mode 100644 index 0000000..30bf659 --- /dev/null +++ b/localwiki/Macro_Arch_Axis_System_Repartition.html @@ -0,0 +1,314 @@ +Macro Arch Axis System Repartition

      Macro Arch Axis System Repartition

      + +
      + + + + + + + + + + + + + + + + + + + + + + + + + + +
      +

      Text-x-python.png Macro Arch Axis System Repartition

      +
      Description +
      Make an Arch Axis system along a line. +
      Author +
      rockn +
      Links +
      Macros recipes
      How to install macros
      How to customize toolbars +
      Version +
      1.0 +
      Date last modification +
      2014-12-22 +
      +

      + +
      ArchAxisSystemRepartition +
      +


      +

      +

      Description

      +

      This macro help you to create an Arch Axis System along a line with a set of parameters. You can even create a Structural System directly from the FreeCAD-Library. +

      +

      Use

      +
      • Launch the macro with or without selected line.
      • +
      • A Gui TaskPanel set up in the task widget.
      • +
      • Set the lenght : if a line is selected, setting length actualize and forced to the line length ; if there is nothing selected the length can be changed.
      • +
      • Set the desired regular spacing ; the number of divide and left spacing are automatically calculating.
      • +
      • Or set the desired number of divide quantity ; this make an equal divide with no left spacing.
      • +
      • Choose if you want the left spacing to be at the beginning of the repartition or at the end or each side equal.
      • +
      • Check if you want a piece at the begging of the line, you can set an offset (end line direction).
      • +
      • Check if you want a piece at the begging of the line, you can set an offset (start line direction).
      • +
      • To validate clic on Ok button :
      • +
      • If a line is selected the Arch Axis System take the placement of the line else the placement is 0.0.0.
      • +
      • If you have the FreeCAD-Library gui open, the FCStd or Step file selected is imported and a Structural System is made.
      +

      Script

      +

      Repartition.FCMacro +

      +
      #!/usr/bin/env python
      +# -*- coding: utf-8 -*-
      +
      +#***************************************************************************
      +#*                                                                         *
      +#*   Copyright (c) 2014 Jonathan Wiedemann <wood.galaxy@gmail.com          *
      +#*                                                                         *
      +#*   This program is free software; you can redistribute it and/or modify  *
      +#*   it under the terms of the GNU Lesser General Public License (LGPL)    *
      +#*   as published by the Free Software Foundation; either version 2 of     *
      +#*   the License, or (at your option) any later version.                   *
      +#*   for detail see the LICENCE text file.                                 *
      +#*                                                                         *
      +#*   This program is distributed in the hope that it will be useful,       *
      +#*   but WITHOUT ANY WARRANTY; without even the implied warranty of        *
      +#*   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the         *
      +#*   GNU Library General Public License for more details.                  *
      +#*                                                                         *
      +#*   You should have received a copy of the GNU Library General Public     *
      +#*   License along with this program; if not, write to the Free Software   *
      +#*   Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  *
      +#*   USA                                                                   *
      +#*                                                                         *
      +#***************************************************************************
      +
      +__title__="Repartition"
      +__author__ = "Jonathan Wiedemann"
      +__url__ = "http://www.freecad-france.com"
      +
      +import FreeCAD, FreeCADGui, DraftGeomUtils, DraftVecUtils
      +import Arch
      +import Part
      +import math
      +from PySide import QtCore, QtGui
      +
      +class _RepartitionTaskPanel:
      +def __init__(self):
      +self.title = QtGui.QLabel('Repartition')
      +self.grid = QtGui.QGridLayout()
      +self.grid.addWidget(self.title, 1, 0)
      +
      +self.longueurLabel = QtGui.QLabel('Longueur')
      +
      +self.dSBLongueur = QtGui.QDoubleSpinBox()
      +self.dSBLongueur.setRange(0., 9999999.)
      +self.sel = FreeCADGui.Selection.getSelection()
      +if self.sel:
      +self.longueur = self.sel[0].Shape.Length
      +self.dSBLongueur.setValue(self.longueur)
      +else:
      +self.dSBLongueur.setValue(5000.)
      +
      +self.grid.addWidget(self.longueurLabel, 2, 0)
      +self.grid.addWidget(self.dSBLongueur, 2, 1)
      +
      +self.ecartementLabel = QtGui.QLabel('Ecartement')
      +self.ecartementDSB = QtGui.QDoubleSpinBox()
      +self.ecartementDSB.setRange(0., 9999999.)
      +self.ecartementDSB.setValue(500.)
      +self.grid.addWidget(self.ecartementLabel, 3, 0)
      +self.grid.addWidget(self.ecartementDSB, 3, 1)
      +
      +self.qteLabel = QtGui.QLabel('Quantite')
      +self.qteSB = QtGui.QSpinBox()
      +self.qteSB.setRange(0,99999)
      +self.grid.addWidget(self.qteLabel, 4, 0)
      +self.grid.addWidget(self.qteSB, 4, 1)
      +
      +self.infoText = QtGui.QLabel('Espace restant = ')
      +self.grid.addWidget(self.infoText, 5, 0)
      +self.combobox = QtGui.QComboBox()
      +items = ["Debut","Fin","Divise"]
      +self.combobox.addItems(items)
      +self.combobox.setCurrentIndex(items.index("Fin"))
      +self.grid.addWidget(self.combobox, 5, 1)
      +
      +self.debutLabel = QtGui.QLabel('Debut')
      +self.grid.addWidget(self.debutLabel, 6, 0)
      +
      +self.debutRepartitionCB = QtGui.QCheckBox()
      +self.debutRepartitionCB.setCheckState(QtCore.Qt.CheckState.Checked)
      +self.grid.addWidget(self.debutRepartitionCB, 6, 1)
      +
      +self.decalageDebutLabel = QtGui.QLabel('Decalage')
      +self.grid.addWidget(self.decalageDebutLabel, 7, 0)
      +
      +self.decalageDebutDSB = QtGui.QDoubleSpinBox()
      +self.decalageDebutDSB.setRange(0., 9999999.)
      +self.grid.addWidget(self.decalageDebutDSB, 7, 1)
      +
      +self.finLabel = QtGui.QLabel('Fin')
      +self.grid.addWidget(self.finLabel, 8, 0)
      +
      +self.finRepartitionCB = QtGui.QCheckBox()
      +self.finRepartitionCB.setCheckState(QtCore.Qt.CheckState.Checked)
      +self.grid.addWidget(self.finRepartitionCB, 8, 1)
      +
      +self.decalageFinLabel = QtGui.QLabel('Decalage')
      +self.grid.addWidget(self.decalageFinLabel, 9, 0)
      +
      +self.decalageFinDSB = QtGui.QDoubleSpinBox()
      +self.decalageFinDSB.setRange(0., 9999999.)
      +self.grid.addWidget(self.decalageFinDSB, 9, 1)
      +
      +groupBox = QtGui.QGroupBox()
      +groupBox.setLayout(self.grid)
      +self.form = groupBox
      +
      +QtCore.QObject.connect(self.dSBLongueur,QtCore.SIGNAL("valueChanged(double)"),self.changerLongueur)
      +QtCore.QObject.connect(self.ecartementDSB,QtCore.SIGNAL("valueChanged(double)"),self.changerEcartement)
      +QtCore.QObject.connect(self.qteSB,QtCore.SIGNAL("valueChanged(int)"),self.changerQte)
      +QtCore.QObject.connect(self.combobox,QtCore.SIGNAL("currentIndexChanged(int)"),self.afficherResultats)
      +self.changerLongueur()
      +
      +def recupererDonnees(self):
      +self.sel = FreeCADGui.Selection.getSelection()
      +if self.sel:
      +self.longueur = self.sel[0].Shape.Length
      +else:
      +self.longueur = self.dSBLongueur.value()
      +self.ecartementRegulier = self.ecartementDSB.value()
      +self.qteEcartement = self.qteSB.value()
      +
      +self.objetDebut =  self.debutRepartitionCB.isChecked()
      +self.decalageDebut = self.decalageDebutDSB.value()
      +self.plEspaceRestant = self.combobox.currentIndex()
      +self.objetFin = self.finRepartitionCB.isChecked()
      +self.decalageFin = self.decalageFinDSB.value()
      +
      +def changerLongueur(self):
      +self.recupererDonnees()
      +self.qteEcartement = int(math.ceil(self.longueur/self.ecartementRegulier))
      +self.afficherResultats()
      +
      +def changerEcartement(self):
      +self.recupererDonnees()
      +self.qteEcartement = int(math.ceil(self.longueur/self.ecartementRegulier))
      +self.afficherResultats()
      +
      +def changerQte(self):
      +self.recupererDonnees()
      +self.ecartementRegulier = self.longueur/self.qteEcartement
      +self.afficherResultats()
      +
      +def afficherResultats(self):
      +self.dSBLongueur.blockSignals(True)
      +self.dSBLongueur.setValue(self.longueur)
      +self.dSBLongueur.blockSignals(False)
      +
      +self.ecartementDSB.blockSignals(True)
      +self.ecartementDSB.setValue(self.ecartementRegulier)
      +self.ecartementDSB.blockSignals(False)
      +
      +
      +self.qteSB.blockSignals(True)
      +self.qteSB.setValue(self.qteEcartement)
      +self.qteSB.blockSignals(False)
      +
      +self.espaceRestant = self.longueur - (self.qteEcartement-1) * self.ecartementRegulier
      +if round(self.espaceRestant,2) == round(self.ecartementRegulier,2):
      +self.espaceRestant = 0.
      +if self.combobox.currentIndex() == 2:
      +self.infoText.setText( str('Espace restant = 2 x ') + str(round(self.espaceRestant/2,2)) + str(' mm') )
      +else:
      +self.infoText.setText( str('Espace restant = ') + str(round(self.espaceRestant,2)) + str(' mm') )
      +
      +def accept(self):
      +self.recupererDonnees()
      +distancesListe = []
      +if self.objetDebut:
      +distancesListe.append(self.decalageDebut)
      +if self.plEspaceRestant == 0:
      +distancesListe.append(self.espaceRestant)
      +if self.plEspaceRestant == 1:
      +distancesListe.append(self.ecartementRegulier-self.decalageDebut)
      +if self.plEspaceRestant == 2:
      +distancesListe.append(self.espaceRestant/2-self.decalageDebut)
      +for i in range(self.qteEcartement-2):
      +distancesListe.append(self.ecartementRegulier)
      +if self.objetFin:
      +if self.plEspaceRestant == 0:
      +distancesListe.append(self.ecartementRegulier-self.decalageFin-self.decalageDebut)
      +if self.plEspaceRestant == 1:
      +distancesListe.append(self.espaceRestant-self.decalageFin)
      +if self.plEspaceRestant == 2:
      +distancesListe.append(self.ecartementRegulier)
      +distancesListe.append((self.espaceRestant/2)-self.decalageFin)
      +repartition = Arch.makeAxis(num=len(distancesListe), name="Repartition")
      +repartition.Length = 1000.00
      +repartition.Distances= distancesListe
      +
      +self.sel = FreeCADGui.Selection.getSelection()
      +if self.sel:
      +edges = DraftGeomUtils.sortEdges(self.sel[0].Shape.Wires[0].Edges)
      +vec1 = edges[0].Vertexes[-1].Point.sub(edges[0].Vertexes[0].Point)
      +point1 = edges[0].Vertexes[0].Point
      +rot = math.degrees(DraftVecUtils.angle(vec1))*-1
      +repartition.Placement = App.Placement(App.Vector(point1),App.Rotation(App.Vector(0.0,0.0,1.0),rot))
      +FreeCAD.ActiveDocument.recompute()
      +else:
      +repartition.Placement = App.Placement(App.Vector(0.0,0.0,0.0),App.Rotation(App.Vector(0.0,0.0,1.0),0))
      +
      +m = FreeCADGui.getMainWindow()
      +w = m.findChild(QtGui.QDockWidget,"PartsLibrary")
      +if w:
      +if w.isVisible():
      +index = w.folder_view.selectedIndexes()[0]
      +path = w.dirmodel.filePath(index)
      +if path.lower().endswith(".stp") or path.lower().endswith(".step") or path.lower().endswith(".brep"):
      +objetRepartit = Part.show(Part.read(path))
      +else:
      +objetRepartit = FreeCADGui.ActiveDocument.mergeProject(path)
      +repartitionStructurel = Arch.makeStructuralSystem([FreeCAD.ActiveDocument.Objects[-1],],[repartition,], name="RepartitionStructurelle")
      +return True
      +
      +def reject(self):
      +return True
      +
      +def getStandardButtons(self):
      +return int(QtGui.QDialogButtonBox.Ok 
      +

      Links

      + +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Macro_ArrayCopy.html b/localwiki/Macro_ArrayCopy.html new file mode 100644 index 0000000..d08c02b --- /dev/null +++ b/localwiki/Macro_ArrayCopy.html @@ -0,0 +1,120 @@ +Macro ArrayCopy

      Macro ArrayCopy

      + +
      + + + + + + + + + + + + + + + + + + + + + + + + + + +
      +

      Text-x-python.png ArrayCopy

      +
      Description +
      This macro copies the selected object several times, on an array grid +
      Author +
      Yorik +
      Links +
      Macros recipes
      How to install macros
      How to customize toolbars +
      Version +
      1.0 +
      Date last modification +
      2014-05-04 +
      +

      Contents

      + +
      + +
      +


      +

      This macro copies the selected object several times, on an array grid. You can define the number of rows and columns and the distance between them. +


      +

      +
      import FreeCAD, FreeCADGui, Part
      +from PySide import QtGui,QtCore
      + 
      +def proceed():
      +    try:
      +        u = (int(l1.text()),float(l2.text()))   
      +        v = (int(l3.text()),float(l4.text()))
      +    except:
      +        FreeCAD.Console.PrintError("Wrong input! Only numbers allowed...\n")
      +    sel = FreeCADGui.Selection.getSelection()
      +    if sel:
      +        sel = sel[0]
      +        name = sel.Name   
      +        shape = sel.Shape
      +        for column in range(u[0]):
      +            for row in range(v[0]):
      +                if (column != 0) or (row != 0):
      +                    delta = FreeCAD.Vector(column*u[1],row*v[1],0)   
      +                    newshape = sel.Shape.copy()
      +                    newshape.translate(delta)
      +                    newobject = FreeCAD.ActiveDocument.addObject("Part::Feature",name)
      +                    newobject.Shape = newshape
      +    else:
      +        FreeCAD.Console.PrintError("Error: One object must be selected")
      +    hide()
      + 
      +def hide():
      +    dialog.hide()
      + 
      +dialog = QtGui.QDialog()
      +dialog.resize(200,300)
      +dialog.setWindowTitle("Array")
      +la = QtGui.QVBoxLayout(dialog)
      +t1 = QtGui.QLabel("number of columns")
      +la.addWidget(t1)
      +l1 = QtGui.QLineEdit()
      +la.addWidget(l1)
      +t2 = QtGui.QLabel("distance between columns")
      +la.addWidget(t2)
      +l2 = QtGui.QLineEdit()
      +la.addWidget(l2)
      +t3 = QtGui.QLabel("number of rows")
      +la.addWidget(t3)
      +l3 = QtGui.QLineEdit()
      +la.addWidget(l3)
      +t4 = QtGui.QLabel("distance between rows")   
      +la.addWidget(t4)
      +l4 = QtGui.QLineEdit()
      +la.addWidget(l4)
      +okbox = QtGui.QDialogButtonBox(dialog)
      +okbox.setOrientation(QtCore.Qt.Horizontal)
      +okbox.setStandardButtons(QtGui.QDialogButtonBox.Cancel 
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Macro_Assemblage_Imprimante_3D.html b/localwiki/Macro_Assemblage_Imprimante_3D.html new file mode 100644 index 0000000..0505a03 --- /dev/null +++ b/localwiki/Macro_Assemblage_Imprimante_3D.html @@ -0,0 +1,156 @@ +Macro Assemblage Imprimante 3D

      Macro Assemblage Imprimante 3D

      + +
      + + + + + + + + + + + + + + + + + + + + + + + + + + +
      +

      Text-x-python.png Macro_Assemblage_Imprimante_3D

      +
      Description +
      Simulates the motion of a 3D printer in the Z axis.. +
      Author +
      fran6t +
      Links +
      Macros recipes
      How to install macros
      How to customize toolbars +
      Version +
      1.0 +
      Date last modification +
      2015-07-13 +
      +

      + +
      +


      +

      Simulates the motion of a 3D printer in the Z axis. +

      +
      Assemblage Imprimante 3D.gif
      +

      Uses

      +

      Download the file and open it in FreeCAD +

      Copy the macro and paste in the console Python and anjoy +

      To stop the animation tip : +

      +
      animation.stop() 
      +

      The File

      +

      00_assemblage_total.fcstd +

      +

      Script

      +

      The script author is Javier Martínez García (JMG) and has been adapted for this project. +

      00-assemblage-total.FCMacro +

      +
      # Mouvement va et vient du chariot et tete selon axe Z
      +#
      +# Pour arreter l'animation il faut taper animation.stop() dans la console
      +
      +__author__ = "Javier Martínez García"
      +
      +import FreeCAD as App, FreeCADGui as Gui, Part, time, sys, math, Draft, DraftGeomUtils
      +
      +try:
      +    from PyQt4 import QtGui,QtCore
      +except Exception:
      +    from PySide import QtGui,QtCore
      +
      +class Animation(object):
      +   def __init__(self):
      +      App.Console.PrintMessage('init')
      +      App.ActiveDocument.recompute()
      +      self.timer = QtCore.QTimer()
      +      QtCore.QObject.connect(self.timer, QtCore.SIGNAL("timeout()"), self.my_update)
      +      self.timer.start(50)
      +
      +      self.an = 0
      +      self.Tige_Guide_X = 142
      +      self.X_End_Tendeur = 90
      +      self.X_Chariot = 102
      +      self.Nema_17_motor_X = 119
      +      self.Anti_Backslash_Z_Gauche = 88
      +      self.Jhead_droite = 126.5
      +      self.enstopX = 168
      +      self.sens = 1
      +
      +   def my_update(self):
      +      if ( self.an == 0 ) :
      +         self.sens = 1
      +      if ( self.an == 245 ) :
      +         self.sens = -1
      +      self.an = self.an + self.sens
      +      self.Tige_Guide_X = self.Tige_Guide_X + self.sens
      +      self.X_End_Tendeur = self.X_End_Tendeur + self.sens
      +      self.X_Chariot = self.X_Chariot + self.sens
      +      self.Nema_17_motor_X = self.Nema_17_motor_X + self.sens
      +      self.Jhead_droite = self.Jhead_droite + self.sens
      +      self.Anti_Backslash_Z_Gauche = self.Anti_Backslash_Z_Gauche + self.sens
      +      self.enstopX = self.enstopX + self.sens
      +
      +      #12-X-End-Moteur
      +      #FreeCAD.getDocument("_0_assemblage_total").getObject("Pocket013").Placement = App.Placement(App.Vector(-133,0,self.an),App.Rotation(App.Vector(0,0,1),0))
      +      FreeCAD.getDocument("_0_assemblage_total").getObject("refine002").Placement = App.Placement(App.Vector(0,0,self.an),App.Rotation(App.Vector(0,0,1),0))      
      +      #Tige-Guide-X      
      +      FreeCAD.getDocument("_0_assemblage_total").getObject("Pad025").Placement = App.Placement(App.Vector(-180,13.55,self.Tige_Guide_X),App.Rotation(App.Vector(0.57735,0.57735,0.57735),120))
      +      #14-X-End-Tendeur      
      +      FreeCAD.getDocument("_0_assemblage_total").getObject("Pocket011").Placement = App.Placement(App.Vector(236,0,self.X_End_Tendeur),App.Rotation(App.Vector(0,0,1),0))
      +      #13-X-Chariot
      +      FreeCAD.getDocument("_0_assemblage_total").getObject("Pocket014").Placement = App.Placement(App.Vector(-18,25,self.X_Chariot),App.Rotation(App.Vector(1,0,0),90))
      +      #Nema-17-motor-X
      +      FreeCAD.getDocument("_0_assemblage_total").getObject("Chamfer003").Placement = App.Placement(App.Vector(-205.2,63,self.Nema_17_motor_X),App.Rotation(App.Vector(1,0,0),90))
      +      #15-Anti-Backslash-Z-x2-1
      +      FreeCAD.getDocument("_0_assemblage_total").getObject("Pad012").Placement = App.Placement(App.Vector(-156,-15,self.Anti_Backslash_Z_Gauche),App.Rotation(App.Vector(0.999985,0.00555547,0),180))
      +      #Jhead-Droite
      +      FreeCAD.getDocument("_0_assemblage_total").getObject("Pocket015").Placement = App.Placement(App.Vector(-50.8,-4.4,self.Jhead_droite),App.Rotation(App.Vector(0,0,1),0))
      +      #Endstop X
      +      FreeCAD.getDocument("_0_assemblage_total").getObject("refine003").Placement = App.Placement(App.Vector(-154.2,15,self.enstopX),App.Rotation(App.Vector(0.57735,0.57735,-0.57735),120))
      +   def stop(self):
      +      self.timer.stop()     
      +
      +animation = Animation() 
      +

      Link

      +

      The forum discussion page: Je galere pour tourner une piece +

      The Youtube channel of the macro author FreeCAD: Gear Animation Tutorial and its blog +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Macro_Assembly.html b/localwiki/Macro_Assembly.html new file mode 100644 index 0000000..7ebfaae --- /dev/null +++ b/localwiki/Macro_Assembly.html @@ -0,0 +1,343 @@ +Macro Assembly

      Macro Assembly

      + +
      + + + + + + + + + + + + + + + + + + + + + + + + + + +
      +

      Text-x-python.png Assy Simul

      +
      Description +
      FreeCad Python assembly animation. +
      Author +
      ralvejd +
      Links +
      Macros recipes
      How to install macros
      How to customize toolbars +
      Version +
      1.0 +
      Date last modification +
      2014-08-08 +
      +

      + +
      +


      +

      Simulate assembly . +

      +
      Assy.gif
      +


      +

      +

      Uses

      +

      Download the files in FreeCAD and run the macro +

      +

      The File

      +

      Assy.fcstd +

      +

      Script

      +
      #******************************************************************************
      +#
      +# Assembly animation by Joakim Isaksson 20140803
      +#
      +#******************************************************************************
      +
      +import FreeCAD, FreeCADGui, Draft, Part
      +from FreeCAD import Gui
      +import math
      +from pivy import coin
      +from PySide import QtCore, QtGui
      +from time import sleep
      +
      +# + + + + + + BEGIN Animation configuration  + + + + + +
      +
      +doc_name = "Assy"      # The document name of the FreeCAD model
      +ani_startwait = 3000   # Milliseconds before the animation starting
      +ani_partwait   = 50   # Milliseconds before the part begin to move
      +ani_bitrate = 10      # Milliseconds between part moves
      +ani_dist = 5         # Distance part moves each time
      +ani_offset_dist = 200   # Distance part is moved before the animation starts
      +
      +# Tuples for all parts label
      +#  *  First item in Tuples is the animation view angle
      +#  *  The remaining items are label on parts to be assembled in list sequence
      +ani_1  = ( "z-" , "ChassieBack_001" , "ChassieWall_001" , "ChassieWall_002" ,
      +           "ChassieWall_003" , "ChassieWall_004" , "ChassieWall_005" ,
      +           "ChassieFront_001" ) ;
      +ani_2  = ( "z-" , "ISO4762_M4x12_001" , "ISO4762_M4x12_002" ,
      +           "ISO4762_M4x12_003" , "ISO4762_M4x12_004" , "ISO4762_M4x12_005" ,
      +           "ISO4762_M4x12_006" , "ISO4762_M4x12_007" , "ISO4762_M4x12_008" ,
      +           "ISO4762_M4x12_009" , "ISO4762_M4x12_010" ) ;
      +ani_3  = ( "z+" , "ISO4762_M4x12_011" , "ISO4762_M4x12_012" ,
      +           "ISO4762_M4x12_013" , "ISO4762_M4x12_014" , "ISO4762_M4x12_015" ,
      +           "ISO4762_M4x12_016" , "ISO4762_M4x12_017" , "ISO4762_M4x12_018" ,
      +           "ISO4762_M4x12_019" , "ISO4762_M4x12_020" ) ;
      +ani_4  = ( "z+" , "EuroCard_001" , "EuroCard_002" , "EuroCard_003" ,
      +           "EuroCard_004" ) ;
      +ani_5  = ( "z+" , "Panel_005" ,  "Panel_006" , "Panel_007" , "Panel_008" ) ;
      +ani_6  = ( "z+" , "ISO7380_M3x8_" , "ISO7380_M3x8_001" , "ISO7380_M3x8_002" ,
      +           "ISO7380_M3x8_003" , "ISO7380_M3x8_004" , "ISO7380_M3x8_005" ,
      +           "ISO7380_M3x8_006" , "ISO7380_M3x8_007" , "ISO7380_M3x8_008" ,
      +           "ISO7380_M3x8_009" ) ;
      +ani_7  = ( "z-" , "Panel_001" , "Panel_002" , "Panel_003" , "Panel_004" ) ;
      +ani_8  = ( "z-" , "ISO7380_M3x8_010" , "ISO7380_M3x8_011" ,
      +           "ISO7380_M3x8_012" , "ISO7380_M3x8_013" , "ISO7380_M3x8_014" ,
      +           "ISO7380_M3x8_015" , "ISO7380_M3x8_016" , "ISO7380_M3x8_017" ,
      +           "ISO7380_M3x8_018" , "ISO7380_M3x8_019" ) ;
      +ani_9  = ( "y-" , "LidBottom_001" ) ;
      +ani_10 = ( "y-" , "ISO10642_M3x8_" , "ISO10642_M3x8_001" ,
      +           "ISO10642_M3x8_002" , "ISO10642_M3x8_003" , "ISO10642_M3x8_004" ,
      +           "ISO10642_M3x8_005" , "ISO10642_M3x8_006" , "ISO10642_M3x8_007" ,
      +           "ISO10642_M3x8_008" , "ISO10642_M3x8_009" ) ;
      +ani_11 = ( "y+" , "LidTop_001" ) ;
      +ani_12 = ( "y+" , "ISO10642_M3x8_010" , "ISO10642_M3x8_011" ,
      +           "ISO10642_M3x8_012" , "ISO10642_M3x8_013" , "ISO10642_M3x8_014" ,
      +           "ISO10642_M3x8_015" , "ISO10642_M3x8_016" , "ISO10642_M3x8_017" ,
      +           "ISO10642_M3x8_018" , "ISO10642_M3x8_019" ) ;
      +
      +# Set the animation end view
      +ani_end = "z-"
      +
      +# Camera oriantations
      +#  *  Edit this tuples to your need
      +rear_view_pos    = ( -400 , -80 , 480 ) ;
      +rear_view_ang    = ( 0 , 1 , 0  ) ;
      +front_view_pos    = ( -400 , 80 , 480 ) ;
      +front_view_ang    = ( 0 , -1 , 0  ) ;
      +top_view_pos    = ( -400 , -80 , 480  ) ;
      +top_view_ang    = ( -1 , 0 , 0 ) ;
      +bottom_view_pos = ( -400 , 80 , -480 );
      +bottom_view_ang = ( 1 , 0 , 0 ) ;
      +
      +# + + + + + + END Animation configuration  + + + + + +
      +
      +# + + + + + + Function  + + + + + +
      +
      +def pulse(milliseconds):
      +   for i in range(milliseconds/10  ):
      +      Gui.updateGui( )
      +      sleep(0.01)
      +
      +def setView(axis_vector, rotation_vector):
      +   r=App.Rotation(App.Vector(axis_vector),App.Vector(rotation_vector))
      +   Gui.ActiveDocument.ActiveView.setCameraOrientation(r.Q)
      +
      +def getPartName(label):
      +   for i in App.ActiveDocument.Objects:
      +      if str(i.Label) == label:
      +         #App.Console.PrintMessage(str(i.Name) + "  <->  " + i.Label + "\n")
      +         return str(i.Name)
      +
      +def animate(aniList):
      +   total = len(aniList)
      +   for n in range(1,total):
      +      direction = aniList[0]
      +      #App.Console.PrintMessage(str(aniList) + " : " + str(direction) + "\n")
      +      part_name = getPartName(aniList[n])
      +      tmpX = App.getDocument(doc_name).getObject(part_name).Placement.Base[0]
      +      tmpY = App.getDocument(doc_name).getObject(part_name).Placement.Base[1]
      +      tmpZ = App.getDocument(doc_name).getObject(part_name).Placement.Base[2]
      +      tmpRotation=App.ActiveDocument.getObject(part_name).Placement.Rotation
      +      #Show the part
      +      if direction == "x+":   #TODO not tested
      +         setView(rear_view_pos , rear_view_ang)
      +         tmpDist = tmpX + ani_offset_dist
      +         sel = FreeCADGui.Selection.clearSelection (doc_name )
      +         App.ActiveDocument.getObject(part_name).Placement=App.Placement\
      +               (App.Vector(tmpX,tmpDist,tmpZ), App.Rotation(tmpRotation),\
      +                App.Vector(0,0,0))
      +         Gui.getDocument(doc_name).getObject(part_name).Visibility=True
      +         pulse(ani_partwait)
      +         
      +         for i in range(0,ani_step):
      +            tmpDist = tmpDist - ani_dist
      +            App.ActiveDocument.getObject(part_name).Placement=\
      +                   App.Placement(App.Vector(tmpX,tmpDist,tmpZ),\
      +                   App.Rotation(tmpRotation), App.Vector(0,0,0))
      +            pulse(ani_bitrate)
      +
      +      elif direction == "x-":   #TODO not tested
      +         setView(front_view_pos , front_view_ang)
      +         tmpDist = tmpX - ani_offset_dist
      +         sel = FreeCADGui.Selection.clearSelection (doc_name )
      +         App.ActiveDocument.getObject(part_name).Placement=App.Placement\
      +               (App.Vector(tmpX,tmpDist,tmpZ),\
      +               App.Rotation(tmpRotation), App.Vector(0,0,0))
      +         Gui.getDocument(doc_name).getObject(part_name).Visibility=True
      +         pulse(ani_partwait)
      +         
      +         for i in range(0,ani_step):
      +            tmpDist = tmpDist + ani_dist
      +            App.ActiveDocument.getObject(part_name).Placement=App.\
      +                   Placement(App.Vector(tmpX,tmpDist,tmpZ),\
      +                   App.Rotation(tmpRotation), App.Vector(0,0,0))
      +            pulse(ani_bitrate)
      +
      +      elif direction == "y+":
      +         setView(rear_view_pos , rear_view_ang)
      +         tmpDist = tmpY + ani_offset_dist
      +         sel = FreeCADGui.Selection.clearSelection (doc_name )
      +         App.ActiveDocument.getObject(part_name).Placement=App.Placement\
      +               (App.Vector(tmpX,tmpDist,tmpZ), App.Rotation(tmpRotation),\
      +               App.Vector(0,0,0))
      +         Gui.getDocument(doc_name).getObject(part_name).Visibility=True
      +         pulse(ani_partwait)
      +         
      +         for i in range(0,ani_step):
      +            tmpDist = tmpDist - ani_dist
      +            App.ActiveDocument.getObject(part_name).Placement=App.\
      +                   Placement(App.Vector(tmpX,tmpDist,tmpZ),\
      +                   App.Rotation(tmpRotation),App.Vector(0,0,0))
      +            pulse(ani_bitrate)
      +
      +      elif direction == "y-":
      +         setView(front_view_pos , front_view_ang)
      +         tmpDist = tmpY - ani_offset_dist
      +         sel = FreeCADGui.Selection.clearSelection (doc_name )
      +         App.ActiveDocument.getObject(part_name).Placement=App.Placement\
      +               (App.Vector(tmpX,tmpDist,tmpZ), App.Rotation(tmpRotation),\
      +               App.Vector(0,0,0))
      +         Gui.getDocument(doc_name).getObject(part_name).Visibility=True
      +         pulse(ani_partwait)
      +         
      +         for i in range(0,ani_step):
      +            tmpDist = tmpDist + ani_dist
      +            App.ActiveDocument.getObject(part_name).Placement=App.\
      +                   Placement(App.Vector(tmpX,tmpDist,tmpZ),\
      +                   App.Rotation(tmpRotation), App.Vector(0,0,0))
      +            pulse(ani_bitrate)
      +
      +      elif direction == "z+":
      +         setView(top_view_pos , top_view_ang)
      +         tmpDist = tmpZ +ani_offset_dist
      +         sel = FreeCADGui.Selection.clearSelection (doc_name )
      +         App.ActiveDocument.getObject(part_name).Placement=App.Placement\
      +               (App.Vector(tmpX,tmpY,tmpDist), App.Rotation(tmpRotation),\
      +               App.Vector(0,0,0))
      +         Gui.getDocument(doc_name).getObject(part_name).Visibility=True
      +         pulse(ani_partwait)
      +         
      +         for i in range(0,ani_step):
      +            tmpDist = tmpDist - ani_dist
      +            App.ActiveDocument.getObject(part_name).Placement=App.\
      +                   Placement(App.Vector(tmpX,tmpY,tmpDist),\
      +                   App.Rotation(tmpRotation), App.Vector(0,0,0))
      +            pulse(ani_bitrate)
      +
      +      elif direction == "z-":
      +         setView(bottom_view_pos , bottom_view_ang)
      +         tmpDist = tmpZ - ani_offset_dist
      +         sel = FreeCADGui.Selection.clearSelection (doc_name )
      +         App.ActiveDocument.getObject(part_name).Placement=App.Placement\
      +               (App.Vector(tmpX,tmpY,tmpDist), App.Rotation(tmpRotation),\
      +               App.Vector(0,0,0))
      +         Gui.getDocument(doc_name).getObject(part_name).Visibility=True
      +         pulse(ani_partwait)
      +         
      +         for i in range(0,ani_step):
      +            tmpDist = tmpDist + ani_dist
      +            App.ActiveDocument.getObject(part_name).Placement=App.\
      +                   Placement(App.Vector(tmpX,tmpY,tmpDist),\
      +                   App.Rotation(tmpRotation), App.Vector(0,0,0))
      +            pulse(ani_bitrate)
      +
      +def theend(direction):
      +   if direction == "x+":
      +      setView(rear_view_pos , rear_view_ang)
      +   elif direction == "x-":
      +      setView(front_view_pos , front_view_ang)
      +   elif direction == "y+":
      +      setView(rear_view_pos , rear_view_ang)
      +   elif direction == "y-":
      +      setView(front_view_pos , front_view_ang)
      +   elif direction == "z+":
      +      setView(top_view_pos , top_view_ang)
      +   elif direction == "z-":
      +      setView(bottom_view_pos , bottom_view_ang)
      +
      +def startAnimation():
      + # Animation sequence
      +   animate(ani_1)
      +   animate(ani_2)
      +   animate(ani_3)
      +   animate(ani_4)
      +   animate(ani_5)
      +   animate(ani_6)
      +   animate(ani_7)
      +   animate(ani_8)
      +   animate(ani_9)
      +   animate(ani_10)
      +   animate(ani_11)
      +   animate(ani_12)
      +   theend(ani_end)
      +   Gui.ActiveDocument.ActiveView.startAnimating(0,1,0,0.2) #TODO fixit
      +
      +# + + + + + + Main + + + + + +
      +# Set full screen
      +App.setActiveDocument(doc_name)
      +App.ActiveDocument=App.getDocument(doc_name)
      +ActiveDocument=Gui.getDocument(doc_name)
      +Gui.updateGui ( )
      +mw=QtGui.qApp.activeWindow()
      +ev=QtGui.QKeyEvent(QtCore.QEvent.KeyPress,\
      +   QtCore.Qt.Key_F11,QtCore.Qt.NoModifier)
      +QtGui.qApp.sendEvent(mw,ev)
      +
      +# A short break for the GUI to catch up
      +pulse(ani_startwait)
      +
      +# Adjust ani_offset if Modulus != 0
      +ani_offset_dist = ani_offset_dist - ani_offset_dist % ani_dist
      +
      +# Calculate the required number of steps for the animation
      +ani_step = ani_offset_dist / ani_dist
      +
      +startAnimation() 
      +

      Link

      +

      The page discussion FreeCad Python assembly animation +

      See the animation on YouTube. +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Macro_Automatic_drawing.html b/localwiki/Macro_Automatic_drawing.html new file mode 100644 index 0000000..4d963c4 --- /dev/null +++ b/localwiki/Macro_Automatic_drawing.html @@ -0,0 +1,150 @@ +Macro Automatic drawing

      Macro Automatic drawing

      + +
      + + + + + + + + + + + + + + + + + + + + + + + + + + +
      +

      Text-x-python.png Automatic drawing

      +
      Description +
      This code allow the user to get the view of his object in a drawing with 4 different position(front,top,iso,right). Needs some modification to be perfectly effective. +
      Author +
      unknown +
      Links +
      Macros recipes
      How to install macros
      How to customize toolbars +
      Version +
      1.0 +
      Date last modification +
      2016-09-26 +
      +

      + +
      +


      +

      This code generates a Drawing page with three orthographic views (front, top and right) aligned to each other, and an isometric view placed at the top right of the page. It calculates the scale based on the model size and space available on the sheet. The iso view is scaled to 2/3 of the ortho views.
      +It uses the first-angle projection. +

      +

      How to use

      +

      An object needs to be selected before launching the macro. +

      +

      Limitations

      +
      • Scale is not standard. You may need to change the views manually to a standard scale.
      • +
      • It only works with a single object (this is a limitation from the Drawing Workbench)
      • +
      • Needs to be modified to work for third-angle projection used in the US and Canada.
      +

      The script

      +
      import FreeCAD, Part, Drawing
      +if len(Gui.Selection.getSelectionEx())>1:
      +   App.Console.PrintError("Warning: Only the first item is generate")
      +if len(Gui.Selection.getSelectionEx())==0:
      +   App.Console.PrintError("Warning: Need to select one item")
      +Piece=Gui.Selection.getSelectionEx()[0]
      +App.activeDocument().addObject('Drawing::FeaturePage','AutoDrawing')
      +App.activeDocument().AutoDrawing.Template = App.getResourceDir()+'Mod/Drawing/Templates/A3_Landscape.svg'
      +DH=20
      +DL=30
      +L=Piece.Object.Shape.BoundBox.XMax
      +H=Piece.Object.Shape.BoundBox.ZMax
      +P=Piece.Object.Shape.BoundBox.YMax
      +Sc=(400-3*DL)/(L+H)
      +Sc2=(250-3*DH)/(P+H)
      +if Sc>Sc2 : 
      +   Sc=Sc2
      +TopX=DL+Sc*L
      +FrontX=DL+Sc*L
      +RightX=2*DL+Sc*L
      +IsoX=2*DL+Sc*(L)
      +TopY=DH+Sc*P
      +RightY=DH+P*Sc
      +FrontY=2*DH+Sc*(P+H)
      +IsoY=2*DH+Sc*P
      +
      +print TopX,RightX,TopY,FrontY
      +
      +#Create topView
      +App.activeDocument().addObject('Drawing::FeatureViewPart','topView')
      +App.activeDocument().topView.Source =Piece.Object
      +App.activeDocument().topView.Direction = (0,0,1)
      +App.activeDocument().topView.Rotation=180
      +App.activeDocument().topView.X = TopX
      +App.activeDocument().topView.Y = TopY
      +App.activeDocument().topView.ShowHiddenLines=True
      +App.activeDocument().AutoDrawing.addObject(App.activeDocument().topView)
      +App.activeDocument().topView.Scale = Sc
      +#Create FrontView
      +App.activeDocument().addObject('Drawing::FeatureViewPart','FrontView')
      +App.activeDocument().FrontView.Source =Piece.Object
      +App.activeDocument().FrontView.Direction = (0,-1,0)
      +App.activeDocument().FrontView.Rotation=90
      +App.activeDocument().FrontView.Scale = Sc
      +App.activeDocument().FrontView.X = FrontX
      +App.activeDocument().FrontView.Y = FrontY
      +App.activeDocument().FrontView.ShowHiddenLines=True
      +App.activeDocument().AutoDrawing.addObject(App.activeDocument().FrontView)
      +#Create RightView
      +App.activeDocument().addObject('Drawing::FeatureViewPart','RightView')
      +App.activeDocument().RightView.Source =Piece.Object
      +App.activeDocument().RightView.Direction = (1,0,0)
      +App.activeDocument().RightView.Scale = Sc
      +App.activeDocument().RightView.X = RightX
      +App.activeDocument().RightView.Y = RightY
      +App.activeDocument().RightView.ShowHiddenLines=True
      +App.activeDocument().AutoDrawing.addObject(App.activeDocument().RightView)
      +#Create IsotView
      +App.activeDocument().addObject('Drawing::FeatureViewPart','IsoView')
      +App.activeDocument().IsoView.Source =Piece.Object
      +App.activeDocument().IsoView.Direction = (1,1,1)
      +App.activeDocument().IsoView.Rotation=60
      +App.activeDocument().IsoView.Scale = Sc*.6
      +App.activeDocument().IsoView.X = IsoX
      +App.activeDocument().IsoView.Y = IsoY
      +App.activeDocument().IsoView.ShowHiddenLines=True
      +App.activeDocument().AutoDrawing.addObject(App.activeDocument().IsoView) 
      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Macro_BOLTS.html b/localwiki/Macro_BOLTS.html new file mode 100644 index 0000000..715d8ab --- /dev/null +++ b/localwiki/Macro_BOLTS.html @@ -0,0 +1,86 @@ +Macro BOLTS

      Macro BOLTS

      + +
      + + + + + + + + + + + + + + + + + + + + + + + + + + +
      +

      Macro BOLTS.png BOLTS

      +
      Description +
      BOLTS tries to provide a library of common and standard parts for FreeCAD +
      Author +
      jreinhardt +
      Links +
      Macros recipes
      How to install macros
      How to customize toolbars +
      Version +
      01.00 +
      Date last modification +
      2013-11-08 +
      +

      + +
      +


      +

      The aim of BOLTS is to build a free and open-source standard parts library for CAD applications. It does so by providing a common database that can be utilized by many different CAD applications, and leveraging the parametric power of FreeCAD to create many different variatiants and sizes of a part. +

      BOLTS for FreeCAD provides a widget that allows to insert parts into the active document. Sizes and variants of a part can be selected in the widget, and the part is given a descriptive label. +

      +
      The BOLTS widget and a bearing from BOLTS
      +
      +


      +More information about BOLTS can be found on its webpage. +

      The webpage also provides a list of all the parts that BOLTS currently includes, including drawings and tables with dimensions. +

      note: BOLTS is also part of the FreeCAD addons and can be installed from the addons installer macro +

      +

      How to use

      +

      There are detailed instruction in the Documentation section of the webpage: +

      +
      • How to install BOLTS for FreeCAD
      • +
      • How to setup a toolbar button for BOLTS
      • +
      • How to use BOLTS for FreeCAD
      +

      Contribute

      +

      A library of parts that is useful for a broad range of people can only be realised as a community effort. There are many possibilities to contribute to BOLTS in a number of different ways. +

      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Macro_BoundingBox_Tracing.html b/localwiki/Macro_BoundingBox_Tracing.html new file mode 100644 index 0000000..e99e3c9 --- /dev/null +++ b/localwiki/Macro_BoundingBox_Tracing.html @@ -0,0 +1,444 @@ +Macro BoundingBox Tracing

      Macro BoundingBox Tracing

      + +
      + + + + + + + + + + + + + + + + + + + + + + + + + + +
      +

      BoundBoxTracing.png Macro BoundingBox Tracing

      +
      Description +
      This macro red trace (editable) around the BoundingBox with 6 rectangles. +
      Author +
      Mario52 +
      Links +
      Macros recipes
      How to install macros
      How to customize toolbars +
      Version +
      0.7 +
      Date last modification +
      2018-01-28 +
      +

      + +
      +


      +

      +

      Description

      +

      This macro red trace (editable) around the BoundingBox 6 Faces with 6 rectangles. +

      CenterFace +

      +
      +


      +

      +

      Use

      +

      Select the object and launch the macro. 6 rectangles are colored red (can be changed) +

      Info contener +

      +
      +


      +If createVol = 1 (Line 33) one volume is created +

      To change the color or other options change the values lines 31 to 49 Section configuration +

      +
      ##exampleCode##
      +##### Section configuration begin ##################
      +##### for volume begin ###################
      +createVol         = 1           # give 1 for create Volume # mettre a 1 pour creer un volume
      +createDimVol      = 1           # 1 = create dimension info : 0 = not dimension info
      +
      +##### for volume end   ###################
      +
      +##### for dimensions info begin ##########
      +createDim         = 1           # 1 = create dimension info : 0 = not create dimension info
      +DisplayModeText   = "Screen"    # available : "Screen" or "World"
      +JustificationText = "Center"    # available : "Center" or "Left" or "Right"
      +FontSizeText      = 10.0        # text info dimension
      +TextColorText_R   = 0.0         # text color info red      1 = 255
      +TextColorText_G   = 0.0         # text color info green    1 = 255
      +TextColorText_B   = 0.0         # text color info blue     1 = 255
      +arondi            = 3           # round the info ex: 3 = 3 decimals
      +
      +##### for dimensions info end   ##########
      +##### Section configuration end #################### 
      +

      Icon

      +

      Download the file image and copy in your macro repertory. +

      Click the image, in the new window position the mouse over the image, click the right mouse and do "Save target as ..." +

      Button +

      +

      Macro

      +

      Macro_BoundingBox_Tracing.FCMacro +

      +
      # -*- coding: utf-8 -*-
      +# cette macro trace en rouge (modifiable) le tour du boundingbox avec 6 rectangles
      +# si "createVol" = 1 il sera cree un volume (rouge) de la dimension du BoundBox
      +# this macro red trace (editable) around the BoundingBox with 6 rectangles
      +# if "createVol" = 1 on volume (red) is created 
      +# Macro_BoundingBox_Tracing
      +#
      +#OS: Windows Vista       #OS: Windows 8.1                                  #OS: Windows 10
      +#Platform: 32-bit        #Word size of OS: 64-bit                          #Word size of OS: 64-bit
      +#Version: 0.14.3389      #Word size of FreeCAD: 64-bit                     #Word size of FreeCAD: 64-bit
      +#Python version: 2.6.2   #Version: 0.15.4671 (Git)                         #Version: 0.16.6700 (Git)
      +#Qt version: 4.5.2       #Branch: releases/FreeCAD-0-15                    #Build type: Release
      +#Coin version: 3.1.0     #Hash: 244b3aef360841646cbfe80a1b225c8b39c8380c   #Branch: releases/FreeCAD-0-16
      +#SoQt version: 1.4.1     #Python version: 2.7.8                            #Hash: 7b925d11aa69ac405b423635adb1e2833f18a817
      +#OCC version: 6.5.1      #Qt version: 4.8.6                                #Python version: 2.7.8
      +#                        #Coin version: 4.0.0a                             #Qt version: 4.8.6
      +#                        #OCC version: 6.8.0.oce-0.17                      #Coin version: 4.0.0a
      +                                                                           #OCC version: 6.8.0.oce-0.17
      +
      +__title__   = "BoundingBox_Tracing"
      +__author__  = "Mario52"
      +__url__     = "http://www.freecadweb.org/index-fr.html"
      +__Wiki__    = "https://www.freecadweb.org/wiki/Macro_BoundingBox_Tracing"
      +__version__ = "0.7"
      +__date__    = "28/01/2018"
      +
      +
      +import FreeCAD, FreeCADGui, Draft, Part
      +App = FreeCAD
      +
      +##### Section configuration begin ##################
      +##### for volume begin ###################
      +createVol         = 1           # give 1 for create Volume # mettre a 1 pour creer un volume
      +createDimVol      = 1           # 1 = create dimension info : 0 = not dimension info
      +
      +##### for volume end   ###################
      +
      +##### for dimensions info begin ##########
      +createDim         = 1           # 1 = create dimension info : 0 = not create dimension info
      +DisplayModeText   = "Screen"    # available : "Screen" or "World"
      +JustificationText = "Center"    # available : "Center" or "Left" or "Right"
      +FontSizeText      = 10.0        # text info dimension
      +TextColorText_R   = 0.0         # text color info red      1 = 255
      +TextColorText_G   = 0.0         # text color info green    1 = 255
      +TextColorText_B   = 0.0         # text color info blue     1 = 255
      +arondi            = 3           # round the info ex: 3 = 3 decimals
      +
      +##### for dimensions info end   ##########
      +##### Section configuration end ####################
      +
      +sel   = FreeCADGui.Selection.getSelection()
      +selEx = FreeCADGui.Selection.getSelectionEx()
      +objs  = [selobj.Object for selobj in selEx]
      +    
      +if len(objs) >= 1:
      +    if hasattr(objs[0], "Shape"):
      +        s = objs[0].Shape
      +    elif hasattr(objs[0], "Mesh"):      # upgrade with wmayer thanks #http://forum.freecadweb.org/viewtopic.php?f=13&t=22331
      +        s = objs[0].Mesh
      +    elif hasattr(objs[0], "Points"):
      +        s = objs[0].Points
      +
      +    try:
      +        # LineColor
      +        red   = 1.0  # 1 = 255
      +        green = 0.0  #
      +        blue  = 0.0  #
      +    
      +        # boundBox
      +        boundBox_ = s.BoundBox
      +        boundBoxLX = boundBox_.XLength
      +        boundBoxLY = boundBox_.YLength
      +        boundBoxLZ = boundBox_.ZLength
      +        nameLabel  = sel[0].Label
      +        import unicodedata    
      +        nameLabel  = unicodedata.normalize('NFKD', nameLabel).encode('ascii','ignore')
      +
      +        a = str(boundBox_)
      +        a,b = a.split('(')
      +        c = b.split(',')
      +        oripl_X = float(c[0])
      +        oripl_Y = float(c[1])
      +        oripl_Z = float(c[2])
      +    
      +        App.Console.PrintMessage(str(boundBox_)+"\r\n")
      +        App.Console.PrintMessage("Rectangle      : "+str(boundBoxLX)+" x "+str(boundBoxLY)+" x "+str(boundBoxLZ)+"\r\n")
      +    
      +        if (createVol == 1) and (boundBoxLX > 0) and (boundBoxLY > 0) and (boundBoxLZ > 0):  # Create Volume
      +            BDvol = App.ActiveDocument.addObject("Part::Box",nameLabel + "_BoundBoxVolume")
      +            #BDvol.Label = "BoundBoxVolume"
      +            BDvol.Length.Value = boundBoxLX
      +            BDvol.Width.Value  = boundBoxLY
      +            BDvol.Height.Value = boundBoxLZ
      +            BDvol.Placement=App.Placement(App.Vector(oripl_X,oripl_Y,oripl_Z), App.Rotation(App.Vector(0,0,1),0), App.Vector(0,0,0))
      +            FreeCADGui.ActiveDocument.getObject(BDvol.Name).LineColor  = (red, green, blue)
      +            FreeCADGui.ActiveDocument.getObject(BDvol.Name).PointColor = (red, green, blue)
      +            FreeCADGui.ActiveDocument.getObject(BDvol.Name).ShapeColor = (red, green, blue)
      +            FreeCADGui.ActiveDocument.getObject(BDvol.Name).Transparency = 80
      +            App.Console.PrintMessage(nameLabel + "_BoundBoxVolume : " + str(BDvol.Shape.Volume)+"\r\n")
      +    
      +            if createDimVol == 1:    # section create dimension info for volume
      +                conteneurVol = []
      +                del conteneurVol[:]
      +                conteneurVol = App.activeDocument().addObject("App::DocumentObjectGroup",nameLabel + "_BoundBoxVolume_Info")
      +    
      +                pl_0C1 = Draft.makeText([str(round(boundBoxLX,arondi))],point=FreeCAD.Vector(oripl_X + (boundBoxLX/2), oripl_Y, oripl_Z))
      +                pl_0C1.ViewObject.DisplayMode   = DisplayModeText
      +                pl_0C1.ViewObject.Justification = JustificationText
      +                pl_0C1.ViewObject.TextColor     = (TextColorText_R, TextColorText_G, TextColorText_B)
      +                pl_0C1.ViewObject.FontSize      = FontSizeText
      +                pl_0C1.Label      = nameLabel + "_Volume_X_" + str(round(boundBoxLX,arondi))
      +                conteneurVol.addObject(pl_0C1)
      +    
      +                pl_0C2 = Draft.makeText([str(round(boundBoxLY,arondi))],point=FreeCAD.Vector(oripl_X, oripl_Y + (boundBoxLY/2), oripl_Z))
      +                pl_0C2.ViewObject.DisplayMode   = DisplayModeText
      +                pl_0C2.ViewObject.Justification = JustificationText
      +                pl_0C2.ViewObject.TextColor     = (TextColorText_R, TextColorText_G, TextColorText_B)
      +                pl_0C2.ViewObject.FontSize      = FontSizeText
      +                pl_0C2.Label      = nameLabel + "_Volume_Y_" + str(round(boundBoxLY,arondi))
      +                conteneurVol.addObject(pl_0C2)
      +        
      +                pl_0C3 = Draft.makeText([str(round(boundBoxLZ,arondi))],point=FreeCAD.Vector(oripl_X, oripl_Y, oripl_Z + (boundBoxLZ/2)))
      +                pl_0C3.ViewObject.DisplayMode   = DisplayModeText
      +                pl_0C3.ViewObject.Justification = JustificationText
      +                pl_0C3.ViewObject.TextColor     = (TextColorText_R, TextColorText_G, TextColorText_B)
      +                pl_0C3.ViewObject.FontSize      = FontSizeText
      +                pl_0C3.Label      = nameLabel + "_Volume_Z_" + str(round(boundBoxLZ,arondi))
      +                conteneurVol.addObject(pl_0C3)
      +    
      +        else:
      +            App.Console.PrintMessage("Not BoundBox possible"+"\r\n")
      +        App.Console.PrintMessage("_____________________"+"\r\n")
      +    
      +        #####
      +        conteneurRectangle = []
      +        del conteneurRectangle[:]
      +        conteneurRectangle = App.activeDocument().addObject("App::DocumentObjectGroup",nameLabel + "_BoundBoxRectangle")
      +
      +        if createDim == 1:    # conteneur dimension info
      +            conteneurInfo = []
      +            del conteneurInfo[:]
      +            conteneurInfo = App.activeDocument().addObject("App::DocumentObjectGroup",nameLabel + "_BoundBoxRectangle_Info")
      +        try:
      +            if (boundBoxLX and boundBoxLY) > 0.0:
      +                pl_0 = App.Placement(App.Vector(oripl_X,oripl_Y,oripl_Z), App.Rotation(0.0,0.0,0.0))
      +                double = Draft.makeRectangle(length=boundBoxLX,height=boundBoxLY,placement=pl_0,face=False,support=None) #OK
      +                double.Label = nameLabel + "_BoundBoxRectangle_Bo"
      +                FreeCADGui.activeDocument().activeObject().LineColor = (red, green, blue)
      +                conteneurRectangle.addObject(double)
      +    #        else:
      +    #            App.Console.PrintError("not value 0"+"\n")
      +    
      +            if createDim == 1:    # section create dimension info
      +                pl_0C1 = Draft.makeText([str(round(boundBoxLX,arondi))],point=FreeCAD.Vector(pl_0.Base.x + (boundBoxLX/2), pl_0.Base.y, pl_0.Base.z))
      +                pl_0C1.ViewObject.DisplayMode   = DisplayModeText
      +                pl_0C1.ViewObject.Justification = JustificationText
      +                pl_0C1.ViewObject.TextColor     = (TextColorText_R, TextColorText_G, TextColorText_B)
      +                pl_0C1.ViewObject.FontSize      = FontSizeText
      +                pl_0C1.Label      = nameLabel + "_Rectangle_Bo_0X_" + str(round(boundBoxLX,arondi))
      +                conteneurInfo.addObject(pl_0C1)
      +        
      +                pl_0C2 = Draft.makeText([str(round(boundBoxLY,arondi))],point=FreeCAD.Vector(pl_0.Base.x, pl_0.Base.y + (boundBoxLY/2), pl_0.Base.z))
      +                pl_0C2.ViewObject.DisplayMode   = DisplayModeText
      +                pl_0C2.ViewObject.Justification = JustificationText
      +                pl_0C2.ViewObject.TextColor     = (TextColorText_R, TextColorText_G, TextColorText_B)
      +                pl_0C2.ViewObject.FontSize      = FontSizeText
      +                pl_0C2.Label      = nameLabel + "_Rectangle_Bo_0Y_" + str(round(boundBoxLY,arondi))
      +                conteneurInfo.addObject(pl_0C2)
      +    
      +        except:
      +            App.Console.PrintError("not done 0"+"\n")
      +        try:
      +            if (boundBoxLX and boundBoxLY) > 0.0:
      +                pl_1 = App.Placement(App.Vector(oripl_X,oripl_Y,oripl_Z+boundBoxLZ), App.Rotation(0.0,0.0,0.0))
      +                double = Draft.makeRectangle(length=boundBoxLX,height=boundBoxLY,placement=pl_1,face=False,support=None) #Ok
      +                double.Label = nameLabel + "_BoundBoxRectangle_To"
      +                FreeCADGui.activeDocument().activeObject().LineColor = (red, green, blue)
      +                conteneurRectangle.addObject(double)
      +    #        else:
      +    #            App.Console.PrintError("not value 1"+"\n")
      +    
      +            if createDim == 1:    # section create dimension info
      +                pl_0C1 = Draft.makeText([str(round(boundBoxLX,arondi))],point=FreeCAD.Vector(pl_1.Base.x + (boundBoxLX/2), pl_1.Base.y, pl_1.Base.z))
      +                pl_0C1.ViewObject.DisplayMode   = DisplayModeText
      +                pl_0C1.ViewObject.Justification = JustificationText
      +                pl_0C1.ViewObject.TextColor     = (TextColorText_R, TextColorText_G, TextColorText_B)
      +                pl_0C1.ViewObject.FontSize      = FontSizeText
      +                pl_0C1.Label      = nameLabel + "_Rectangle_To_1X_" + str(round(boundBoxLX,arondi))
      +                conteneurInfo.addObject(pl_0C1)
      +        
      +                pl_0C2 = Draft.makeText([str(round(boundBoxLY,arondi))],point=FreeCAD.Vector(pl_1.Base.x, pl_1.Base.y + (boundBoxLY/2), pl_1.Base.z))
      +                pl_0C2.ViewObject.DisplayMode   = DisplayModeText
      +                pl_0C2.ViewObject.Justification = JustificationText
      +                pl_0C2.ViewObject.TextColor     = (TextColorText_R, TextColorText_G, TextColorText_B)
      +                pl_0C2.ViewObject.FontSize      = FontSizeText
      +                pl_0C2.Label      = nameLabel + "_Rectangle_To_1Y_" + str(round(boundBoxLY,arondi))
      +                conteneurInfo.addObject(pl_0C2)
      +    
      +        except:
      +            App.Console.PrintError("not done 1"+"\n")
      +        try:
      +            if (boundBoxLX and boundBoxLZ) > 0.0:
      +                pl_2 = App.Placement(App.Vector(oripl_X,oripl_Y,oripl_Z), App.Rotation(0.0,0.0,90))
      +                double = Draft.makeRectangle(length=boundBoxLX,height=boundBoxLZ,placement=pl_2,face=False,support=None) #Ok
      +                double.Label = nameLabel + "_BoundBoxRectangle_Fr"
      +                FreeCADGui.activeDocument().activeObject().LineColor = (red, green, blue)
      +                conteneurRectangle.addObject(double)
      +    #        else:
      +    #            App.Console.PrintError("not value 2"+"\n")
      +    
      +            if createDim == 1:    # section create dimension info
      +                pl_0C1 = Draft.makeText([str(round(boundBoxLX,arondi))],point=FreeCAD.Vector(pl_2.Base.x + (boundBoxLX/2), pl_2.Base.y, pl_2.Base.z))
      +                pl_0C1.ViewObject.DisplayMode   = DisplayModeText
      +                pl_0C1.ViewObject.Justification = JustificationText
      +                pl_0C1.ViewObject.TextColor     = (TextColorText_R, TextColorText_G, TextColorText_B)
      +                pl_0C1.ViewObject.FontSize      = FontSizeText
      +                pl_0C1.Label      = nameLabel + "_Rectangle_Fr_2X_" + str(round(boundBoxLX,arondi))
      +                conteneurInfo.addObject(pl_0C1)
      +       
      +                pl_0C2 = Draft.makeText([str(round(boundBoxLZ,arondi))],point=FreeCAD.Vector(pl_2.Base.x, pl_2.Base.y, pl_2.Base.z + (boundBoxLZ/2)))
      +                pl_0C2.ViewObject.DisplayMode   = DisplayModeText
      +                pl_0C2.ViewObject.Justification = JustificationText
      +                pl_0C2.ViewObject.TextColor     = (TextColorText_R, TextColorText_G, TextColorText_B)
      +                pl_0C2.ViewObject.FontSize      = FontSizeText
      +                pl_0C2.Label      = nameLabel + "_Rectangle_Fr_2Z_" + str(round(boundBoxLZ,arondi))
      +                conteneurInfo.addObject(pl_0C2)
      +    
      +        except:
      +            App.Console.PrintError("not done 2"+"\n")
      +        try:
      +            if (boundBoxLX and boundBoxLZ) > 0.0:
      +                pl_3 = App.Placement(App.Vector(oripl_X,oripl_Y+boundBoxLY,oripl_Z), App.Rotation(0.0,0.0,90))
      +                double = Draft.makeRectangle(length=boundBoxLX,height=boundBoxLZ,placement=pl_3,face=False,support=None) #Ok
      +                double.Label = nameLabel + "_BoundBoxRectangle_Re"
      +                FreeCADGui.activeDocument().activeObject().LineColor = (red, green, blue)
      +                conteneurRectangle.addObject(double)
      +    #        else:
      +    #            App.Console.PrintError("not value 3"+"\n")
      +    
      +            if createDim == 1:    # section create dimension info
      +                pl_0C1 = Draft.makeText([str(round(boundBoxLX,arondi))],point=FreeCAD.Vector(pl_3.Base.x + (boundBoxLX/2), pl_3.Base.y, pl_3.Base.z))
      +                pl_0C1.ViewObject.DisplayMode   = DisplayModeText
      +                pl_0C1.ViewObject.Justification = JustificationText
      +                pl_0C1.ViewObject.TextColor     = (TextColorText_R, TextColorText_G, TextColorText_B)
      +                pl_0C1.ViewObject.FontSize      = FontSizeText
      +                pl_0C1.Label      = nameLabel + "_Rectangle_Re_3X_" + str(round(boundBoxLX,arondi))
      +                conteneurInfo.addObject(pl_0C1)
      +        
      +                pl_0C2 = Draft.makeText([str(round(boundBoxLZ,arondi))],point=FreeCAD.Vector(pl_3.Base.x, pl_3.Base.y, pl_3.Base.z + (boundBoxLZ/2)))
      +                pl_0C2.ViewObject.DisplayMode   = DisplayModeText
      +                pl_0C2.ViewObject.Justification = JustificationText
      +                pl_0C2.ViewObject.TextColor     = (TextColorText_R, TextColorText_G, TextColorText_B)
      +                pl_0C2.ViewObject.FontSize      = FontSizeText
      +                pl_0C2.Label      = nameLabel + "_Rectangle_Re_3Z_" + str(round(boundBoxLZ,arondi))
      +                conteneurInfo.addObject(pl_0C2)
      +    
      +        except:
      +            App.Console.PrintError("not done 3"+"\n")
      +        try:
      +            if (boundBoxLY and boundBoxLZ) > 0.0:
      +                pl_4 = App.Placement(App.Vector(oripl_X,oripl_Y,oripl_Z), App.Rotation(90,0.0,90))
      +                double = Draft.makeRectangle(length=boundBoxLY,height=boundBoxLZ,placement=pl_4,face=False,support=None) #Ok
      +                double.Label = nameLabel + "_BoundBoxRectangle_Le"
      +                FreeCADGui.activeDocument().activeObject().LineColor = (red, green, blue)
      +                conteneurRectangle.addObject(double)
      +    #        else:
      +    #            App.Console.PrintError("not value 4"+"\n")
      +    
      +            if createDim == 1:    # section create dimension info
      +                pl_0C1 = Draft.makeText([str(round(boundBoxLY,arondi))],point=FreeCAD.Vector(pl_4.Base.x, pl_4.Base.y + (boundBoxLY/2), pl_4.Base.z))
      +                pl_0C1.ViewObject.DisplayMode   = DisplayModeText
      +                pl_0C1.ViewObject.Justification = JustificationText
      +                pl_0C1.ViewObject.TextColor     = (TextColorText_R, TextColorText_G, TextColorText_B)
      +                pl_0C1.ViewObject.FontSize      = FontSizeText
      +                pl_0C1.Label      = nameLabel + "_Rectangle_Le_4Y_" + str(round(boundBoxLY,arondi))
      +                conteneurInfo.addObject(pl_0C1)
      +        
      +                pl_0C2 = Draft.makeText([str(round(boundBoxLZ,arondi))],point=FreeCAD.Vector(pl_4.Base.x, pl_4.Base.y, pl_4.Base.z + (boundBoxLZ/2)))
      +                pl_0C2.ViewObject.DisplayMode   = DisplayModeText
      +                pl_0C2.ViewObject.Justification = JustificationText
      +                pl_0C2.ViewObject.TextColor     = (TextColorText_R, TextColorText_G, TextColorText_B)
      +                pl_0C2.ViewObject.FontSize      = FontSizeText
      +                pl_0C2.Label      = nameLabel + "_Rectangle_Le_4Z_" + str(round(boundBoxLZ,arondi))
      +                conteneurInfo.addObject(pl_0C2)
      +    
      +        except:
      +            App.Console.PrintError("not done 4"+"\n")
      +        try:
      +            if (boundBoxLY and boundBoxLZ) > 0.0:
      +                pl_5 = App.Placement(App.Vector(oripl_X+boundBoxLX,oripl_Y,oripl_Z), App.Rotation(90,0.0,90))
      +                double = Draft.makeRectangle(length=boundBoxLY,height=boundBoxLZ,placement=pl_5,face=False,support=None) #Ok
      +                double.Label = nameLabel + "_BoundBoxRectangle_Ri"
      +                FreeCADGui.activeDocument().activeObject().LineColor = (red, green, blue)
      +                conteneurRectangle.addObject(double)
      +#            else:
      +#                App.Console.PrintError("not value 5"+"\n")
      +    
      +            if createDim == 1:    # section create dimension info
      +                pl_0C1 = Draft.makeText([str(round(boundBoxLY,arondi))],point=FreeCAD.Vector(pl_5.Base.x, pl_5.Base.y + (boundBoxLY/2), pl_5.Base.z))
      +                pl_0C1.ViewObject.DisplayMode   = DisplayModeText
      +                pl_0C1.ViewObject.Justification = JustificationText
      +                pl_0C1.ViewObject.TextColor     = (TextColorText_R, TextColorText_G, TextColorText_B)
      +                pl_0C1.ViewObject.FontSize      = FontSizeText
      +                pl_0C1.Label      = nameLabel + "_Rectangle_Ri_5Y_" + str(round(boundBoxLY,arondi))
      +                conteneurInfo.addObject(pl_0C1)
      +        
      +                pl_0C2 = Draft.makeText([str(round(boundBoxLZ,arondi))],point=FreeCAD.Vector(pl_5.Base.x, pl_5.Base.y, pl_5.Base.z + (boundBoxLZ/2)))
      +                pl_0C2.ViewObject.DisplayMode   = DisplayModeText
      +                pl_0C2.ViewObject.Justification = JustificationText
      +                pl_0C2.ViewObject.TextColor     = (TextColorText_R, TextColorText_G, TextColorText_B)
      +                pl_0C2.ViewObject.FontSize      = FontSizeText
      +                pl_0C2.Label      = nameLabel + "_Rectangle_Ri_5Z_" + str(round(boundBoxLZ,arondi))
      +                conteneurInfo.addObject(pl_0C2)
      +    
      +        except:
      +            App.Console.PrintError("not done 5"+"\n")
      +    
      +        #####
      +        App.ActiveDocument.recompute()
      +    except Exception:
      +        App.Console.PrintError("Bad selection"+"\n")
      +else:
      +    App.Console.PrintMessage("Select an object !"+"\n") 
      +

      Version

      +

      ver 0.7 le 28/01/2018: correct error with label accent "nameLabel = unicodedata.normalize('NFKD', nameLabel).encode('ascii','ignore')" +

      ver 0.6 le 08/08/2017: add text info dimension , contener for rectangles, info rectangles, info volume, add section configuration color , label object selected +

      ver 0.5 le 08/05/2017 : upgrade now accept the "mesh" and "Points" thanks wmayer Makro Bounding-Box für STL importierte Teile und für Punktewolken +

      ver 0.4 le 04/06/2016 : test if value = 0 then not create boundbox (ex: object Draft) +

      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Macro_Build_Utility.html b/localwiki/Macro_Build_Utility.html new file mode 100644 index 0000000..544361e --- /dev/null +++ b/localwiki/Macro_Build_Utility.html @@ -0,0 +1,290 @@ +Macro Build Utility

      Macro Build Utility

      + +
      + + + + + + + + + + + + + + + + + + + + + + + + + + +
      +

      Macro Build Utility.png Macro Build Utility

      +
      Description +
      This macro provides a Build Utility to assemble multiple project files into one project file. +
      Author +
      Piffpoof +
      Links +
      Macros recipes
      How to install macros
      How to customize toolbars +
      Version +
      1.0 +
      Date last modification +
      2015-01-21 +
      +

      + +
      +


      +

      +

      Description

      +

      This macro is intended for use on large projects, ones involving hundreds of objects. It's use on a small single file project would be pointless and unnecessary. However on a large project with many objects and many files to be merged into the final one, it will save time, avoid the user being involved in repetitive actions, and remove human errors. +

      +

      Installation

      +

      All the code for buildUtility.FCMacro is in one macro. So installation is comprised of copying the code to the appropriate Macro directory and invoking the Build Utility from the Macro menu, the Python console or a toolbar button (the preferred method). +

      + +

      Usage

      +

      The Build Utility works on the same principals as the build files that are used to assemble large software system (like FreeCAD). A text editor is used to create a text file which adheres to the formats required by the Build Utility. The Build Utility then simply reads each line of the text file and performs the actions specified by that text file. +

      The macro asks the user for a "build file". It then parses that build file, there are 3 legal line types: +

      +
      • lines starting with the comment character "#" which are ignored as being comments or remarks
      • +
      • lines starting with the subfile character "@" which are ignored
        Note: the "@" character is for future enhancement when sub-build files will be handled
      • +
      • all other lines which may be a project file or a sub-directory
      +

      The file extension for Build Utility file is ".FCBld". This is so file do not get mixed up with other uses and applications. +

      Any file specified in the build file is assumed to have the extension ".FCStd" +If the line starts with a directory then the project file is read from that subfolder. Otherwise it is assumed the line specifies a project file. Directories within directories are supported so nesting of arbitrary depths is possible. The file specification format is the "Unix" style with different levels separated by the forward slash character "/". +

      Any missing file is printed onto the Report view. Any missing directory is printed onto the Report view. +

      A new document is created and each project is "Project Merged" into that new and empty document. +The document is not saved at the end, this is left for the user if desired. +If the file does not exist then the file name is Printed to the Report view +

      +

      User Interface

      +

      There really isn't a GUI at all for this macro. The macro reads a text file that has been prepared with a text editor and produces a model in an output document. Other than clicking the button on the toolbar to start the process, there is no user interaction. +

      +

      Example

      +

      You are working with some other departments in your company to use FreeCAD to generate a large CAD model for an external client. To prepare for the upcoming presentation you need to integrate the models represented in the 'black' and 'blue' subsystems, the engineering department has responsibility for the 'green' and 'grey' subsystems and you have the 'metal' subsystem on your own computer. The client also uses FreeCAD and your design must integrate with their subsystems "red', and 'yellow'. The external client has told you that the Stacker Assembly is not ready for you to use so you comment it out in your build file. +

      There are a lot of directory paths to type in so you enter the commands into the Build Utility text file which means you can run it with a single click on a toolbar button. +

      MacroBuildUtilityTreeDiagram.jpg +

      The contents of the build file "buildFile.FCBld" shown below shows the file structure for the project described above. +

      +
      #this is the build file for the complete assembly
      +#==============================
      +@sub-build-files - not presently implemented
      +# first the top-level file
      +metal
      +# now some misc files
      +./black/black
      +./blue/blue
      +# file does not exist
      +zebra 
      +# folder does not exist
      +/bear/bear
      +# multiple files in one sub-folder
      +./engineering/green
      +./engineering/grey
      +#multiple files in hierarchical folders
      +./externalModules/white
      +./externalModules/red/red
      +#./externalModules/red/stackerAssembly - commented out as not currently loading
      +./externalModules/red/orange
      +./externalModules/red/level3/yellow 
      +

      A summary of the file and how it is processed is: +

      +
      • the first two lines are treated as comments and everything following the initial character of the hash sign is ignored
      +
      #this is the build file for the complete assembly
      +#============================== 
      +
      • the third line is also ignored because it's first character is the ampersand character which is reserved for future use where command files can invoke other commend files
      +
      @sub-build-files - not presently implemented 
      +
      • the fifth line is the first file specification, the file is in the same directory as the build file, not in a sub-directory
      +
      metal 
      +
      • the seventh and eighth lines are both file specifications where the file is in a sub-directory, note that the sub-directory is of the form "./black/" where "black" is the directory name, so a file called "sheetFold.FCstd" in the directory "outsourcing" would appear "./outsourcing/sheetFold"
      +
      ./black/black
      +./blue/blue 
      +
      • the nineteenth line shows a file specification which exists but is not being included in this build operation
      +
      #./externalModules/red/stackerAssembly - commented out as not currently loading 
      +
      • the last two lines show file specifications where the file is in more than one level of sub-directory
      +
      ./externalModules/red/orange
      +./externalModules/red/level3/yellow 
      +

      Options

      +

      There is no GUI so there are no options. The only alternatives that exist are by using the 3 types of lines in the text file as described above. +

      +

      Remarks

      +

      To reiterate what was stated at the outset, there is no use for this macro on a small single file model. But for persons modeling a plane, locomotive, ship, building, physical plant, complex circuity there is a definitive use and advantage. By choosing the ".FCBld" file extension it is hoped a standard of sorts can be set for build files within FreeCAD. By reserving the "@" prefix character in the command file definition it is hoped that future use and (if needed) growth can be accommodated. +

      +

      Links

      +

      none (so far) +

      +

      Script

      +
      #
      +#Build Utility
      +#                       v 0.0 - build from files and files in sub-folders
      +#
      +#***********************************************************************************
      +# routine to read in a build file and merge all specified projects
      +"""
      +This function asks the user for a "build file". It then parses that build file, there
      +are 3 legal line types:
      +- lines starting with the comment character "#" which are ignored
      +- lines starting with the subfile character "@" which are ignored
      +Note:the "@" character is for future enhancement when sub-build files 
      +will be handled
      +- all other lines which may be a project file or a subfolder (sub-directory)
      +If the line is a subfolder then the project file is read from that subfolder.
      +Otherwise it is assumed the line specifies a project file.
      +A new document is created and each project is "Project Merged" into that new and empty document.
      +The document is not saved at the end, this is left for the user if desired.
      +If the file does not exist then the file name is Printed to the Report view
      +"""
      +"""
      +Example file:
      +#this is a sample build file
      +#==============================
      +@sub-build-files - not presently inplemented
      +# first the top-level file
      +metal
      +# now some misc files
      +./black/black
      +./blue/blue
      +# file does not exist
      +zebra 
      +# folder does not exist
      +/bear/bear
      +# multiple files in one sub-folder
      +./engineering/green
      +./engineering/grey
      +#multiple files in hierarchical folders
      +./externalModules/white
      +./externalModules/red/red
      +#./externalModules/red/stackerAssembly - commented out as not currently loading
      +./externalModules/red/orange
      +./externalModules/red/level3/yellow
      +"""
      +# import statements
      +import FreeCAD
      +import os.path
      +from PySide import QtGui
      +
      +# UI Class definitions
      +
      +# Class definitions
      +
      +# Function definitionss
      +
      +# Constant definitions
      +buildTargetDocument = "build_target"
      +commentTag = "#"
      +subfileTag = "@"
      +lineFeed = "\n"
      +subfolder = "./"
      +carriageReturn = "\r"
      +fileSeparator = "/"
      +fcFileExtension      = ".FCStd"
      +fcFileExtensionUC  = ".FCSTD"
      +fcFileExtensionLen = -6
      +
      +# code ***********************************************************************************
      +buildFilePathName=QtGui.QFileDialog.getOpenFileName()[0]
      +if len(buildFilePathName) > 0:
      +# set up a new empty "build_target" document
      +FreeCAD.newDocument(buildTargetDocument)
      +FreeCAD.setActiveDocument(buildTargetDocument)
      +FreeCAD.ActiveDocument=FreeCAD.getDocument(buildTargetDocument)
      +guiDoc=FreeCADGui.ActiveDocument
      +#
      +lastFileSeparator = buildFilePathName.rindex(fileSeparator)
      +buildFilePath = buildFilePathName[: lastFileSeparator]
      +buildFileName = buildFilePathName[lastFileSeparator +1:]
      +#
      +buildFileContents = open(buildFilePathName,"r")
      +buildFileLines = buildFileContents.readlines()
      +buildFileContents.close()
      +#
      +for line in buildFileLines:
      +if line[0] == commentTag:
      +# line of internal comment
      +pass
      +elif line[0] == subfileTag:
      +# line of sub-build-file (not presently implemented)
      +pass
      +else:
      +# a line which should specify a FreeCAD project file
      +# - may be preceded by a sub-directory e.g. "./subdir309/"
      +# - project file may be missing file extension
      +#
      +# if line break at end of file spec then remove
      +if line[-1:] == lineFeed:
      +line = line[:-1]
      +if line[-1:] == carriageReturn:
      +line = line[:-1]
      +# if no FreeCAD project file extension supplied then append one
      +# make an uppercase comparison in case of mixed case
      +tempLine = fcFileExtension + line.upper()
      +if fcFileExtensionUC != tempLine[fcFileExtensionLen:]:
      +line = line + fcFileExtension
      +# if there is a leading subdirectory then remove "./" from beginning
      +if subfolder[0:2] == line[0:2]:
      +line = line[2:]
      +projectFileSpec = str(buildFilePath) + str("/") + str(line)
      +if os.path.exists(projectFileSpec):
      +guiDoc.mergeProject(projectFileSpec)
      +else:
      +FreeCAD.Console.PrintMessage('project file "' + projectFileSpec + '" not found' + "\n")
      +
      +# set view back to "build_target", it is up to user to save it (if they want)
      +FreeCAD.setActiveDocument(buildTargetDocument)
      +FreeCAD.ActiveDocument=FreeCAD.getDocument(buildTargetDocument)
      +FreeCADGui.ActiveDocument=FreeCADGui.getDocument(buildTargetDocument)
      +FreeCADGui.SendMsgToActiveView("ViewFit")
      +FreeCADGui.activeDocument().activeView().viewAxometric()
      +#
      +#OS: Mac OS X
      +#Word size: 64-bit
      +#Version: 0.14.3703 (Git)
      +#Branch: releases/FreeCAD-0-14
      +#Hash: c6edd47334a3e6f209e493773093db2b9b4f0e40
      +#Python version: 2.7.5
      +#Qt version: 4.8.6
      +#Coin version: 3.1.3
      +#SoQt version: 1.5.0
      +#OCC version: 6.7.0
      +#
      +#thus ends the macro... 
      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Macro_Cabinets32.html b/localwiki/Macro_Cabinets32.html new file mode 100644 index 0000000..1a8b24b --- /dev/null +++ b/localwiki/Macro_Cabinets32.html @@ -0,0 +1,599 @@ +Macro Cabinets32

      Macro Cabinets32

      + +
      + + + + + + + + + + + + + + + + + + + + + + + + + + +
      +

      Cabinets32.png Cabinets32

      +
      Description +
      drill holes for System32 cabinets. +
      Author +
      Berner +
      Links +
      Macros recipes
      How to install macros
      How to customize toolbars +
      Version +
      1.0 +
      Date last modification +
      2015-01-22 +
      +

      + +
      cabinetside +

      cabinettop +

      +
      +


      +

      +

      Description

      +

      This macro creates Top/Bottom and sidewalls for a cabinet with System32 specification. +The defaults in the Macro are for parts of manufacturer Hettich. +

      +

      Use

      +
      • Launch the macro and change length, height and width of your cabinet-board.
      • +
      • The Gui ask to drill one or two-hole connectors.
      • +
      • You can drill the hole board with holes in 32 mm distance.
      • +
      • You can drill holes for top/bottom boards of your cabinet.
      +


      +

      +

      Script

      +

      Cabinets32.FCMacro +

      +
      +#!/usr/bin/env python
      +# -*- coding: utf-8 -*-
      +# ***************************************************************************
      +# *                                                                         *
      +# *   Copyright (c) 2015 Bruno Bueckmann reset12 at gmx.de                  *
      +# *                      http://home.bb-24.net                              *
      +# *   This program is free software; you can redistribute it and/or modify  *
      +# *   it under the terms of the GNU Lesser General Public License (LGPL)    *
      +# *   as published by the Free Software Foundation; either version 2 of     *
      +# *   the License, or (at your option) any later version.                   *
      +# *   for detail see the LICENCE text file.                                 *
      +# *                                                                         *
      +# *   This program is distributed in the hope that it will be useful,       *
      +# *   but WITHOUT ANY WARRANTY; without even the implied warranty of        *
      +# *   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the         *
      +# *   GNU Library General Public License for more details.                  *
      +# *                                                                         *
      +# *   You should have received a copy of the GNU Library General Public     *
      +# *   License along with this program; if not, write to the Free Software   *
      +# *   Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  *
      +# *   USA                                                                   *
      +# *                                                                         *
      +# ***************************************************************************
      +
      +
      +# Macro Begin: cabinets32.FCMacro ++++++++++++++++++++++++++++++++++++++++++++++
      +# This Macro generates holes and a groove for the side Base cabinet
      +# Top and Bottom Wall are OUTSIDE the side base
      +# like :
      +# -------
      +# |     |
      +# |     |
      +# -------
      +
      +from __future__ import division
      +
      +import FreeCAD as App
      +import FreeCADGui as Gui
      +from PySide import QtGui
      +
      +# GUI
      +debug = False  # debugging on
      +guiok = True  # flag for abort input
      +
      +width, ok = QtGui.QInputDialog.getDouble(
      +    QtGui.QWidget(), 'Thickness', 'Thickness of cabinet-side', 19, 0, 50, 2)
      +if ok:
      +    length, ok = QtGui.QInputDialog.getDouble(
      +        QtGui.QWidget(), 'Depth', 'Depth of cabinet-side', 600, 0, 2000, 2)
      +else:
      +    guiok = False
      +
      +if ok and guiok:
      +    height, ok = QtGui.QInputDialog.getDouble(
      +        QtGui.QWidget(), 'Height', 'Height of cabinet-side', 2000, 0, 3000, 2)
      +else:
      +    guiok = False
      +
      +if ok and guiok:
      +    bradius, ok = QtGui.QInputDialog.getDouble(
      +        QtGui.QWidget(), 'Bradius', 'Radius of drill holes in cabinet-side',
      +        2.5, 0, 50, 2)
      +else:
      +    guiok = False
      +
      +if ok:
      +    bdeep, ok = QtGui.QInputDialog.getDouble(
      +        QtGui.QWidget(), 'Bdeep', 'Depth of drill holes in cabinet-side',
      +        12, 0, 50, 2)
      +else:
      +    guiok = False
      +
      +if ok:
      +    fdist, ok = QtGui.QInputDialog.getDouble(
      +        QtGui.QWidget(), 'Fdist', 'Distance to Front of cabinet-side',
      +        37, 0, 50, 2)
      +else:
      +    guiok = False
      +
      +if ok:
      +    hole1, ok = QtGui.QInputDialog.getDouble(
      +        QtGui.QWidget(), 'Hole1',
      +        'Distance first hole from top or bottom of cabinet-side', 10, 0, 50, 2)
      +else:
      +    guiok = False
      +
      +if ok:
      +    holedistance, ok = QtGui.QInputDialog.getDouble(
      +        QtGui.QWidget(), 'Holedistance',
      +        'Distance from hole to hole (System 32)', 32, 1, 50, 2)
      +else:
      +    guiok = False
      +
      +if ok:
      +    groovethickness, ok = QtGui.QInputDialog.getDouble(
      +        QtGui.QWidget(), 'Groovethickness', 'Thickness of backpanel',
      +        3, 1, 50, 2)
      +else:
      +    guiok = False
      +
      +if ok:
      +    groovedeep, ok = QtGui.QInputDialog.getDouble(
      +        QtGui.QWidget(), 'Groovedeep',
      +        'Overlapping of backpanel in cabinet-side', 12, 1, 50, 2)
      +else:
      +    guiok = False
      +
      +if guiok:
      +    # VB 35 / 18 or VB 36 M /19 from Hettich
      +    connector, ok = QtGui.QInputDialog.getInt(
      +        QtGui.QWidget(), 'Connectortype',
      +        'Zerohole(0) Singlehole(1) or Doublehole(2) Connector', 2, 0, 2, 1)
      +
      +if ok:
      +    fillwithholes, ok = QtGui.QInputDialog.getItem(None,
      +            "Fillwithholes",
      +            "Fill Board with holes?",
      +            ["no", "yes"],
      +            editable=False)
      +else:
      +    guiok = False
      +
      +endhole = 9.5
      +
      +if ok and guiok:
      +    endholes, ok = QtGui.QInputDialog.getItem(None,
      +            "Endholes",
      +            "Drill Holes on Top/Bottom vertical for Connectors",
      +            ['no', 'yes'],
      +            editable=False)
      +
      +if ok and guiok and endholes == 'yes':
      +    endhole, ok = QtGui.QInputDialog.getDouble(
      +        QtGui.QWidget(), 'Endhole',
      +        'Endhole distance from inner cabinet-side', 9.5, 1, 50, 2)
      +if debug:
      +    App.Console.PrintMessage("ok?: {}\n".format(ok))
      +    App.Console.PrintMessage("width = {}\n".format(width))
      +    App.Console.PrintMessage("length = {}\n".format(length))
      +    App.Console.PrintMessage("bradius = {}\n".format(bradius))
      +    App.Console.PrintMessage("bdeep = {}\n".format(bdeep))
      +    App.Console.PrintMessage("fdist = {}\n".format(fdist))
      +    App.Console.PrintMessage("hole1 = {}\n".format(hole1))
      +    App.Console.PrintMessage("holedistance = {}\n".format(holedistance))
      +    App.Console.PrintMessage("groovethickness = {}\n".format(groovethickness))
      +    App.Console.PrintMessage("groovedeep = {}\n".format(groovedeep))
      +    App.Console.PrintMessage("connector = {}\n".format(connector))
      +    App.Console.PrintMessage("fillwithholes = {}\n".format(fillwithholes))
      +    App.Console.PrintMessage("endholes = {}\n".format(endholes))
      +    App.Console.PrintMessage("endhole = {}\n".format(endhole))
      +    App.Console.PrintMessage("guiok = {}\n".format(guiok))
      +# End GUI
      +
      +if guiok:
      +    # width= 19# thickness of korpus
      +    # length= 600# width of korpus
      +    # height= 2000# height of korpus
      +    #
      +    # bradius = 2.5  # Radius drill hole
      +    # bdeep = 12     # deepness of drill hole
      +    # fdist = 37    # Distance to Front
      +    # hole1 = 9.5# Distance first hole from top or bottom of korpus
      +    # holedistance = 32  # System 32
      +    # groovethickness = 3 # 3 mm backpanel
      +    # groovedeep = width-8 # deep of groovedeep
      +    if int(width) > 16:
      +        # First hole depends on specs for VB36 M / 19 for 19 mm boards from
      +        # Hettich.
      +        holetop = 9.5  # holedistance for screw of vb36
      +        hole1 = 9.5 + 0.5  # distance hole 1 from end of board
      +        hole1r = 10  # radius first hole
      +        hole1d = 14  # deepness first hole
      +        hole2r = 5  # radius 2. hole
      +        hole2d = 10.5  # deepness 2. hole
      +    else:
      +        # First hole depends on specs for VB36 M / 16 for 16 mm boards from
      +        # Hettich.
      +        holetop = 9.5  # holedistance for screw of vb36
      +        hole1 = 9.5 + 0.5  # distance hole 1 from end of board
      +        hole1r = 10  # radius first hole
      +        hole1d = 12.5  # deepness first hole
      +        hole2r = 5  # radius 2. hole
      +        hole2d = 10.5  # deepness 2. hole
      +
      +    if debug:
      +        App.Console.PrintMessage("hole1d = {}\n".format(hole1d))
      +
      +    # functions
      +    def cut(tool):
      +        global cutsnr
      +        global cuts
      +        # cuts objects defined in string cuts
      +        if debug:
      +            App.Console.PrintMessage("cuts = {}, cutsnr = {}\n".format(
      +                cuts, cutsnr))
      +        data = 'App.activeDocument().addObject("Part::Cut","' + str(cuts.split(" ")[cutsnr + 1]) + '")'
      +        if debug:
      +            App.Console.PrintMessage(str(data) + "\n")
      +        exec(data)
      +        data = "App.activeDocument()." + str(cuts.split(" ")[cutsnr + 1])
      +        data = data + ".Base = App.activeDocument()." + str(cuts.split(" ")[cutsnr])
      +        if debug:
      +            App.Console.PrintMessage(str(data) + "\n")
      +        exec(data)
      +        data = "App.activeDocument()." + str(cuts.split(" ")[cutsnr + 1])
      +        data = data + ".Tool = App.activeDocument()." + str(tool)
      +        if debug:
      +            App.Console.PrintMessage(str(data) + "\n")
      +        exec(data)
      +        cutsnr = cutsnr + 1
      +        cuts = cuts + " Cut%03d" % cutsnr
      +        return 0
      +
      +    # end functions
      +
      +    doc = App.activeDocument()
      +
      +    # Korpus
      +    box = doc.addObject("Part::Box", "Box")
      +    box.Label = "Cube"
      +    box.Length = length
      +    box.Width = width
      +    box.Height = height
      +    # Change Color of Object.
      +    box.ViewObject.DiffuseColor = (0.67, 0.67, 0.0)
      +    if debug:
      +        doc.recompute()
      +    # Groove
      +    groove = doc.addObject("Part::Box", "Groove")
      +    groove.Label = "Groove"
      +    groove.Length = groovethickness
      +    groove.Width = groovedeep
      +    groove.Height = height - (2 * groovedeep)
      +    groove.ViewObject.DiffuseColor = (0.67, 0.67, 0.0)
      +    groove.Placement = App.Placement(
      +        App.Vector(length - groovethickness, 0, groovedeep),
      +        App.Rotation())
      +    if debug:
      +        doc.recompute()
      +
      +    # make endholes
      +    cylinders = ""  # labels of cylinders to cut
      +    if endholes == 'y':
      +        # Bottom holes
      +        cylendl = doc.addObject("Part::Cylinder", "Cylinderendl")
      +        cylendl.Label = "Cylinderendl001"
      +        cylendl.Radius = bradius
      +        cylendl.Height = bdeep
      +        cylendl.Angle = 360
      +        cylinders = cylinders + " " + cylendl.Name
      +        cylendl.ViewObject.DiffuseColor = (0.0, 0.0, 0.0)
      +        doc.ActiveObject.Placement = App.Placement(
      +            App.Vector(fdist, bdeep, holetop),
      +            App.Rotation(App.Vector(1, 0, 0), 90))
      +        if debug:
      +            doc.recompute()
      +        cylendr = doc.addObject("Part::Cylinder", "Cylinderendr")
      +        cylendr.Label = "Cylinderendr001"
      +        cylendr.Radius = bradius
      +        cylendr.Height = bdeep
      +        cylendr.Angle = 360
      +        cylinders = cylinders + " " + cylendr.Name
      +        cylendr.ViewObject.DiffuseColor = (0.0, 0.0, 0.0)
      +        cylendr.Placement = App.Placement(
      +            App.Vector(length - fdist, bdeep, holetop),
      +            App.Rotation(App.Vector(1, 0, 0), 90))
      +        if debug:
      +            doc.recompute()
      +
      +        # Top holes
      +        cylendl = doc.addObject("Part::Cylinder", "Cylinderendl")
      +        cylendl.Label = "Cylinderendl002"
      +        cylendl.Radius = bradius
      +        cylendl.Height = bdeep
      +        cylendl.Angle = 360
      +        cylinders = cylinders + " " + cylendl.Name
      +        cylendl.ViewObject.DiffuseColor = (0.0, 0.0, 0.0)
      +        cylendl.Placement = App.Placement(
      +            App.Vector(fdist, bdeep, height - holetop),
      +            App.Rotation(App.Vector(1, 0, 0), 90))
      +        if debug:
      +            doc.recompute()
      +        cylendr = doc.addObject("Part::Cylinder", "Cylinderendr")
      +        cylendr.Label = "Cylinderendr002"
      +        cylendr.Radius = bradius
      +        cylendr.Height = bdeep
      +        cylendr.Angle = 360
      +        cylinders = cylinders + " " + cylendr.Name
      +        cylendr.ViewObject.DiffuseColor = (0.0, 0.0, 0.0)
      +        cylendr.Placement = App.Placement(
      +            App.Vector(length - fdist, bdeep, height-holetop),
      +            App.Rotation(App.Vector(1, 0, 0), 90))
      +        if debug:
      +            doc.recompute()
      +
      +    if fillwithholes == 'no':
      +        n = 0
      +    else:
      +        n = int(height / 2 / holedistance)
      +
      +    # drill holes from bottom to half height
      +    # reduce holes for test to 2 alternative use n
      +    # Holes for Hettich VB36
      +    # Bohrloecher
      +    x = -1  # init value
      +    if connector >= 1:
      +        x = 0
      +        App.Console.PrintMessage("x="+str(x) + " " + "\n")
      +        cyll = doc.addObject("Part::Cylinder", "Cylinderl")
      +        cyll.Label = "Cylinderl%03d" % x
      +        cyll.Radius = hole1r
      +        cyll.Height = hole1d
      +        cyll.Angle = 360
      +        cylinders = cylinders + " " + cyll.Name
      +        cyll.ViewObject.DiffuseColor = (0.0, 0.0, 0.0)
      +        cyll.Placement = App.Placement(
      +            App.Vector(fdist, hole1d, hole1 + x * holedistance),
      +            App.Rotation(App.Vector(1, 0, 0), 90))
      +        if debug:
      +            doc.recompute()
      +
      +        cylr = doc.addObject("Part::Cylinder", "Cylinderr")
      +        cylr.Label = "Cylinderr%03d" % x
      +        cylr.Radius = hole1r
      +        cylr.Height = hole1d
      +        cylr.Angle = 360
      +        cylinders = cylinders + " " + cylr.Name
      +        cylr.ViewObject.DiffuseColor = (0.0, 0.0, 0.0)
      +        cylr.Placement = App.Placement(
      +            App.Vector(length - fdist, hole1d, hole1 + x * holedistance),
      +            App.Rotation(App.Vector(1, 0, 0), 90))
      +
      +    if connector == 2:
      +        x = 1
      +        cyll = doc.addObject("Part::Cylinder", "Cylinderl")
      +        cyll.Label = "Cylinderl%03d" % x
      +        cyll.Radius = hole2r
      +        cyll.Height = hole2d
      +        cyll.Angle = 360
      +        cylinders = cylinders + " " + cyll.Name
      +        cyll.ViewObject.DiffuseColor = (0.0, 0.0, 0.0)
      +        cyll.Placement = App.Placement(
      +            App.Vector(fdist, hole2d, hole1 + x * holedistance),
      +            App.Rotation(App.Vector(1, 0, 0), 90))
      +        if debug:
      +            doc.recompute()
      +
      +        cylr = doc.addObject("Part::Cylinder", "Cylinderr")
      +        cylr.Label = "Cylinderr%03d" % x
      +        cylr.Radius = hole2r
      +        cylr.Height = hole2d
      +        cylr.Angle = 360
      +        cylinders = cylinders + " " + cylr.Name
      +        cylr.ViewObject.DiffuseColor = (0.0, 0.0, 0.0)
      +        cylr.Placement = App.Placement(
      +            App.Vector(length - fdist, hole2d, hole1 + x * holedistance),
      +            App.Rotation(App.Vector(1, 0, 0), 90))
      +        if debug:
      +            doc.recompute()
      +
      +    xs = x + 1
      +    for x in range(xs, n):
      +        # Bohrloecher
      +        cyll = doc.addObject("Part::Cylinder", "Cylinderl")
      +        cyll.Label = "Cylinderl%03d" % x
      +        cyll.Radius = bradius
      +        cyll.Height = bdeep
      +        cyll.Angle = 360
      +        cylinders = cylinders + " " + cyll.Name
      +        cyll.ViewObject.DiffuseColor = (0.0, 0.0, 0.0)
      +        cyll.Placement = App.Placement(
      +            App.Vector(fdist, bdeep, hole1 + x * holedistance),
      +            App.Rotation(App.Vector(1, 0, 0), 90))
      +        if debug:
      +            doc.recompute()
      +
      +        cylr = doc.addObject("Part::Cylinder", "Cylinderr")
      +        cylr.Label = "Cylinderr%03d" % x
      +        cylr.Radius = bradius
      +        cylr.Height = bdeep
      +        cylr.Angle = 360
      +        cylinders = cylinders + " " + cylr.Name
      +        cylr.ViewObject.DiffuseColor = (0.0, 0.0, 0.0)
      +        cylr.Placement = App.Placement(
      +            App.Vector(length - fdist, bdeep, hole1 + x * holedistance),
      +            App.Rotation(App.Vector(1, 0, 0), 90))
      +        if debug:
      +            doc.recompute()
      +
      +    # drill holes from Top to half height
      +    # # Holes for Hettich VB36
      +    x = -1  # init value
      +    if connector >= 1:
      +        x = 0
      +        cyll = doc.addObject("Part::Cylinder", "Cylinderl")
      +        cyll.Label = "Cylinderl%03d" % x
      +        cyll.Radius = hole1r
      +        cyll.Height = hole1d
      +        cyll.Angle = 360
      +        cylinders = cylinders + " " + cyll.Name
      +        cyll.ViewObject.DiffuseColor = (0.0, 0.0, 0.0)
      +        cyll.Placement = App.Placement(
      +            App.Vector(fdist, hole1d, height - hole1 - x * holedistance),
      +            App.Rotation(App.Vector(1, 0, 0), 90))
      +        if debug:
      +            doc.recompute()
      +
      +        cylr = doc.addObject("Part::Cylinder", "Cylinderr")
      +        cylr.Label = "Cylinderr%03d" % x
      +        cylr.Radius = hole1r
      +        cylr.Height = hole1d
      +        cylr.Angle = 360
      +        cylinders = cylinders + " " + cylr.Name
      +        cylr.ViewObject.DiffuseColor = (0.0, 0.0, 0.0)
      +        cylr.Placement = App.Placement(
      +            App.Vector(length - fdist, hole1d, height-hole1 - x * holedistance),
      +            App.Rotation(App.Vector(1, 0, 0), 90))
      +        if debug:
      +            doc.recompute()
      +
      +    if connector == 2:
      +        x = 1
      +        cyll = doc.addObject("Part::Cylinder", "Cylinderl")
      +        cyll.Label = "Cylinderl%03d" % x
      +        cyll.Radius = hole2r
      +        cyll.Height = hole2d
      +        cyll.Angle = 360
      +        cylinders = cylinders + " " + cyll.Name
      +        cyll.ViewObject.DiffuseColor = (0.0, 0.0, 0.0)
      +        cyll.Placement = App.Placement(
      +            App.Vector(fdist, hole2d, height - hole1 - x * holedistance),
      +            App.Rotation(App.Vector(1, 0, 0), 90))
      +        if debug:
      +            doc.recompute()
      +
      +        cylr = doc.addObject("Part::Cylinder", "Cylinderr")
      +        cylr.Label = "Cylinderr%03d" % x
      +        cylr.Radius = hole2r
      +        cylr.Height = hole2d
      +        cylr.Angle = 360
      +        cylinders = cylinders + " " + cylr.Name
      +        cylr.ViewObject.DiffuseColor = (0.0, 0.0, 0.0)
      +        cylr.Placement = App.Placement(
      +            App.Vector(
      +                length - fdist, hole2d, height - hole1 - x * holedistance),
      +            App.Rotation(App.Vector(1, 0, 0), 90))
      +        if debug:
      +            doc.recompute()
      +
      +    xs = x + 1
      +    for x in range(xs, n):
      +        # Drillholes
      +        cyll = doc.addObject("Part::Cylinder", "Cylinderl")
      +        cyll.Label = "Cylinderl%03d" % x
      +        cyll.Radius = bradius
      +        cyll.Height = bdeep
      +        cyll.Angle = 360
      +        cylinders = cylinders + " " + cyll.Name
      +        cyll.ViewObject.DiffuseColor = (0.0, 0.0, 0.0)
      +        cyll.Placement = App.Placement(
      +            App.Vector(fdist, bdeep, height - hole1 - x * holedistance),
      +            App.Rotation(App.Vector(1, 0, 0), 90))
      +        if debug:
      +            doc.recompute()
      +
      +        cylr = doc.addObject("Part::Cylinder", "Cylinderr")
      +        cylr.Label = "Cylinderr%03d" % x
      +        cylr.Radius = bradius
      +        cylr.Height = bdeep
      +        cylr.Angle = 360
      +        cylinders = cylinders + " " + cylr.Name
      +        cylr.ViewObject.DiffuseColor = (0.0, 0.0, 0.0)
      +        cylr.Placement = App.Placement(
      +            App.Vector(
      +                length - fdist, bdeep, height - hole1 - x * holedistance),
      +            App.Rotation(App.Vector(1, 0, 0), 90))
      +        if debug:
      +            doc.recompute()
      +
      +    if debug:
      +        App.Console.PrintMessage("cylinders = ")
      +        App.Console.PrintMessage(cylinders + "\n")
      +
      +    # cut all holes
      +    cuts = "Box Cut"  # cut labels
      +    cutsnr = 0     # index number in cuts
      +    # cut groove
      +    cut("Groove")
      +    cyls = cylinders.split()  # number of words
      +    if debug:
      +        App.Console.PrintMessage("n=" + str(cyls) + "\n")
      +    for x in cyls:
      +        if debug:
      +            App.Console.PrintMessage("cylinder(" + x + ")=" + str(x) + "\n")
      +        cut(str(x))
      +    doc.recompute()
      +    Gui.SendMsgToActiveView('ViewFit')
      +
      +# OS: Ubuntu 14.04.1 LTS
      +# Word size of OS: 32-bit
      +# Word size of FreeCAD: 32-bit
      +# Version: 0.15.4410 (Git)
      +# Branch: master
      +# Hash: 9ee08a97ea81304e2690694f76ee2dc013556a5d
      +# Python version: 2.7.6
      +# Qt version: 4.8.6
      +# Coin version: 4.0.0a
      +
      +

      Links

      + +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Macro_CartoucheFC.html b/localwiki/Macro_CartoucheFC.html new file mode 100644 index 0000000..85abae3 --- /dev/null +++ b/localwiki/Macro_CartoucheFC.html @@ -0,0 +1,978 @@ +Macro CartoucheFC

      Macro CartoucheFC

      + +
      + + + + + + + + + + + + + + + + + + + + + + + + + + +
      +

      Text-x-python.png Macro CartoucheFC

      +
      Description +
      This macro is a complete application, it allows to fill the cartridge of the drawing sheet delivered with FreeCAD. +
      Author +
      Mario52 +
      Links +
      Macros recipes
      How to install macros
      How to customize toolbars +
      Version +
      0.3 +
      Date last modification +
      2014-07-02 +
      +

      + +
      +


      +

      This macro is a complete application, it allows to fill simply all the fields of the cartridge of the drawing sheet delivered with FreeCAD. +

      The date and time fields are separated by a "space negative space" " - " and constitute a single line textedit. +

      CartoucheFC +


      +Fields in red are the "freecad:editable" fields, fields in green are annotations inserted in the template.
      +Here the version for the new sheet with all the editable text fields. +

      +

      Use

      +

      Changing the map in Inkscape can at the moment cause operation problems in the program (where you remove the symbol on the worksheet, same problem with FreeCAD), work on a copy of A3_Landscape.svg.
      +PS: Some characters such as & $ are not accepted (and possibly other special characters). +

      If you have any questions or want to add a function, you can address you on the french forum Remplir cartouche
      +

      +
      • The window remains above other Windows, thereby controlling the cartridge without leaving the program.
      • +
      • Copy the code into a file named Macro_CartoucheFC.FCMacro and place it in your usual macros directory.
      • +
      • After you have created your drawing sheet using the Drawing of FreeCAD module, run the macro Macro_CartoucheFC.
      • +
      • At the opening, the program will register in memory all data already present in the cartridge of the sheet (if they are filled), all these data will be automatically returned to using the button Memo and kept in memory until the closure of the programme.
      • +
      • Date button D. and time H. displayed the date and time of the system.
      +
      • The date format depends on the selected symbol EU or US which determines the regional format. Change does not happen automatically (for the case or you have entered a date manually) you must again click buttons dates if you change the symbol (check before printing).
      +
      • The field A3 is not functional (this program is based on the the A3 of FreeCAD sheet cartridge).
      • +
      • Button Symbole EU or US change the meaning of the symbol of projection "Select your Symbol" is displayed by default, and then the active symbol appears. Click on the button and check the leaf symbol, click a second time to modify the symbol.
      +
      • The choice of this symbol, affects the date format EU = dd/MM/yyyy and US = MM/dd/yyyy.
      • +
      • Attention: this command does not pass through the button Apply and immediately changes the symbol to each presses on the key, always check if you have the appropriate symbol on your worksheet.
      +
      • Button Clean Clears all fields in the cartridge. You can revert to the original data using the button Memo.
      • +
      • Button Apply saves all fields of the cartridge in the sheet. You can revert to the original data using the button Memo (except for the regional symbol that works in independent and is effective immediately).
      +

      Code

      +

      Macro_CartoucheFC.FCMacro +


      +

      +
      # -*- coding: utf-8 -*-
      +# Macro_CartoucheFC.py
      +# Remplir les zones du cartouche de la feuille originale de FreeCAD
      +# http://www.freecadweb.org/wiki/index.php?title=Macro_CartoucheFC/fr
      +# il faut que la page (drawing viewer) s'appelle " Page " qui est le nom par défaut du module Drawing
      +# Fill the area of the cartridge
      +# http://www.freecadweb.org/wiki/index.php?title=Macro_CartoucheFC
      +# It is necessary that the page (drawing viewer) is called "Page", which is the default name of the Drawing module
      +# ver 0.3
      +# Created: 02/07/2014
      +# Created:  by mario52
      +# PyQt and PySide 
      +
      +#OS: Windows Vista
      +#Word size: 32-bit
      +#Version: 0.14.3700 (Git)
      +#Branch: releases/FreeCAD-0-14
      +#Hash: 32f5aae0a64333ec8d5d160dbc46e690510c8fe1
      +#Python version: 2.6.2
      +#Qt version: 4.5.2
      +#Coin version: 3.1.0
      +#SoQt version: 1.4.1
      +
      +try:
      +    import PyQt4
      +    from PyQt4 import QtCore, QtGui
      +except Exception:
      +    import PySide
      +    from PySide import QtCore, QtGui
      +
      +import Draft, Part, FreeCAD, math, PartGui, FreeCADGui
      +from math import sqrt, pi, sin, cos, asin
      +from FreeCAD import Base
      +
      +global  path
      +
      +path = FreeCAD.ConfigGet("AppHomePath")
      +
      +def heure():
      +    return QtCore.QTime().currentTime().toString('hh:mm:ss')
      +def dateEu():
      +    return QtCore.QDate().currentDate().toString('dd/MM/yyyy') # forme euro
      +def dateUs():
      +    return QtCore.QDate().currentDate().toString('MM/dd/yyyy') # forme us
      +def dateComp():
      +    return QtCore.QDate().currentDate().toString('dddd d MMMM yyyy') # Retourne "dimanche 20 Juillet 69"
      +
      +try:
      +    _fromUtf8 = QtCore.QString.fromUtf8
      +except AttributeError:
      +    def _fromUtf8(s):
      +        return s
      +try:
      +    _encoding = QtGui.QApplication.UnicodeUTF8
      +    def _translate(context, text, disambig):
      +        return QtGui.QApplication.translate(context, text, disambig, _encoding)
      +except AttributeError:
      +    def _translate(context, text, disambig):
      +        return QtGui.QApplication.translate(context, text, disambig)
      +
      +def errorDialog(msg):
      +    # Create a simple dialog QMessageBox
      +    # The first argument indicates the icon used: one of QtGui.QMessageBox.{NoIcon, Information, Warning, Critical, Question} 
      +    diag = QtGui.QMessageBox(QtGui.QMessageBox.Critical,u"Error Message",msg)
      +    try:
      +        diag.setWindowFlags(PyQt4.QtCore.Qt.WindowStaysOnTopHint)  #PyQt4 cette fonction met la fenêtre en avant
      +    except Exception:
      +        diag.setWindowFlags(PySide.QtCore.Qt.WindowStaysOnTopHint) #PySide cette fonction met la fenêtre en avant
      +    #diag.setWindowModality(QtCore.Qt.ApplicationModal) # la fonction a été désactivée pour favoriser "WindowStaysOnTopHint"
      +    diag.exec_()
      +
      +def symbol_EU(depx,depy):    #symbol_EU
      +    try:
      +        App.getDocument(App.ActiveDocument.Name).removeObject("Symbol_US")
      +    except:
      +        None
      +    try:
      +        App.getDocument(App.ActiveDocument.Name).removeObject("Symbol_EU")
      +    except:
      +        None
      +    try:
      +        App.getDocument(App.ActiveDocument.Name).removeObject("SymbolUS")
      +    except:
      +        None
      +    try:
      +        App.getDocument(App.ActiveDocument.Name).removeObject("SymbolEU")
      +    except:
      +        None
      +    App.activeDocument().addObject('Sketcher::SketchObject','Symbol_EU')
      +    App.activeDocument().Symbol_EU.Placement = App.Placement(App.Vector(0.0,0.0,0.0),App.Rotation(0.000000,0.000000,0.000000,1.000000))
      +    App.ActiveDocument.Symbol_EU.addGeometry(Part.Line(App.Vector(-7.5,0.0,0.0),App.Vector(20.0,0.0,0.0)))
      +
      +    App.ActiveDocument.Symbol_EU.Placement = App.Placement(App.Vector(0.0,0.0),App.Rotation(0.000000,0.000000,0.000000,1.000000))
      +    App.ActiveDocument.Symbol_EU.addGeometry(Part.Line(App.Vector(12.50,-7.5,0),App.Vector(12.50,7.5,0.0)))
      +    App.ActiveDocument.Symbol_EU.addGeometry(Part.Circle(App.Vector(12.50,0.0,0),App.Vector(0,0,1),2.5))
      +    App.ActiveDocument.Symbol_EU.addGeometry(Part.Circle(App.Vector(12.50,0.0,0),App.Vector(0,0,1),5.0))
      +
      +    App.ActiveDocument.Symbol_EU.addGeometry(Part.Line(App.Vector(5.0,5.0,0.0),App.Vector(-5.0,2.5,0.0)))
      +    App.ActiveDocument.Symbol_EU.addGeometry(Part.Line(App.Vector(-5.0,-2.5,0.0),App.Vector(-5.0,2.5,0.0)))
      +    App.ActiveDocument.Symbol_EU.addGeometry(Part.Line(App.Vector(5.0,-5.0,0.0),App.Vector(-5.0,-2.5,0.0)))
      +    App.ActiveDocument.Symbol_EU.addGeometry(Part.Line(App.Vector(5.0,-5.0,0.0),App.Vector(5.0,5.0,0.0)))
      +    Gui.getDocument(App.ActiveDocument.Name).resetEdit()
      +    FreeCADGui.getDocument(App.ActiveDocument.Name).getObject("Symbol_EU").LineColor = (0.00,0.00,0.00)
      +    App.ActiveDocument.recompute()
      +
      +    App.activeDocument().addObject('Drawing::FeatureViewPart','SymbolEU')
      +    App.activeDocument().SymbolEU.Source = App.activeDocument().Symbol_EU
      +    App.activeDocument().SymbolEU.Direction = (0.0,0.0,1.0)
      +    App.activeDocument().SymbolEU.X = depx
      +    App.activeDocument().SymbolEU.Y = depy
      +    App.activeDocument().SymbolEU.Scale = 0.8
      +    App.activeDocument().Page.addObject(App.activeDocument().SymbolEU)
      +    App.ActiveDocument.recompute()
      +#    App.getDocument(App.ActiveDocument.Name).removeObject("Symbol_EU")
      +    FreeCADGui.getDocument(App.ActiveDocument.Name).getObject("Symbol_EU").Visibility = False
      +
      +def symbol_US(depx,depy):    #symbol_US
      +    try:
      +        App.getDocument(App.ActiveDocument.Name).removeObject("Symbol_US")
      +    except:
      +        None
      +    try:
      +        App.getDocument(App.ActiveDocument.Name).removeObject("Symbol_EU")
      +    except:
      +        None
      +    try:
      +        App.getDocument(App.ActiveDocument.Name).removeObject("SymbolUS")
      +    except:
      +        None
      +    try:
      +        App.getDocument(App.ActiveDocument.Name).removeObject("SymbolEU")
      +    except:
      +        None
      +    App.activeDocument().addObject('Sketcher::SketchObject','Symbol_US')
      +    App.activeDocument().Symbol_US.Placement = App.Placement(App.Vector(0.0,0.0,0.0),App.Rotation(0.000000,0.000000,0.000000,1.000000))
      +    App.ActiveDocument.Symbol_US.addGeometry(Part.Line(App.Vector(-7.5,0.0,0.0),App.Vector(20.0,0.0,0.0)))
      +
      +    App.ActiveDocument.Symbol_US.Placement = App.Placement(App.Vector(0.0,0.0),App.Rotation(0.000000,0.000000,0.000000,1.000000))
      +    App.ActiveDocument.Symbol_US.addGeometry(Part.Line(App.Vector(0.0,-7.5,0.0),App.Vector(0.0,7.5,0.0)))
      +    App.ActiveDocument.Symbol_US.addGeometry(Part.Circle(App.Vector(0.0,0.0,0.0),App.Vector(0,0,1),2.5))
      +    App.ActiveDocument.Symbol_US.addGeometry(Part.Circle(App.Vector(0.0,0.0,0.0),App.Vector(0,0,1),5.0))
      +
      +    App.ActiveDocument.Symbol_US.addGeometry(Part.Line(App.Vector(17.5,5.0,0.0),App.Vector(7.5,2.5,0.0)))
      +    App.ActiveDocument.Symbol_US.addGeometry(Part.Line(App.Vector(7.5,-2.5,0.0),App.Vector(7.5,2.5,0.0)))
      +    App.ActiveDocument.Symbol_US.addGeometry(Part.Line(App.Vector(17.5,-5.0,0.0),App.Vector(7.5,-2.5,0.0)))
      +    App.ActiveDocument.Symbol_US.addGeometry(Part.Line(App.Vector(17.5,-5.0,0.0),App.Vector(17.5,5.0,0.0)))
      +    Gui.getDocument(App.ActiveDocument.Name).resetEdit()
      +    FreeCADGui.getDocument(App.ActiveDocument.Name).getObject("Symbol_US").LineColor = (0.00,0.00,0.00)
      +    App.ActiveDocument.recompute()
      +
      +    App.activeDocument().addObject('Drawing::FeatureViewPart','SymbolUS')
      +    App.activeDocument().SymbolUS.Source = App.activeDocument().Symbol_US
      +    App.activeDocument().SymbolUS.Direction = (0.0,0.0,1.0)
      +    App.activeDocument().SymbolUS.X = depx
      +    App.activeDocument().SymbolUS.Y = depy
      +    App.activeDocument().SymbolUS.Scale = 0.8
      +    App.activeDocument().Page.addObject(App.activeDocument().SymbolUS)
      +    App.ActiveDocument.recompute()
      +#    App.getDocument(App.ActiveDocument.Name).removeObject("Symbol_US")
      +    FreeCADGui.getDocument(App.ActiveDocument.Name).getObject("Symbol_US").Visibility = False
      +
      +try:
      +    DESIGNED_BY = App.activeDocument().getObject("Page").EditableTexts[0] #lineEdit01 DESIGNED_BY
      +    CREATION_DATE = App.activeDocument().getObject("Page").EditableTexts[1] #lineEdit02 CREATION_DATE date
      +    CREA_DATE = CREATION_DATE[0:10] # lineEdit02h date
      +    CREA_TIME = CREATION_DATE[13:21] # lineEdit02h heure
      +    CHECKED_BY = App.activeDocument().getObject("Page").EditableTexts[2] # lineEdit03
      +    CHECK_DATE = App.activeDocument().getObject("Page").EditableTexts[3] # lineEdit04 date
      +    CHEC_DATE = CHECK_DATE[0:10] # lineEdit04 date
      +    CHEC_TIME = CHECK_DATE[13:21] # lineEdit04h heure
      +    SIZE = "A3"  # lineEdit05
      +    SCALE = App.activeDocument().getObject("Page").EditableTexts[4] # lineEdit06
      +    WEIGHT = App.activeDocument().getObject("Page").EditableTexts[5] # lineEdit07
      +    DRAWING_NUMBER = App.activeDocument().getObject("Page").EditableTexts[6] # lineEdit08
      +    SHEET = App.activeDocument().getObject("Page").EditableTexts[7] # lineEdit09
      +    TITLE = App.activeDocument().getObject("Page").EditableTexts[8] # textEdit_01
      +    DESCRIPTION = App.activeDocument().getObject("Page").EditableTexts[9] # textEdit_02
      +
      +except:
      +    errorDialog("erreur cartouche")
      +try:
      +    try:
      +        lineEdit18 = App.activeDocument().getObject("Note_I").Text[0] 
      +    except:
      +        lineEdit18 = ""
      +    try:
      +        lineEdit17 = App.activeDocument().getObject("Note_H").Text[0] 
      +    except:
      +        lineEdit17 = ""
      +    try:
      +        lineEdit16 = App.activeDocument().getObject("Note_G").Text[0] 
      +    except:
      +        lineEdit16 = ""
      +    try:
      +        lineEdit15 = App.activeDocument().getObject("Note_F").Text[0] 
      +    except:
      +        lineEdit15 = ""
      +    try:
      +        lineEdit14 = App.activeDocument().getObject("Note_E").Text[0] 
      +    except:
      +        lineEdit14 = ""
      +    try:
      +        lineEdit13 = App.activeDocument().getObject("Note_D").Text[0] 
      +    except:
      +        lineEdit13 = ""
      +    try:
      +        lineEdit12 = App.activeDocument().getObject("Note_C").Text[0] 
      +    except:
      +        lineEdit12 = ""
      +    try:
      +        lineEdit11 = App.activeDocument().getObject("Note_B").Text[0] 
      +    except:
      +        lineEdit11 = ""
      +    try:
      +        lineEdit10 = App.activeDocument().getObject("Note_A").Text[0] 
      +    except:
      +        lineEdit10 = ""
      +    try:
      +        lineEdit20 = App.activeDocument().getObject("CopyRight").Text[0] 
      +    except:
      +        lineEdit20 = ""
      +except:
      +    errorDialog("erreur note")
      +
      +class Ui_MainWindow(object):
      +
      +    def __init__(self, MainWindow):
      +        self.window = MainWindow
      +#___________________________________________________________________________________
      +
      +        MainWindow.setObjectName(_fromUtf8("MainWindow"))
      +        MainWindow.resize(810, 440)
      +        MainWindow.setMaximumSize(QtCore.QSize(810, 480))
      +        self.centralWidget = QtGui.QWidget(MainWindow)
      +        self.centralWidget.setObjectName(_fromUtf8("centralWidget"))
      +
      +#        self.pushButton01 = QtGui.QPushButton(self.centralWidget)
      +#        self.pushButton01.setGeometry(QtCore.QRect(115, 360, 93, 28))
      +#        self.pushButton01.setObjectName(_fromUtf8("pushButton01"))
      +#        self.pushButton01.clicked.connect(self.on_pushButton01_clicked) #connection pushButton01
      +
      +        self.pushButton02 = QtGui.QPushButton(self.centralWidget)
      +        self.pushButton02.setGeometry(QtCore.QRect(225, 360, 93, 28))
      +        self.pushButton02.setObjectName(_fromUtf8("pushButton02"))
      +        self.pushButton02.clicked.connect(self.on_pushButton02_clicked) #connection pushButton02
      +
      +        self.pushButton03 = QtGui.QPushButton(self.centralWidget)
      +        self.pushButton03.setGeometry(QtCore.QRect(335, 360, 93, 28))
      +        self.pushButton03.setObjectName(_fromUtf8("pushButton03"))
      +        self.pushButton03.clicked.connect(self.on_pushButton03_clicked) #connection pushButton03
      +
      +        self.pushButton04 = QtGui.QPushButton(self.centralWidget)
      +        self.pushButton04.setGeometry(QtCore.QRect(445, 360, 93, 28))
      +        self.pushButton04.setObjectName(_fromUtf8("pushButton04"))
      +        self.pushButton04.clicked.connect(self.on_pushButton04_clicked) #connection pushButton04
      +
      +        self.pushButton05 = QtGui.QPushButton(self.centralWidget)
      +        self.pushButton05.setGeometry(QtCore.QRect(555, 360, 93, 28))
      +        self.pushButton05.setObjectName(_fromUtf8("pushButton05"))
      +        self.pushButton05.clicked.connect(self.on_pushButton05_clicked) #connection pushButton05
      +
      +        self.pushButton06 = QtGui.QPushButton(self.centralWidget)
      +        self.pushButton06.setGeometry(QtCore.QRect(170, 56, 20, 20))
      +        self.pushButton06.setObjectName(_fromUtf8("pushButton06"))
      +        self.pushButton06.clicked.connect(self.on_pushButton06_clicked) #connection pushButton06
      +
      +        self.pushButton07 = QtGui.QPushButton(self.centralWidget)
      +        self.pushButton07.setGeometry(QtCore.QRect(190, 56, 20, 20))
      +        self.pushButton07.setObjectName(_fromUtf8("pushButton07"))
      +        self.pushButton07.clicked.connect(self.on_pushButton07_clicked) #connection pushButton07
      +
      +        self.pushButton08 = QtGui.QPushButton(self.centralWidget)
      +        self.pushButton08.setGeometry(QtCore.QRect(170, 136, 20, 20))
      +        self.pushButton08.setObjectName(_fromUtf8("pushButton08"))
      +        self.pushButton08.clicked.connect(self.on_pushButton08_clicked) #connection pushButton08
      +
      +        self.pushButton09 = QtGui.QPushButton(self.centralWidget)
      +        self.pushButton09.setGeometry(QtCore.QRect(190, 136, 20, 20))
      +        self.pushButton09.setObjectName(_fromUtf8("pushButton09"))
      +        self.pushButton09.clicked.connect(self.on_pushButton09_clicked) #connection pushButton09
      +
      +        self.pushButton10 = QtGui.QPushButton(self.centralWidget)
      +        self.pushButton10.setGeometry(QtCore.QRect(100, 220, 101, 20))
      +        self.pushButton10.setObjectName(_fromUtf8("pushButton10"))
      +        self.pushButton10.clicked.connect(self.on_pushButton10_clicked) #connection pushButton10
      +
      +        self.lineEdit_01 = QtGui.QLineEdit(self.centralWidget)
      +        self.lineEdit_01.setGeometry(QtCore.QRect(20, 20, 181, 16))
      +        font = QtGui.QFont()
      +        font.setPointSize(7)
      +        self.lineEdit_01.setFont(font)
      +        self.lineEdit_01.setObjectName(_fromUtf8("lineEdit_01"))
      +        self.lineEdit_01.setText(DESIGNED_BY)
      +
      +        self.lineEdit_02 = QtGui.QLineEdit(self.centralWidget)
      +        self.lineEdit_02.setGeometry(QtCore.QRect(20, 60, 82, 16))
      +        font = QtGui.QFont()
      +        font.setPointSize(7)
      +        self.lineEdit_02.setFont(font)
      +        self.lineEdit_02.setObjectName(_fromUtf8("lineEdit_02"))
      +        self.lineEdit_02.setText(CREA_DATE)
      +
      +        self.lineEdit_02h = QtGui.QLineEdit(self.centralWidget)
      +        self.lineEdit_02h.setGeometry(QtCore.QRect(98, 60, 72, 16))
      +        font = QtGui.QFont()
      +        font.setPointSize(7)
      +        self.lineEdit_02h.setFont(font)
      +        self.lineEdit_02h.setObjectName(_fromUtf8("lineEdit_02h"))
      +        self.lineEdit_02h.setText(CREA_TIME)
      +
      +        self.lineEdit_03 = QtGui.QLineEdit(self.centralWidget)
      +        self.lineEdit_03.setGeometry(QtCore.QRect(20, 100, 181, 16))
      +        font = QtGui.QFont()
      +        font.setPointSize(7)
      +        self.lineEdit_03.setFont(font)
      +        self.lineEdit_03.setObjectName(_fromUtf8("lineEdit_03"))
      +        self.lineEdit_03.setText(CHECKED_BY)
      +
      +        self.lineEdit_04 = QtGui.QLineEdit(self.centralWidget)
      +        self.lineEdit_04.setGeometry(QtCore.QRect(20, 140, 82, 16))
      +        font = QtGui.QFont()
      +        font.setPointSize(7)
      +        self.lineEdit_04.setFont(font)
      +        self.lineEdit_04.setObjectName(_fromUtf8("lineEdit_04"))
      +        self.lineEdit_04.setText(CHEC_DATE)
      +
      +        self.lineEdit_04h = QtGui.QLineEdit(self.centralWidget)
      +        self.lineEdit_04h.setGeometry(QtCore.QRect(98, 140, 72, 16))
      +        font = QtGui.QFont()
      +        font.setPointSize(7)
      +        self.lineEdit_04h.setFont(font)
      +        self.lineEdit_04h.setObjectName(_fromUtf8("lineEdit_04h"))
      +        self.lineEdit_04h.setText(CHEC_TIME)
      +
      +        self.lineEdit_05 = QtGui.QLineEdit(self.centralWidget)
      +        self.lineEdit_05.setGeometry(QtCore.QRect(20, 180, 61, 61))
      +        font = QtGui.QFont()
      +        font.setPointSize(17)
      +        font.setBold(False)
      +        font.setWeight(50)
      +        self.lineEdit_05.setFont(font)
      +        self.lineEdit_05.setAlignment(QtCore.Qt.AlignCenter)
      +        self.lineEdit_05.setObjectName(_fromUtf8("lineEdit_05"))
      +        self.lineEdit_05.setText(SIZE)
      +
      +        self.lineEdit_06 = QtGui.QLineEdit(self.centralWidget)
      +        self.lineEdit_06.setGeometry(QtCore.QRect(20, 280, 61, 41))
      +        font = QtGui.QFont()
      +        font.setPointSize(10)
      +        self.lineEdit_06.setFont(font)
      +        self.lineEdit_06.setAlignment(QtCore.Qt.AlignCenter)
      +        self.lineEdit_06.setObjectName(_fromUtf8("lineEdit_06"))
      +        self.lineEdit_06.setText(SCALE)
      +
      +        self.lineEdit_07 = QtGui.QLineEdit(self.centralWidget)
      +        self.lineEdit_07.setGeometry(QtCore.QRect(100, 280, 101, 41))
      +        font = QtGui.QFont()
      +        font.setPointSize(10)
      +        self.lineEdit_07.setFont(font)
      +        self.lineEdit_07.setAlignment(QtCore.Qt.AlignCenter)
      +        self.lineEdit_07.setObjectName(_fromUtf8("lineEdit_07"))
      +        self.lineEdit_07.setText(WEIGHT)
      +
      +        self.lineEdit_08 = QtGui.QLineEdit(self.centralWidget)
      +        self.lineEdit_08.setGeometry(QtCore.QRect(220, 280, 341, 41))
      +        self.lineEdit_08.setObjectName(_fromUtf8("lineEdit_08"))
      +        self.lineEdit_08.setText(DRAWING_NUMBER)
      +
      +        self.lineEdit_09 = QtGui.QLineEdit(self.centralWidget)
      +        self.lineEdit_09.setGeometry(QtCore.QRect(570, 280, 81, 41))
      +        self.lineEdit_09.setObjectName(_fromUtf8("lineEdit_09"))
      +        self.lineEdit_09.setText(SHEET)
      +
      +        self.lineEdit_10 = QtGui.QLineEdit(self.centralWidget)
      +        self.lineEdit_10.setGeometry(QtCore.QRect(690, 290, 101, 30))
      +        self.lineEdit_10.setObjectName(_fromUtf8("lineEdit_10"))
      +        self.lineEdit_10.setText(lineEdit10)
      +
      +        self.lineEdit_11 = QtGui.QLineEdit(self.centralWidget)
      +        self.lineEdit_11.setGeometry(QtCore.QRect(690, 260, 101, 30))
      +        self.lineEdit_11.setObjectName(_fromUtf8("lineEdit_11"))
      +        self.lineEdit_11.setText(lineEdit11)
      +
      +        self.lineEdit_12 = QtGui.QLineEdit(self.centralWidget)
      +        self.lineEdit_12.setGeometry(QtCore.QRect(690, 230, 101, 30))
      +        self.lineEdit_12.setObjectName(_fromUtf8("lineEdit_12"))
      +        self.lineEdit_12.setText(lineEdit12)
      +
      +        self.lineEdit_13 = QtGui.QLineEdit(self.centralWidget)
      +        self.lineEdit_13.setGeometry(QtCore.QRect(690, 200, 101, 30))
      +        self.lineEdit_13.setObjectName(_fromUtf8("lineEdit_13"))
      +        self.lineEdit_13.setText(lineEdit13)
      +
      +        self.lineEdit_14 = QtGui.QLineEdit(self.centralWidget)
      +        self.lineEdit_14.setGeometry(QtCore.QRect(690, 170, 101, 30))
      +        self.lineEdit_14.setObjectName(_fromUtf8("lineEdit_14"))
      +        self.lineEdit_14.setText(lineEdit14)
      +
      +        self.lineEdit_15 = QtGui.QLineEdit(self.centralWidget)
      +        self.lineEdit_15.setGeometry(QtCore.QRect(690, 140, 101, 30))
      +        self.lineEdit_15.setObjectName(_fromUtf8("lineEdit_15"))
      +        self.lineEdit_15.setText(lineEdit15)
      +
      +        self.lineEdit_16 = QtGui.QLineEdit(self.centralWidget)
      +        self.lineEdit_16.setGeometry(QtCore.QRect(690, 110, 101, 30))
      +        self.lineEdit_16.setObjectName(_fromUtf8("lineEdit_16"))
      +        self.lineEdit_16.setText(lineEdit16)
      +
      +        self.lineEdit_17 = QtGui.QLineEdit(self.centralWidget)
      +        self.lineEdit_17.setGeometry(QtCore.QRect(690, 80, 101, 30))
      +        self.lineEdit_17.setObjectName(_fromUtf8("lineEdit_17"))
      +        self.lineEdit_17.setText(lineEdit17)
      +
      +        self.lineEdit_18 = QtGui.QLineEdit(self.centralWidget)
      +        self.lineEdit_18.setGeometry(QtCore.QRect(690, 50, 101, 30))
      +        self.lineEdit_18.setObjectName(_fromUtf8("lineEdit_18"))
      +        self.lineEdit_18.setText(lineEdit18)
      +
      +        self.lineEdit_20 = QtGui.QLineEdit(self.centralWidget) # Copyright
      +        self.lineEdit_20.setGeometry(QtCore.QRect(20, 330, 771, 22))
      +        self.lineEdit_20.setObjectName(_fromUtf8("lineEdit_20"))
      +        self.lineEdit_20.setText(lineEdit20)
      +
      +        self.textEdit_01 = QtGui.QTextEdit(self.centralWidget)
      +        self.textEdit_01.setGeometry(QtCore.QRect(220, 20, 431,60 ))
      +        font = QtGui.QFont()
      +        font.setPointSize(15)
      +        font.setBold(True)
      +        font.setWeight(75)
      +        self.textEdit_01.setFont(font)
      +        self.textEdit_01.setObjectName(_fromUtf8("textEdit_01"))
      +        self.textEdit_01.setText(TITLE)
      +
      +        self.textEdit_02 = QtGui.QTextEdit(self.centralWidget)
      +        self.textEdit_02.setGeometry(QtCore.QRect(220, 90, 431, 60))
      +        self.textEdit_02.setObjectName(_fromUtf8("textEdit_02"))
      +        self.textEdit_02.setText(DESCRIPTION)
      +
      +#        self.graphicsView_01 = QtGui.QGraphicsView(self.centralWidget)
      +#        self.graphicsView_01.setGeometry(QtCore.QRect(100, 160, 101, 81))
      +#        brush = QtGui.QBrush(QtGui.QColor(0, 170, 255))
      +#        brush.setStyle(QtCore.Qt.NoBrush)
      +#        self.graphicsView_01.setBackgroundBrush(brush)
      +#        self.graphicsView_01.setObjectName(_fromUtf8("graphicsView_01"))
      +
      +        self.textEdit_03 = QtGui.QTextEdit(self.centralWidget)
      +        self.textEdit_03.setGeometry(QtCore.QRect(100, 160, 101, 55))
      +        self.textEdit_03.setAlignment(QtCore.Qt.AlignCenter)
      +        self.textEdit_03.setObjectName(_fromUtf8("textEdit_03"))
      +        self.textEdit_03.setText("Select your Symbol")
      +
      +        self.graphicsView_02 = QtGui.QGraphicsView(self.centralWidget)
      +        self.graphicsView_02.setGeometry(QtCore.QRect(220, 160, 431, 81))#570, 160, 81, 81
      +        self.graphicsView_02.setObjectName(_fromUtf8("graphicsView_02"))
      +
      +        self.label_01 = QtGui.QLabel(self.centralWidget)
      +        self.label_01.setGeometry(QtCore.QRect(20, 0, 91, 16))
      +        self.label_01.setObjectName(_fromUtf8("label_01"))
      +
      +        self.label_02 = QtGui.QLabel(self.centralWidget)
      +        self.label_02.setGeometry(QtCore.QRect(20, 40, 53, 16))
      +        self.label_02.setObjectName(_fromUtf8("label_02"))
      +
      +        self.label_03 = QtGui.QLabel(self.centralWidget)
      +        self.label_03.setGeometry(QtCore.QRect(20, 80, 101, 16))
      +        self.label_03.setObjectName(_fromUtf8("label_03"))
      +
      +        self.label_04 = QtGui.QLabel(self.centralWidget)
      +        self.label_04.setGeometry(QtCore.QRect(20, 120, 91, 16))
      +        self.label_04.setObjectName(_fromUtf8("label_04"))
      +
      +        self.label_05 = QtGui.QLabel(self.centralWidget)
      +        self.label_05.setGeometry(QtCore.QRect(20, 160, 53, 16))
      +        self.label_05.setObjectName(_fromUtf8("label_05"))
      +
      +        self.label_06 = QtGui.QLabel(self.centralWidget)
      +        self.label_06.setGeometry(QtCore.QRect(20, 260, 53, 16))
      +        self.label_06.setObjectName(_fromUtf8("label_06"))
      +
      +        self.label_07 = QtGui.QLabel(self.centralWidget)
      +        self.label_07.setGeometry(QtCore.QRect(100, 260, 101, 16))
      +        self.label_07.setObjectName(_fromUtf8("label_07"))
      +
      +        self.label_08 = QtGui.QLabel(self.centralWidget)
      +        self.label_08.setGeometry(QtCore.QRect(220, 260, 121, 16))
      +        self.label_08.setObjectName(_fromUtf8("label_08"))
      +
      +        self.label_09 = QtGui.QLabel(self.centralWidget)
      +        self.label_09.setGeometry(QtCore.QRect(570, 260, 53, 16))
      +        self.label_09.setObjectName(_fromUtf8("label_09"))
      +
      +        self.label_10 = QtGui.QLabel(self.centralWidget)
      +        self.label_10.setGeometry(QtCore.QRect(670, 290, 16, 33))
      +        font = QtGui.QFont()
      +        font.setPointSize(12)
      +        font.setBold(True)
      +        font.setWeight(75)
      +        self.label_10.setFont(font)
      +        self.label_10.setObjectName(_fromUtf8("label_10"))
      +
      +        self.label_11 = QtGui.QLabel(self.centralWidget)
      +        self.label_11.setGeometry(QtCore.QRect(670, 260, 16, 33))
      +        font = QtGui.QFont()
      +        font.setPointSize(12)
      +        font.setBold(True)
      +        font.setWeight(75)
      +        self.label_11.setFont(font)
      +        self.label_11.setObjectName(_fromUtf8("label_11"))
      +
      +        self.label_12 = QtGui.QLabel(self.centralWidget)
      +        self.label_12.setGeometry(QtCore.QRect(670, 230, 16, 33))
      +        font = QtGui.QFont()
      +        font.setPointSize(12)
      +        font.setBold(True)
      +        font.setWeight(75)
      +        self.label_12.setFont(font)
      +        self.label_12.setObjectName(_fromUtf8("label_12"))
      +
      +        self.label_13 = QtGui.QLabel(self.centralWidget)
      +        self.label_13.setGeometry(QtCore.QRect(670, 200, 18, 33))
      +        font = QtGui.QFont()
      +        font.setPointSize(12)
      +        font.setBold(True)
      +        font.setWeight(75)
      +        self.label_13.setFont(font)
      +        self.label_13.setObjectName(_fromUtf8("label_13"))
      +
      +        self.label_14 = QtGui.QLabel(self.centralWidget)
      +        self.label_14.setGeometry(QtCore.QRect(670, 170, 15, 33))
      +        font = QtGui.QFont()
      +        font.setPointSize(12)
      +        font.setBold(True)
      +        font.setWeight(75)
      +        self.label_14.setFont(font)
      +        self.label_14.setObjectName(_fromUtf8("label_14"))
      +
      +        self.label_15 = QtGui.QLabel(self.centralWidget)
      +        self.label_15.setGeometry(QtCore.QRect(670, 140, 14, 33))
      +        font = QtGui.QFont()
      +        font.setPointSize(12)
      +        font.setBold(True)
      +        font.setWeight(75)
      +        self.label_15.setFont(font)
      +        self.label_15.setObjectName(_fromUtf8("label_15"))
      +
      +        self.label_16 = QtGui.QLabel(self.centralWidget)
      +        self.label_16.setGeometry(QtCore.QRect(670, 110, 18, 33))
      +        font = QtGui.QFont()
      +        font.setPointSize(12)
      +        font.setBold(True)
      +        font.setWeight(75)
      +        self.label_16.setFont(font)
      +        self.label_16.setObjectName(_fromUtf8("label_16"))
      +
      +        self.label_17 = QtGui.QLabel(self.centralWidget)
      +        self.label_17.setGeometry(QtCore.QRect(670, 80, 18, 33))
      +        font = QtGui.QFont()
      +        font.setPointSize(12)
      +        font.setBold(True)
      +        font.setWeight(75)
      +        self.label_17.setFont(font)
      +        self.label_17.setObjectName(_fromUtf8("label_17"))
      +
      +        self.label_18 = QtGui.QLabel(self.centralWidget)
      +        self.label_18.setGeometry(QtCore.QRect(670, 50, 10, 33))
      +        font = QtGui.QFont()
      +        font.setPointSize(12)
      +        font.setBold(True)
      +        font.setWeight(75)
      +        self.label_18.setFont(font)
      +        self.label_18.setObjectName(_fromUtf8("label_18"))
      +
      +        self.label_19 = QtGui.QLabel(self.centralWidget)
      +        self.label_19.setGeometry(QtCore.QRect(720, 15, 100, 33))
      +        self.label_19.setObjectName(_fromUtf8("label_19"))
      +
      +        MainWindow.setCentralWidget(self.centralWidget)
      +        self.menuBar = QtGui.QMenuBar(MainWindow)
      +        self.menuBar.setGeometry(QtCore.QRect(0, 0, 810, 26))
      +        self.menuBar.setObjectName(_fromUtf8("menuBar"))
      +        MainWindow.setMenuBar(self.menuBar)
      +        self.statusBar = QtGui.QStatusBar(MainWindow)
      +        self.statusBar.setObjectName(_fromUtf8("statusBar"))
      +        MainWindow.setStatusBar(self.statusBar)
      +
      +        self.retranslateUi(MainWindow)
      +        QtCore.QMetaObject.connectSlotsByName(MainWindow)
      +
      +    def retranslateUi(self, MainWindow):
      +        try:
      +            MainWindow.setWindowFlags(PyQt4.QtCore.Qt.WindowStaysOnTopHint)  # PyQt4 cette fonction met la fenêtre en avant
      +        except Exception:
      +            MainWindow.setWindowFlags(PySide.QtCore.Qt.WindowStaysOnTopHint) # PySide cette fonction met la fenêtre en avant
      +
      +        MainWindow.setWindowTitle(_translate("MainWindow", "Cartouche", None))
      +#        self.pushButton01.setText(_translate("MainWindow", "Position", None))
      +        self.pushButton02.setText(_translate("MainWindow", "Quitter", None))
      +        self.pushButton03.setText(_translate("MainWindow", "Memo", None))
      +        self.pushButton04.setText(_translate("MainWindow", "Nettoyer", None))
      +        self.pushButton05.setText(_translate("MainWindow", "Appliquer", None))
      +        self.pushButton06.setText(_translate("MainWindow", "D.", None))
      +        self.pushButton07.setText(_translate("MainWindow", "H.", None))
      +        self.pushButton08.setText(_translate("MainWindow", "D.", None))
      +        self.pushButton09.setText(_translate("MainWindow", "H.", None))
      +        self.pushButton10.setText(_translate("MainWindow", "Symbole EU", None))
      +
      +
      +        self.label_01.setText(_translate("MainWindow", "Designed by :", None))
      +        self.label_02.setText(_translate("MainWindow", "Date :", None))
      +        self.label_03.setText(_translate("MainWindow", "Checked by :", None))
      +        self.label_04.setText(_translate("MainWindow", "Date :", None))
      +        self.label_05.setText(_translate("MainWindow", "Size :", None))
      +        self.label_06.setText(_translate("MainWindow", "Scale :", None))
      +        self.label_07.setText(_translate("MainWindow", "Weight (Kg) :", None))
      +        self.label_08.setText(_translate("MainWindow", "Drawing number :", None))
      +        self.label_09.setText(_translate("MainWindow", "Sheet :", None))
      +        self.label_10.setText(_translate("MainWindow", "A", None))
      +        self.label_11.setText(_translate("MainWindow", "B", None))
      +        self.label_12.setText(_translate("MainWindow", "C", None))
      +        self.label_13.setText(_translate("MainWindow", "D", None))
      +        self.label_14.setText(_translate("MainWindow", "E", None))
      +        self.label_15.setText(_translate("MainWindow", "F", None))
      +        self.label_16.setText(_translate("MainWindow", "G", None))
      +        self.label_17.setText(_translate("MainWindow", "H", None))
      +        self.label_18.setText(_translate("MainWindow", "I", None))
      +        self.label_19.setText(_translate("MainWindow", "Notes", None))
      +#______________________________________________________________________________________
      +    # Boutons
      +    def on_pushButton10_clicked(self):    # Bouton /Symbole
      +        if self.textEdit_03.toPlainText()=="Symbole US":
      +            self.pushButton10.setText(_translate("MainWindow", "Symbole US", None))
      +            self.textEdit_03.setText("Symbole EU")
      +            symbol_EU(247.5,263.5) #(247.5,263.5)
      +        else:
      +            self.pushButton10.setText(_translate("MainWindow", "Symbole EU", None))
      +            self.textEdit_03.setText("Symbole US")
      +            symbol_US(247.5,263.5) #(247.5,263.5)
      +    def on_pushButton09_clicked(self):    # Bouton /heure document
      +        self.lineEdit_04h.setText(str(heure()))
      +    def on_pushButton08_clicked(self):    # Bouton date/ document
      +        if self.textEdit_03.toPlainText()=="Symbole US":
      +            self.lineEdit_04.setText(str(dateUs()))
      +        else:
      +            self.lineEdit_04.setText(str(dateEu()))
      +    def on_pushButton07_clicked(self):    # Bouton /heure checked
      +        self.lineEdit_02h.setText(str(heure()))
      +    def on_pushButton06_clicked(self):    # Bouton date/ checked
      +        if self.textEdit_03.toPlainText()=="Symbole US":
      +            self.lineEdit_02.setText(str(dateUs()))
      +        else:
      +            self.lineEdit_02.setText(str(dateEu()))
      +    def on_pushButton05_clicked(self):    # Bouton Appliquer
      +        DESIGNED_BY = self.lineEdit_01.text()     
      +        CREATION_DATE = self.lineEdit_02.text()+" - "+self.lineEdit_02h.text()
      +        CHECKED_BY = self.lineEdit_03.text()
      +        CHECK_DATE = self.lineEdit_04.text()+" - "+self.lineEdit_04h.text()
      +        SIZE  = "A3" # self.lineEdit_05.text()
      +        SCALE = self.lineEdit_06.text()
      +        WEIGHT = self.lineEdit_07.text()
      +        DRAWING_NUMBER = self.lineEdit_08.text()
      +        SHEET = self.lineEdit_09.text()
      +        TITLE = self.textEdit_01.toPlainText()
      +        DESCRIPTION = self.textEdit_02.toPlainText()
      +        SYMBOL = self.textEdit_03.toPlainText()
      +        try:
      +            FreeCAD.getDocument (App.ActiveDocument.Name).getObject("Page").EditableTexts = [unicode(DESIGNED_BY, 'utf-8'), unicode(CREATION_DATE, 'utf-8'), unicode(CHECKED_BY, 'utf-8'), unicode(CHECK_DATE, 'utf-8'), unicode(SCALE, 'utf-8'), unicode(WEIGHT, 'utf-8'), unicode(DRAWING_NUMBER, 'utf-8'), unicode(SHEET, 'utf-8'), unicode(TITLE, 'utf-8'), unicode(DESCRIPTION, 'utf-8'),]
      +        except Exception:
      +            FreeCAD.getDocument (App.ActiveDocument.Name).getObject("Page").EditableTexts = [DESIGNED_BY.encode('utf-8'), CREATION_DATE.encode('utf-8'), CHECKED_BY.encode('utf-8'), CHECK_DATE.encode('utf-8'), SCALE.encode('utf-8'), WEIGHT.encode('utf-8'), DRAWING_NUMBER.encode('utf-8'), SHEET.encode('utf-8'), TITLE.encode('utf-8'), DESCRIPTION.encode('utf-8'),]
      +
      +        #print App.ActiveDocument.Name
      +        try:
      +            App.activeDocument().removeObject('Note_I')
      +        except:
      +            None
      +        try:
      +            App.activeDocument().removeObject('Note_H')
      +        except:
      +            None
      +        try:
      +            App.activeDocument().removeObject('Note_G')
      +        except:
      +            None
      +        try:
      +            App.activeDocument().removeObject('Note_F')
      +        except:
      +            None
      +        try:
      +            App.activeDocument().removeObject('Note_E')
      +        except:
      +            None
      +        try:
      +            App.activeDocument().removeObject('Note_D')
      +        except:
      +            None
      +        try:
      +            App.activeDocument().removeObject('Note_C')
      +        except:
      +            None
      +        try:
      +            App.activeDocument().removeObject('Note_B')
      +        except:
      +            None
      +        try:
      +            App.activeDocument().removeObject('Note_A')
      +        except:
      +            None
      +        try:
      +            App.activeDocument().removeObject('CopyRight')
      +        except:
      +            None
      +        if self.lineEdit_18.text() != "":
      +            App.activeDocument().addObject('Drawing::FeatureViewAnnotation','Note_I')
      +            App.activeDocument().Note_I.X = 391.0
      +            App.activeDocument().Note_I.Y = 232
      +            App.activeDocument().Note_I.Scale = 3.0
      +            App.activeDocument().Note_I.Text = str(self.lineEdit_18.text())
      +            App.activeDocument().Page.addObject(App.activeDocument().Note_I)
      +        if self.lineEdit_17.text() != "":
      +            App.activeDocument().addObject('Drawing::FeatureViewAnnotation','Note_H')
      +            App.activeDocument().Note_H.X = 391.0
      +            App.activeDocument().Note_H.Y = 238.8
      +            App.activeDocument().Note_H.Scale = 3.0
      +            App.activeDocument().Note_H.Text = str(self.lineEdit_17.text())
      +            App.activeDocument().Page.addObject(App.activeDocument().Note_H)
      +        if self.lineEdit_16.text() != "":
      +            App.activeDocument().addObject('Drawing::FeatureViewAnnotation','Note_G')
      +            App.activeDocument().Note_G.X = 391.0
      +            App.activeDocument().Note_G.Y = 245.4
      +            App.activeDocument().Note_G.Scale = 3.0
      +            App.activeDocument().Note_G.Text = str(self.lineEdit_16.text())
      +            App.activeDocument().Page.addObject(App.activeDocument().Note_G)
      +        if self.lineEdit_15.text() != "":
      +            App.activeDocument().addObject('Drawing::FeatureViewAnnotation','Note_F')
      +            App.activeDocument().Note_F.X = 391.0
      +            App.activeDocument().Note_F.Y = 252
      +            App.activeDocument().Note_F.Scale = 3.0
      +            App.activeDocument().Note_F.Text = str(self.lineEdit_15.text())
      +            App.activeDocument().Page.addObject(App.activeDocument().Note_F)
      +        if self.lineEdit_14.text() != "":
      +            App.activeDocument().addObject('Drawing::FeatureViewAnnotation','Note_E')
      +            App.activeDocument().Note_E.X = 391.0
      +            App.activeDocument().Note_E.Y = 258.6
      +            App.activeDocument().Note_E.Scale = 3.0
      +            App.activeDocument().Note_E.Text = str(self.lineEdit_14.text())
      +            App.activeDocument().Page.addObject(App.activeDocument().Note_E)
      +        if self.lineEdit_13.text() != "":
      +            App.activeDocument().addObject('Drawing::FeatureViewAnnotation','Note_D')
      +            App.activeDocument().Note_D.X = 391.0
      +            App.activeDocument().Note_D.Y = 265.2
      +            App.activeDocument().Note_D.Scale = 3.0
      +            App.activeDocument().Note_D.Text = str(self.lineEdit_13.text())
      +            App.activeDocument().Page.addObject(App.activeDocument().Note_D)
      +        if self.lineEdit_12.text() != "":
      +            App.activeDocument().addObject('Drawing::FeatureViewAnnotation','Note_C')
      +            App.activeDocument().Note_C.X = 391.0
      +            App.activeDocument().Note_C.Y = 271.8
      +            App.activeDocument().Note_C.Scale = 3.0
      +            App.activeDocument().Note_C.Text =  str(self.lineEdit_12.text())
      +            App.activeDocument().Page.addObject(App.activeDocument().Note_C)
      +        if self.lineEdit_11.text() != "":
      +            App.activeDocument().addObject('Drawing::FeatureViewAnnotation','Note_B')
      +            App.activeDocument().Note_B.X = 391.0
      +            App.activeDocument().Note_B.Y = 278.4
      +            App.activeDocument().Note_B.Scale = 3.0
      +            App.activeDocument().Note_B.Text = str(self.lineEdit_11.text())
      +            App.activeDocument().Page.addObject(App.activeDocument().Note_B)
      +        if self.lineEdit_10.text() != "":
      +            App.activeDocument().addObject('Drawing::FeatureViewAnnotation','Note_A')
      +            App.activeDocument().Note_A.X = 391.0
      +            App.activeDocument().Note_A.Y = 285.0
      +            App.activeDocument().Note_A.Scale = 3.0
      +            App.activeDocument().Note_A.Text = str(self.lineEdit_10.text())
      +            App.activeDocument().Page.addObject(App.activeDocument().Note_A)
      +        if self.lineEdit_20.text() != "":
      +            App.activeDocument().addObject('Drawing::FeatureViewAnnotation','CopyRight')
      +            App.activeDocument().CopyRight.X = 221
      +            App.activeDocument().CopyRight.Y = 286
      +            App.activeDocument().CopyRight.Scale = 3.0
      +            App.activeDocument().CopyRight.Text = str(self.lineEdit_20.text())
      +            App.activeDocument().Page.addObject(App.activeDocument().CopyRight)
      +
      +        App.ActiveDocument.recompute()
      +
      +    def on_pushButton04_clicked(self):    # Bouton nettoyer
      +        try:
      +            App.getDocument(App.ActiveDocument.Name).removeObject("Symbol_US")
      +        except:
      +            None
      +        try:
      +            App.getDocument(App.ActiveDocument.Name).removeObject("Symbol_EU")
      +        except:
      +            None
      +        try:
      +            App.getDocument(App.ActiveDocument.Name).removeObject("SymbolUS")
      +        except:
      +            None
      +        try:
      +            App.getDocument(App.ActiveDocument.Name).removeObject("SymbolEU")
      +        except:
      +            None
      +        DESIGNED_BY = ""    ;self.lineEdit_01.setText("")
      +        CREATION_DATE = ""  ;self.lineEdit_02.setText("")
      +        self.lineEdit_02h.setText("")
      +        CHECKED_BY = ""     ;self.lineEdit_03.setText("")
      +        CHECK_DATE = ""     ;self.lineEdit_04.setText("")
      +        self.lineEdit_04h.setText("")
      +        SIZE  = "A3"        ;self.lineEdit_05.setText("A3")
      +        SCALE = ""          ;self.lineEdit_06.setText("")
      +        WEIGHT = ""         ;self.lineEdit_07.setText("")
      +        DRAWING_NUMBER = "" ;self.lineEdit_08.setText("")
      +        SHEET = ""          ;self.lineEdit_09.setText("")
      +        TITLE = ""          ;self.textEdit_01.setText("")
      +        DESCRIPTION = ""    ;self.textEdit_02.setText("")
      +        
      +        self.lineEdit_10.setText("")
      +        self.lineEdit_11.setText("")
      +        self.lineEdit_12.setText("")
      +        self.lineEdit_13.setText("")
      +        self.lineEdit_14.setText("")
      +        self.lineEdit_15.setText("")
      +        self.lineEdit_16.setText("")
      +        self.lineEdit_17.setText("")
      +        self.lineEdit_18.setText("")
      +        self.lineEdit_20.setText("")
      +
      +    def on_pushButton03_clicked(self):    # Bouton Memo
      +        self.lineEdit_01.setText(DESIGNED_BY)
      +        self.lineEdit_02.setText(CREA_DATE)
      +        self.lineEdit_02h.setText(CREA_TIME)
      +        self.lineEdit_03.setText(CHECKED_BY)
      +        self.lineEdit_04.setText(CHEC_DATE)
      +        self.lineEdit_04h.setText(CHEC_TIME)
      +        self.lineEdit_05.setText(SIZE)
      +        self.lineEdit_06.setText(SCALE)
      +        self.lineEdit_07.setText(WEIGHT)
      +        self.lineEdit_08.setText(DRAWING_NUMBER)
      +        self.lineEdit_09.setText(SHEET)
      +        self.textEdit_01.setText(TITLE)
      +        self.textEdit_02.setText(DESCRIPTION)
      +
      +        self.lineEdit_18.setText(lineEdit18)
      +        self.lineEdit_17.setText(lineEdit17)
      +        self.lineEdit_16.setText(lineEdit16)
      +        self.lineEdit_15.setText(lineEdit15)
      +        self.lineEdit_14.setText(lineEdit14)
      +        self.lineEdit_13.setText(lineEdit13)
      +        self.lineEdit_12.setText(lineEdit12)
      +        self.lineEdit_11.setText(lineEdit11)
      +        self.lineEdit_10.setText(lineEdit10)
      +        self.lineEdit_20.setText(lineEdit20)
      +
      +    def on_pushButton02_clicked(self):    # Bouton Quitter
      +        App.Console.PrintMessage("Terminé\r\n")
      +        self.window.hide()
      +#    def on_pushButton01_clicked(self):    # Bouton appel de Position
      +#        MainWindow.resize(210, 480)
      +#        executer()
      +#        MainWindow.resize(810, 480)
      +#______________________________________________________________________________________
      +
      +MainWindow = QtGui.QMainWindow()
      +ui = Ui_MainWindow(MainWindow)
      +MainWindow.show() 
      +

      Other

      +

      The fields have no length limit, check your cartouche.
      +This program creates a drawing representing the regional projection symbol on your project, do not touch it is registered therefore hidden form invisible.
      +If you want it to be cleared uncomment the commented lines and vice versa +

      +
      #    App.getDocument(App.ActiveDocument.Name).removeObject("Symbol_EU")
      +    FreeCADGui.getDocument(App.ActiveDocument.Name).getObject("Symbol_EU").Visibility = False
      +et
      +#    App.getDocument(App.ActiveDocument.Name).removeObject("Symbol_US")
      +    FreeCADGui.getDocument(App.ActiveDocument.Name).getObject("Symbol_US").Visibility = False 
      +


      +(I had some times an error in execution when the symbol was erased)
      +This module works with the drawing sheet included in FreeCAD this sheet is called Page, do not change the name of this sheet! +

      +

      Revision

      +

      ver 0.3 02/07/2014 converted to PyQt4 and PySide +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Macro_CartoucheFC_2.html b/localwiki/Macro_CartoucheFC_2.html new file mode 100644 index 0000000..64fe8ce --- /dev/null +++ b/localwiki/Macro_CartoucheFC_2.html @@ -0,0 +1,747 @@ +Macro CartoucheFC 2

      Macro CartoucheFC 2

      + +
      + + + + + + + + + + + + + + + + + + + + + + + + + + +
      +

      Text-x-python.png Macro CartoucheFC 2

      +
      Description +
      This macro is a complete application, it allows to fill the cartridge of the drawing sheet with full editabletext. +
      Author +
      Mario52 +
      Links +
      Macros recipes
      How to install macros
      How to customize toolbars +
      Version +
      5.0 +
      Date last modification +
      2014-08-08 +
      +

      + +
      +


      +

      This macro is a complete application, it allows to fill simply all the fields of the cartridge A3 Landscape english +

      Macro CartoucheFC Modele 2 +

      The picture represents the hierarchy of filling the fields occupied in the "textEditable" window in FreeCAD +

      +

      Utilisation

      +

      Usage is very easy, run the macro and modify the fields. +

      +
      • The Quit button to exit the application.
      • +
      • The Memo button renders the contents of the cartridge at the opening of the macro.
      • +
      • The Clear button clean all the fields in the macro (fields are rendered by pressing on the Memo).
      • +
      • The Apply button applies the changes to the template.
      +

      The window stays above all windows to visualize the changes (this function can be unpleasant if you decide to open a new window and remains unavailable) +


      +

      PS: Some characters such as & $ are not accepted (and possibly other special characters). +

      If you have any questions or want to add a function, you can address you on the french forum Remplir cartouche +

      +

      Code

      +

      Macro_CartoucheFC_2.FcMacro +

      +
      # -*- coding: utf-8 -*-
      +"""
      +***************************************************************************
      +*   Copyright (c) 2014 <mario52>                                          *
      +*                                                                         *
      +*   This file is a supplement to the FreeCAD CAD development system.      *
      +*                                                                         *
      +*   This program is free software; you can redistribute it and/or modify  *
      +*   it under the terms of the GNU Lesser General Public License (LGPL)    *
      +*   as published by the Free Software Foundation; either version 2 of     *
      +*   the License, or (at your option) any later version.                   *
      +*   for detail see the LICENCE text file.                                 *
      +*                                                                         *
      +*   This software is distributed in the hope that it will be useful,      *
      +*   but WITHOUT ANY WARRANTY; without even the implied warranty of        *
      +*   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the         *
      +*   GNU Library General Public License for more details.                  *
      +*                                                                         *
      +*   You should have received a copy of the GNU Library General Public     *
      +*   License along with this macro; if not, write to the Free Software     *
      +*   Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  *
      +*   USA                                                                   *
      +***************************************************************************
      +*           WARNING! All changes in this file will be lost and            *  
      +*                  may cause malfunction of the program                   *
      +***************************************************************************
      +"""
      +# Macro_CartoucheFC_2.FcMacro
      +# 
      +# il faut que la page (drawing viewer) s'appelle " Page " qui est le nom par défaut du module Drawing
      +# cette macro fonctionne avec la feuille A3_Landscape_ qui possede tous les champs EditableTexts
      +# 
      +# http://www.freecadweb.org/wiki/index.php?title=Drawing_templates
      +# Fill the area of the cartridge
      +# It is necessary that the page (drawing viewer) is called "Page", which is the default name of the Drawing module
      +# Python 2.6
      +# 08/08/2014 ver 5.0 (pour cartouche modèle 2 (A3 Landscape english)) # PyQt and PySide 
      +# Created:  by mario52
      +# PyQt and PySide 
      +
      +#OS: Windows Vista
      +#Word size: 32-bit
      +#Version: 0.14.3700 (Git)
      +#Branch: releases/FreeCAD-0-14
      +#Hash: 32f5aae0a64333ec8d5d160dbc46e690510c8fe1
      +#Python version: 2.6.2
      +#Qt version: 4.5.2
      +#Coin version: 3.1.0
      +#SoQt version: 1.4.1
      +
      +try:
      +    import PyQt4                        # PyQt4
      +    from PyQt4 import QtCore, QtGui     # PyQt4
      +except Exception:
      +    import PySide                       # PySide
      +    from PySide import QtCore, QtGui    # PySide
      +
      +import Draft, Part, FreeCAD, math, PartGui, FreeCADGui
      +from math import sqrt, pi, sin, cos, asin
      +from FreeCAD import Base
      +
      +def utf8(unio):
      +    return unicode(unio).encode('UTF8')
      +
      +global path
      +global Drawn_by               ; Drawn_by       = ""   # lineEdit_001
      +global DRAWN_BY               ; DRAWN_BY       = ""   # lineEdit_002
      +global Controlled_by          ; Controlled_by  = ""   # lineEdit_003
      +global CONTROLLED_BY          ; CONTROLLED_BY  = ""   # lineEdit_004
      +global Date                   ; Date           = ""   # lineEdit_005
      +global DATE                   ; DATE           = ""   # lineEdit_006
      +global Controlled_2           ; Controlled_2   = ""   # lineEdit_007
      +global CONTROLLED_2           ; CONTROLLED_2   = ""   # lineEdit_008
      +global Controlled_3           ; Controlled_3   = ""   # lineEdit_009
      +global CONTROLLED_3           ; CONTROLLED_3   = ""   # lineEdit_010
      +global SCALE                  ; SCALE          = ""   # lineEdit_011
      +global MOD                    ; MOD            = ""   # lineEdit_012
      +global COMPANY                ; COMPANY        = ""   # lineEdit_013
      +global ADRESS                 ; ADRESS         = ""   # lineEdit_014
      +global COUNTRY                ; COUNTRY        = ""   # lineEdit_015
      +global PART_NAME              ; PART_NAME      = ""   # lineEdit_016
      +global Project_number         ; Project_number = ""   # lineEdit_017
      +global A_                     ; A_             = ""   # lineEdit_018
      +global A__                    ; A__            = ""   # lineEdit_019
      +global B_                     ; B_             = ""   # lineEdit_020
      +global B__                    ; B__            = ""   # lineEdit_021
      +global C_                     ; C_             = ""   # lineEdit_022
      +global C__                    ; C__            = ""   # lineEdit_023
      +global D_                     ; D_             = ""   # lineEdit_024
      +global D__                    ; D__            = ""   # lineEdit_025
      +global E_                     ; E_             = ""   # lineEdit_026
      +global E__                    ; E__            = ""   # lineEdit_027
      +global Quantity               ; Quantity       = ""   # lineEdit_028
      +global Part_ID_number         ; Part_ID_number = ""   # lineEdit_029
      +global Fabrication_tolerances ; Fabrication_tolerance = "" #lineEdit_030
      +global Material               ; Material       = ""   # lineEdit_031
      +global _01                    ; _01            = ""   # lineEdit_032
      +global _001_001               ; _001_001       = ""   # lineEdit_033
      +global ISO2768_fh             ; ISO2768_fh     = ""   # lineEdit_034
      +global IRON                   ; IRON           = ""   # lineEdit_035
      +
      +path = FreeCAD.ConfigGet("AppHomePath")
      +
      +try:
      +    _fromUtf8 = QtCore.QString.fromUtf8
      +except AttributeError:
      +    def _fromUtf8(s):
      +        return s
      +try:
      +    _encoding = QtGui.QApplication.UnicodeUTF8
      +    def _translate(context, text, disambig):
      +        return QtGui.QApplication.translate(context, text, disambig, _encoding)
      +except AttributeError:
      +    def _translate(context, text, disambig):
      +        return QtGui.QApplication.translate(context, text, disambig)
      +
      +def errorDialog(msg):
      +    # Create a simple dialog QMessageBox
      +    # The first argument indicates the icon used: one of QtGui.QMessageBox.{NoIcon, Information, Warning, Critical, Question} 
      +    diag = QtGui.QMessageBox(QtGui.QMessageBox.Critical,u"Error Message",msg)
      +    try:
      +        diag.setWindowFlags(PyQt4.QtCore.Qt.WindowStaysOnTopHint)  # PyQt4 cette fonction met la fenêtre en avant
      +    except Exception:
      +        diag.setWindowFlags(PySide.QtCore.Qt.WindowStaysOnTopHint) # PySide cette fonction met la fenêtre en avant
      +    #diag.setWindowModality(QtCore.Qt.ApplicationModal) # la fonction a été désactivée pour favoriser "WindowStaysOnTopHint"
      +    diag.exec_()
      +
      +try:
      +    Drawn_by = App.activeDocument().getObject("Page").EditableTexts[0]          # lineEdit_001
      +    DRAWN_BY = App.activeDocument().getObject("Page").EditableTexts[1]          # lineEdit_002
      +    Controlled_by = App.activeDocument().getObject("Page").EditableTexts[2]     # lineEdit_003
      +    CONTROLLED_BY = App.activeDocument().getObject("Page").EditableTexts[3]     # lineEdit_004
      +    Date = App.activeDocument().getObject("Page").EditableTexts[4]              # lineEdit_005
      +    DATE = App.activeDocument().getObject("Page").EditableTexts[5]              # lineEdit_006
      +    Controlled_2 = App.activeDocument().getObject("Page").EditableTexts[6]      # lineEdit_007
      +    CONTROLLED_2 = App.activeDocument().getObject("Page").EditableTexts[7]      # lineEdit_008
      +    Controlled_3 = App.activeDocument().getObject("Page").EditableTexts[8]      # lineEdit_009
      +    CONTROLLED_3 = App.activeDocument().getObject("Page").EditableTexts[9]      # lineEdit_010
      +    SCALE = App.activeDocument().getObject("Page").EditableTexts[10]            # lineEdit_011
      +    MOD = App.activeDocument().getObject("Page").EditableTexts[11]              # lineEdit_012
      +    COMPANY = App.activeDocument().getObject("Page").EditableTexts[12]          # lineEdit_013
      +    ADRESS = App.activeDocument().getObject("Page").EditableTexts[13]           # lineEdit_014
      +    COUNTRY = App.activeDocument().getObject("Page").EditableTexts[14]          # lineEdit_015
      +    PART_NAME = App.activeDocument().getObject("Page").EditableTexts[15]        # lineEdit_016
      +    Project_number = App.activeDocument().getObject("Page").EditableTexts[16]   # lineEdit_017
      +    A_ = App.activeDocument().getObject("Page").EditableTexts[17]               # lineEdit_018
      +    A__ = App.activeDocument().getObject("Page").EditableTexts[18]              # lineEdit_019
      +    B_ = App.activeDocument().getObject("Page").EditableTexts[19]               # lineEdit_020
      +    B__ = App.activeDocument().getObject("Page").EditableTexts[20]              # lineEdit_021
      +    C_ = App.activeDocument().getObject("Page").EditableTexts[21]               # lineEdit_022
      +    C__ = App.activeDocument().getObject("Page").EditableTexts[22]              # lineEdit_023
      +    D_ = App.activeDocument().getObject("Page").EditableTexts[23]               # lineEdit_024
      +    D__ = App.activeDocument().getObject("Page").EditableTexts[24]              # lineEdit_025
      +    E_ = App.activeDocument().getObject("Page").EditableTexts[25]               # lineEdit_026
      +    E__ = App.activeDocument().getObject("Page").EditableTexts[26]              # lineEdit_027
      +    Quantity= App.activeDocument().getObject("Page").EditableTexts[27]          # lineEdit_028
      +    Part_ID_number = App.activeDocument().getObject("Page").EditableTexts[28]   # lineEdit_029
      +    Fabrication_tolerance = App.activeDocument().getObject("Page").EditableTexts[29] #lineEdit_030
      +    Material = App.activeDocument().getObject("Page").EditableTexts[30]         # lineEdit_031
      +    _01 = App.activeDocument().getObject("Page").EditableTexts[31]              # lineEdit_032
      +    _001_001 = App.activeDocument().getObject("Page").EditableTexts[32]         # lineEdit_033
      +    ISO2768_fh = App.activeDocument().getObject("Page").EditableTexts[33]       # lineEdit_034
      +    IRON = App.activeDocument().getObject("Page").EditableTexts[34]             # lineEdit_035
      +
      +except:
      +    errorDialog("Error read cartridge")
      +
      +class Ui_MainWindow(object):
      +
      +    def __init__(self, MainWindow):
      +        self.window = MainWindow
      +
      +        MainWindow.setObjectName(_fromUtf8("MainWindow"))
      +        MainWindow.resize(849, 462)
      +        MainWindow.setMaximumSize(QtCore.QSize(849, 462))
      +        self.centralWidget = QtGui.QWidget(MainWindow)
      +        self.centralWidget.setObjectName(_fromUtf8("centralWidget"))
      +
      +        self.pushButton02 = QtGui.QPushButton(self.centralWidget)
      +        self.pushButton02.setGeometry(QtCore.QRect(210, 420, 93, 28))
      +        self.pushButton02.setObjectName(_fromUtf8("pushButton_2"))
      +        self.pushButton02.clicked.connect(self.on_pushButton02_clicked) # Bouton Quitter # Quit
      +
      +        self.pushButton03 = QtGui.QPushButton(self.centralWidget)
      +        self.pushButton03.setGeometry(QtCore.QRect(320, 420, 93, 28))
      +        self.pushButton03.setObjectName(_fromUtf8("pushButton_3"))
      +        self.pushButton03.clicked.connect(self.on_pushButton03_clicked) # Bouton Memo # Memo
      +
      +        self.pushButton04 = QtGui.QPushButton(self.centralWidget)
      +        self.pushButton04.setGeometry(QtCore.QRect(430, 420, 93, 28))
      +        self.pushButton04.setObjectName(_fromUtf8("pushButton_4"))
      +        self.pushButton04.clicked.connect(self.on_pushButton04_clicked) # Bouton nettoyer # Clear
      +
      +        self.pushButton01 = QtGui.QPushButton(self.centralWidget)
      +        self.pushButton01.setGeometry(QtCore.QRect(540, 420, 93, 28))
      +        self.pushButton01.setObjectName(_fromUtf8("pushButton"))
      +        self.pushButton01.clicked.connect(self.on_pushButton01_clicked) # Bouton Appliquer # Apply
      +
      +        self.lineEdit_001 = QtGui.QLineEdit(self.centralWidget)
      +        self.lineEdit_001.setGeometry(QtCore.QRect(540, 100, 101, 22))
      +        self.lineEdit_001.setObjectName(_fromUtf8("lineEdit_001"))
      +        self.lineEdit_001.setText(Drawn_by)
      +
      +        self.lineEdit_002 = QtGui.QLineEdit(self.centralWidget)
      +        self.lineEdit_002.setGeometry(QtCore.QRect(650, 100, 121, 22))
      +        self.lineEdit_002.setObjectName(_fromUtf8("lineEdit_002"))
      +        self.lineEdit_002.setText(DRAWN_BY)
      +
      +        self.lineEdit_003 = QtGui.QLineEdit(self.centralWidget)
      +        self.lineEdit_003.setGeometry(QtCore.QRect(540, 140, 101, 22))
      +        self.lineEdit_003.setObjectName(_fromUtf8("lineEdit_003"))
      +        self.lineEdit_003.setText(Controlled_by)
      +
      +        self.lineEdit_004 = QtGui.QLineEdit(self.centralWidget)
      +        self.lineEdit_004.setGeometry(QtCore.QRect(650, 140, 121, 22))
      +        self.lineEdit_004.setObjectName(_fromUtf8("lineEdit_004"))
      +        self.lineEdit_004.setText(CONTROLLED_BY)
      +
      +        self.lineEdit_005 = QtGui.QLineEdit(self.centralWidget)
      +        self.lineEdit_005.setGeometry(QtCore.QRect(540, 180, 101, 22))
      +        self.lineEdit_005.setObjectName(_fromUtf8("lineEdit_005"))
      +        self.lineEdit_005.setText(Date)
      +
      +        self.lineEdit_006 = QtGui.QLineEdit(self.centralWidget)
      +        self.lineEdit_006.setGeometry(QtCore.QRect(650, 180, 121, 22))
      +        self.lineEdit_006.setObjectName(_fromUtf8("lineEdit_006"))
      +        self.lineEdit_006.setText(DATE)
      +
      +        self.lineEdit_007 = QtGui.QLineEdit(self.centralWidget)
      +        self.lineEdit_007.setGeometry(QtCore.QRect(540, 220, 101, 22))
      +        self.lineEdit_007.setObjectName(_fromUtf8("lineEdit_007"))
      +        self.lineEdit_007.setText(Controlled_2)
      +
      +        self.lineEdit_008 = QtGui.QLineEdit(self.centralWidget)
      +        self.lineEdit_008.setGeometry(QtCore.QRect(650, 220, 121, 22))
      +        self.lineEdit_008.setObjectName(_fromUtf8("lineEdit_008"))
      +        self.lineEdit_008.setText(CONTROLLED_2)
      +
      +        self.lineEdit_009 = QtGui.QLineEdit(self.centralWidget)
      +        self.lineEdit_009.setGeometry(QtCore.QRect(540, 260, 101, 22))
      +        self.lineEdit_009.setObjectName(_fromUtf8("lineEdit_009"))
      +        self.lineEdit_009.setText(Controlled_3)
      +
      +        self.lineEdit_010 = QtGui.QLineEdit(self.centralWidget)
      +        self.lineEdit_010.setGeometry(QtCore.QRect(650, 260, 121, 22))
      +        self.lineEdit_010.setObjectName(_fromUtf8("lineEdit_010"))
      +        self.lineEdit_010.setText(CONTROLLED_3)
      +
      +        self.lineEdit_011 = QtGui.QLineEdit(self.centralWidget)
      +        self.lineEdit_011.setGeometry(QtCore.QRect(780, 100, 61, 61))
      +        self.lineEdit_011.setAlignment(QtCore.Qt.AlignCenter)
      +        self.lineEdit_011.setObjectName(_fromUtf8("lineEdit_011"))
      +        self.lineEdit_011.setText(SCALE)
      +
      +        self.lineEdit_012 = QtGui.QLineEdit(self.centralWidget)
      +        self.lineEdit_012.setGeometry(QtCore.QRect(10, 100, 131, 181))
      +        font = QtGui.QFont()
      +        font.setPointSize(20)
      +        self.lineEdit_012.setFont(font)
      +        self.lineEdit_012.setAlignment(QtCore.Qt.AlignCenter)
      +        self.lineEdit_012.setObjectName(_fromUtf8("lineEdit_012"))
      +        self.lineEdit_012.setText(MOD)
      +
      +        self.lineEdit_013 = QtGui.QLineEdit(self.centralWidget)
      +        self.lineEdit_013.setGeometry(QtCore.QRect(10, 300, 261, 22))
      +        font = QtGui.QFont()
      +        font.setPointSize(10)
      +        self.lineEdit_013.setFont(font)
      +        self.lineEdit_013.setObjectName(_fromUtf8("lineEdit_013"))
      +        self.lineEdit_013.setText(COMPANY)
      +
      +        self.lineEdit_014 = QtGui.QLineEdit(self.centralWidget)
      +        self.lineEdit_014.setGeometry(QtCore.QRect(10, 340, 261, 22))
      +        font = QtGui.QFont()
      +        font.setPointSize(10)
      +        self.lineEdit_014.setFont(font)
      +        self.lineEdit_014.setObjectName(_fromUtf8("lineEdit_014"))
      +        self.lineEdit_014.setText(ADRESS)
      +
      +        self.lineEdit_015 = QtGui.QLineEdit(self.centralWidget)
      +        self.lineEdit_015.setGeometry(QtCore.QRect(10, 380, 261, 22))
      +        font = QtGui.QFont()
      +        font.setPointSize(10)
      +        self.lineEdit_015.setFont(font)
      +        self.lineEdit_015.setObjectName(_fromUtf8("lineEdit_015"))
      +        self.lineEdit_015.setText(COUNTRY)
      +
      +        self.lineEdit_016 = QtGui.QLineEdit(self.centralWidget)
      +        self.lineEdit_016.setGeometry(QtCore.QRect(280, 300, 301, 101))
      +        font = QtGui.QFont()
      +        font.setPointSize(14)
      +        self.lineEdit_016.setFont(font)
      +        self.lineEdit_016.setAlignment(QtCore.Qt.AlignCenter)
      +        self.lineEdit_016.setObjectName(_fromUtf8("lineEdit_016"))
      +        self.lineEdit_016.setText(PART_NAME)
      +
      +        self.lineEdit_017 = QtGui.QLineEdit(self.centralWidget)
      +        self.lineEdit_017.setGeometry(QtCore.QRect(590, 300, 251, 101))
      +        self.lineEdit_017.setMinimumSize(QtCore.QSize(0, 0))
      +        font = QtGui.QFont()
      +        font.setPointSize(8)
      +        self.lineEdit_017.setFont(font)
      +        self.lineEdit_017.setAlignment(QtCore.Qt.AlignCenter)
      +        self.lineEdit_017.setObjectName(_fromUtf8("lineEdit_017"))
      +        self.lineEdit_017.setText(Project_number)
      +
      +        self.lineEdit_018 = QtGui.QLineEdit(self.centralWidget)
      +        self.lineEdit_018.setGeometry(QtCore.QRect(150, 260, 71, 22))
      +        self.lineEdit_018.setObjectName(_fromUtf8("lineEdit_018"))
      +        self.lineEdit_018.setText(A_)
      +
      +        self.lineEdit_019 = QtGui.QLineEdit(self.centralWidget)
      +        self.lineEdit_019.setGeometry(QtCore.QRect(230, 260, 301, 22))
      +        self.lineEdit_019.setObjectName(_fromUtf8("lineEdit_019"))
      +        self.lineEdit_019.setText(A__)
      +
      +        self.lineEdit_020 = QtGui.QLineEdit(self.centralWidget)
      +        self.lineEdit_020.setGeometry(QtCore.QRect(150, 220, 71, 22))
      +        self.lineEdit_020.setObjectName(_fromUtf8("lineEdit_020"))
      +        self.lineEdit_020.setText(B_)
      +
      +        self.lineEdit_021 = QtGui.QLineEdit(self.centralWidget)
      +        self.lineEdit_021.setGeometry(QtCore.QRect(230, 220, 301, 22))
      +        self.lineEdit_021.setObjectName(_fromUtf8("lineEdit_021"))
      +        self.lineEdit_021.setText(B__)
      +
      +        self.lineEdit_022 = QtGui.QLineEdit(self.centralWidget)
      +        self.lineEdit_022.setGeometry(QtCore.QRect(150, 180, 71, 22))
      +        self.lineEdit_022.setObjectName(_fromUtf8("lineEdit_022"))
      +        self.lineEdit_022.setText(C_)
      +
      +        self.lineEdit_023 = QtGui.QLineEdit(self.centralWidget)
      +        self.lineEdit_023.setGeometry(QtCore.QRect(230, 180, 301, 22))
      +        self.lineEdit_023.setObjectName(_fromUtf8("lineEdit_023"))
      +        self.lineEdit_023.setText(C__)
      +
      +        self.lineEdit_024 = QtGui.QLineEdit(self.centralWidget)
      +        self.lineEdit_024.setGeometry(QtCore.QRect(150, 140, 71, 22))
      +        self.lineEdit_024.setObjectName(_fromUtf8("lineEdit_024"))
      +        self.lineEdit_024.setText(D_)
      +
      +        self.lineEdit_025 = QtGui.QLineEdit(self.centralWidget)
      +        self.lineEdit_025.setGeometry(QtCore.QRect(230, 140, 301, 22))
      +        self.lineEdit_025.setObjectName(_fromUtf8("lineEdit_025"))
      +        self.lineEdit_025.setText(D__)
      +
      +        self.lineEdit_026 = QtGui.QLineEdit(self.centralWidget)
      +        self.lineEdit_026.setGeometry(QtCore.QRect(150, 100, 71, 22))
      +        self.lineEdit_026.setObjectName(_fromUtf8("lineEdit_026"))
      +        self.lineEdit_026.setText(E_)
      +
      +        self.lineEdit_027 = QtGui.QLineEdit(self.centralWidget)
      +        self.lineEdit_027.setGeometry(QtCore.QRect(230, 100, 301, 22))
      +        self.lineEdit_027.setObjectName(_fromUtf8("lineEdit_027"))
      +        self.lineEdit_027.setText(E__)
      +
      +        self.lineEdit_028 = QtGui.QLineEdit(self.centralWidget)
      +        self.lineEdit_028.setGeometry(QtCore.QRect(10, 60, 101, 22))
      +        self.lineEdit_028.setAlignment(QtCore.Qt.AlignCenter)
      +        self.lineEdit_028.setObjectName(_fromUtf8("lineEdit_028"))
      +        self.lineEdit_028.setText(Quantity)
      +
      +        self.lineEdit_029 = QtGui.QLineEdit(self.centralWidget)
      +        self.lineEdit_029.setGeometry(QtCore.QRect(120, 60, 131, 22))
      +        self.lineEdit_029.setAlignment(QtCore.Qt.AlignCenter)
      +        self.lineEdit_029.setObjectName(_fromUtf8("lineEdit_029"))
      +        self.lineEdit_029.setText(Part_ID_number)
      +
      +        self.lineEdit_030 = QtGui.QLineEdit(self.centralWidget)
      +        self.lineEdit_030.setGeometry(QtCore.QRect(260, 60, 381, 22))
      +        self.lineEdit_030.setAlignment(QtCore.Qt.AlignCenter)
      +        self.lineEdit_030.setObjectName(_fromUtf8("lineEdit_030"))
      +        self.lineEdit_030.setText(Fabrication_tolerance)
      +
      +        self.lineEdit_031 = QtGui.QLineEdit(self.centralWidget)
      +        self.lineEdit_031.setGeometry(QtCore.QRect(650, 60, 191, 22))
      +        self.lineEdit_031.setAlignment(QtCore.Qt.AlignCenter)
      +        self.lineEdit_031.setObjectName(_fromUtf8("lineEdit_031"))
      +        self.lineEdit_031.setText(Material)
      +
      +        self.lineEdit_032 = QtGui.QLineEdit(self.centralWidget)
      +        self.lineEdit_032.setGeometry(QtCore.QRect(10, 20, 101, 22))
      +        self.lineEdit_032.setObjectName(_fromUtf8("lineEdit_032"))
      +        self.lineEdit_032.setText(_01)
      +
      +        self.lineEdit_033 = QtGui.QLineEdit(self.centralWidget)
      +        self.lineEdit_033.setGeometry(QtCore.QRect(120, 20, 131, 22))
      +        self.lineEdit_033.setObjectName(_fromUtf8("lineEdit_033"))
      +        self.lineEdit_033.setText(_001_001)
      +
      +        self.lineEdit_034 = QtGui.QLineEdit(self.centralWidget)
      +        self.lineEdit_034.setGeometry(QtCore.QRect(260, 20, 381, 22))
      +        self.lineEdit_034.setObjectName(_fromUtf8("lineEdit_034"))
      +        self.lineEdit_034.setText(ISO2768_fh)
      +
      +        self.lineEdit_035 = QtGui.QLineEdit(self.centralWidget)
      +        self.lineEdit_035.setGeometry(QtCore.QRect(650, 20, 191, 22))
      +        self.lineEdit_035.setObjectName(_fromUtf8("lineEdit_035"))
      +        self.lineEdit_035.setText(IRON)
      +
      +        self.label_1 = QtGui.QLabel(self.centralWidget)
      +        self.label_1.setGeometry(QtCore.QRect(790, 85, 41, 16))
      +        self.label_1.setObjectName(_fromUtf8("label"))
      +        self.label_2 = QtGui.QLabel(self.centralWidget)
      +        self.label_2.setGeometry(QtCore.QRect(10, 325, 53, 16))
      +        self.label_2.setObjectName(_fromUtf8("label_2"))
      +        self.label_3 = QtGui.QLabel(self.centralWidget)
      +        self.label_3.setGeometry(QtCore.QRect(10, 365, 53, 16))
      +        self.label_3.setObjectName(_fromUtf8("label_3"))
      +        self.label_4 = QtGui.QLabel(self.centralWidget)
      +        self.label_4.setGeometry(QtCore.QRect(10, 285, 161, 16))
      +        self.label_4.setObjectName(_fromUtf8("label_4"))
      +        self.label_5 = QtGui.QLabel(self.centralWidget)
      +        self.label_5.setGeometry(QtCore.QRect(280, 285, 151, 16))
      +        self.label_5.setObjectName(_fromUtf8("label_5"))
      +        self.label_6 = QtGui.QLabel(self.centralWidget)
      +        self.label_6.setGeometry(QtCore.QRect(590, 285, 191, 16))
      +        self.label_6.setObjectName(_fromUtf8("label_6"))
      +        self.label_7 = QtGui.QLabel(self.centralWidget)
      +        self.label_7.setGeometry(QtCore.QRect(10, 85, 53, 16))
      +        self.label_7.setObjectName(_fromUtf8("label_7"))
      +        self.label_8 = QtGui.QLabel(self.centralWidget)
      +        self.label_8.setGeometry(QtCore.QRect(150, 85, 53, 16))
      +        self.label_8.setObjectName(_fromUtf8("label_8"))
      +        self.label_9 = QtGui.QLabel(self.centralWidget)
      +        self.label_9.setGeometry(QtCore.QRect(540, 85, 61, 16))
      +        self.label_9.setObjectName(_fromUtf8("label_9"))
      +        self.label_10 = QtGui.QLabel(self.centralWidget)
      +        self.label_10.setGeometry(QtCore.QRect(540, 125, 101, 16))
      +        self.label_10.setObjectName(_fromUtf8("label_10"))
      +        self.label_11 = QtGui.QLabel(self.centralWidget)
      +        self.label_11.setGeometry(QtCore.QRect(540, 165, 53, 16))
      +        self.label_11.setObjectName(_fromUtf8("label_11"))
      +        self.label_12 = QtGui.QLabel(self.centralWidget)
      +        self.label_12.setGeometry(QtCore.QRect(540, 205, 81, 16))
      +        self.label_12.setObjectName(_fromUtf8("label_12"))
      +        self.label_13 = QtGui.QLabel(self.centralWidget)
      +        self.label_13.setGeometry(QtCore.QRect(540, 245, 81, 16))
      +        self.label_13.setObjectName(_fromUtf8("label_13"))
      +        self.label_14 = QtGui.QLabel(self.centralWidget)
      +        self.label_14.setGeometry(QtCore.QRect(10, 45, 71, 16))
      +        self.label_14.setObjectName(_fromUtf8("label_14"))
      +        self.label_15 = QtGui.QLabel(self.centralWidget)
      +        self.label_15.setGeometry(QtCore.QRect(120, 45, 121, 16))
      +        self.label_15.setObjectName(_fromUtf8("label_15"))
      +        self.label_16 = QtGui.QLabel(self.centralWidget)
      +        self.label_16.setGeometry(QtCore.QRect(260, 45, 141, 16))
      +        self.label_16.setObjectName(_fromUtf8("label_16"))
      +        self.label_17 = QtGui.QLabel(self.centralWidget)
      +        self.label_17.setGeometry(QtCore.QRect(650, 45, 71, 16))
      +        self.label_17.setObjectName(_fromUtf8("label_17"))
      +
      +        self.graphicsView = QtGui.QGraphicsView(self.centralWidget)     # Fenêtre pour logo # Logo windows
      +        self.graphicsView.setGeometry(QtCore.QRect(780, 220, 61, 61))
      +        self.graphicsView.setObjectName(_fromUtf8("graphicsView"))
      +        self.label_18 = QtGui.QLabel(self.centralWidget)
      +        self.label_18.setGeometry(QtCore.QRect(790, 205, 41, 16))
      +        self.label_18.setObjectName(_fromUtf8("label_18"))
      +        MainWindow.setCentralWidget(self.centralWidget)
      +
      +        self.retranslateUi(MainWindow)
      +        QtCore.QMetaObject.connectSlotsByName(MainWindow)
      +
      +    def retranslateUi(self, MainWindow):
      +        try:
      +            MainWindow.setWindowFlags(PyQt4.QtCore.Qt.WindowStaysOnTopHint)  # PyQt4
      +        except Exception:
      +            MainWindow.setWindowFlags(PySide.QtCore.Qt.WindowStaysOnTopHint) # PySide
      +
      +        MainWindow.setWindowTitle(_translate("MainWindow", "Cartouche mod 2", None))
      +
      +        self.pushButton01.setText(_translate("MainWindow", "Apply", None))
      +        self.pushButton02.setText(_translate("MainWindow", "Quit", None))
      +        self.pushButton03.setText(_translate("MainWindow", "Memo", None))
      +        self.pushButton04.setText(_translate("MainWindow", "Clear", None))
      +
      +        self.lineEdit_001.setText(_translate("MainWindow", "Drawn_by", None))
      +        self.lineEdit_002.setText(_translate("MainWindow", "DRAWN_BY", None))
      +        self.lineEdit_003.setText(_translate("MainWindow", "Controlled_by", None))
      +        self.lineEdit_004.setText(_translate("MainWindow", "CONTROLLED_BY", None))
      +        self.lineEdit_005.setText(_translate("MainWindow", "Date", None))
      +        self.lineEdit_006.setText(_translate("MainWindow", "DATE", None))
      +        self.lineEdit_007.setText(_translate("MainWindow", "Controlled_2", None))
      +        self.lineEdit_008.setText(_translate("MainWindow", "CONTROLLED_2", None))
      +        self.lineEdit_009.setText(_translate("MainWindow", "Controlled_3", None))
      +        self.lineEdit_010.setText(_translate("MainWindow", "CONTROLLED_3", None))
      +        self.lineEdit_011.setText(_translate("MainWindow", "SCALE", None))
      +        self.lineEdit_012.setText(_translate("MainWindow", "MOD", None))
      +        self.lineEdit_013.setText(_translate("MainWindow", "COMPANY", None))
      +        self.lineEdit_014.setText(_translate("MainWindow", "ADRESS", None))
      +        self.lineEdit_015.setText(_translate("MainWindow", "COUNTRY", None))
      +        self.lineEdit_016.setText(_translate("MainWindow", "PART_NAME", None))
      +        self.lineEdit_017.setText(_translate("MainWindow", "Project_number", None))
      +        self.lineEdit_018.setText(_translate("MainWindow", "A_", None))
      +        self.lineEdit_019.setText(_translate("MainWindow", "A__", None))
      +        self.lineEdit_020.setText(_translate("MainWindow", "B_", None))
      +        self.lineEdit_021.setText(_translate("MainWindow", "B__", None))
      +        self.lineEdit_022.setText(_translate("MainWindow", "C_", None))
      +        self.lineEdit_023.setText(_translate("MainWindow", "C__", None))
      +        self.lineEdit_024.setText(_translate("MainWindow", "D_", None))
      +        self.lineEdit_025.setText(_translate("MainWindow", "D__", None))
      +        self.lineEdit_026.setText(_translate("MainWindow", "E_", None))
      +        self.lineEdit_027.setText(_translate("MainWindow", "E__", None))
      +        self.lineEdit_028.setText(_translate("MainWindow", "Quantity", None))
      +        self.lineEdit_029.setText(_translate("MainWindow", "Part_ID_number", None))
      +        self.lineEdit_030.setText(_translate("MainWindow", "Fabrication_tolerance", None))
      +        self.lineEdit_031.setText(_translate("MainWindow", "Material", None))
      +        self.lineEdit_032.setText(_translate("MainWindow", "_01", None))
      +        self.lineEdit_033.setText(_translate("MainWindow", "_001_001", None))
      +        self.lineEdit_034.setText(_translate("MainWindow", "ISO2768_fh", None))
      +        self.lineEdit_035.setText(_translate("MainWindow", "IRON", None))
      +
      +        self.label_1.setText(_translate("MainWindow", "Scale :", None))
      +        self.label_2.setText(_translate("MainWindow", "Address :", None))
      +        self.label_3.setText(_translate("MainWindow", "Country :", None))
      +        self.label_4.setText(_translate("MainWindow", "Company name :", None))
      +        self.label_5.setText(_translate("MainWindow", "Part name :", None))
      +        self.label_6.setText(_translate("MainWindow", "Project number / id :", None))
      +        self.label_7.setText(_translate("MainWindow", "Size :", None))
      +        self.label_8.setText(_translate("MainWindow", "Notes :", None))
      +        self.label_9.setText(_translate("MainWindow", "Draw by :", None))
      +        self.label_10.setText(_translate("MainWindow", "Controlled by :", None))
      +        self.label_11.setText(_translate("MainWindow", "Date :", None))
      +        self.label_12.setText(_translate("MainWindow", "Controlled 2 :", None))
      +        self.label_13.setText(_translate("MainWindow", "Controlled 3 :", None))
      +        self.label_14.setText(_translate("MainWindow", "Quantity :", None))
      +        self.label_15.setText(_translate("MainWindow", "Part ID / Number :", None))
      +        self.label_16.setText(_translate("MainWindow", "Fabrication tolerance :", None))
      +        self.label_17.setText(_translate("MainWindow", "Material :", None))
      +        self.label_18.setText(_translate("MainWindow", "Logo :", None))
      +
      +    def on_pushButton01_clicked(self):    # Bouton Appliquer # Appli buttom
      +        Drawn_by = utf8(self.lineEdit_001.text())
      +        DRAWN_BY = utf8(self.lineEdit_002.text())
      +        Controlled_by = utf8(self.lineEdit_003.text())
      +        CONTROLLED_BY = utf8(self.lineEdit_004.text())
      +        Date = utf8(self.lineEdit_005.text())
      +        DATE = utf8(self.lineEdit_006.text())
      +        Controlled_2 = utf8(self.lineEdit_007.text())
      +        CONTROLLED_2 = utf8(self.lineEdit_008.text())
      +        Controlled_3 = utf8(self.lineEdit_009.text())
      +        CONTROLLED_3 = utf8(self.lineEdit_010.text())
      +        SCALE = utf8(self.lineEdit_011.text())
      +        MOD = utf8(self.lineEdit_012.text())
      +        COMPANY = utf8(self.lineEdit_013.text())
      +        ADRESS = utf8(self.lineEdit_014.text())
      +        COUNTRY = utf8(self.lineEdit_015.text())
      +        PART_NAME = utf8(self.lineEdit_016.text())
      +        Project_number = utf8(self.lineEdit_017.text())
      +        A_ = utf8(self.lineEdit_018.text())
      +        A__ = utf8(self.lineEdit_019.text())
      +        B_ = utf8(self.lineEdit_020.text())
      +        B__ = utf8(self.lineEdit_021.text())
      +        C_ = utf8(self.lineEdit_022.text())
      +        C__ = utf8(self.lineEdit_023.text())
      +        D_ = utf8(self.lineEdit_024.text())
      +        D__ = utf8(self.lineEdit_025.text())
      +        E_ = utf8(self.lineEdit_026.text())
      +        E__ = utf8(self.lineEdit_027.text())
      +        Quantity = utf8(self.lineEdit_028.text())
      +        Part_ID_number = utf8(self.lineEdit_029.text())
      +        Fabrication_tolerance = utf8(self.lineEdit_030.text())
      +        Material = utf8(self.lineEdit_031.text())
      +        _01 = utf8(self.lineEdit_032.text())
      +        _001_001 = utf8(self.lineEdit_033.text())
      +        ISO2768_fh = utf8(self.lineEdit_034.text())
      +        IRON = utf8(self.lineEdit_035.text())
      +
      +        try:
      +            FreeCAD.getDocument (App.ActiveDocument.Name).getObject("Page").EditableTexts =[unicode(Drawn_by,'utf-8'), unicode(DRAWN_BY,'utf-8'), unicode(Controlled_by,'utf-8'), unicode(CONTROLLED_BY,'utf-8'), unicode(Date,'utf-8'), unicode(DATE,'utf-8'), unicode(Controlled_2, 'utf-8'), unicode(CONTROLLED_2,'utf-8'), unicode(Controlled_3,'utf-8'), unicode(CONTROLLED_3,'utf-8'), unicode(SCALE,'utf-8'), unicode(MOD,'utf-8'), unicode(COMPANY,'utf-8'), unicode(ADRESS,'utf-8'), unicode(COUNTRY, 'utf-8'), unicode(PART_NAME,'utf-8'), unicode(Project_number,'utf-8'), unicode(A_,'utf-8'), unicode(A__,'utf-8'), unicode(B_,'utf-8'), unicode(B__,'utf-8'), unicode(C_,'utf-8'), unicode(C__,'utf-8'), unicode(D_,'utf-8'), unicode(D__,'utf-8'), unicode(E_,'utf-8'), unicode(E__,'utf-8'), unicode(Quantity,'utf-8'), unicode(Part_ID_number,'utf-8'), unicode(Fabrication_tolerance,'utf-8'), unicode(Material,'utf-8'), unicode(_01,'utf-8'), unicode(_001_001,'utf-8'), unicode(ISO2768_fh,'utf-8'), unicode(IRON,'utf-8'),]  # PyQt4
      +            App.ActiveDocument.recompute()
      +        except Exception:#
      +            FreeCAD.getDocument (App.ActiveDocument.Name).getObject("Page").EditableTexts =[Drawn_by.encode('utf-8'), DRAWN_BY.encode('utf-8'), Controlled_by.encode('utf-8'), CONTROLLED_BY.encode('utf-8'), Date.encode('utf-8'), DATE.encode('utf-8'), Controlled_2.encode('utf-8'), CONTROLLED_2.encode('utf-8'), Controlled_3.encode('utf-8'), CONTROLLED_3.encode('utf-8'), SCALE.encode('utf-8'), MOD.encode('utf-8'), COMPANY.encode('utf-8'), ADRESS.encode('utf-8'), COUNTRY.encode('utf-8'), PART_NAME.encode('utf-8'), Project_number.encode('utf-8'), A_.encode('utf-8'), A__.encode('utf-8'), B_.encode('utf-8'), B__.encode('utf-8'), C_.encode('utf-8'), C__.encode('utf-8'), D_.encode('utf-8'), D__.encode('utf-8'), E_.encode('utf-8'), E__.encode('utf-8'), Quantity.encode('utf-8'), Part_ID_number.encode('utf-8'), Fabrication_tolerance.encode('utf-8'), Material.encode('utf-8'), _01.encode('utf-8'), _001_001.encode('utf-8'), ISO2768_fh.encode('utf-8'), IRON.encode('utf-8'),]                                       # PySide
      +            App.ActiveDocument.recompute()
      +
      +    def on_pushButton04_clicked(self):    # Bouton nettoyer # Clear buttom
      +
      +        Drawn_by = ""             ;self.lineEdit_001.setText("")
      +        DRAWN_BY = ""             ;self.lineEdit_002.setText("")
      +        Controlled_by = ""        ;self.lineEdit_003.setText("")
      +        CONTROLLED_BY = ""        ;self.lineEdit_004.setText("")
      +        Date  = ""                ;self.lineEdit_005.setText("")
      +        DATE = ""                 ;self.lineEdit_006.setText("")
      +        Controlled_2 = ""         ;self.lineEdit_007.setText("")
      +        CONTROLLED_2 = ""         ;self.lineEdit_008.setText("")
      +        Controlled_3 = ""         ;self.lineEdit_009.setText("")
      +        CONTROLLED_3 = ""         ;self.lineEdit_010.setText("")
      +        SCALE = ""                ;self.lineEdit_011.setText("")
      +        MOD = ""                  ;self.lineEdit_012.setText("")
      +        COMPANY = ""              ;self.lineEdit_013.setText("")
      +        ADRESS = ""               ;self.lineEdit_014.setText("")
      +        COUNTRY = ""              ;self.lineEdit_015.setText("")
      +        PART_NAME = ""            ;self.lineEdit_016.setText("")
      +        Project_number = ""       ;self.lineEdit_017.setText("")
      +        A_ = ""                   ;self.lineEdit_018.setText("")
      +        A__ = ""                  ;self.lineEdit_019.setText("")
      +        B_ = ""                   ;self.lineEdit_020.setText("")
      +        B__ = ""                  ;self.lineEdit_021.setText("")
      +        C_ = ""                   ;self.lineEdit_022.setText("")
      +        C__ = ""                  ;self.lineEdit_023.setText("")
      +        D_ = ""                   ;self.lineEdit_024.setText("")
      +        D__ = ""                  ;self.lineEdit_025.setText("")
      +        E_ = ""                   ;self.lineEdit_026.setText("")
      +        E__ = ""                  ;self.lineEdit_027.setText("")
      +        Quantity = ""             ;self.lineEdit_028.setText("")
      +        Part_ID_number = ""       ;self.lineEdit_029.setText("")
      +        Fabrication_tolerance = "";self.lineEdit_030.setText("")
      +        Material = ""             ;self.lineEdit_031.setText("")
      +        _01 = ""                  ;self.lineEdit_032.setText("")
      +        _001_001 = ""             ;self.lineEdit_033.setText("")
      +        ISO2768_fh = ""           ;self.lineEdit_034.setText("")
      +        IRON = ""                 ;self.lineEdit_035.setText("")
      +
      +    def on_pushButton03_clicked(self):    # Bouton Memo # Memo buttom
      +        self.lineEdit_001.setText(Drawn_by)
      +        self.lineEdit_002.setText(DRAWN_BY)
      +        self.lineEdit_003.setText(Controlled_by)
      +        self.lineEdit_004.setText(CONTROLLED_BY)
      +        self.lineEdit_005.setText(Date)
      +        self.lineEdit_006.setText(DATE)
      +        self.lineEdit_007.setText(Controlled_2)
      +        self.lineEdit_008.setText(CONTROLLED_2)
      +        self.lineEdit_009.setText(Controlled_3)
      +        self.lineEdit_010.setText(CONTROLLED_3)
      +        self.lineEdit_011.setText(SCALE)
      +        self.lineEdit_012.setText(MOD)
      +        self.lineEdit_013.setText(COMPANY)
      +        self.lineEdit_014.setText(ADRESS)
      +        self.lineEdit_015.setText(COUNTRY)
      +        self.lineEdit_016.setText(PART_NAME)
      +        self.lineEdit_017.setText(Project_number)
      +        self.lineEdit_018.setText(A_)
      +        self.lineEdit_019.setText(A__)
      +        self.lineEdit_020.setText(B_)
      +        self.lineEdit_021.setText(B__)
      +        self.lineEdit_022.setText(C_)
      +        self.lineEdit_023.setText(C__)
      +        self.lineEdit_024.setText(D_)
      +        self.lineEdit_025.setText(D__)
      +        self.lineEdit_026.setText(E_)
      +        self.lineEdit_027.setText(E__)
      +        self.lineEdit_028.setText(Quantity)
      +        self.lineEdit_029.setText(Part_ID_number)
      +        self.lineEdit_030.setText(Fabrication_tolerance)
      +        self.lineEdit_031.setText(Material)
      +        self.lineEdit_032.setText(_01)
      +        self.lineEdit_033.setText(_001_001)
      +        self.lineEdit_034.setText(ISO2768_fh)
      +        self.lineEdit_035.setText(IRON)
      +
      +    def on_pushButton02_clicked(self):    # Bouton Quitter # Quit buttom
      +        App.Console.PrintMessage("End cartridge mod 2\r\n")
      +        self.window.hide()
      +
      +MainWindow = QtGui.QMainWindow()
      +ui = Ui_MainWindow(MainWindow)
      +MainWindow.show() 
      +

      Version

      +

      5.0 : 08/08/2014 +

      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Macro_CartoucheFC_Full.html b/localwiki/Macro_CartoucheFC_Full.html new file mode 100644 index 0000000..9c06ce6 --- /dev/null +++ b/localwiki/Macro_CartoucheFC_Full.html @@ -0,0 +1,1235 @@ +Macro CartoucheFC Full

      Macro CartoucheFC Full

      + +
      + + + + + + + + + + + + + + + + + + + + + + + + + + +
      +

      Macro CartoucheFC Full.png Macro_CartoucheFC_Full

      +
      Description +
      This macro is a complete application, it allows to fill the cartridge of the drawing sheet with full editabletext. +
      Author +
      Mario52 +
      Links +
      Macros recipes
      How to install macros
      How to customize toolbars +
      Version +
      00.10 +
      Date last modification +
      2017-02-15 +
      +

      + +
      +


      +

      This macro is a complete application, it allows to fill simply all the fields of the cartridge +

      Choice in the page Misc_templates_Full +

      Here the order of filling in the line FreeCAD texteditable. The date and time fields are separated by a "space negative space" " - " and constitute a single line textedit. +

      CartoucheFC_Full +

      +

      Use

      +

      PS: Some characters such as & $ are not accepted (and possibly other special characters). +

      If you have any questions or want to add a function, you can address you on the french forum Remplir cartouche +

      +
      • The window remains above other Windows, thereby controlling the cartridge without leaving the program.
      • +
      • Copy the code into a file named Macro_CartoucheFC_Full.FCMacro and place it in your usual macros directory.
      • +
      • After you have created your drawing sheet using the Drawing of FreeCAD module, run the macro Macro_CartoucheFC_Full.
      • +
      • At the opening, the program will register in memory all data already present in the cartridge of the sheet (if they are filled), all these data will be automatically returned to using the button Memo and kept in memory until the closure of the programme.
      • +
      • First select your page to work
      • +
      • Date button D. and time H. displayed the date and time of the system.
      +
      • The date format depends on the selected symbol EU or US which determines the regional format. Change does not happen automatically (for the case or you have entered a date manually) you must again click buttons dates if you change the symbol (check before printing).
      +
      • Choice your format page
      • +
      • Button Symbole EU or US change the meaning of the symbol of projection "Select your Symbol" is displayed by default, and then the active symbol appears. Click on the button and check the leaf symbol, click a second time to modify the symbol.
      +
      • The choice of this symbol, affects the date format EU = dd/MM/yyyy and US = MM/dd/yyyy.
      • +
      • Attention: this command does not pass through the button Apply and immediately changes the symbol to each presses on the key, always check if you have the appropriate symbol on your worksheet.
      +
      • Button Clean Clears all fields in the cartridge. You can revert to the original data using the button Memo.
      • +
      • Button Apply saves all fields of the cartridge in the sheet. You can revert to the original data using the button Memo (except for the regional symbol that works in independent and is effective immediately).
      +

      Code

      +

      The icon for you toolBar Macro CartoucheFC Full.png +

      Macro_CartoucheFC_Full.FCMacro +

      +
      # -*- coding: utf-8 -*-
      +from __future__ import unicode_literals
      +"""
      +***************************************************************************
      +*   Copyright (c) 2014 2016 2017 <mario52>                                *
      +*                                                                         *
      +*   This file is a supplement to the FreeCAD CAx development system.      *
      +*                                                                         *
      +*   This program is free software; you can redistribute it and/or modify  *
      +*   it under the terms of the GNU Lesser General Public License (LGPL)    *
      +*   as published by the Free Software Foundation; either version 2 of     *
      +*   the License, or (at your option) any later version.                   *
      +*   for detail see the LICENCE text file.                                 *
      +*                                                                         *
      +*   This software is distributed in the hope that it will be useful,      *
      +*   but WITHOUT ANY WARRANTY; without even the implied warranty of        *
      +*   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the         *
      +*   GNU Library General Public License for more details.                  *
      +*                                                                         *
      +*   You should have received a copy of the GNU Library General Public     *
      +*   License along with this macro; if not, write to the Free Software     *
      +*   Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  *
      +*   USA                                                                   *
      +***************************************************************************
      +*           WARNING! All changes in this file will be lost and            *  
      +*                  may cause malfunction of the program                   *
      +***************************************************************************
      +"""
      +#OS: Windows 10
      +#Word size of OS: 64-bit
      +#Word size of FreeCAD: 64-bit
      +#Version: 0.16.6706 (Git)
      +#Build type: Release
      +#Branch: releases/FreeCAD-0-16
      +#Hash: f86a4e411ff7848dea98d7242f43b7774bee8fa0
      +#Python version: 2.7.8
      +#Qt version: 4.8.7
      +#Coin version: 4.0.0a
      +#OCC version: 6.8.0.oce-0.17
      +
      +__title__   = "Macro_CartoucheFC_Full"
      +__author__  = "Mario52"
      +__url__     = "http://www.freecadweb.org/index-fr.html"
      +__Wiki__    = "http://www.freecadweb.org/wiki/Macro_CartoucheFC_Full"
      +__version__ = "00.10"
      +__date__    = "15/02/2017"
      +
      +__Requires__ = ("all version and freecad " +
      +" DESIGNED_BY, CREATION_DATE, CHECKED_BY, CHECK_DATE, SIZE, SCALE, WEIGHT, DRAWING_NUMBER, SHEET, " +
      +" TITLE, DESCRIPTION, COMPANY, COPYRIGHT, Note_A, Note_B, Note_C, Note_D, Note_E, Note_F, Note_G, Note_H, Note_I" )
      +__Template__ = " A3_Landscape_xx_FULL.svg, A3_Portrait_xx_FULL, A4_Landscape_xx_FULL.svg, A4_Portrait_xx_FULL"
      +__Template_Link__ = "http://www.freecadweb.org/wiki/index.php?title=Misc_templates_Full"
      +
      +import PySide
      +from PySide import QtCore, QtGui
      +
      +import Draft, Part, FreeCAD, math, PartGui, FreeCADGui
      +from math import sqrt, pi, sin, cos, asin
      +from FreeCAD import Base
      +
      +def utf8(unio):
      +    return unicode(unio).encode('UTF8')
      +
      +global path
      +#path = FreeCAD.ConfigGet("AppHomePath")
      +path = FreeCAD.ConfigGet("UserAppData")
      +
      +global PageActive      ; PageActive  = "Select your page" # essais 
      +#global PageActive      ; PageActive  = "Page" # page active
      +global DESIGNED_BY     ; DESIGNED_BY = ""     # lineEdit01 DESIGNED_BY
      +global MDESIGNED_BY    ; MDESIGNED_BY = ""    # 
      +global CREATION_DATE   ; CREATION_DATE = ""   # lineEdit02 CREATION_DATE date
      +global MCREATION_DATE  ; MCREATION_DATE = ""  # 
      +global CREA_DATE       ; CREA_DATE = ""       # lineEdit02h date
      +global MCREA_DATE      ; MCREA_DATE = ""      # 
      +global CREA_TIME       ; CREA_TIME = ""       # lineEdit02h heure
      +global MCREA_TIME      ; MCREA_TIME = ""      # 
      +global CHECKED_BY      ; CHECKED_BY = ""      # lineEdit03
      +global MCHECKED_BY     ; MCHECKED_BY = ""     # 
      +global CHECK_DATE      ; CHECK_DATE = ""      # lineEdit04 date
      +global MCHECK_DATE     ; MCHECK_DATE = ""     # 
      +global CHEC_DATE       ; CHEC_DATE = ""       # lineEdit04 date
      +global MCHEC_DATE      ; MCHEC_DATE = ""      # 
      +global CHEC_TIME       ; CHEC_TIME = ""       # lineEdit04h heure
      +global MCHEC_TIME      ; MCHEC_TIME = ""      # 
      +global SIZE            ; SIZE = ""            # lineEdit05
      +global MSIZE           ; MSIZE = ""           # 
      +global SCALE           ; SCALE =  ""          # lineEdit06
      +global MSCALE          ; MSCALE =  ""         # 
      +global WEIGHT          ; WEIGHT =  ""         # lineEdit07
      +global MWEIGHT         ; MWEIGHT =  ""        # 
      +global DRAWING_NUMBER  ; DRAWING_NUMBER = ""  # lineEdit08
      +global MDRAWING_NUMBER ; MDRAWING_NUMBER = "" # 
      +global SHEET           ; SHEET =  ""          # lineEdit09
      +global MSHEET          ; MSHEET =  ""         # 
      +global TITLE           ; TITLE =  ""          # textEdit_01
      +global MTITLE          ; MTITLE =  ""         # 
      +global DESCRIPTION     ; DESCRIPTION =  ""    # textEdit_02
      +global MDESCRIPTION    ; MDESCRIPTION = ""    # 
      +global COMPANY         ; COMPANY = ""         # textEdit_02b
      +global MCOMPANY        ; MCOMPANY = ""        # 
      +global COPYRIGHT       ; COPYRIGHT = ""       # lineEdit_20
      +global MCOPYRIGHT      ; MCOPYRIGHT = ""      # 
      +global Note_A          ; Note_A = ""          # lineEdit_10
      +global MNote_A         ; MNote_A = ""         # 
      +global Note_B          ; Note_B = ""          # lineEdit_11
      +global MNote_B         ; MNote_B = ""         # 
      +global Note_C          ; Note_C = ""          # lineEdit_12
      +global MNote_C         ; MNote_C = ""         # 
      +global Note_D          ; Note_D = ""          # lineEdit_13
      +global MNote_D         ; MNote_D = ""         # 
      +global Note_E          ; Note_E = ""          # lineEdit_14
      +global MNote_E         ; MNote_E = ""         # 
      +global Note_F          ; Note_F = ""          # lineEdit_15
      +global MNote_F         ; MNote_F = ""         # 
      +global Note_G          ; Note_G = ""          # lineEdit_16
      +global MNote_G         ; MNote_G = ""         # 
      +global Note_H          ; Note_H = ""          # lineEdit_17
      +global MNote_H         ; MNote_H = ""         # 
      +global Note_I          ; Note_I = ""          # lineEdit_18
      +global MNote_I         ; MNote_I = ""         # 
      +
      +global SymbolSwitch    ; SymbolSwitch = 1     # 0=US 1=EU
      +global ui              ; ui     = ""
      +
      +def heure():
      +    return QtCore.QTime().currentTime().toString('hh:mm:ss')
      +def dateEu():
      +    return QtCore.QDate().currentDate().toString('dd/MM/yyyy') # forme euro
      +def dateUK():
      +    return QtCore.QDate().currentDate().toString('yyyy/MM/dd') # forme UK
      +def dateUs():
      +    return QtCore.QDate().currentDate().toString('MM/dd/yyyy') # forme US
      +def dateComp():
      +    return QtCore.QDate().currentDate().toString('dddd d MMMM yyyy') # Retourne "dimanche 20 Juillet 77"
      +
      +try:
      +    _fromUtf8 = QtCore.QString.fromUtf8
      +except AttributeError:
      +    def _fromUtf8(s):
      +        return s
      +try:
      +    _encoding = QtGui.QApplication.UnicodeUTF8
      +    def _translate(context, text, disambig):
      +        return QtGui.QApplication.translate(context, text, disambig, _encoding)
      +except AttributeError:
      +    def _translate(context, text, disambig):
      +        return QtGui.QApplication.translate(context, text, disambig)
      +
      +def errorDialog(msg):
      +    diag = QtGui.QMessageBox(QtGui.QMessageBox.Critical,u"Error Message",msg)
      +    diag.setWindowFlags(PySide.QtCore.Qt.WindowStaysOnTopHint) # cette fonction met la fenetre en avant
      +    diag.exec_()
      +
      +def symbol_EU(depx, depy, scale):    #symbol_EU =O
      +    global PageActive
      +    global ui
      +
      +    try:
      +        page = App.activeDocument().getObjectsByLabel(PageActive.encode('utf-8'))[0]
      +    except Exception:
      +        page = App.activeDocument().getObjectsByLabel(PageActive)[0]
      +    
      +    if len(str(page)) != 2:
      +        comP   = []
      +        nameL  = []
      +        if "Page" in (page.Name):
      +            for ii in (page.Group):
      +                if ((ii.Label) == "Symbol_EU") or ((ii.Label) == "Symbol_US") :
      +                    App.activeDocument().removeObject(ii.Name)
      +
      +        points=[FreeCAD.Vector(-7.5,0.0,0.0),FreeCAD.Vector(20.0,0.0,0.0)]
      +        i = Draft.makeWire(points,closed=False,face=False,support=None)
      +        comP.append(i.Shape)
      +        nameL.append(i.Name)
      +        points=[FreeCAD.Vector(12.5,7.5,0.0),FreeCAD.Vector(12.5,-7.5,0.0)]
      +        i = Draft.makeWire(points,closed=False,face=False,support=None)
      +        comP.append(i.Shape)
      +        nameL.append(i.Name)
      +        points=[FreeCAD.Vector(-5,2.5,0.0),FreeCAD.Vector(5.0,5.0,0.0),FreeCAD.Vector(5.0,-5.0,0.0),FreeCAD.Vector(-5.0,-2.5,0.0)]
      +        i = Draft.makeWire(points,closed=True,face=False,support=None)
      +        comP.append(i.Shape)
      +        nameL.append(i.Name)
      +        pl=FreeCAD.Placement()
      +        pl.Rotation.Q=(0.0,-0.0,-0.0,1.0)
      +        pl.Base=FreeCAD.Vector(12.5,-0.0,0.0)
      +        i = Draft.makeCircle(radius=2.5,placement=pl,face=False,support=None)
      +        comP.append(i.Shape)
      +        nameL.append(i.Name)
      +        i = Draft.makeCircle(radius=5.0,placement=pl,face=False,support=None)
      +        comP.append(i.Shape)
      +        nameL.append(i.Name)
      +    
      +        comp = Part.makeCompound(comP)
      +        Part.show(comp)
      +        App.ActiveDocument.ActiveObject.Label = "Symbol_EU"
      +    
      +        obj = FreeCAD.ActiveDocument.ActiveObject
      +        obj.ViewObject.LineColor = (0.0,0.0,0.0)
      +        obj.ViewObject.Visibility = False
      +        
      +        obj2 = Draft.makeDrawingView(obj, page) 
      +        obj2.X = depx
      +        obj2.Y = depy
      +        obj2.Scale = scale #0.8    # A3
      +        obj2.Label = "Symbol_EU"
      +    
      +        for i in nameL: App.activeDocument().removeObject(i)
      +    
      +        App.activeDocument().getObjectsByLabel(PageActive.encode('utf-8'))[0].addObject(obj)
      +        App.activeDocument().getObjectsByLabel(PageActive.encode('utf-8'))[0].addObject(obj2)
      +        App.ActiveDocument.recompute()
      +    else:
      +        ui.pushButton05.setStyleSheet("background-color: red")       # This function gives a color button
      +        FreeCAD.Console.PrintError("Error selected page [ " + PageActive + " ]" + "\n")
      +
      +def symbol_US(depx, depy, scale):    #symbol_US O=
      +    global PageActive
      +    global ui
      +
      +    try:
      +        page = App.activeDocument().getObjectsByLabel(PageActive.encode('utf-8'))[0]
      +    except Exception:
      +        page = App.activeDocument().getObjectsByLabel(PageActive)[0]
      +
      +    if len(str(page)) != 2:
      +        comP   = []
      +        nameL  = []
      +    
      +        if "Page" in (page.Name):
      +            for ii in (page.Group):
      +                if ((ii.Label) == "Symbol_EU") or ((ii.Label) == "Symbol_US") :
      +                    App.activeDocument().removeObject(ii.Name)
      +
      +        points=[FreeCAD.Vector(-7.5,0.0,0.0),FreeCAD.Vector(20.0,0.0,0.0)]
      +        i = Draft.makeWire(points,closed=False,face=False,support=None)
      +        comP.append(i.Shape)
      +        nameL.append(i.Name)
      +        points=[FreeCAD.Vector(0.0,7.5,0.0),FreeCAD.Vector(0.0,-7.5,0.0)]
      +        i = Draft.makeWire(points,closed=False,face=False,support=None)
      +        comP.append(i.Shape)
      +        nameL.append(i.Name)
      +        points=[FreeCAD.Vector(7.5,2.5,0.0),FreeCAD.Vector(17.5,5.0,0.0),FreeCAD.Vector(17.5,-5.0,0.0),FreeCAD.Vector(7.5,-2.5,0.0)]
      +        i = Draft.makeWire(points,closed=True,face=False,support=None)
      +        comP.append(i.Shape)
      +        nameL.append(i.Name)
      +        pl=FreeCAD.Placement()
      +        pl.Rotation.Q=(0.0,-0.0,-0.0,1.0)
      +        pl.Base=FreeCAD.Vector(0.0,-0.0,0.0)
      +        i = Draft.makeCircle(radius=2.5,placement=pl,face=False,support=None)
      +        comP.append(i.Shape)
      +        nameL.append(i.Name)
      +        i = Draft.makeCircle(radius=5.0,placement=pl,face=False,support=None)
      +        comP.append(i.Shape)
      +        nameL.append(i.Name)
      +    
      +        comp = Part.makeCompound(comP)
      +        Part.show(comp)
      +        App.ActiveDocument.ActiveObject.Label = "Symbol_US"
      +    
      +        obj = FreeCAD.ActiveDocument.ActiveObject
      +        obj.ViewObject.LineColor = (0.0,0.0,0.0)
      +        obj.ViewObject.Visibility = False
      +    
      +        obj2 = Draft.makeDrawingView(obj, page) 
      +        obj2.X = depx
      +        obj2.Y = depy
      +        obj2.Scale = scale #0.8    # A3
      +        obj2.Label = "Symbol_US"
      +    
      +        for i in nameL: App.activeDocument().removeObject(i)
      +    
      +        App.activeDocument().getObjectsByLabel(PageActive.encode('utf-8'))[0].addObject(obj)
      +        App.activeDocument().getObjectsByLabel(PageActive.encode('utf-8'))[0].addObject(obj2)
      +        App.ActiveDocument.recompute()
      +    else:
      +        ui.pushButton05.setStyleSheet("background-color: red")       # This function gives a color button
      +        FreeCAD.Console.PrintError("Error selected page [ " + PageActive + " ]" + "\n")
      +
      +def memoEntree():
      +    global MDESIGNED_BY, MCREATION_DATE, MCREA_DATE  , MCREA_TIME, MCHECKED_BY, MCHECK_DATE
      +    global MCHEC_DATE  , MCHEC_TIME    , MSIZE       , MSCALE    , MWEIGHT    ,MDRAWING_NUMBER
      +    global MSHEET      , MTITLE        , MDESCRIPTION, MCOMPANY  , MCOPYRIGHT
      +    global MNote_A, MNote_B, MNote_C, MNote_D, MNote_E, MNote_F, MNote_G, MNote_H, MNote_I
      +    global PageActive
      +
      +    try:
      +        page = App.activeDocument().getObjectsByLabel(PageActive.encode('utf-8'))[0].Name
      +    except Exception:
      +        page = App.activeDocument().getObjectsByLabel(PageActive)[0]
      +
      +    try:
      +        MDESIGNED_BY   = App.activeDocument().getObject(page).EditableTexts[0]  # lineEdit01 DESIGNED_BY
      +        MCREATION_DATE = App.activeDocument().getObject(page).EditableTexts[1]  # lineEdit02 CREATION_DATE date
      +
      +        MCREA_DATE = MCREA_TIME = MCHEC_DATE = MCHEC_TIME = ""
      +
      +        try:
      +            MCREA_DATE = MCREATION_DATE.split(" - ")[0]                         # lineEdit02h date
      +        except:
      +            MCREA_DATE = MCREATION_DATE
      +        try:
      +            MCREA_TIME = MCREATION_DATE.split(" - ")[1]                         # lineEdit02h heure
      +        except: None    
      +
      +        MCHECKED_BY = App.activeDocument().getObject(page).EditableTexts[2]     # lineEdit03
      +        MCHECK_DATE = App.activeDocument().getObject(page).EditableTexts[3]     # lineEdit04 date
      +
      +        try:
      +            MCHEC_DATE = MCHECK_DATE.split(" - ")[0]                            # lineEdit04 date
      +        except:
      +            MCHEC_DATE = MCHECK_DATE
      +        try:
      +            MCHEC_TIME = MCHECK_DATE.split(" - ")[1]                            # lineEdit04h heure
      +        except: None    
      +
      +        MSIZE = App.activeDocument().getObject(page).EditableTexts[4]           # lineEdit05
      +        MSCALE = App.activeDocument().getObject(page).EditableTexts[5]          # lineEdit06
      +        MWEIGHT = App.activeDocument().getObject(page).EditableTexts[6]         # lineEdit07
      +        MDRAWING_NUMBER = App.activeDocument().getObject(page).EditableTexts[7] # lineEdit08
      +        MSHEET = App.activeDocument().getObject(page).EditableTexts[8]          # lineEdit09
      +        MTITLE = App.activeDocument().getObject(page).EditableTexts[9]          # textEdit_01
      +
      +        try:
      +            MDESCRIPTION = App.activeDocument().getObject(page).EditableTexts[10]   # textEdit_02
      +            MCOMPANY = App.activeDocument().getObject(page).EditableTexts[11]       # textEdit_02b
      +            MCOPYRIGHT = App.activeDocument().getObject(page).EditableTexts[12]     # lineEdit_20
      +            MNote_A = App.activeDocument().getObject(page).EditableTexts[13]        # lineEdit_10
      +            MNote_B = App.activeDocument().getObject(page).EditableTexts[14]        # lineEdit_11
      +            MNote_C = App.activeDocument().getObject(page).EditableTexts[15]        # lineEdit_12
      +            MNote_D = App.activeDocument().getObject(page).EditableTexts[16]        # lineEdit_13
      +            MNote_E = App.activeDocument().getObject(page).EditableTexts[17]        # lineEdit_14
      +            MNote_F = App.activeDocument().getObject(page).EditableTexts[18]        # lineEdit_15
      +            MNote_G = App.activeDocument().getObject(page).EditableTexts[19]        # lineEdit_16
      +            MNote_H = App.activeDocument().getObject(page).EditableTexts[20]        # lineEdit_17
      +            MNote_I = App.activeDocument().getObject(page).EditableTexts[21]        # lineEdit_18
      +        except Exception:
      +            App.Console.PrintError("Erreur cartouche level DESCRIPTION (Missing field)"+"\n"
      +                        "You may be using an inadequate template. Try with this template"+"\n")
      +            App.Console.PrintMessage("http://www.freecadweb.org/wiki/index.php?title=Misc_templates_Full"+"\n\n")
      +            App.Console.PrintError("Or for the original FreeCAD template use this macro"+"\n")
      +            App.Console.PrintMessage("http://www.freecadweb.org/wiki/index.php?title=Macro_CartoucheFC"+"\n")
      +    
      +            errorDialog("Erreur cartouche level DESCRIPTION (Missing field)"+"\n"
      +                        "You may be using an inadequate template. Try with this template"+"\n"
      +                        "http://www.freecadweb.org/wiki/index.php?title=Misc_templates_Full"+"\n\n"
      +                        "Or for the original FreeCAD template use this macro"+"\n"
      +                        "http://www.freecadweb.org/wiki/index.php?title=Macro_CartoucheFC"+"\n\n")
      +
      +    except:
      +        errorDialog("Erreur cartouche")
      +
      +class Ui_MainWindow(object):
      +
      +    def __init__(self, MainWindow):
      +        global path
      +        global PageActive
      +        self.window = MainWindow
      +
      +        MainWindow.setObjectName(_fromUtf8("MainWindow"))
      +        MainWindow.resize(810, 400)
      +        MainWindow.setMaximumSize(QtCore.QSize(810, 400))
      +        self.centralWidget = QtGui.QWidget(MainWindow)
      +        self.centralWidget.setObjectName(_fromUtf8("centralWidget"))
      +
      +#        self.pushButton01 = QtGui.QPushButton(self.centralWidget)
      +#        self.pushButton01.setGeometry(QtCore.QRect(115, 360, 93, 28))
      +#        self.pushButton01.setObjectName(_fromUtf8("pushButton01"))
      +#        self.pushButton01.clicked.connect(self.on_pushButton01_clicked) #connection pushButton01
      +
      +        self.pushButton02 = QtGui.QPushButton(self.centralWidget)
      +        self.pushButton02.setGeometry(QtCore.QRect(225, 360, 93, 28))
      +        self.pushButton02.setObjectName(_fromUtf8("pushButton02"))
      +        self.pushButton02.clicked.connect(self.on_pushButton02_clicked) #connection pushButton02
      +
      +        self.pushButton03 = QtGui.QPushButton(self.centralWidget)
      +        self.pushButton03.setGeometry(QtCore.QRect(335, 360, 93, 28))
      +        self.pushButton03.setToolTip("The memo button work only with the first Page")
      +        self.pushButton03.setObjectName(_fromUtf8("pushButton03"))
      +        self.pushButton03.clicked.connect(self.on_pushButton03_clicked) #connection pushButton03
      +
      +        self.pushButton04 = QtGui.QPushButton(self.centralWidget)
      +        self.pushButton04.setGeometry(QtCore.QRect(445, 360, 93, 28))
      +        self.pushButton04.setObjectName(_fromUtf8("pushButton04"))
      +        self.pushButton04.clicked.connect(self.on_pushButton04_clicked) #connection pushButton04
      +
      +        self.pushButton05 = QtGui.QPushButton(self.centralWidget)
      +        self.pushButton05.setGeometry(QtCore.QRect(555, 360, 93, 28))
      +#        self.pushButton05.setStyleSheet("background-color: red")       # This function gives a color button
      +        self.pushButton05.setObjectName(_fromUtf8("pushButton05"))
      +        self.pushButton05.clicked.connect(self.on_pushButton05_clicked) #connection pushButton05
      +
      +        #####
      +        self.groupBox = QtGui.QGroupBox(self.centralWidget)
      +        self.groupBox.setGeometry(QtCore.QRect(20, 159, 190, 101))
      +        self.groupBox.setObjectName(_fromUtf8("groupBox"))
      +
      +        self.label_20 = QtGui.QLabel(self.groupBox)
      +        self.label_20.setGeometry(QtCore.QRect(115, 5, 61, 17))
      +        self.label_20.setObjectName(_fromUtf8("label_20"))
      +        ############### font and color Label
      +        font = QtGui.QFont()
      +        font.setBold(True)
      +        self.label_20.setFont(font)
      +        self.label_20.setStyleSheet("color : #ff0000")
      +        ############### font and color
      +        self.label_20.setVisible(False)
      +
      +        self.radioButton_0 = QtGui.QRadioButton(self.groupBox)
      +        self.radioButton_0.setGeometry(QtCore.QRect(95, 1, 91, 17))
      +        self.radioButton_0.setChecked(True)
      +        self.radioButton_0.setEnabled(False)
      +        self.radioButton_0.setVisible(False)
      +        self.radioButton_0.setObjectName(_fromUtf8("radioButton_0"))
      +
      +        self.radioButton_1 = QtGui.QRadioButton(self.groupBox)
      +        self.radioButton_1.setGeometry(QtCore.QRect(95, 20, 91, 17))
      +        self.radioButton_1.setObjectName(_fromUtf8("radioButton_1"))
      +        self.radioButton_1.clicked.connect(self.on_radioButton_A3_clicked)# connect radioButton_A3
      +
      +        self.radioButton_2 = QtGui.QRadioButton(self.groupBox)
      +        self.radioButton_2.setGeometry(QtCore.QRect(95, 39, 91, 17))
      +        self.radioButton_2.setObjectName(_fromUtf8("radioButton_2"))
      +        self.radioButton_2.clicked.connect(self.on_radioButton_A3_clicked)# connect radioButton_A3
      +
      +        self.radioButton_3 = QtGui.QRadioButton(self.groupBox)
      +        self.radioButton_3.setGeometry(QtCore.QRect(95, 58, 91, 17))
      +        self.radioButton_3.setObjectName(_fromUtf8("radioButton_3"))
      +        self.radioButton_3.clicked.connect(self.on_radioButton_A4_clicked)# connect radioButton_A4
      +
      +        self.radioButton_4 = QtGui.QRadioButton(self.groupBox)
      +        self.radioButton_4.setGeometry(QtCore.QRect(95, 76, 91, 17))
      +        self.radioButton_4.setObjectName(_fromUtf8("radioButton_4"))
      +        self.radioButton_4.clicked.connect(self.on_radioButton_A4_clicked)# connect radioButton_A4
      +
      +        self.lineEdit_05 = QtGui.QLineEdit(self.groupBox)
      +        self.lineEdit_05.setGeometry(QtCore.QRect(10, 16, 75, 41))
      +        font = QtGui.QFont()
      +        font.setPointSize(25)
      +        font.setBold(False)
      +        font.setWeight(50)
      +        self.lineEdit_05.setFont(font)
      +        self.lineEdit_05.setAlignment(QtCore.Qt.AlignCenter)
      +        self.lineEdit_05.setObjectName(_fromUtf8("lineEdit_05"))
      +        self.lineEdit_05.setText(SIZE)
      +
      +        self.frame = QtGui.QFrame(self.groupBox)
      +        self.frame.setGeometry(QtCore.QRect(10, 58, 74, 41))
      +        self.frame.setFrameShape(QtGui.QFrame.StyledPanel)
      +        self.frame.setFrameShadow(QtGui.QFrame.Raised)
      +        self.frame.setObjectName(_fromUtf8("frame"))
      +
      +        self.radioButton_EU = QtGui.QRadioButton(self.frame)
      +        self.radioButton_EU.setGeometry(QtCore.QRect(0, 1, 41, 17))
      +        self.radioButton_EU.setChecked(True)
      +        self.radioButton_EU.setObjectName(_fromUtf8("radioButton_EU"))
      +        self.radioButton_EU.clicked.connect(self.on_radioButton_EU_clicked) #connection radioButton_EU
      +
      +        self.radioButton_US = QtGui.QRadioButton(self.frame)
      +        self.radioButton_US.setGeometry(QtCore.QRect(37, 1, 41, 17))
      +        self.radioButton_US.setObjectName(_fromUtf8("radioButton_US"))
      +        self.radioButton_US.clicked.connect(self.on_radioButton_US_clicked) #connection radioButton_US
      +
      +        self.pushButton10 = QtGui.QPushButton(self.frame)
      +        self.pushButton10.setGeometry(QtCore.QRect(0, 18, 75, 23))
      +        self.pushButton10.setToolTip("Create the symbol EU or US"+"\n"
      +                                     "This button is Independent of the Write button"+"\n"
      +                                     "If you desire modify the symbol in the cartouche,"+"\n"
      +                                     "delete the inadequate symbol manualy.")
      +        self.pushButton10.setEnabled(False)
      +        self.pushButton10.setObjectName(_fromUtf8("pushButton10"))
      +        self.pushButton10.clicked.connect(self.on_pushButton10_clicked)     #connection pushButton10
      +
      +        #####
      +
      +        self.pushButton06 = QtGui.QPushButton(self.centralWidget)
      +        self.pushButton06.setGeometry(QtCore.QRect(170, 57, 20, 20))
      +        self.pushButton06.setObjectName(_fromUtf8("pushButton06"))
      +        self.pushButton06.clicked.connect(self.on_pushButton06_clicked) #connection pushButton06
      +
      +        self.pushButton07 = QtGui.QPushButton(self.centralWidget)
      +        self.pushButton07.setGeometry(QtCore.QRect(190, 57, 20, 20))
      +        self.pushButton07.setObjectName(_fromUtf8("pushButton07"))
      +        self.pushButton07.clicked.connect(self.on_pushButton07_clicked) #connection pushButton07
      +
      +        self.pushButton08 = QtGui.QPushButton(self.centralWidget)
      +        self.pushButton08.setGeometry(QtCore.QRect(170, 137, 20, 20))
      +        self.pushButton08.setObjectName(_fromUtf8("pushButton08"))
      +        self.pushButton08.clicked.connect(self.on_pushButton08_clicked) #connection pushButton08
      +
      +        self.pushButton09 = QtGui.QPushButton(self.centralWidget)
      +        self.pushButton09.setGeometry(QtCore.QRect(190, 137, 20, 20))
      +        self.pushButton09.setObjectName(_fromUtf8("pushButton09"))
      +        self.pushButton09.clicked.connect(self.on_pushButton09_clicked) #connection pushButton09
      +
      +        self.lineEdit_01 = QtGui.QLineEdit(self.centralWidget)
      +        self.lineEdit_01.setGeometry(QtCore.QRect(20, 20, 190, 16))
      +        font = QtGui.QFont()
      +        font.setPointSize(7)
      +        self.lineEdit_01.setFont(font)
      +        self.lineEdit_01.setObjectName(_fromUtf8("lineEdit_01"))
      +        self.lineEdit_01.setText(DESIGNED_BY)
      +
      +        self.lineEdit_02 = QtGui.QLineEdit(self.centralWidget)
      +        self.lineEdit_02.setGeometry(QtCore.QRect(20, 60, 82, 16))
      +        font = QtGui.QFont()
      +        font.setPointSize(7)
      +        self.lineEdit_02.setFont(font)
      +        self.lineEdit_02.setObjectName(_fromUtf8("lineEdit_02"))
      +        self.lineEdit_02.setText(CREA_DATE)
      +
      +        self.lineEdit_02h = QtGui.QLineEdit(self.centralWidget)
      +        self.lineEdit_02h.setGeometry(QtCore.QRect(98, 60, 72, 16))
      +        font = QtGui.QFont()
      +        font.setPointSize(7)
      +        self.lineEdit_02h.setFont(font)
      +        self.lineEdit_02h.setObjectName(_fromUtf8("lineEdit_02h"))
      +        self.lineEdit_02h.setText(CREA_TIME)
      +
      +        self.lineEdit_03 = QtGui.QLineEdit(self.centralWidget)
      +        self.lineEdit_03.setGeometry(QtCore.QRect(20, 100, 190, 16))
      +        font = QtGui.QFont()
      +        font.setPointSize(7)
      +        self.lineEdit_03.setFont(font)
      +        self.lineEdit_03.setObjectName(_fromUtf8("lineEdit_03"))
      +        self.lineEdit_03.setText(CHECKED_BY)
      +
      +        self.lineEdit_04 = QtGui.QLineEdit(self.centralWidget)
      +        self.lineEdit_04.setGeometry(QtCore.QRect(20, 140, 82, 16))
      +        font = QtGui.QFont()
      +        font.setPointSize(7)
      +        self.lineEdit_04.setFont(font)
      +        self.lineEdit_04.setObjectName(_fromUtf8("lineEdit_04"))
      +        self.lineEdit_04.setText(CHEC_DATE)
      +
      +        self.lineEdit_04h = QtGui.QLineEdit(self.centralWidget)
      +        self.lineEdit_04h.setGeometry(QtCore.QRect(98, 140, 72, 16))
      +        font = QtGui.QFont()
      +        font.setPointSize(7)
      +        self.lineEdit_04h.setFont(font)
      +        self.lineEdit_04h.setObjectName(_fromUtf8("lineEdit_04h"))
      +        self.lineEdit_04h.setText(CHEC_TIME)
      +
      +        self.lineEdit_06 = QtGui.QLineEdit(self.centralWidget)
      +        self.lineEdit_06.setGeometry(QtCore.QRect(20, 280, 61, 41))
      +        font = QtGui.QFont()
      +        font.setPointSize(10)
      +        self.lineEdit_06.setFont(font)
      +        self.lineEdit_06.setAlignment(QtCore.Qt.AlignCenter)
      +        self.lineEdit_06.setObjectName(_fromUtf8("lineEdit_06"))
      +        self.lineEdit_06.setText(SCALE)
      +
      +        self.lineEdit_07 = QtGui.QLineEdit(self.centralWidget)
      +        self.lineEdit_07.setGeometry(QtCore.QRect(100, 280, 101, 41))
      +        font = QtGui.QFont()
      +        font.setPointSize(10)
      +        self.lineEdit_07.setFont(font)
      +        self.lineEdit_07.setAlignment(QtCore.Qt.AlignCenter)
      +        self.lineEdit_07.setObjectName(_fromUtf8("lineEdit_07"))
      +        self.lineEdit_07.setText(WEIGHT)
      +
      +        self.lineEdit_08 = QtGui.QLineEdit(self.centralWidget)
      +        self.lineEdit_08.setGeometry(QtCore.QRect(220, 280, 341, 41))
      +        self.lineEdit_08.setObjectName(_fromUtf8("lineEdit_08"))
      +        self.lineEdit_08.setText(DRAWING_NUMBER)
      +
      +        self.lineEdit_09 = QtGui.QLineEdit(self.centralWidget)
      +        self.lineEdit_09.setGeometry(QtCore.QRect(570, 280, 81, 41))
      +        self.lineEdit_09.setObjectName(_fromUtf8("lineEdit_09"))
      +        self.lineEdit_09.setText(SHEET)
      +
      +        self.lineEdit_20 = QtGui.QLineEdit(self.centralWidget) # Copyright
      +        self.lineEdit_20.setGeometry(QtCore.QRect(20, 330, 771, 22))
      +        self.lineEdit_20.setObjectName(_fromUtf8("lineEdit_20"))
      +        self.lineEdit_20.setText(COPYRIGHT)
      +
      +        self.lineEdit_10 = QtGui.QLineEdit(self.centralWidget)
      +        self.lineEdit_10.setGeometry(QtCore.QRect(690, 290, 101, 30))
      +        self.lineEdit_10.setObjectName(_fromUtf8("lineEdit_10"))
      +        self.lineEdit_10.setText(Note_A)
      +
      +        self.lineEdit_11 = QtGui.QLineEdit(self.centralWidget)
      +        self.lineEdit_11.setGeometry(QtCore.QRect(690, 260, 101, 30))
      +        self.lineEdit_11.setObjectName(_fromUtf8("lineEdit_11"))
      +        self.lineEdit_11.setText(Note_B)
      +
      +        self.lineEdit_12 = QtGui.QLineEdit(self.centralWidget)
      +        self.lineEdit_12.setGeometry(QtCore.QRect(690, 230, 101, 30))
      +        self.lineEdit_12.setObjectName(_fromUtf8("lineEdit_12"))
      +        self.lineEdit_12.setText(Note_C)
      +
      +        self.lineEdit_13 = QtGui.QLineEdit(self.centralWidget)
      +        self.lineEdit_13.setGeometry(QtCore.QRect(690, 200, 101, 30))
      +        self.lineEdit_13.setObjectName(_fromUtf8("lineEdit_13"))
      +        self.lineEdit_13.setText(Note_D)
      +
      +        self.lineEdit_14 = QtGui.QLineEdit(self.centralWidget)
      +        self.lineEdit_14.setGeometry(QtCore.QRect(690, 170, 101, 30))
      +        self.lineEdit_14.setObjectName(_fromUtf8("lineEdit_14"))
      +        self.lineEdit_14.setText(Note_E)
      +
      +        self.lineEdit_15 = QtGui.QLineEdit(self.centralWidget)
      +        self.lineEdit_15.setGeometry(QtCore.QRect(690, 140, 101, 30))
      +        self.lineEdit_15.setObjectName(_fromUtf8("lineEdit_15"))
      +        self.lineEdit_15.setText(Note_F)
      +
      +        self.lineEdit_16 = QtGui.QLineEdit(self.centralWidget)
      +        self.lineEdit_16.setGeometry(QtCore.QRect(690, 110, 101, 30))
      +        self.lineEdit_16.setObjectName(_fromUtf8("lineEdit_16"))
      +        self.lineEdit_16.setText(Note_G)
      +
      +        self.lineEdit_17 = QtGui.QLineEdit(self.centralWidget)
      +        self.lineEdit_17.setGeometry(QtCore.QRect(690, 80, 101, 30))
      +        self.lineEdit_17.setObjectName(_fromUtf8("lineEdit_17"))
      +        self.lineEdit_17.setText(Note_H)
      +
      +        self.lineEdit_18 = QtGui.QLineEdit(self.centralWidget)
      +        self.lineEdit_18.setGeometry(QtCore.QRect(690, 50, 101, 30))
      +        self.lineEdit_18.setObjectName(_fromUtf8("lineEdit_18"))
      +        self.lineEdit_18.setText(Note_I)
      +##
      +        self.lineEdit_page = QtGui.QLineEdit(self.centralWidget)         # nom de page
      +        self.lineEdit_page.setGeometry(QtCore.QRect(20, 365, 181, 20))
      +        self.lineEdit_page.setToolTip("Name page to work"+"\n"
      +                                      "The name of the first page is always named 'Page'"
      +                                      "Select the new page in the Combo view")
      +        self.lineEdit_page.setObjectName(_fromUtf8("lineEdit_page"))
      +        self.lineEdit_page.setEnabled(False)
      +        self.lineEdit_page.setStyleSheet("color: red")
      +        self.lineEdit_page.setText(PageActive)
      +        self.lineEdit_page.textChanged.connect(self.on_lineEdit_page_Pressed) # 
      +
      +        self.label_01T = QtGui.QLabel(self.centralWidget)
      +        self.label_01T.setGeometry(QtCore.QRect(220, 0, 91, 16))
      +        self.label_01T.setObjectName(_fromUtf8("label_01T"))
      +
      +        self.textEdit_01 = QtGui.QTextEdit(self.centralWidget)            # Title
      +        self.textEdit_01.setGeometry(QtCore.QRect(220, 20, 431,55 ))
      +        font = QtGui.QFont()
      +        font.setPointSize(15)
      +        font.setBold(True)
      +        font.setWeight(75)
      +        self.textEdit_01.setFont(font)
      +        self.textEdit_01.setObjectName(_fromUtf8("textEdit_01"))
      +        self.textEdit_01.setText(TITLE)
      +
      +        self.label_02T = QtGui.QLabel(self.centralWidget)
      +        self.label_02T.setGeometry(QtCore.QRect(220, 80, 101, 16))
      +        self.label_02T.setObjectName(_fromUtf8("label_02T"))
      +
      +        self.textEdit_02 = QtGui.QTextEdit(self.centralWidget)            # DESCRIPTION
      +        self.textEdit_02.setGeometry(QtCore.QRect(220, 100, 431, 55))
      +        self.textEdit_02.setObjectName(_fromUtf8("textEdit_02"))
      +        self.textEdit_02.setText(DESCRIPTION)
      +
      +        self.label_02bT = QtGui.QLabel(self.centralWidget)
      +        self.label_02bT.setGeometry(QtCore.QRect(220, 160, 90, 16))
      +        self.label_02bT.setObjectName(_fromUtf8("label_02bT"))
      +
      +        self.textEdit_02b = QtGui.QTextEdit(self.centralWidget)            # COMPANY
      +        self.textEdit_02b.setGeometry(QtCore.QRect(220, 180, 340, 60))
      +        self.textEdit_02b.setObjectName(_fromUtf8("textEdit_02b"))
      +        self.textEdit_02b.setText(COMPANY)
      +
      +        self.label_01 = QtGui.QLabel(self.centralWidget)
      +        self.label_01.setGeometry(QtCore.QRect(20, 0, 91, 16))
      +        self.label_01.setObjectName(_fromUtf8("label_01"))
      +
      +        self.label_02 = QtGui.QLabel(self.centralWidget)
      +        self.label_02.setGeometry(QtCore.QRect(20, 40, 53, 16))
      +        self.label_02.setObjectName(_fromUtf8("label_02"))
      +
      +        self.label_03 = QtGui.QLabel(self.centralWidget)
      +        self.label_03.setGeometry(QtCore.QRect(20, 80, 101, 16))
      +        self.label_03.setObjectName(_fromUtf8("label_03"))
      +
      +        self.label_04 = QtGui.QLabel(self.centralWidget)
      +        self.label_04.setGeometry(QtCore.QRect(20, 120, 91, 16))
      +        self.label_04.setObjectName(_fromUtf8("label_04"))
      +
      +        self.label_06 = QtGui.QLabel(self.centralWidget)
      +        self.label_06.setGeometry(QtCore.QRect(20, 260, 53, 16))
      +        self.label_06.setObjectName(_fromUtf8("label_06"))
      +
      +        self.label_07 = QtGui.QLabel(self.centralWidget)
      +        self.label_07.setGeometry(QtCore.QRect(100, 260, 101, 16))
      +        self.label_07.setObjectName(_fromUtf8("label_07"))
      +
      +        self.label_08 = QtGui.QLabel(self.centralWidget)
      +        self.label_08.setGeometry(QtCore.QRect(220, 260, 121, 16))
      +        self.label_08.setObjectName(_fromUtf8("label_08"))
      +
      +        self.label_09 = QtGui.QLabel(self.centralWidget)
      +        self.label_09.setGeometry(QtCore.QRect(570, 260, 53, 16))
      +        self.label_09.setObjectName(_fromUtf8("label_09"))
      +
      +        self.label_10 = QtGui.QLabel(self.centralWidget)
      +        self.label_10.setGeometry(QtCore.QRect(670, 290, 16, 33))
      +        font = QtGui.QFont()
      +        font.setPointSize(12)
      +        font.setBold(True)
      +        font.setWeight(75)
      +        self.label_10.setFont(font)
      +        self.label_10.setObjectName(_fromUtf8("label_10"))
      +
      +        self.label_11 = QtGui.QLabel(self.centralWidget)
      +        self.label_11.setGeometry(QtCore.QRect(670, 260, 16, 33))
      +        font = QtGui.QFont()
      +        font.setPointSize(12)
      +        font.setBold(True)
      +        font.setWeight(75)
      +        self.label_11.setFont(font)
      +        self.label_11.setObjectName(_fromUtf8("label_11"))
      +
      +        self.label_12 = QtGui.QLabel(self.centralWidget)
      +        self.label_12.setGeometry(QtCore.QRect(670, 230, 16, 33))
      +        font = QtGui.QFont()
      +        font.setPointSize(12)
      +        font.setBold(True)
      +        font.setWeight(75)
      +        self.label_12.setFont(font)
      +        self.label_12.setObjectName(_fromUtf8("label_12"))
      +
      +        self.label_13 = QtGui.QLabel(self.centralWidget)
      +        self.label_13.setGeometry(QtCore.QRect(670, 200, 18, 33))
      +        font = QtGui.QFont()
      +        font.setPointSize(12)
      +        font.setBold(True)
      +        font.setWeight(75)
      +        self.label_13.setFont(font)
      +        self.label_13.setObjectName(_fromUtf8("label_13"))
      +
      +        self.label_14 = QtGui.QLabel(self.centralWidget)
      +        self.label_14.setGeometry(QtCore.QRect(670, 170, 15, 33))
      +        font = QtGui.QFont()
      +        font.setPointSize(12)
      +        font.setBold(True)
      +        font.setWeight(75)
      +        self.label_14.setFont(font)
      +        self.label_14.setObjectName(_fromUtf8("label_14"))
      +
      +        self.label_15 = QtGui.QLabel(self.centralWidget)
      +        self.label_15.setGeometry(QtCore.QRect(670, 140, 14, 33))
      +        font = QtGui.QFont()
      +        font.setPointSize(12)
      +        font.setBold(True)
      +        font.setWeight(75)
      +        self.label_15.setFont(font)
      +        self.label_15.setObjectName(_fromUtf8("label_15"))
      +
      +        self.label_16 = QtGui.QLabel(self.centralWidget)
      +        self.label_16.setGeometry(QtCore.QRect(670, 110, 18, 33))
      +        font = QtGui.QFont()
      +        font.setPointSize(12)
      +        font.setBold(True)
      +        font.setWeight(75)
      +        self.label_16.setFont(font)
      +        self.label_16.setObjectName(_fromUtf8("label_16"))
      +
      +        self.label_17 = QtGui.QLabel(self.centralWidget)
      +        self.label_17.setGeometry(QtCore.QRect(670, 80, 18, 33))
      +        font = QtGui.QFont()
      +        font.setPointSize(12)
      +        font.setBold(True)
      +        font.setWeight(75)
      +        self.label_17.setFont(font)
      +        self.label_17.setObjectName(_fromUtf8("label_17"))
      +
      +        self.label_18 = QtGui.QLabel(self.centralWidget)
      +        self.label_18.setGeometry(QtCore.QRect(670, 50, 10, 33))
      +        font = QtGui.QFont()
      +        font.setPointSize(12)
      +        font.setBold(True)
      +        font.setWeight(75)
      +        self.label_18.setFont(font)
      +        self.label_18.setObjectName(_fromUtf8("label_18"))
      +
      +        self.label_19 = QtGui.QLabel(self.centralWidget)
      +        self.label_19.setGeometry(QtCore.QRect(720, 15, 100, 33))
      +        self.label_19.setObjectName(_fromUtf8("label_19"))
      +
      +        self.label_page = QtGui.QLabel(self.centralWidget)
      +        self.label_page.setGeometry(QtCore.QRect(20, 350, 181, 16))
      +        self.label_page.setObjectName(_fromUtf8("label_page"))
      +
      +        self.label_Version = QtGui.QLabel(self.centralWidget)        # Version
      +        self.label_Version.setGeometry(QtCore.QRect(685, 383, 121, 20))
      +        self.label_Version.setObjectName(_fromUtf8("label_Version"))
      +
      +        MainWindow.setCentralWidget(self.centralWidget)
      +
      +        self.retranslateUi(MainWindow)
      +        QtCore.QMetaObject.connectSlotsByName(MainWindow)
      +
      +    def retranslateUi(self, MainWindow):
      +        MainWindow.setWindowFlags(PySide.QtCore.Qt.WindowStaysOnTopHint) # cette fonction met la fenetre en avant
      +        MainWindow.setWindowTitle("Cartouche (Full)")
      +#        self.pushButton01.setText("Position")
      +        self.pushButton02.setText("Quit") #Quitter
      +        self.pushButton03.setText("Memo")
      +        self.pushButton04.setText("Clean")#Nettoyer
      +        self.pushButton05.setText("Write")#Appliquer
      +        self.pushButton06.setText("D.")
      +        self.pushButton07.setText("H.")
      +        self.pushButton08.setText("D.")
      +        self.pushButton09.setText("H.")
      +        self.pushButton10.setText("Create Symb.")
      +
      +        self.label_01.setText("Designed by :")
      +        self.label_02.setText("Date :")
      +        self.label_03.setText("Checked by :")
      +        self.label_04.setText("Date :")
      +        self.label_06.setText("Scale :")
      +        self.label_07.setText("Weight (Kg) :")
      +        self.label_08.setText("Drawing number :")
      +        self.label_01T.setText("Title :")
      +        self.label_02T.setText("Description :")
      +        self.label_02bT.setText("Company :")
      +        self.label_09.setText("Sheet :")
      +
      +        self.label_10.setText("A")
      +        self.label_11.setText("B")
      +        self.label_12.setText("C")
      +        self.label_13.setText("D")
      +        self.label_14.setText("E")
      +        self.label_15.setText("F")
      +        self.label_16.setText("G")
      +        self.label_17.setText("H")
      +        self.label_18.setText("I")
      +        self.label_19.setText("Notes")
      +        self.label_20.setText("Warning")
      +        self.label_page.setText("Name page to work")
      +        self.label_Version.setText("Ver: 00.10 15/02/2017")        # Version
      +        self.groupBox.setTitle("Size :")
      +        self.radioButton_1.setText("A3 Landscape")
      +        self.radioButton_2.setText("A3 Portrait")
      +        self.radioButton_3.setText("A4 Landscape")
      +        self.radioButton_4.setText("A4 Portrait")
      +        self.radioButton_EU.setText("EU")
      +        self.radioButton_US.setText("US")
      +        self.lineEdit_05.setText("?")
      +
      +#______________________________________________________________________________________
      +    # Radio Boutons
      +    def on_radioButton_A3_clicked(self):  # connect radioButton_A3
      +        self.label_20.setVisible(False)
      +        self.pushButton10.setEnabled(True)
      +        self.lineEdit_05.setText("A3")
      +        self.pushButton10.setStyleSheet("color: QPalette.Base")           # origin system
      +
      +    def on_radioButton_A4_clicked(self):  # connect radioButton_A4
      +        self.label_20.setVisible(False)
      +        self.pushButton10.setEnabled(True)
      +        self.lineEdit_05.setText("A4")
      +        self.pushButton10.setStyleSheet("color: QPalette.Base")           # origin system
      +    # Radio Boutons
      +
      +    def on_radioButton_EU_clicked(self):    # Bouton /Symbole EU
      +        global SymbolSwitch
      +        SymbolSwitch = 1
      +
      +    def on_radioButton_US_clicked(self):    # Bouton /Symbole US
      +        global SymbolSwitch
      +        SymbolSwitch = 0
      +
      +    def on_pushButton10_clicked(self):      # Bouton /Symbole EU US disposition dans le cartouche
      +        global SymbolSwitch
      +        global PageActive
      +        self.label_20.setVisible(False)
      +
      +        if self.radioButton_0.isChecked():
      +            self.label_20.setVisible(True)
      +            self.pushButton10.setEnabled(False)
      +            self.pushButton10.setStyleSheet("color: red")
      +            self.lineEdit_page.setStyleSheet("color: red")
      +            FreeCAD.Console.PrintError("Select one format A3 or A4 for the Symbole" + "\n")
      +        else:
      +            self.pushButton10.setEnabled(True)
      +            self.pushButton10.setStyleSheet("background-color: #FF5B2B")
      +            self.pushButton10.setText("Wait.")
      +            FreeCADGui.updateGui()                # rafraichi l'ecran
      +            if SymbolSwitch == 1:
      +                if self.radioButton_1.isChecked():
      +                    symbol_EU(247.5, 263.5, 0.8)  # A3 Landscape
      +                elif self.radioButton_2.isChecked():
      +                    symbol_EU(124.55, 386.3, 0.8) # A3 Portrait
      +                elif self.radioButton_3.isChecked():
      +                    symbol_EU(158.7, 181.35, 0.6) # A4 Landscape
      +                elif self.radioButton_4.isChecked():
      +                    symbol_EU(71.9, 269.0, 0.6)   # A4 Portrait
      +            else:
      +                if self.radioButton_1.isChecked():
      +                    symbol_US(247.5, 263.5, 0.8)  # A3 Landscape
      +                elif self.radioButton_2.isChecked():
      +                    symbol_US(124.55, 386.3, 0.8) # A3 Portrait
      +                elif self.radioButton_3.isChecked():
      +                    symbol_US(158.7, 181.35, 0.6) # A4 Landscape
      +                elif self.radioButton_4.isChecked():
      +                    symbol_US(71.9, 269.0, 0.6)   # A4 Portrait
      +            self.pushButton10.setStyleSheet("color: QPalette.Base")           # origin system
      +            self.pushButton10.setText("Create Symb.")
      +            FreeCADGui.updateGui()                                 # rafraichi l'ecran
      +        
      +    def on_lineEdit_page_Pressed(self):   # Name page
      +        global PageActive
      +        PageActive = self.lineEdit_page.text()
      +
      +    def on_pushButton09_clicked(self):    # Bouton /heure document
      +        self.lineEdit_04h.setText(str(heure()))
      +
      +    def on_pushButton08_clicked(self):    # Bouton date/ document
      +        global SymbolSwitch
      +        if SymbolSwitch==0:
      +            self.lineEdit_04.setText(str(dateUs()))
      +        else:
      +            self.lineEdit_04.setText(str(dateEu()))
      +
      +    def on_pushButton07_clicked(self):    # Bouton /heure checked
      +        self.lineEdit_02h.setText(str(heure()))
      +
      +    def on_pushButton06_clicked(self):    # Bouton date/ checked
      +        global SymbolSwitch
      +        if SymbolSwitch==0:
      +            self.lineEdit_02.setText(str(dateUs()))
      +        else:
      +            self.lineEdit_02.setText(str(dateEu()))
      +
      +    def on_pushButton05_clicked(self):    # Bouton Appliquer
      +        try:
      +            global DESIGNED_BY, CREATION_DATE, CREA_DATE  , CREA_TIME, CHECKED_BY, CHECK_DATE
      +            global CHEC_DATE  , CHEC_TIME    , SIZE       , SCALE    , WEIGHT    ,DRAWING_NUMBER
      +            global SHEET      , TITLE        , DESCRIPTION, COMPANY  , COPYRIGHT
      +            global Note_A, Note_B, Note_C, Note_D, Note_E, Note_F, Note_G, Note_H, Note_I
      +            global ui
      +            global SymbolSwitch
      +            global PageActive
      +
      +            try:
      +                page = App.activeDocument().getObjectsByLabel(PageActive.encode('utf-8'))[0]
      +            except Exception:
      +                page = App.activeDocument().getObjectsByLabel(PageActive)[0]
      +    
      +            if len(str(page)) != 2:
      +    
      +                self.pushButton05.setStyleSheet("background-color: #FF5B2B")
      +                self.pushButton05.setText("Wait.")
      +                FreeCADGui.updateGui()                # rafraichi l'ecran
      +
      +                DESIGNED_BY = (self.lineEdit_01.text())
      +                CREATION_DATE = (self.lineEdit_02.text())+" - "+(self.lineEdit_02h.text())
      +                CHECKED_BY = (self.lineEdit_03.text())
      +                CHECK_DATE = (self.lineEdit_04.text())+" - "+(self.lineEdit_04h.text())
      +                SIZE = (self.lineEdit_05.text())
      +                SCALE = (self.lineEdit_06.text())
      +                WEIGHT = (self.lineEdit_07.text())
      +                DRAWING_NUMBER = (self.lineEdit_08.text())
      +                SHEET = (self.lineEdit_09.text())
      +                TITLE = (self.textEdit_01.toPlainText())
      +                DESCRIPTION = (self.textEdit_02.toPlainText())
      +                COMPANY = (self.textEdit_02b.toPlainText())
      +                COPYRIGHT = (self.lineEdit_20.text())
      +    
      +                Note_A = (self.lineEdit_10.text())
      +                Note_B = (self.lineEdit_11.text())
      +                Note_C = (self.lineEdit_12.text())
      +                Note_D = (self.lineEdit_13.text())
      +                Note_E = (self.lineEdit_14.text())
      +                Note_F = (self.lineEdit_15.text())
      +                Note_G = (self.lineEdit_16.text())
      +                Note_H = (self.lineEdit_17.text())
      +                Note_I = (self.lineEdit_18.text())
      +    
      +                try:
      +                    FreeCAD.getDocument(App.ActiveDocument.Name).getObject(page.Name).EditableTexts = [DESIGNED_BY, CREATION_DATE, CHECKED_BY, CHECK_DATE, SIZE, SCALE, WEIGHT, DRAWING_NUMBER, SHEET, TITLE, DESCRIPTION, COMPANY, COPYRIGHT, Note_A, Note_B, Note_C, Note_D, Note_E, Note_F, Note_G, Note_H, Note_I, ]
      +#old                    FreeCAD.getDocument(App.ActiveDocument.Name).getObjectsByLabel(PageActive.encode('utf-8'))[0].EditableTexts = [DESIGNED_BY, CREATION_DATE, CHECKED_BY, CHECK_DATE, SIZE, SCALE, WEIGHT, DRAWING_NUMBER, SHEET, TITLE, DESCRIPTION, COMPANY, COPYRIGHT, Note_A, Note_B, Note_C, Note_D, Note_E, Note_F, Note_G, Note_H, Note_I, ]
      +                    App.ActiveDocument.recompute()
      +                    FreeCAD.Console.PrintMessage("Write done to ( " + page.Label + " )" + "\n")
      +                    self.pushButton05.setStyleSheet("color: QPalette.Base")
      +                except Exception:
      +                    FreeCAD.Console.PrintError("Error write cartouche or verify the selected page ( " + page.Label + " )" + "\n")
      +                    self.pushButton05.setStyleSheet("background-color: red")
      +            else:
      +                FreeCAD.Console.PrintError("Error selected page ( " + Page.Label + " )" + "\n")
      +                self.pushButton05.setStyleSheet("background-color: red")
      +
      +        except Exception:
      +            self.pushButton05.setStyleSheet("background-color: red")
      +            FreeCAD.Console.PrintError("Error or not page " + "\n")
      +        self.pushButton05.setText("Write")
      +        App.ActiveDocument.recompute()
      +
      +    def on_pushButton04_clicked(self):    # Bouton nettoyer
      +
      +        self.lineEdit_01.setText("")
      +        self.lineEdit_02.setText("")
      +        self.lineEdit_02h.setText("")
      +        self.lineEdit_03.setText("")
      +        self.lineEdit_04.setText("")
      +        self.lineEdit_04h.setText("")
      +        self.lineEdit_05.setText("?")
      +        self.lineEdit_06.setText("")
      +        self.lineEdit_07.setText("")
      +        self.lineEdit_08.setText("")
      +        self.lineEdit_09.setText("")
      +        self.textEdit_01.setText("")
      +        self.textEdit_02.setText("")
      +        self.textEdit_02b.setText("")
      +        self.lineEdit_20.setText("")
      +        self.lineEdit_10.setText("")
      +        self.lineEdit_11.setText("")
      +        self.lineEdit_12.setText("")
      +        self.lineEdit_13.setText("")
      +        self.lineEdit_14.setText("")
      +        self.lineEdit_15.setText("")
      +        self.lineEdit_16.setText("")
      +        self.lineEdit_17.setText("")
      +        self.lineEdit_18.setText("")
      +
      +        self.pushButton10.setStyleSheet("color: QPalette.Base")                # origin system
      +        self.label_20.setVisible(False)
      +        self.radioButton_0.setChecked(True)
      +        self.pushButton05.setEnabled(True)
      +        self.pushButton05.setStyleSheet("background-color: QPalette.Base")     # origin system
      +        self.groupBox.setEnabled(True)
      +
      +    def on_pushButton03_clicked(self):    # Bouton Memo
      +        global MDESIGNED_BY, MCREATION_DATE, MCREA_DATE  , MCREA_TIME, MCHECKED_BY, MCHECK_DATE
      +        global MCHEC_DATE  , MCHEC_TIME    , MSIZE       , MSCALE    , MWEIGHT    ,MDRAWING_NUMBER
      +        global MSHEET      , MTITLE        , MDESCRIPTION, MCOMPANY  , MCOPYRIGHT
      +        global MNote_A, MNote_B, MNote_C, MNote_D, MNote_E, MNote_F, MNote_G, MNote_H, MNote_I
      +        
      +        self.lineEdit_01.setText(MDESIGNED_BY)
      +        self.lineEdit_02.setText(MCREA_DATE)
      +        self.lineEdit_02h.setText(MCREA_TIME)
      +        self.lineEdit_03.setText(MCHECKED_BY)
      +        self.lineEdit_04.setText(MCHEC_DATE)
      +        self.lineEdit_04h.setText(MCHEC_TIME)
      +        self.lineEdit_05.setText("?") #(SIZE)
      +        self.lineEdit_06.setText(MSCALE)
      +        self.lineEdit_07.setText(MWEIGHT)
      +        self.lineEdit_08.setText(MDRAWING_NUMBER)
      +        self.lineEdit_09.setText(MSHEET)
      +        self.textEdit_01.setText(MTITLE)
      +        self.textEdit_02.setText(MDESCRIPTION)
      +        self.textEdit_02b.setText(MCOMPANY)
      +        self.lineEdit_20.setText(MCOPYRIGHT)
      +        self.lineEdit_10.setText(MNote_A)
      +        self.lineEdit_11.setText(MNote_B)
      +        self.lineEdit_12.setText(MNote_C)
      +        self.lineEdit_13.setText(MNote_D)
      +        self.lineEdit_14.setText(MNote_E)
      +        self.lineEdit_15.setText(MNote_F)
      +        self.lineEdit_16.setText(MNote_G)
      +        self.lineEdit_17.setText(MNote_H)
      +        self.lineEdit_18.setText(MNote_I)
      +#        self.lineEdit_page.setText(PageActive)
      +        self.radioButton_0.setChecked(True)
      +
      +    def on_pushButton02_clicked(self):    # Bouton Quitter
      +        App.Console.PrintMessage("End CartoucheFC_Full\r\n")
      +        self.window.hide()
      +        FreeCADGui.Selection.removeObserver(s)           # Uninstalls the resident function
      +        App.Console.PrintMessage("removeObserver"+"\n")
      +
      +#    def on_pushButton01_clicked(self):    # Bouton appel de Position
      +#        MainWindow.resize(210, 480)
      +#        executer()
      +#        MainWindow.resize(810, 480)
      +#______________________________________________________________________________________
      +
      +class SelObserver:
      +    print "run.."
      +    def setSelection(self,document):                     # Selection in ComboView
      +        global PageActive
      +        global ui
      +        if len(Gui.Selection.getSelection(document)) == 1:
      +
      +            ff = ui
      +            ff.lineEdit_page.setStyleSheet("color: QPalette.Base")           # origin system
      +            ff.pushButton05.setEnabled(True)
      +            ff.pushButton05.setStyleSheet("background-color: QPalette.Base") # origin system
      +            ff.groupBox.setEnabled(True)
      +
      +            if (str(Gui.Selection.getSelection(document)[0].Name[0:4]) == "Page"):
      +                PageActive = str(Gui.Selection.getSelection(document)[0].Label.encode('utf-8'))
      +                try:
      +                    ff.lineEdit_page.setText(unicode(PageActive,'utf-8'))    # convert if accent
      +                except Exception:
      +                    ff.lineEdit_page.setText(PageActive)                     # normal
      +
      +                memoEntree()                    # entree memo click mouse
      +                ff.on_pushButton03_clicked()    # Bouton Memo
      +            else:
      +                FreeCAD.Console.PrintError("Select a valid Page__________________________" + "\n")
      +                ff.lineEdit_page.setStyleSheet("color: red")
      +                ff.lineEdit_page.setText("Select a valid Page")              # 
      +                ff.pushButton05.setEnabled(False)
      +                ff.pushButton05.setStyleSheet("background-color: red")       # This function gives a color button
      +                ff.groupBox.setEnabled(False)
      +
      +                FreeCAD.Console.PrintMessage("                 " + "Name            Label" + "\n")
      +                for i in App.ActiveDocument.Objects:
      +                    if i.Name[0:4] == "Page":
      +                        name = i.Name + "                 "
      +                        labe = i.Label+ "                 "
      +                        FreeCAD.Console.PrintMessage("    Valid Page : " + name[:15] + "," + labe[:25] + "\n")
      +                FreeCAD.Console.PrintError("_____________________________________________" + "\n")
      +
      +for obj in FreeCAD.ActiveDocument.Objects:        # deslectionne
      +        FreeCADGui.Selection.removeSelection(obj)
      +
      +s=SelObserver()
      +FreeCADGui.Selection.addObserver(s)               # install the function mode resident 
      +
      +MainWindow = QtGui.QMainWindow()
      +ui = Ui_MainWindow(MainWindow)
      +MainWindow.show() 
      +

      Other

      +

      The fields have no length limit, check your cartouche. +

      This program creates a drawing representing the regional projection symbol on your project, do not touch it is registered therefore hidden form invisible. +

      If you want it to be cleared uncomment the commented lines and vice versa +

      +
      #    App.getDocument(App.ActiveDocument.Name).removeObject("Symbol_EU")
      +    FreeCADGui.getDocument(App.ActiveDocument.Name).getObject("Symbol_EU").Visibility = False 
      +

      et +

      +
      #    App.getDocument(App.ActiveDocument.Name).removeObject("Symbol_US")
      +    FreeCADGui.getDocument(App.ActiveDocument.Name).getObject("Symbol_US").Visibility = False 
      +

      (I had some times an error in execution when the symbol was erased) +

      This module works with the drawing sheet included in FreeCAD this sheet is called Page, do not change the name of this sheet! +

      +

      Revision

      +

      ver "00.10" : 15/02/2017 : tuning page multiple (It is possible to lose a page if there are too many) +

      ver "00.09" : 10/02/2017 : add radio button for choice symbol and correct the placement symbol in the separate page +

      ver "00.08 : 06/02/2017 : the dialog box name page accept the accent +

      ver "00.07 : 05/02/2017 : add save cartouche with name page (for multi page in projects) ps: not for character accentuate "àùé ..." +

      ver 00.06 : 13/10/2016  : selection format page and position for the symbol convention (for FreeCAD ver 0.17) +

      ver 5 : 08/08/2014 PyQt4 and PySide +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Macro_CartoucheFC_Full.png b/localwiki/Macro_CartoucheFC_Full.png new file mode 100644 index 0000000..c880a8b Binary files /dev/null and b/localwiki/Macro_CartoucheFC_Full.png differ diff --git a/localwiki/Macro_CenterFace.html b/localwiki/Macro_CenterFace.html new file mode 100644 index 0000000..2b0446e --- /dev/null +++ b/localwiki/Macro_CenterFace.html @@ -0,0 +1,155 @@ +Macro CenterFace

      Macro CenterFace

      + +
      + + + + + + + + + + + + + + + + + + + + + + + + + + +
      +

      CenterFace.png Macro CenterFace

      +
      Description +
      This macro red trace (editable) the center face (mass) with 1 point and print the coordinates. +
      Author +
      Mario52 +
      Links +
      Macros recipes
      How to install macros
      How to customize toolbars +
      Version +
      0.1 +
      Date last modification +
      2014-04-29 +
      +

      + +
      +


      +

      +

      Description

      +

      This macro red trace (editable) the center face (mass) with 1 point and print the coordinates. +


      +CenterFace +

      +
      +


      +

      +

      Use

      +

      Select one face and launch the macro. 1 point to face are coloured red (can be changed). +

      To change the color of the dot change the lines 36, 37, 38 +

      +
      red   = 1.0  # 1 = 255
      +    green = 0.0  #
      +    blue  = 0.0  # 
      +

      The center of the face (mass) surface and the XYZ coordinates of the face are displayed in the report view. +

      +

      Icone

      +

      Download the file image and copy in your macro repertory. +

      Click the image, in the new window position the mouse over the image, click the right mouse and do "Save target as ..." +

      Button +

      +

      Script

      +

      Macro_CenterFace.FCMacro +

      +
      # -*- coding: utf-8 -*-
      +# 29/04/2014
      +# select a face launch and list the center coordinate XYZ of face
      +# To change the color of the dot change the lines 36, 37, 38
      +# red   = 1.0  # 1 = 255
      +# green = 0.0  #
      +# blue  = 0.0  #
      +# Macro_CenterFace
      +# Mario52
      +
      +#OS: Windows Vista
      +#Platform: 32-bit
      +#Version: 0.14.3389
      +#Python version: 2.6.2
      +#Qt version: 4.5.2
      +#Coin version: 3.1.0
      +#SoQt version: 1.4.1
      +#OCC version: 6.5.1
      +
      +import FreeCAD, FreeCADGui, Draft, Part
      +
      +try:
      +    sel = FreeCADGui.Selection.getSelection()             # get the selection
      +    sh = sel[0].Shape                                     # seletion of the first element
      +
      +    App.Console.PrintMessage("Label : "+ str(sel[0].Label)+"\n")     # extract the Label
      +    App.Console.PrintMessage("Name  : "+ str(sel[0].Name) +"\n")     # extract the Name
      +except:
      +    App.Console.PrintError( "select a face"+"\n")
      +
      +
      +try:
      +    SubElement = FreeCADGui.Selection.getSelectionEx()# "getSelectionEx" Used for selecting subobjects
      +    element_ = SubElement[0].SubElementNames[0]       # seletion of the first element
      +
      +#    print element_
      +#    print sh.Faces
      +
      +    # LineColor
      +    red   = 1.0  # 1 = 255
      +    green = 0.0  #
      +    blue  = 0.0  #
      +
      +    for i in range(len(sh.Faces)):                    # list and extract the data
      +        App.Console.PrintMessage( "Center Face "+str(i)+" "+str(sh.Faces[i].CenterOfMass)+"\n") # Vector center mass to face
      +#        print "X : ",sh.Faces[i].CenterOfMass.x                                                # Coord. X center mass to face
      +#        print "Y : ",sh.Faces[i].CenterOfMass.y                                                # Coord. Y center mass to face
      +#        print "Z : ",sh.Faces[i].CenterOfMass.z                                                # Coord. Z center mass to face
      +        Draft.makePoint(sh.Faces[i].CenterOfMass.x,sh.Faces[i].CenterOfMass.y,sh.Faces[i].CenterOfMass.z) # create a point
      +        FreeCADGui.activeDocument().activeObject().PointColor = (red, green, blue)
      +
      +        App.Console.PrintMessage( "       Surface   : "+str(sel[0].Shape.Faces[i-1].Area)+"\n")
      +        fco = 0
      +        for f0 in sel[0].Shape.Faces[i].Vertexes:      # Vertexes faces
      +            fco += 1
      +            App.Console.PrintMessage("       Vertexe X"+str(fco)+": "+str(f0.Point.x)+" Y"+str(fco)+": "+str(f0.Point.y)+" Z"+str(fco)+": "+str(f0.Point.z)+"\n")
      +
      +except:
      +    App.Console.PrintError( "select a face *"+"\n") 
      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Macro_Center_Align_Objects_with_Faces_or_Edges.html b/localwiki/Macro_Center_Align_Objects_with_Faces_or_Edges.html new file mode 100644 index 0000000..b82fc84 --- /dev/null +++ b/localwiki/Macro_Center_Align_Objects_with_Faces_or_Edges.html @@ -0,0 +1,134 @@ +Macro Center Align Objects with Faces or Edges

      Macro Center Align Objects with Faces or Edges

      + +
      + + + + + + + + + + + + + + + + + + + + + + + + + + +
      +

      Macro Center Align Objects with Faces or Edges.png Center Faces of Parts

      +
      Description +
      This macro Aligns Objects through Faces or Edges constraints +
      Author +
      easyw-fc +
      Links +
      Macros recipes
      How to install macros
      How to customize toolbars +
      Version +
      1.5.3 +
      Date last modification +
      2017-10-01 +
      +

      + +
      +


      +

      +

      Description

      +

      Note: this Macro is now included in Manipulator Workbench which is the only regularly updated.

      +

      Aligner Aligner-ico.png: a set of tools to move and align 3D parts +

      Mover Mover-ico.png: a set of tools to move and rotate 3D parts on different Axis +

      Measure Caliper-ico.png: a set of tools to measure 3D parts, with some Snap facility and Radius, Length, Angle measurements. +

      These helpers work with Part, App::Part and Body objects. +Each Tool can be Floating or Docked Left or Right. +

      +
      +

      OLD References

      +

      This macro covers the following constraints: +
      - Concentric constraint among non cylindrical parts; +
      - Constraint on center Faces and/or Edges. +
      It works also with the new Body and App::Part containers, as well as with STEP hierarchy. +

      +
      +

      Center-align-faces.png +

      +
      +

      Center-align-faces-in-action.gif +

      +
      +

      Center-align-Body-objects.gif +

      +
      +

      Utube-alignment-tool-tutorial.png +

      +
      +

      Aligning tool video tutorial +

      +
      +

      Utube-alignment-STEP-models.png +

      +
      +

      Aligning STEP models video tutorial +

      +
      +


      +

      +

      Use

      +

      Faces or Edges constraint among non cylindrical parts: Just open a FC document, launch the Macro and select two or more Faces/Edges to be aligned. Click on Align button and that's it! +

      +

      Script

      +

      The icon for your toolbar Macro Center Align Objects with Faces or Edges.png +

      Macro Center Faces of Parts.FCMacro +

      After downloading the file here
      +GitHub page +
      +https://github.com/easyw/FreeCAD_Macros/tree/master/Align%20Objects +
      +code: +
      +https://github.com/easyw/FreeCAD_Macros/raw/master/Align%20Objects/CenterAlignObjectswFacesEdges.py +
      +you need to copy the file to your macro directory. +
      +How to install macros +

      +

      Link

      +

      Forum : Faces or Edges constraint among non cylindrical parts Macro +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Macro_Circle.html b/localwiki/Macro_Circle.html new file mode 100644 index 0000000..69212ae --- /dev/null +++ b/localwiki/Macro_Circle.html @@ -0,0 +1,192 @@ +Macro Circle

      Macro Circle

      + +
      + + + + + + + + + + + + + + + + + + + + + + + + + + +
      +

      Text-x-python.png Macro Circle

      +
      Description +
      Creates a circle or arc with parameters. +
      Author +
      mario52 +
      Links +
      Macros recipes
      How to install macros
      How to customize toolbars +
      Version +
      0.3 +
      Date last modification +
      2018-06-10 +
      +

      + +
      +


      +

      +

      Description

      +

      This small macro create a circle or arc giving radius, diameter, circumference, area, startangle, endangle, arc, anglecenter, cord, arrow, center (point), placemObject on choice. +

      The circle is still facing the screen (with getCameraOrientation) (or give the placement) +

      +

      Use

      +

      Copy the code and paste it in the console Python the FreeCAD the command is used all the time to the disposal FreeCAD open +give the parameter on choice : +

      +
      • x y z : coordinates of circle if not coordinates the circle is created on point 0,0,0
      • +
      • radius : radius of cicle
      • +
      • diameter : diameter of circle
      • +
      • circumference : circumference of circle
      • +
      • area : area of circle
      • +
      • startangle : start angle for arc
      • +
      • endangle : end angle for arc
      • +
      • arc and anglecenter : arc in combination with anglecenter +
        • arc = length of arc
        • +
        • anglecenter = angle of center circle to extremities of arc
      • +
      • cord and arrow : cord in combination with arrow of circle +
        • cord : length of cord of circle
        • +
        • arrow : length of arrow of circle
      • +
      • center : if center as different 0 one point is created on center of circle
      • +
      • placemObject +
        • example :
        • +
        • pl=FreeCAD.Placement()
        • +
        • pl.Rotation.Q=(0.0,-0.0,-0.0,1.0)
        • +
        • pl.Base=FreeCAD.Vector(-1.89847898483,-0.490152746439,0.0)
        • +
        • give placemObject = pl
      +

      if there is no parameter "circle()" a list of functions is displayed in the report view +

      +Example entrance : +

      +
      circle(arc=50,anglecenter=20,center=1)
      +circle(cord = 100,arrow = 20,center=1)
      +circle(circumference = 100,center=1) 
      +

      Script

      +

      Macro_circle.FCMacro +

      +
      # -*- coding: utf-8 -*-
      +# creer un cercle ou un arc entierement parametrabel en utilisant :
      +# create a circle or arc fully parametrabel using:
      +# x x x coordinates
      +#with radius
      +#with diameter
      +#with circumference
      +#with area
      +#with startangle
      +#with endangle
      +#with [arc and anglecenter]      in combination (angle in degrees)
      +#with [cord and arrow]           in combination
      +#with center (if center as different 0 one point is created on center of circle)
      +#give placemObject  
      +# ex :pl=FreeCAD.Placement()
      +#     pl.Rotation.Q=(0.0,-0.0,-0.0,1.0)
      +#     pl.Base=FreeCAD.Vector(-1.89847898483,-0.490152746439,0.0)
      +#     placemObject = pl
      +# s'il n'y a pas de parametre "circle()" une liste des fonctions s'affiche dans la Vue rapport
      +# if there is no parameter "circle()" a list of functions is displayed in the report view
      +
      +__title__   = "circle"
      +__author__  = "Mario52"
      +__date__    = "10/06/2018"
      +
      +import Draft #, Part
      +def circle(x=0.0,y=0.0,z=0.0,radius=0.0,diameter=0.0,circumference=0.0,area=0.0,startangle=0.0,endangle=0.0,arc=0.0,anglecenter=0.0,cord=0.0,arrow=0.0,center=0,placemObject=""):
      +    from math import sqrt, pi
      +    if placemObject == "":
      +        pl = FreeCAD.Placement()
      +        pl.Rotation = FreeCADGui.ActiveDocument.ActiveView.getCameraOrientation()   
      +        pl.Base = FreeCAD.Vector(x,y,z)
      +    else:
      +        pl = placemObject                                  # placement imposted
      +
      +    if diameter != 0:                                      # with diameter
      +        radius = diameter / 2.0
      +    elif circumference != 0:                               # with circumference
      +        radius = (circumference / pi) / 2.0
      +    elif area != 0:                                        # with area
      +        radius =  sqrt((area / pi))
      +    elif (cord != 0) and (arrow != 0):                     # with cord and arrow
      +        radius = ((arrow**2) + (cord**2) / 4.0) / (arrow*2) 
      +    elif (arc != 0) and (anglecenter != 0):                # with arc and anglecenter central in degrees
      +        radius = ((360/anglecenter)*arc) / pi/2.0
      +        if endangle != 0:
      +            startangle  = endangle - anglecenter
      +        endangle   = anglecenter + startangle
      +        startangle  = endangle - anglecenter
      +
      +    if radius != 0:
      +        try:
      +            Draft.makeCircle(radius,placement=pl,face=False,startangle=startangle,endangle=endangle,support=None)
      +            if center != 0:
      +                Draft.makePoint(x,y,z)
      +        except Exception:
      +            App.Console.PrintError("Unexpected keyword argument" + "\n")
      +    else:
      +        App.Console.PrintMessage("Unexpected keyword argument" + "\n")
      +        App.Console.PrintMessage("circle(x,y,z,radius,diameter,circumference,area,startangle,endangle,[arc,anglecenter],[cord,arrow],center,placemObject)" + "\n")
      +
      +#example
      +#circle(arc=50,anglecenter=20,center=1) 
      +

      Memo of circle

      +

      Examples codes +

      +
      circle(radius=10)    # example 1
      +circle(x=15,diameter=20)    # example 2
      +circle(y=45,circumference=100)    # example 3 
      +
      examples 1, 2, 3
      +
      +


      +

      +
      circle(y=-15,area=100)    # example 4
      +circle(y=-15,x=15,startangle=60,endangle=-20,center=1)    # example 5
      +circle(y=-15,x=45,cord=9,arrow=3,center=1)    # example 6 left
      +circle(x=65,y=-15,arc=3.5,anglecenter=40,startangle=20,center=1)    # example 6 rigth 
      +
      examples
      +
      +

      Version

      +

      ver 0.3 10/06/2018 : replace /2 to /2.0 (float) +

      ver 0.2 24/02/2015 : adding function "placemObject" +

      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Macro_Circular_Text.html b/localwiki/Macro_Circular_Text.html new file mode 100644 index 0000000..ff737fe --- /dev/null +++ b/localwiki/Macro_Circular_Text.html @@ -0,0 +1,788 @@ +Macro Circular Text

      Macro Circular Text

      + +
      + + + + + + + + + + + + + + + + + + + + + + + + + + +
      +

      FCCircularTextButtom.png Macro Circular Text

      +
      Description +
      This macro creates a text around a cylinder. +
      Author +
      Mario52 +
      Links +
      Macros recipes
      How to install macros
      How to customize toolbars +
      Version +
      0.13 +
      Date last modification +
      2018-01-30 +
      +

      + +
      +


      +

      +

      Description

      +

      This macro writes a text, standing or flat, circumferential or helical in the manner of Trajan Column and creates a clock with Arabic numerals 1 2 3 ... or Roman I II III ... (inspired to Macro to Create Clock Face to cblt2l) +


      +texte 360 degrees +

      +

      Utilisation

      +

      Principle: The options that are not useful for the selected function are dimmed so inaccessible. +

      A function can gray out options if they are not for him. +

      Launch the macro folder FcString for created characters and a file FcClock for created clocks. +

      All the characters are and remain independent. When creating extrusions nothing is deleted. If Compound is created with Run Comp is copied out of the folder. +

      The options are shaded by default and are active in all functions if they are checked : +

      +
      • Extrude Char.
      • +
      • Placement.
      • +
      • SP. inclination.
      +

      Except for one Clock Service Placement box Z is activated and moves the text in the direction Z to place the text on the support surface. +

      +

      Presentation

      +

      Overview +

      GUI +

      +
      +


      +

      +

      First section

      +
      FCCircularText 07.png
      +
      +


      +

      +
      • TextEdit window that lets you copy the text to display (click on the Reset allows to know the number of the input string that is displayed in the window title)
      • +
      • The Reverse to reverse the text
      • +
      • The New Font to select a new font to use +
        • Default ARIAL.TTF
      +

      Second Section

      +

      Configuring characters in FCCircularText +

      +
      FCCircularText 08.png
      +
      +


      +

      +

      First zone

      +

      Your choice : +

      +
      FCCircularText 09.png
      +
      + +
      +
      +


      +

      +
      FCCircularText 24.png
      +
      • Mode Stand or Mode Flat : The text will be placed standing or flat (same as clock) options Outdoor and Indoor are reversed.
      +
      +


      +

      +
      + +
      +
      + +
      +

      Second area

      +

      This section allows you to configure the overall behavior of characters in all the choices available but with some variation. +If the command is not used in the option chosen, it will be grayed out. +

      +
      FCCircularText 10.png
      +
      • Radius of circle : Radius of the circle. (Default 10)
      • +
      • Size character  : Character height. (Default 2)
      • +
      • Begin angle  : Starting angle of the first character in the circle. (Default 0 °)
      • +
      • End angle  : Angle end of the last character of the text. (Default 360)
      • +
      • Correction angle : Character correction angle to make it tangent to the circle. (Default 10 °)
      • +
      • Correction radius: Fixed the radius of the circle characters (optional). (Default 0.15)
      • +
      • +
      • Pivot Character : Pivot the character on himself. (Inactive Default)
      • +
      • Extrude Char  : Checkbox extrusion characters. (Inactive Default)
      • +
      • Placement  : Text placement in the 3D view. (Inactive Default)
      • +
      • Sp. inclination  : Inclination of characters in three axes X, Y and Z (example to cover such a cone). (Inactive Default)
      +
      +


      +

      +

      Outdoor

      +

      Default mode. The text is written on the outside of the circumference of the circle. +

      +
      + +
      +

      Indoor

      +

      The text is written on the inner side of the circumference of the circle +

      +
      + +
      +

      Helix

      +

      The text is entered on the outer circumference of a helix. +

      +
      + +
      +
      FCCircularText 11.png
      +
      • The helix area is grayed out by default.
      +
      +
      FCCircularText 14.png
      +
      • All characters configuration options are available.
      • +
      • Step of helix which corresponds to the pitch of the helix turns and displays 2 (character height) by default.
      • +
      • Char. per turn activates and displays 10 by default, which corresponds to 10 characters per helical turn.
      +
      +
      FCCircularText 15.png
      +
      • If Step of helix (helix pitch) is zero, Spinboxes Base Helix and End Helix are activated.
      • +
      • Base Helix provides the basis for starting the helix (even Placement Z). If 'Placement Z' is different from zero, the starting point is added to Z Placement
      • +
      • End Helix End of the helix pitch of the helix will be calculated relative to the height and the number of characters per helical turn.
      +


      +

      +

      Clock

      +

      The figures are part of a circle with Arabic numerals or Romans. +

      +
      + +
      +
      FCCircularText 12.png
      +
      • By default, the section is grayed.
      +
      +
      FCCircularText 16.png
      +
      • When the selection is made, the following functions get dark and are usable: +
        1. Begin angle.
        2. +
        3. End angle.
        4. +
        5. Correction angle.
        6. +
        7. Correction radius.
        8. +
        9. The buttom Mode Stand or Mode Flat.
      • +
      • The area Clock is activated.
      +
      +


      +

      +
      FCCircularText 19.png
      +
      • Radius of support : If a value is given, support will be created (default 0).
      • +
      • If Support number face is different from zero a support is created. (If Extrude support = zero then a face is created). +
        • 1 = A circle is created (circle appears).
        • +
        • 2 = A rectangle is created (length = (Radius of media * 1.5) width = Radius of support) (Rectangle appears).
        • +
        • 3 = A triangle is created (circumscribed) (Triangle appears).
        • +
        • 4 = A square is created (Radius of support) (Square appears).
        • +
        • 5 = A polygon with the number of faces displayed (circumscribed) (Polygon appears).
      • +
      • Extrude support is activated and an extrusion dimension can be given.
      +
      +


      +

      +
      FCCircularText 17.png
      FCCircularText 38.png +
      +
      FCCircularText 18.png
      FCCircularText 37.png +
      +


      +

      +
      • If Support number face is equal to zero there is no support.
      • +
      • Mode Roman : The writing will be in Roman figures I II III IIII V VI VII VIII IX X XI XII
      • +
      • Axial  : The figures will be written axially.
      +

      Commands

      +

      FCCircularText 13.png +

      +
      +


      +

      +
      • Exit  : Leaves the macro.
      • +
      • Reset  : Reset all values and displays the number of characters displayed in the window.
      • +
      • Run Comp : Launches the macro and creates a Compount object of all characters.
      • +
      • Run  : Launches the macro
      +

      Launch the macro folder FcString for created characters and a file FcClock for created clocks. +

      +

      Script

      +

      Download the script : +

      - on github Macro_FCCircularText.FCMacro ver 0.13 09/08/2016 +

      - at the forum Extrude from curved surface of cylinder +

      The button icon: +

      - in .PNG FCCircularTextButtom.png +

      - in .SVG FCCircularTextButtom.svg +

      (See Customize_Toolbars for more) +

      +

      Example

      +
      + +
      +


      +

      +
      + +
      +


      +


      +

      +
      + +
      +


      +


      +

      +
      + +
      +


      +


      +

      +
      + +
      +


      +


      +

      +
      + +
      +


      +

      +

      Example onto Ellipse

      +
      + +
      +


      +

      +
      + +
      +


      +

      +
      + +
      +


      +

      +
      + +
      +


      +

      +
      + +
      +


      +Mode relief: +

      +
      + +
      +


      +

      +
      + +
      +


      +

      +
      + +
      +


      +

      +
      + +
      +


      +

      +

      Little bug

      +

      It is possible that two characters overlap, here a small remedy with Macro_Rotate_To_Point +
      +

      +
      + +
      +


      +

      (not fully developed) +

      Planned : +

      Writing on a path circular text of position object selected. +

      (PS : it is possible that an error is made between version 2 Please wait for the next or return to the previous version thank you) +

      +

      Currently:

      +
      • ver 0.13 30/01/2018 add feature Pivot for rotate the character on himself
      +
      • ver 0.13 09/08/2016 replace the button "New font" to "fontComboBox" cause , with Windows 10 the window Font stay empty the files are hidden
      +
      • ver 0.12 03/07/2016 optimize the code for accept the decimal number in determination angle
      +

      replace the line +

      +
      for angleTr in range(debut,rotation,((rotation-debut)/nombre)): 
      +

      to +

      +
      for angleTrFloat in range((debut*10000),(rotation*10000),int((round(((float(rotation)-float(debut))/float(nombre)),4)*10000)) ):    # pour 4 decimales
      +                angleTr = (float(angleTrFloat)/10000) 
      +
      • ver 0.10 17/05/2015 adding lines 1365, 1366 only created more clock face ?? ()
      +
      supp.MakeFace = True
      +            App.activeDocument().recompute() 
      +
      • ver 0.9 11/05/2015 thank you NormandC for testing
      +

      replace +

      +
      self.DS_InclinaisonX.setSuffix(" X°")
      +        self.DS_InclinaisonY.setSuffix(" Y°")
      +        self.DS_InclinaisonZ.setSuffix(" Z°") 
      +

      to +

      +
      self.DS_InclinaisonX.setSuffix(unicode(" X°"))
      +        self.DS_InclinaisonY.setSuffix(unicode(" Y°"))
      +        self.DS_InclinaisonZ.setSuffix(unicode(" Z°")) 
      +
      • ver 0.8 10/05/2015 replace "String=texte[ii2]" to "String=unicode(texte[ii2])" line 1290. cause "TypeError: Property 'FontFile': type must be str or unicode, not QString"
      +
      # ver 0.8 10/05/2015 /_ # testing with OS :
      +##################################################################################################
      +# OS: Ubuntu 14.04.1 LTS                          # OS: Ubuntu 14.04.2 LTS
      +# Platform: 32-bit                                # Word size of OS: 32-bit
      +# Version: 0.14.2935 (Git)                        # Word size of FreeCAD: 32-bit
      +# Branch: master                                  # Version: 0.16.4928 (Git)
      +# Hash: eab159b6ee675012bf79de838c206a311e911d85  # Branch: master
      +# Python version: 2.7.6                           # Hash: d8f63bcfd10301f3d1e141cced4370f0782238d0
      +# Qt version: 4.8.6                               # Python version: 2.7.6
      +# Coin version: 4.0.0a                            # Qt version: 4.8.6
      +# SoQt version: 1.6.0a                            # Coin version: 4.0.0a
      +# OCC version: 6.7.0                              # OCC version: 6.8.0.oce-0.17
      +##################################################################################################
      +# OS: Windows Vista                               # OS: Windows Vista
      +# Word size of OS: 32-bit                         # Word size of OS: 32-bit
      +# Word size of FreeCAD: 32-bit                    # Word size of FreeCAD: 32-bit
      +# Version: 0.15.4527 (Git)                        # Version: 0.15.4671 (Git)
      +# Branch: master                                  # Branch: releases/FreeCAD-0-15
      +# Hash: 0da2e4c45a9a259c26abd54c2a35393e1c15696f  # Hash: 244b3aef360841646cbfe80a1b225c8b39c8380c
      +# Python version: 2.7.8                           # Python version: 2.7.8
      +# Qt version: 4.8.6                               # Qt version: 4.8.6
      +# Coin version: 4.0.0a                            # Coin version: 4.0.0a
      +# OCC version: 6.7.1                              # OCC version: 6.8.0.oce-0.17
      +################################################################################################## 
      +
      • ver 0.7 02/02/2015 suppression 2 str App.Console.PrintMessage(str(PolicePath)+"\n") to App.Console.PrintMessage((PolicePath)+"\n") that caused an error with the characters above 128 in the police path.
      • +
      • ver 0.6 23/11/2014 corrected "texte = unicode(self.textEdit.toPlainText())" now accept "'éèà@..."
      • +
      • ver 0.5 19/11/2014 Gui
      • +
      • ver 0.4 10/10/2014 add variable "rotation" in the loop (for i in range(0,rotation,(rotation/nombre)): # 360 a parametrer)
      • +
      • ver 0.4 27/08/2014 correction error of de radius (exterieur=0, debout=1)
      • +
      • ver 0.3 26/08/2014 add creation text of flat curve
      • +
      • ver 0.2 26/08/2014 add creation text of internal curve
      • +
      • ver 0.1
      +

      (2537) +

      +

      Links

      +

      To comment on the Extrude from curved surface of cylinder +

      +
      +
      +

      +

      + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Macro_CloneConvert.html b/localwiki/Macro_CloneConvert.html new file mode 100644 index 0000000..927b5b3 --- /dev/null +++ b/localwiki/Macro_CloneConvert.html @@ -0,0 +1,143 @@ +Macro CloneConvert

      Macro CloneConvert

      + +
      + + + + + + + + + + + + + + + + + + + + + + + + + + +
      +

      Macro CloneConvert.png Macro CloneConvert

      +
      Description +
      Creates a clone of the object and the converted in the chosen position and size (inch, mm, m, µm...). +
      Author +
      mario52 +
      Links +
      Macros recipes
      How to install macros
      How to customize toolbars +
      Version +
      0.11 +
      Date last modification +
      2018-03-30 +
      +

      + +
      +


      +

      +

      Description

      +

      Creates a clone or copy of the object and the converted in the chosen position and size (inch, mm, m, µm...) or free. The base object is recognized in mm (FreeCAd base) +

      +

      Uses

      +

      Run the macro, the XYZ settings, choose "Clone" or "Copy" a unit or one value of choice select your object, and click Ok button. +

      If no value is entered a copy or clone will be created without modification. If no object is selected the Ok button will be colored in red. +

      The value of the BoundingBox, Volume and Surface is diplayed in the Report view, in the case of Copy multiple object, the display will show BoundingBox 0.0. +


      +The base is the mm example with a 1 mm cube of side : +

      Select in the comboBox inch, 1 inch = 25.4 mm , the fields "Scale free" automatically adjusts to 25.4 (the values ​​in "Scale-free" can be changed separately). Click Ok button, the clone created will have 25,4 mm x 25,4 mm x 25,4 mm +

      150% = 1,50 in the "Scale free" fields
      +104% = 1,04 in the "Scale free" fields +

      Inverse operation : +

      If you want to reduce an object ex: a cube 25.4 mm (1 inch) in cube 1 mm sides, use the following formula, 1 / 25.4 = 0.0393700 and enter the value 0,0393700 (with comma) in the Scale field XY and Z. +

      In a cube of 5 mm, made​​ 5 / 25.4 = 0.1968503 and enter the value 0,1968503 (with comma) in the Scale field XY and Z. +

      50% = 0,50 in the "Scale free" fields
      + 4% = 0,04 in the "Scale free" fields +
      +

      Predefined units are : +km, hm, dam, m, dm, cm, mm, µm, nm, inch, link, foot, yard, perch, chain, furlong, mile, league, nautique. +

      +

      +
      CloneConvert
      +
      • Mode
      • +
      • Clone  : The object(s) clone are create
      • +
      • Copy  : One copy of the objet(s) is create
      • +
      • Comp  : One compound of the objet(s) is create
      • +
      • Increm. : incrementing the coordinates data to the original coordinates of the object (Placement, Rotation ...)
        If this is not checked the Placement begin in coordinates 0,0,0 of FreeCAD
        In case a compound Placement information is [0,0,0] the Placement begin in the position of object
        If the real location is away from the base coordinates 0,0,0 use the ValueAt() button for the real Placement of the subObject selected Face, Wire, Line ....
      • +
      • Unique  : If this checkBox is checked and multiple object selected, the clone created is one unique object
      +
      • Coordinates
      • +
      • ... : This button align the YZ values on the value of X to have the same values ​​XYZ (or manually). Two click reset the coordinates values to 0.0
      • +
      • Coordinate X : Move the copy to the Coordinate X selected (Base 0,0,0 if Increm. is not checked)
      • +
      • Coordinate Y : Move the copy to the Coordinate Y selected (Base 0,0,0 if Increm. is not checked)
      • +
      • Coordinate Z : Move the copy to the Coordinate Z selected (Base 0,0,0 if Increm. is not checked)
      +
      • Rotation
      • +
      • ... : This button align the Pitch and Roll values on the value of Yaw to have the same values ​​Rotation (or manually)
        Two click reset the rotations values to 0.0
      • +
      • Yaw (Z )  : Rotate the copy to the axis Z (Yaw) (Begin 0 if Increm. is not checked)
      • +
      • Pitch ( Y ) : Rotate the copy to the axis Y (Pitch) (Begin 0 if Increm. is not checked)
      • +
      • Roll ( X )  : Rotate the copy to the axis X (Roll) (Begin 0 if Increm. is not checked)
      +
      • Scale predefined
      • +
      • Scale predefined : predefined scales in units, km, hm, dam, m, dm, cm, mm, µm, nm, inch, link, foot, yard, perch, chain, furlong, mile, league, nautique or choose a free value in the Scale free field.
      +
      • Number copy
      • +
      • Number copy : number of copies
      +
      • Scale free
      • +
      • ... : This button align the Scales values on the value of Scale X to have the same values ​​XYZ (or manually)
        Two click reset the scales values to 1.0
      • +
      • Scale X : free scale , if the value is negative ( -10) , the object is scaled x 10 and will be reversed in the X axis, to reduce the shape give a decimal value (0,5)
      • +
      • Scale Y : free scale , if the value is negative ( -10) , the object is scaled x 10 and will be reversed in the Y axis, to reduce the shape give a decimal value (0,5)
      • +
      • Scale Z : free scale , if the value is negative ( -10) , the object is scaled x 10 and will be reversed in the Z axis, to reduce the shape give a decimal value (0,5)
      +
      • ValueAt() : Give the valueAt() the subObject selected Face, Wire, Line ...
        This option is useful in case a compound Placement information [0,0,0] and its real location is away from the base coordinates 0,0,0 (gives no provide information about the rotation of the object)
      • +
      • Ok : the OK button validates and launches the command, if no object is selected the Ok button will be coloured in red
      • +
      • Reset : the Reset button puts all the values to zero
      • +
      • Quit : the Quit button exit the macro
      +
      +


      +

      +

      Script

      +

      The icon Macro CloneConvert.png +

      Macro_CloneConvert.FCMacro +

      Download the macro to Gist Macro_CloneConvert.FCMacro +

      +

      Revision

      +

      30/03/2018 ver 0.11 = odd checkBox, if multi selection the clone are object unique or object separate +

      07/06/2017 ver 0.10 = replace Draft...Copy to Part..Shape cause section Copy : not draw copy scaled of object but copy not scaled ?? +

      14/06/2016 ver 0.9 = adding the choice of number of copies and labels optimization +

      31/01/2016 ver 0.8 = modify the buttons reset section for two click for reset (in case modification the value) +

      30/01/2016 ver 0.7 = rewriting code with Placement and Increment and adding buttons Compound, Increment, ValueAt(), +

      26/01/2016 ver 0.6 = correction placement with many objets Copy +

      26/07/2015 ver 0.5 = correction rotate many objects Function Copy +

      25/07/2015 ver 0.4 = adding rotation +

      11/08/2014 replace "AttributeError" to "Exception" +

      02/07/2014 ver. 0.3 = modified to operate PyQt4 and PySide +

      09/05/2014 ver. 0.2 = adding function "Copy" +

      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Macro_CloneConvert.png b/localwiki/Macro_CloneConvert.png new file mode 100644 index 0000000..75951f6 Binary files /dev/null and b/localwiki/Macro_CloneConvert.png differ diff --git a/localwiki/Macro_Compound_Plus.html b/localwiki/Macro_Compound_Plus.html new file mode 100644 index 0000000..440f450 --- /dev/null +++ b/localwiki/Macro_Compound_Plus.html @@ -0,0 +1,824 @@ +Macro Compound Plus

      Macro Compound Plus

      + +
      + + + + + + + + + + + + + + + + + + + + + + + + + + +
      +

      Macro Compound Plus.png Macro Compound Plus

      +
      Description +
      Draf command set in a small macro. +
      Author +
      Mario52 +
      Links +
      Macros recipes
      How to install macros
      How to customize toolbars +
      Version +
      00.02 +
      Date last modification +
      2018-01-24 +
      +

      + +
      +


      +

      +

      Description

      +

      Draf command set in a small macro for the 2D sketch example: work with the DXF files +

      +

      Use

      +

      Macro_Compound_Plus_00 +

      +
      • Compound I Type I [1 + 1 = 1] : Create one compound unique of all objects selected without history.
      • +
      • Compound II Type II [1 + 1 = A (1 + 1)] : Create one compound of all objects selected with history of all objects. Same "Menu > Part > Make compound".
      • +
      • Option lines: +
        • Line colour : Gives a colour to object.
        • +
        • Width line : Gives a thickness to line(s).
      • +
      • Convert (A) = convert the text Draft Text.png in a shape string Draft ShapeString.png (The thickness of the text converted is respected but the visual result may not be respected, see the Combo view property for confirm)
      • +
      • 8.00  : Gives a thickness of the character and font Family.
      • +
      • Convert Edge : This command convert the wire in one line with coordinates. (ex: one compound downgraded does not have coordinates, this function create a line with coordinates)
      • +
      • For Compound I and Convert Edge
      +

      This section work only with the menus Compound I, Convert (A) and Convert Edge +

      +
      • None : Everything originals objects remains as it is.
      • +
      • Hidden original line(s) : Hidden the originals lines.
      • +
      • Delete original line(s) : Delete the originals lines.
      • +
      • Reset : Reset the macro
      • +
      • DownGrade : Downgrade the objects, same Draft Downgrade.png.
      • +
      • Quit : Quit the macro, bye
      +

      Script

      +

      The icon for you toolBar Macro Compound Plus.png copy in same directory to the macro +

      How to Customize Toolbars, How to install macros +

      The script to github Macro_Compound_Plus.FCMacro +

      Macro_Compound_Plus.FCMacro
      +

      +
      # -*- coding: utf-8 -*-
      +from __future__ import unicode_literals
      +"""
      +***************************************************************************
      +*   Copyright (c) 2016 2017 2018 <mario52>                                *
      +*                                                                         *
      +*   This file is a supplement to the FreeCAD CAx development system.      *
      +*                                                                         *
      +*   This program is free software; you can redistribute it and/or modify  *
      +*   it under the terms of the GNU Lesser General Public License (LGPL)    *
      +*   as published by the Free Software Foundation; either version 2 of     *
      +*   the License, or (at your option) any later version.                   *
      +*   for detail see the LICENCE text file.                                 *
      +*                                                                         *
      +*   This software is distributed in the hope that it will be useful,      *
      +*   but WITHOUT ANY WARRANTY; without even the implied warranty of        *
      +*   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the         *
      +*   GNU Library General Public License for more details.                  *
      +*                                                                         *
      +*   You should have received a copy of the GNU Library General Public     *
      +*   License along with this macro; if not, write to the Free Software     *
      +*   Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  *
      +*   USA                                                                   *
      +***************************************************************************
      +*           WARNING! All changes in this file will be lost and            *  
      +*                  may cause malfunction of the program                   *
      +***************************************************************************
      +"""
      +#Macro_Compound_Plus 05/08/2016 /_00 24/01/2018
      +#
      +#OS: Windows 10
      +#Word size of OS: 64-bit
      +#Word size of FreeCAD: 64-bit
      +#Version: 0.16.6706 (Git)
      +#Build type: Release
      +#Branch: releases/FreeCAD-0-16
      +#Hash: f86a4e411ff7848dea98d7242f43b7774bee8fa0
      +#Python version: 2.7.8
      +#Qt version: 4.8.7
      +#Coin version: 4.0.0a
      +#OCC version: 6.8.0.oce-0.17
      +#
      +__title__   = "Macro_Compound_Plus"
      +__author__  = "Mario52"
      +__url__     = "http://www.freecadweb.org/index-fr.html"
      +__version__ = "00.02"
      +__date__    = "24/01/2018"
      +
      +import PySide
      +from PySide import QtGui ,QtCore
      +from PySide.QtGui import *
      +from PySide.QtCore import *
      + 
      +import Draft, Part, FreeCAD, math, PartGui, FreeCADGui, FreeCAD
      +from math import sqrt, pi, sin, cos, asin
      +from FreeCAD import Base
      +
      +App = FreeCAD
      +doc = App.activeDocument()
      +
      +try:
      +    _fromUtf8 = QtCore.QString.fromUtf8
      +except AttributeError:
      +    def _fromUtf8(s):
      +        return s
      +
      +try:
      +    _encoding = QtGui.QApplication.UnicodeUTF8
      +    def _translate(context, text, disambig):
      +        return QtGui.QApplication.translate(context, text, disambig, _encoding)
      +except AttributeError:
      +    def _translate(context, text, disambig):
      +        return QtGui.QApplication.translate(context, text, disambig)
      +
      +def errorDialog(msg):
      +    diag = QtGui.QMessageBox(QtGui.QMessageBox.Critical,u"Error Message",msg )
      +    diag.setWindowFlags(PySide.QtCore.Qt.WindowStaysOnTopHint) # PySide #cette fonction met la fenetre en avant
      +#    diag.setWindowModality(QtCore.Qt.ApplicationModal)       # la fonction a ete desactivee pour favoriser "WindowStaysOnTopHint"
      +    diag.exec_()
      +
      +import os, sys, platform
      +global PolicePath
      +global nomPolice
      +
      +####### detect platform meme dans reset ################### 
      +if platform.system() == "Windows" :
      +    PolicePath = "C:/Windows/Fonts/ARIAL.TTF"
      +elif platform.system() == "Linux" :
      +    PolicePath = "/usr/share/fonts/truetype/ubuntu-font-family/Ubuntu-M.ttf"
      +elif platform.system() == "Darwin":
      +    PolicePath = "/Library/Fonts/Arial.ttf"
      +else:
      +    PolicePath = "C:/Windows/Fonts/ARIAL.TTF"
      +
      +nomPolice = os.path.basename(PolicePath).split('.')[0]
      +
      +class Ui_Compound(object):
      +
      +    def __init__(self):
      +        #self.path          = "Your Path"
      +        #self.path          = FreeCAD.ConfigGet("AppHomePath")
      +        self.path          = FreeCAD.ConfigGet("UserAppData")
      +        self.nameL         = []
      +        self.comP          = []
      +        del        self.nameL[:]
      +        del         self.comP[:]
      +        self.red           = 255.0
      +        self.green         = 0.0
      +        self.blue          = 0.0
      +
      +        self.lineWidth     = 2.0
      +        self.font          = ""
      +        self.TextLabel     = ""
      +        self.TextLabelText = ""
      +        self.TextPosition  = ""
      +        self.TextFontSize  = 8.0
      +        self.TextTextColor = ""
      +        self.FontSize      = 8.0
      +        self.fonte         = ""
      +        self.fontGlobal_08 = ""                       # pour compatibilite Windows Linux pour tous les textes
      +        self.manuel        = False
      +
      +        global PolicePath
      +        global nomPolice
      +#        self.pathFont      = QtGui.QDesktopServices.storageLocation(QtGui.QDesktopServices.FontsLocation) # path font search
      +#        self.fonteComp     = self.pathFont + "/" + self.nomPolice + ".TTF"
      +#        self.fonteComp     = self.fonteComp.replace("\\","/")
      +
      +    def setupUi(self, MainWindow):
      +        global PolicePath
      +        global nomPolice
      +
      +        self.window = MainWindow
      +
      +        Compound.setObjectName(_fromUtf8("Compound"))
      +        Compound.resize(250, 440)
      +        MainWindow.setMinimumSize(QtCore.QSize(250, 440))
      +        MainWindow.setMaximumSize(QtCore.QSize(250, 440))
      +
      +        self.centralwidget = QtGui.QWidget(Compound)
      +        self.centralwidget.setObjectName(_fromUtf8("centralwidget"))
      +
      +        self.fontGlobal_08 = QtGui.QFont()            # pour compatibilite Windows Linux pour tous les textes
      +        self.fontGlobal_08.setFamily("Arial")         # pour compatibilite Windows Linux pour tous les textes
      +        self.fontGlobal_08.setPointSize(8.0)          # pour compatibilite Windows Linux pour tous les textes
      +
      +        self.PB_01_Compound_01 = QtGui.QPushButton(self.centralwidget)
      +        self.PB_01_Compound_01.setGeometry(QtCore.QRect(10, 40, 75, 23))
      +        self.PB_01_Compound_01.setFont(self.fontGlobal_08)
      +        self.PB_01_Compound_01.setToolTip("Make a compound Block unique")
      +        self.PB_01_Compound_01.setObjectName(_fromUtf8("PB_01_Compound_01"))
      +        self.PB_01_Compound_01.clicked.connect(self.on_PB_01_Compound_01)                    # 
      +
      +        self.PB_02_Compound_02 = QtGui.QPushButton(self.centralwidget)
      +        self.PB_02_Compound_02.setGeometry(QtCore.QRect(10, 70, 75, 23))
      +        self.PB_02_Compound_02.setFont(self.fontGlobal_08)
      +        self.PB_02_Compound_02.setToolTip("Make a compound same Part, Menu > Part > Make compound")
      +        self.PB_02_Compound_02.setObjectName(_fromUtf8("PB_02_Compound_02"))
      +        self.PB_02_Compound_02.clicked.connect(self.on_PB_02_Compound_02)                    # 
      +
      +        self.groupBox_00 = QtGui.QGroupBox(self.centralwidget)
      +        self.groupBox_00.setGeometry(QtCore.QRect(10, 100, 231, 91))
      +        self.groupBox_00.setAlignment(Qt.AlignLeft)                    # AlignLeft     AlignCenter      AlignRight
      +        self.groupBox_00.setFont(self.fontGlobal_08)
      +        self.groupBox_00.setToolTip("If this box is unchecked the colors attributes and width line\n"
      +                                    "of the original line(s) are not modified\n"
      +                                    "This chekBox work only with Compound II\n"
      +                                    "Same attributes Part, Menu > Part > Make compound")
      +        self.groupBox_00.setCheckable(True)
      +        self.groupBox_00.setObjectName(_fromUtf8("groupBox_00"))
      +
      +        self.PB_03_Color = QtGui.QPushButton(self.groupBox_00)
      +        self.PB_03_Color.setGeometry(QtCore.QRect(10, 30, 75, 23))
      +        self.PB_03_Color.setFont(self.fontGlobal_08)
      +        self.PB_03_Color.setToolTip("Change the color of object(s) selected(s) value by defaut rvb 255,0,0")
      +        self.PB_03_Color.setObjectName(_fromUtf8("PB_03_Color"))
      +        self.PB_03_Color.clicked.connect(self.on_PB_03_Color)                                # 
      +        self.PB_03_Color.setStyleSheet("background-color: rgb("+str(self.red)+","+str(self.green)+","+str(self.blue)+"); color: cmj("+str(255)+","+str(255)+","+str(255)+")")
      +
      +        self.DS_01_Width = QtGui.QDoubleSpinBox(self.groupBox_00)
      +        self.DS_01_Width.setGeometry(QtCore.QRect(10, 60, 73, 22))
      +        self.DS_01_Width.setFont(self.fontGlobal_08)
      +        self.DS_01_Width.setToolTip("Give a new width for the line(s) selected(s)")
      +        self.DS_01_Width.setObjectName(_fromUtf8("DS_01_Width"))
      +        self.DS_01_Width.setValue(self.lineWidth)
      +        self.DS_01_Width.valueChanged.connect(self.on_DS_01_Width_valueChanged)             # 
      +
      +        self.PB_04_Convert = QtGui.QPushButton(self.centralwidget)
      +        self.PB_04_Convert.setGeometry(QtCore.QRect(10, 200, 75, 23))
      +        self.PB_04_Convert.setFont(self.fontGlobal_08)
      +        self.PB_04_Convert.setToolTip("Convert the selected text in ShapeString\n"
      +                                      "By default Convert (A)utomatic use the font preselected and the size of original text\n"
      +                                      "If the values or font is modified the button change of Convert (M)anual\n"
      +                                      "The label of the texte are modified to SString_original text (max 30 characters)")
      +        self.PB_04_Convert.setObjectName(_fromUtf8("PB_04_Convert"))
      +        self.PB_04_Convert.clicked.connect(self.on_PB_04_Convert)                            # ""
      +
      +        if platform.system() == "Windows" :
      +            self.fontComboBox = QtGui.QFontComboBox(self.centralwidget)
      +            self.fontComboBox.setGeometry(QtCore.QRect(100, 225, 141, 35))
      +            font = QtGui.QFont()
      +            font.setFamily(nomPolice)
      +            font.setPointSize(self.FontSize)
      +
      +#            self.fontComboBox.setFont(self.fontGlobal_08)
      +            self.fontComboBox.setCurrentFont(font)
      +            self.fontComboBox.setToolTip("New font.\nActual : "+nomPolice)
      +            self.fontComboBox.setObjectName(_fromUtf8("fontComboBox"))
      +            self.fontComboBox.currentFontChanged.connect(self.on_PB_Fonte_Win01)                   # 
      +
      +            self.DS_02_Width_Font = QtGui.QDoubleSpinBox(self.centralwidget)
      +            self.DS_02_Width_Font.setGeometry(QtCore.QRect(10, 230, 73, 22))
      +            self.DS_02_Width_Font.setFont(self.fontGlobal_08)
      +            self.DS_02_Width_Font.setToolTip("Give a new width for the font")
      +            self.DS_02_Width_Font.setObjectName(_fromUtf8("DS_02_Width_Font"))
      +            self.DS_02_Width_Font.setValue(self.FontSize)
      +            self.DS_02_Width_Font.valueChanged.connect(self.on_DS_02_Width_Font_valueChanged)             # 
      +
      +        else:                    # Linux +
      +            import os.path
      +            nomPolice = os.path.basename(PolicePath).split('.')[0]
      +            self.PB_Fonte_Linux = QtGui.QPushButton(self.centralwidget)
      +            self.PB_Fonte_Linux.setGeometry(QtCore.QRect(100, 225, 141, 35))
      +            font = QtGui.QFont()
      +            font.setFamily(nomPolice)
      +
      +            font.setPointSize(self.FontSize)
      +            self.PB_Fonte_Linux.setFont(font)
      +            self.PB_Fonte_Linux.setToolTip(_fromUtf8("New font.\nActual : "+nomPolice))
      +            self.PB_Fonte_Linux.setAccessibleDescription(_fromUtf8(""))
      +            self.PB_Fonte_Linux.setText(_fromUtf8(nomPolice))
      +            self.PB_Fonte_Linux.setObjectName(_fromUtf8("PB_Fonte_Linux"))
      +            self.PB_Fonte_Linux.clicked.connect(self.on_PB_Fonte_Linux)
      +
      +            self.DS_02_Width_Font = QtGui.QDoubleSpinBox(self.centralwidget)
      +            self.DS_02_Width_Font.setGeometry(QtCore.QRect(10, 230, 75, 23))
      +            self.DS_02_Width_Font.setFont(self.fontGlobal_08)
      +            self.DS_02_Width_Font.setToolTip("Give a new width for the font")
      +            self.DS_02_Width_Font.setObjectName(_fromUtf8("DS_02_Width_Font"))
      +            self.DS_02_Width_Font.setValue(self.FontSize)
      +            self.DS_02_Width_Font.valueChanged.connect(self.on_DS_02_Width_Font_valueChanged)             # 
      +
      +        self.PB_04c_Convert_Edge = QtGui.QPushButton(self.centralwidget)
      +        self.PB_04c_Convert_Edge.setGeometry(QtCore.QRect(10, 260, 75, 23))
      +        self.PB_04c_Convert_Edge.setFont(self.fontGlobal_08)
      +        self.PB_04c_Convert_Edge.setToolTip("Convert the edge to line with coordinates\n"
      +                                            "Select the edge(s) in the 3D view")
      +        self.PB_04c_Convert_Edge.setObjectName(_fromUtf8("PB_04c_Convert_Edge"))
      +        self.PB_04c_Convert_Edge.clicked.connect(self.on_PB_04c_Convert_Edge)                 # ""
      +
      +        self.PB_05_Reset = QtGui.QPushButton(self.centralwidget)
      +        self.PB_05_Reset.setGeometry(QtCore.QRect(10, 410, 75, 23))
      +        self.PB_05_Reset.setFont(self.fontGlobal_08)
      +        self.PB_05_Reset.setToolTip("Reset the values")
      +        self.PB_05_Reset.setObjectName(_fromUtf8("PB_05_Reset"))
      +        self.PB_05_Reset.clicked.connect(self.on_PB_05_Reset)                               # 
      +
      +        self.PB_06_Downgrade = QtGui.QPushButton(self.centralwidget)
      +        self.PB_06_Downgrade.setGeometry(QtCore.QRect(90, 410, 75, 23))
      +        self.PB_06_Downgrade.setFont(self.fontGlobal_08)
      +        self.PB_06_Downgrade.setToolTip("Downgrade the selected object Same Draft > Downgrade")
      +        self.PB_06_Downgrade.setObjectName(_fromUtf8("PB_06_Downgrade"))
      +        self.PB_06_Downgrade.clicked.connect(self.on_PB_06_Downgrade)                       # 
      +
      +        self.PB_07_Quit = QtGui.QPushButton(self.centralwidget)
      +        self.PB_07_Quit.setGeometry(QtCore.QRect(170, 410, 75, 23))
      +        self.PB_07_Quit.setFont(self.fontGlobal_08)
      +        self.PB_07_Quit.setToolTip("Quit Compound +")
      +        self.PB_07_Quit.setObjectName(_fromUtf8("PB_06_Quit"))
      +        self.PB_07_Quit.clicked.connect(self.on_PB_07_Quit)                                 # 
      +
      +        self.label_01_Titre = QtGui.QLabel(self.centralwidget)
      +        self.label_01_Titre.setGeometry(QtCore.QRect(10, 10, 231, 16))
      +        fontTitle = QtGui.QFont()
      +        fontTitle.setPointSize(12)
      +        self.label_01_Titre.setFont(fontTitle)
      +        self.label_01_Titre.setObjectName(_fromUtf8("label_01_Titre"))
      +
      +        self.label_02_Type_1 = QtGui.QLabel(self.centralwidget)
      +        self.label_02_Type_1.setGeometry(QtCore.QRect(100, 40, 111, 16))
      +        self.label_02_Type_1.setFont(self.fontGlobal_08)
      +        self.label_02_Type_1.setObjectName(_fromUtf8("label_02_Type_1"))
      +
      +        self.label_03_Type_2 = QtGui.QLabel(self.centralwidget)
      +        self.label_03_Type_2.setGeometry(QtCore.QRect(100, 70, 141, 16))
      +        self.label_03_Type_2.setFont(self.fontGlobal_08)
      +        self.label_03_Type_2.setObjectName(_fromUtf8("label_03_Type_2"))
      +
      +        self.label_04_Color = QtGui.QLabel(self.groupBox_00)
      +        self.label_04_Color.setGeometry(QtCore.QRect(100, 30, 121, 16))
      +        self.label_04_Color.setFont(self.fontGlobal_08)
      +        self.label_04_Color.setObjectName(_fromUtf8("label_04_Color"))
      +
      +        self.label_05_DSBox = QtGui.QLabel(self.groupBox_00)
      +        self.label_05_DSBox.setGeometry(QtCore.QRect(100, 60, 121, 16))
      +        self.label_05_DSBox.setFont(self.fontGlobal_08)
      +        self.label_05_DSBox.setObjectName(_fromUtf8("label_05_DSBox"))
      +
      +        self.label_06_Convert = QtGui.QLabel(self.centralwidget)
      +        self.label_06_Convert.setGeometry(QtCore.QRect(100, 200, 141, 16))
      +        self.label_06_Convert.setFont(self.fontGlobal_08)
      +        self.label_06_Convert.setObjectName(_fromUtf8("label_06_Convert"))
      +
      +        self.label_08_Convert_Line = QtGui.QLabel(self.centralwidget)
      +        self.label_08_Convert_Line.setGeometry(QtCore.QRect(100, 260, 141, 16))
      +        self.label_08_Convert_Line.setFont(self.fontGlobal_08)
      +        self.label_08_Convert_Line.setObjectName(_fromUtf8("label_08_Convert_Line"))
      +
      +        self.groupBox_01 = QtGui.QGroupBox(self.centralwidget)
      +        self.groupBox_01.setGeometry(QtCore.QRect(10, 290, 231, 81))
      +        self.groupBox_01.setFont(self.fontGlobal_08)
      +        self.groupBox_01.setObjectName(_fromUtf8("groupBox_01"))
      +
      +        self.RB_01_Default = QtGui.QRadioButton(self.groupBox_01)
      +        self.RB_01_Default.setGeometry(QtCore.QRect(10, 20, 141, 17))
      +        self.RB_01_Default.setFont(self.fontGlobal_08)
      +        self.RB_01_Default.setToolTip("The line stay tel quel\n"
      +                                      "For Compound I and Convert text to String")
      +        self.RB_01_Default.setChecked(True)
      +        self.RB_01_Default.setObjectName(_fromUtf8("RB_01_Default"))
      +
      +        self.RB_02_Hidden = QtGui.QRadioButton(self.groupBox_01)
      +        self.RB_02_Hidden.setGeometry(QtCore.QRect(10, 40, 141, 17))
      +        self.RB_02_Hidden.setFont(self.fontGlobal_08)
      +        self.RB_02_Hidden.setToolTip("The original line are hidden after transform\n"
      +                                      "For Compound I and Convert text to String")
      +        self.RB_02_Hidden.setObjectName(_fromUtf8("RB_02_Hidden"))
      +
      +        self.RB_03_Delete = QtGui.QRadioButton(self.groupBox_01)
      +        self.RB_03_Delete.setGeometry(QtCore.QRect(10, 60, 141, 17))
      +        self.RB_03_Delete.setFont(self.fontGlobal_08)
      +        self.RB_03_Delete.setToolTip("The original line are deleted after transform\n"
      +                                      "For Compound I and Convert text to String")
      +#        self.RB_03_Delete.setChecked(True)
      +        self.RB_03_Delete.setObjectName(_fromUtf8("RB_03_Delete"))
      +
      +        self.progressBar = QtGui.QProgressBar(self.centralwidget)
      +        self.progressBar.setGeometry(QtCore.QRect(10, 380, 231, 20))
      +        self.progressBar.setFont(self.fontGlobal_08)
      +        self.progressBar.setValue(0)
      +        self.progressBar.setAlignment(QtCore.Qt.AlignCenter)
      +        self.progressBar.setObjectName(_fromUtf8("progressBar"))
      +
      +        Compound.setCentralWidget(self.centralwidget)
      +
      +        self.retranslateUi(Compound)
      +        QtCore.QMetaObject.connectSlotsByName(Compound)
      +
      +    def retranslateUi(self, Compound):
      +        Compound.setWindowFlags(PySide.QtCore.Qt.WindowStaysOnTopHint)                     # PySide cette fonction met la fenetre en avant
      +        Compound.setWindowIcon(QtGui.QIcon(self.path + 'Macro_Compound_Plus.png'))         # change l'icone de la fenetre principale
      +        Compound.setWindowTitle("Compound +")
      +        self.PB_01_Compound_01.setText("Compound I")
      +        self.PB_02_Compound_02.setText("Compound II")
      +        self.groupBox_00.setTitle("Options lines")
      +        self.PB_03_Color.setText("Color")
      +        self.PB_04_Convert.setText("Convert (A)")
      +        self.PB_04c_Convert_Edge.setText("Convert Edge")
      +
      +        self.label_01_Titre.setText("Compound +")
      +        self.label_02_Type_1.setText("Type I [ 1 + 1 = 1 ]")
      +        self.label_03_Type_2.setText("Type II [ 1 + 1 = A (1 + 1) ]")
      +        self.label_04_Color.setText("Line color")
      +        self.label_05_DSBox.setText("Width line")
      +        self.label_06_Convert.setText("Convert Text to String")
      +        self.label_08_Convert_Line.setText("Convert Edge to Line")
      +
      +        self.groupBox_01.setTitle("For Compound I and Convert")
      +        self.RB_01_Default.setText("None")
      +        self.RB_02_Hidden.setText("Hidden original line(s) ")
      +        self.RB_03_Delete.setText("Delete original line(s)")
      +        self.PB_05_Reset.setText("Reset")
      +        self.PB_06_Downgrade.setText("DownGrade")
      +        self.PB_07_Quit.setText("Quit")
      +
      +    def on_PB_01_Compound_01(self):
      +        self.selectionObjects = FreeCADGui.Selection.getSelection()
      +        if len(self.selectionObjects) > 0:
      +            try:
      +                self.nameL         = []
      +                self.comP          = []
      +                del        self.nameL[:]
      +                del         self.comP[:]
      +
      +                self.progressBar.setMaximum(len(self.selectionObjects))
      +                compteur = 0
      +                for i in self.selectionObjects:
      +                    self.nameL.append(i.Name)
      +                    self.comP.append(i.Shape)
      +                    compteur += 1
      +                    self.progressBar.setValue(compteur)
      +                    Gui.updateGui()
      +                    print "Object : ",i.Name
      +
      +                comp = Part.makeCompound(self.comP)
      +                Part.show(comp)
      +
      +                if self.groupBox_00.isChecked:
      +                    FreeCADGui.ActiveDocument.ActiveObject.LineWidth  = self.lineWidth
      +                    FreeCADGui.ActiveDocument.ActiveObject.LineColor  = (float(self.red)/255, float(self.green)/255, float(self.blue)/255)
      +                    FreeCADGui.ActiveDocument.ActiveObject.ShapeColor = (float(self.red)/255, float(self.green)/255, float(self.blue)/255)
      +                    FreeCADGui.ActiveDocument.ActiveObject.PointColor = (float(self.red)/255, float(self.green)/255, float(self.blue)/255)
      +
      +                App.ActiveDocument.ActiveObject.Label = "reproShape_TI"
      +        
      +                if self.RB_01_Default.isChecked():
      +                    None
      +                if self.RB_02_Hidden.isChecked():
      +                    for i in range(len(self.nameL)):
      +                        print "Hidden : ",self.nameL[i]
      +                        FreeCADGui.ActiveDocument.getObject(self.nameL[i]).Visibility = False
      +                if self.RB_03_Delete.isChecked():
      +                    for i in range(len(self.nameL)):
      +                        print "Delete : ",self.nameL[i]
      +                        doc.removeObject(self.nameL[i])
      +                self.progressBar.setValue(0)
      +            except Exception:
      +                FreeCAD.Console.PrintError("Error objects "+"\n")
      +        else:
      +            FreeCAD.Console.PrintError("Not objects selected "+"\n")
      +#        FreeCAD.Console.PrintMessage(str("on_PB_01_Compound_01 ")+"\n")
      +
      +    def on_PB_02_Compound_02(self):
      +        self.selectionObjects = FreeCADGui.Selection.getSelection()
      +        if len(self.selectionObjects) > 0:
      +            try:
      +                self.nameL         = []
      +                self.comP          = []
      +                del        self.nameL[:]
      +                del         self.comP[:]
      +                
      +                App.activeDocument().addObject("Part::Compound","Compound")
      +                
      +                self.progressBar.setMaximum(len(self.selectionObjects))
      +                compteur = 0
      +                for i in self.selectionObjects:
      +                    self.nameL.append(App.ActiveDocument.getObject(i.Name))
      +                    compteur += 1
      +                    self.progressBar.setValue(compteur)
      +                    Gui.updateGui()
      +                    print i.Name
      +                self.progressBar.setValue(0)
      +                App.activeDocument().Compound.Links = self.nameL
      +                App.activeDocument().recompute()
      +
      +                if self.groupBox_00.isChecked:
      +                    FreeCADGui.ActiveDocument.ActiveObject.LineWidth  = self.lineWidth
      +                    FreeCADGui.ActiveDocument.ActiveObject.LineColor  = (float(self.red)/255, float(self.green)/255, float(self.blue)/255)
      +                    FreeCADGui.ActiveDocument.ActiveObject.ShapeColor = (float(self.red)/255, float(self.green)/255, float(self.blue)/255)
      +                    FreeCADGui.ActiveDocument.ActiveObject.PointColor = (float(self.red)/255, float(self.green)/255, float(self.blue)/255)
      +
      +                App.ActiveDocument.ActiveObject.Label = "reproShape_TII"
      +        
      +            except Exception:
      +                FreeCAD.Console.PrintError("Error objects "+"\n")
      +        else:
      +            FreeCAD.Console.PrintError("Not objects selected "+"\n")
      +#        FreeCAD.Console.PrintMessage(str("on_PB_02_Compound_02 ")+"\n")
      +
      +    def on_PB_03_Color(self):
      +        self.PB_03_Color.setStyleSheet("background-color: QPalette.Base")        # origin system
      +        self.window.hide()                                                       # hide the window open color
      +        couleur = QtGui.QColorDialog.getColor()
      +        
      +        if couleur.isValid():
      +            self.red   = int(str(couleur.name()[1:3]),16)
      +            self.green = int(str(couleur.name()[3:5]),16)
      +            self.blue  = int(str(couleur.name()[5:7]),16)
      +
      +        self.PB_03_Color.setStyleSheet("background-color: rgb("+str(self.red)+","+str(self.green)+","+str(self.blue)+"); color: cmj("+str(255)+","+str(255)+","+str(255)+")")
      +
      +        self.window.show()                                                        # show the window and close color
      +#        FreeCAD.Console.PrintMessage(str("PB_03_Color ")+"\n")
      +
      +    def on_PB_04_Convert(self):
      +        global PolicePath
      +        global nomPolice
      +
      +        self.selectionObjects = FreeCADGui.Selection.getSelection()
      +
      +        self.progressBar.setMaximum(len(self.selectionObjects))
      +        compteur = 0
      +        if len(self.selectionObjects) > 0:
      +            objA = self.selectionObjects[0]
      +            for objA in self.selectionObjects:
      +                try:
      +                    self.TextLabel     = objA.Label
      +                    self.TextLabelText = objA.LabelText[0]
      +                    self.TextPosition  = objA.Position
      +                    self.TextFontSize  = objA.ViewObject.FontSize 
      +
      +                    if self.manuel:
      +                        self.TextFontSize = self.FontSize
      +
      +                    self.TextTextColor = objA.ViewObject.TextColor
      +                    texte = unicode(self.TextLabelText)
      +
      +                    ss=Draft.makeShapeString(String = texte, FontFile=PolicePath, Size=float(self.TextFontSize), Tracking=0)
      +
      +                    plm=FreeCAD.Placement()
      +                    plm.Base=self.TextPosition
      +                    plm.Rotation.Q=(0.0,-0.0,-0.0,1.0)
      +                    ss.Placement=plm
      +                    ss.Support=None
      +                    ss.Label = "SString_"+texte[:30]
      +                    FreeCADGui.ActiveDocument.getObject(ss.Name).ShapeColor = (float(self.red)/255, float(self.green)/255, float(self.blue)/255)
      +                    FreeCADGui.ActiveDocument.getObject(ss.Name).LineColor  = (float(self.red)/255, float(self.green)/255, float(self.blue)/255)
      +                    FreeCADGui.ActiveDocument.getObject(ss.Name).PointColor = (float(self.red)/255, float(self.green)/255, float(self.blue)/255)
      +                    compteur += 1
      +                    self.progressBar.setValue(compteur)
      +
      +                    if self.RB_01_Default.isChecked():
      +                        None
      +                    if self.RB_02_Hidden.isChecked():
      +                        print "Hidden : ",objA.Name
      +                        FreeCADGui.ActiveDocument.getObject(objA.Name).Visibility = False
      +                    if self.RB_03_Delete.isChecked():
      +                        print "Delete : ",objA.Name
      +                        doc.removeObject(objA.Name)
      +
      +                    Gui.updateGui()
      +                except Exception:
      +                    FreeCAD.Console.PrintError("Not object TEXT or error" + "\n")
      +
      +            self.progressBar.setValue(0)
      +            FreeCAD.ActiveDocument.recompute()
      +        else:
      +            FreeCAD.Console.PrintError("Select one or more objects TEXT" + "\n")
      +#        FreeCAD.Console.PrintMessage(str("on_PB_04_Convert ")+"\n")
      +
      +    def on_PB_Fonte_Win01(self):         # New Font Windows (menu deroulant) fonctionne ok
      +        global PolicePath
      +        global nomPolice
      +
      +        Compound.hide()
      +        fonte     = self.fontComboBox.currentFont()
      +        nomPolice = fonte.rawName()
      +        self.fontComboBox.setToolTip("New font.\nActual : "+nomPolice)
      +        pathFont  = QtGui.QDesktopServices.storageLocation(QtGui.QDesktopServices.FontsLocation) # path font search bon pour Windows
      +        fonteComp = pathFont + "/" + nomPolice + ".TTF"
      +        PolicePath = fonteComp.replace("\\","/")
      +
      +        font = QtGui.QFont()
      +        font.setFamily(nomPolice)
      +        font.setPointSize(self.FontSize)
      +        self.fontComboBox.setFont(font)
      +
      +        self.PB_04_Convert.setText("Convert (M)")
      +        self.manuel = True
      +        Compound.show()
      +#        App.Console.PrintMessage("New Font " + (PolicePath)+"\n")
      +
      +    def on_DS_02_Width_Font_valueChanged(self,value):
      +        self.FontSize = value
      +        self.PB_04_Convert.setText("Convert (M)")
      +        font = QtGui.QFont()
      +        font.setFamily(nomPolice)
      +        font.setPointSize(self.FontSize)
      +
      +        if platform.system() == "Windows" :
      +            self.fontComboBox.setFont(font)
      +        else:
      +            self.PB_Fonte_Linux.setFont(font)
      +            self.PB_Fonte_Linux.setText(_fromUtf8(nomPolice))
      +
      +        self.manuel = True
      +#        App.Console.PrintMessage("New FontSize " + str(self.FontSize)+"\n")
      +
      +    def on_PB_Fonte_Win02(self):         # New Font Windows (menu avec fenetres)
      +        global PolicePath
      +        global nomPolice
      +
      +        Compound.hide()
      +        font, ok = QtGui.QFontDialog.getFont(QFont(nomPolice, self.FontSize))
      +        if ok:
      +            
      +            fonte         = font
      +            nomPolice     = fonte.rawName()
      +            self.FontSize = fonte.pointSizeF()
      +
      +            pathFont   = QtGui.QDesktopServices.storageLocation(QtGui.QDesktopServices.FontsLocation) # path font search bon pour Windows
      +            fonteComp  = pathFont + "/" + nomPolice + ".TTF"
      +            PolicePath = fonteComp.replace("\\","/")
      +
      +            font = QtGui.QFont()
      +            font.setFamily(nomPolice)
      +            font.setPointSize(self.FontSize)
      +            self.label_07_Font.setFont(font)
      +
      +            self.label_07_Font.setText("Actual (" + str(self.FontSize) + ") " + nomPolice)
      +            self.label_07_Font.setToolTip("Actual (" + str(self.FontSize) + ") " + nomPolice)
      +
      +            self.PB_04_Convert.setText("Convert (M)")
      +            self.manuel = True
      +        Compound.show()
      +
      +    def on_PB_Fonte_Linux(self):         # New Font Linux
      +        global PolicePath
      +        global nomPolice
      +        Compound.hide()
      +        OpenName = ""
      +        OpenName, Filter = PySide.QtGui.QFileDialog.getOpenFileName(None, "New Font", PolicePath, "*.ttf") #PySide
      +        try:
      +            if OpenName != "":
      +                PolicePath = str(OpenName)
      +                import os.path
      +                nomPolice = os.path.basename(PolicePath).split('.')[0]
      +                font = QtGui.QFont()
      +                font.setFamily(nomPolice)
      +                font.setPointSize(self.FontSize)
      +                self.PB_Fonte_Linux.setText(nomPolice)
      +                self.PB_Fonte_Linux.setFont(font)
      +                self.PB_Fonte_Linux.setToolTip(_fromUtf8("New font.\nActual : "+nomPolice))
      +
      +        except Exception:
      +            None
      +        Compound.show()
      +
      +#        App.Console.PrintMessage("New Font " + (PolicePath)+"\n")
      +
      +    def on_PB_04c_Convert_Edge(self):                                          # Convert Edge to line
      +        import Draft
      +        points    = []
      +        points[:] = []
      +        selectionObjects = FreeCADGui.Selection.getSelectionEx()               # Select an object or sub object getSelectionEx
      +        for selection in selectionObjects:
      +            for selectedEdge in selection.SubObjects:
      +                if (str(selectedEdge.Curve)[1:5]) == "Line" :
      +                    numberCut = 1                                              # line
      +                else:
      +                    numberCut = 20                                             # not line cut in 20 parts
      +                points = selectedEdge.Edges[0].discretize(int(numberCut + 1))  # Dicretize
      +
      +                for lin in range(len(points)-1):
      +                    creaLine = [FreeCAD.Vector(points[lin]),FreeCAD.Vector(points[lin+1])]
      +                    wire =  Draft.makeLine(FreeCAD.Vector(creaLine[0]),FreeCAD.Vector(creaLine[1]))
      +                    if self.groupBox_00.isChecked:
      +                        FreeCADGui.ActiveDocument.ActiveObject.LineWidth  = self.lineWidth
      +                        FreeCADGui.ActiveDocument.ActiveObject.LineColor  = (float(self.red)/255, float(self.green)/255, float(self.blue)/255)
      +                        FreeCADGui.ActiveDocument.ActiveObject.ShapeColor = (float(self.red)/255, float(self.green)/255, float(self.blue)/255)
      +                        FreeCADGui.ActiveDocument.ActiveObject.PointColor = (float(self.red)/255, float(self.green)/255, float(self.blue)/255)
      +
      +            points[:]  = []
      +        FreeCAD.ActiveDocument.recompute()
      +#        FreeCAD.Console.PrintMessage(str("on_PB_04c_Convert_Edge")+"\n")
      +
      +    def on_DS_01_Width_valueChanged(self,LineWidth):
      +        self.lineWidth = LineWidth
      +#        FreeCAD.Console.PrintMessage(str("on_DS_01_Width_valueChanged ")+str(self.lineWidth)+"\n")
      +
      +    def on_PB_05_Reset(self):                     # 
      +        global PolicePath
      +        global nomPolice
      +        self.red       = 255.0
      +        self.green     = 0.0
      +        self.blue      = 0.0
      +        self.PB_03_Color.setStyleSheet("background-color: rgb("+str(self.red)+","+str(self.green)+","+str(self.blue)+"); color: cmj("+str(255)+","+str(255)+","+str(255)+")")
      +#        self.RB_01_Default.setChecked(True)
      +        self.RB_03_Delete.setChecked(True)
      +        self.lineWidth = 2.0
      +        self.DS_01_Width.setValue(self.lineWidth)
      +        self.FontSize  = 8.0
      +
      +        if platform.system() == "Windows" :
      +            PolicePath = "C:/Windows/Fonts/ARIAL.TTF"
      +
      +            nomPolice = os.path.basename(PolicePath).split('.')[0]
      +            self.DS_02_Width_Font.setValue(self.FontSize)
      +
      +            font = QtGui.QFont()
      +            font.setFamily(nomPolice)
      +            font.setPointSize(self.FontSize)
      +            self.fontComboBox.setCurrentFont(font)
      +
      +        else:
      +            if platform.system() == "Linux" :
      +                PolicePath = "/usr/share/fonts/truetype/ubuntu-font-family/Ubuntu-M.ttf"
      +            elif platform.system() == "Darwin":
      +                PolicePath = "/Library/Fonts/Arial.ttf"
      +            else:
      +                PolicePath = FreeCAD.ConfigGet("AppHomePath")
      +                self.PB_Fonte_Linux.setText("New Font")
      +
      +            nomPolice = os.path.basename(PolicePath).split('.')[0]
      +
      +            font = QtGui.QFont()
      +            font.setFamily(nomPolice)
      +            font.setPointSize(self.FontSize)
      +            self.PB_Fonte_Linux.setFont(font)
      +
      +            self.PB_Fonte_Linux.setText(nomPolice)
      +            self.PB_Fonte_Linux.setToolTip(_fromUtf8("New font.\nActual : "+nomPolice))
      +            self.DS_02_Width_Font.setValue(self.FontSize)
      +
      +        self.manuel    = False
      +        self.PB_04_Convert.setText("Convert (A)")
      +        self.fonte     = PolicePath + "/" + nomPolice + ".TTF"
      +#        FreeCAD.Console.PrintMessage(str("on_PB_05_Reset ")+"\n")
      +
      +    def on_PB_06_Downgrade(self):                     # 
      +        try:
      +            import Draft
      +            Draft.downgrade(FreeCADGui.Selection.getSelection(),delete=True)
      +            FreeCAD.ActiveDocument.recompute()
      +            print
      +        except Exception:
      +            None
      +#        FreeCAD.Console.PrintMessage(str("on_PB_06_Downgrade ")+"\n")
      +
      +    def on_PB_07_Quit(self):                     # 
      +        FreeCAD.Console.PrintMessage("End Compound +"+"\n")
      +        self.window.hide()
      +#        FreeCAD.Console.PrintMessage(str("on_PB_06_Quit ")+"\n")
      +
      +Compound = QtGui.QMainWindow()
      +ui = Ui_Compound()
      +ui.setupUi(Compound)
      +Compound.show() 
      +

      Links

      +

      My macros to Github +

      +

      Version

      +
      • 24/01/2018 ver 00.02 : sup "import PyQt4"
      • +
      • 21/11/2016 ver 00.01 :
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Macro_Compound_Plus.png b/localwiki/Macro_Compound_Plus.png new file mode 100644 index 0000000..68a14f0 Binary files /dev/null and b/localwiki/Macro_Compound_Plus.png differ diff --git a/localwiki/Macro_Compound_Plus_00.png b/localwiki/Macro_Compound_Plus_00.png new file mode 100644 index 0000000..0661999 Binary files /dev/null and b/localwiki/Macro_Compound_Plus_00.png differ diff --git a/localwiki/Macro_Connect_And_Sweep.html b/localwiki/Macro_Connect_And_Sweep.html new file mode 100644 index 0000000..655d498 --- /dev/null +++ b/localwiki/Macro_Connect_And_Sweep.html @@ -0,0 +1,188 @@ +Macro Connect And Sweep

      Macro Connect And Sweep

      + +
      + + + + + + + + + + + + + + + + + + + + + + + + + + +
      +

      Macro Connect And Sweep.png Macro Connect And Sweep

      +
      Description +
      This macro easily creates a connection between two objects. +
      Author +
      Mario52 +
      Links +
      Macros recipes
      How to install macros
      How to customize toolbars +
      Version +
      00.04 +
      Date last modification +
      2017-02-22 +
      +

      + +
      +


      +

      +

      Description

      +

      This macro easily creates a connection between two objects, an object and a point or between two points (the center of the objects are the starting and ending points of the sweep) can be selected form a configurable ellipse polygon circle +

      +
      Macro_Connect_And_Sweep
      +
      +

      Use

      +

      Run the macro select your objects or points choice the form and parameters and click Create. +

      +
      +
      Macro_Connect_And_Sweep
      +
      +

      Images

      +

      These files must be copied to your macros directory +

      (For download : Click Right button op the image and click "Save Image as ...") +

      Center Top left Top rigth Low left Low rigth +

      The icon for the toolbar Icon for the button +

      +

      Script

      +

      Macro_Connect_And_Sweep.FCMacro +

      Download the macro to Gits Macro_Connect_And_Sweep.FCMacro +

      +

      Example

      +

      Path and tubing with Macro_Connect_And_Sweep and Macro_Repro_Wire Macro ReproWire.png +

      +
      + +
      +
      + +
      +
      + +
      +
      + +
      +
      + +
      +
      + +
      +
      + +
      +


      +

      +

      Version

      +

      00.04 22/02/2017 : upgrade the search path +

      00.03 15/09/2016 : add create pipe +

      00.02 13/06/2016 : add options choice angle path rectangle and ellipse +

      00.01 07/06/2016 : add option solid or not centring rectangle or not +

      00.00 05/06/2016 : +

      +

      Links

      +

      The forum discussion Scripting point to point tubing +

      This macro is based to the microelly2 code see Looking for some helpful GUI-commands +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Macro_Connect_And_Sweep.png b/localwiki/Macro_Connect_And_Sweep.png new file mode 100644 index 0000000..69f18a8 Binary files /dev/null and b/localwiki/Macro_Connect_And_Sweep.png differ diff --git a/localwiki/Macro_Connect_And_Sweep_01.png b/localwiki/Macro_Connect_And_Sweep_01.png new file mode 100644 index 0000000..7c5d293 Binary files /dev/null and b/localwiki/Macro_Connect_And_Sweep_01.png differ diff --git a/localwiki/Macro_Connect_And_Sweep_CE.png b/localwiki/Macro_Connect_And_Sweep_CE.png new file mode 100644 index 0000000..416d3ce Binary files /dev/null and b/localwiki/Macro_Connect_And_Sweep_CE.png differ diff --git a/localwiki/Macro_Connect_And_Sweep_LL.png b/localwiki/Macro_Connect_And_Sweep_LL.png new file mode 100644 index 0000000..f3dc4f2 Binary files /dev/null and b/localwiki/Macro_Connect_And_Sweep_LL.png differ diff --git a/localwiki/Macro_Connect_And_Sweep_LR.png b/localwiki/Macro_Connect_And_Sweep_LR.png new file mode 100644 index 0000000..4de7bd8 Binary files /dev/null and b/localwiki/Macro_Connect_And_Sweep_LR.png differ diff --git a/localwiki/Macro_Connect_And_Sweep_TL.png b/localwiki/Macro_Connect_And_Sweep_TL.png new file mode 100644 index 0000000..27cdf5c Binary files /dev/null and b/localwiki/Macro_Connect_And_Sweep_TL.png differ diff --git a/localwiki/Macro_Connect_And_Sweep_TR.png b/localwiki/Macro_Connect_And_Sweep_TR.png new file mode 100644 index 0000000..03da29d Binary files /dev/null and b/localwiki/Macro_Connect_And_Sweep_TR.png differ diff --git a/localwiki/Macro_Constraint_Draft.html b/localwiki/Macro_Constraint_Draft.html new file mode 100644 index 0000000..4ce1d54 --- /dev/null +++ b/localwiki/Macro_Constraint_Draft.html @@ -0,0 +1,91 @@ +Macro Constraint Draft

      Macro Constraint Draft

      + +
      + + + + + + + + + + + + + + + + + + + + + + + + + + +
      +

      Text-x-python.png Constraint Draft

      +
      Description +
      Create simulation using the expressions for link all objects. +
      Author +
      Mario52 +
      Links +
      Macros recipes
      How to install macros
      How to customize toolbars +
      Version +
      1.0 +
      Date last modification +
      2017-04-19 +
      +

      + +
      +


      +

      +

      Description

      +

      Simple example animation Draft wires by use the expressions for associate many wires and simulate or verify the movement. Here the circle rotation create the movement for all objects connected +

      Animation use the constraint expression +

      +

      Uses

      +

      Download the file example Constraint_Draft00.FCStd, open it in FreeCAD +

      +

      Script

      +

      Select the Line005_with_Code object in the Combo View Select Data tab > Memo code > Code for rotation > ... +

      Select the complete code and paste in the Python Console +

      (If do not have the Python console: Menu > View > Panels > select Python console) +

      How copy the code snippet +

      How copy the animation code +

      +

      Rotation with FreeCAD tools

      +

      Rotation with FreeCAD tools +

      +

      Link

      +

      The forum discussion Sketch Feature to create linkage mechanism simulator +

      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Macro_Copy3DViewToClipboard.html b/localwiki/Macro_Copy3DViewToClipboard.html new file mode 100644 index 0000000..386a915 --- /dev/null +++ b/localwiki/Macro_Copy3DViewToClipboard.html @@ -0,0 +1,92 @@ +Macro Copy3DViewToClipboard

      Macro Copy3DViewToClipboard

      + +
      + + + + + + + + + + + + + + + + + + + + + + + + + + +
      +

      Macro Copy3DViewToClipboard.png Macro Copy3DViewToClipboard

      +
      Description +
      Copy contents of 3DView to clipboard +
      Author +
      Mario52 +
      Links +
      Macros recipes
      How to install macros
      How to customize toolbars +
      Version +
      00.01 +
      Date last modification +
      2016-09-14 +
      +

      + +
      +


      +

      +

      Description

      +

      Macro will copy the contents of the 3D view to the clipboard +

      +

      How To Use

      +
      • Run once to activate macro (the macro is loaded resident into the memory of the PC).
      • +
      • Press G to grab the contents of the 3d view and copy them to the clipboard.
      • +
      • Press Q to quit.
      +

      PS: if you wild other format modify the values of the line number 33 ex: +

      +
      glw.resize(640, 480)                                    # reduce the SubWindow 
      +

      to +

      +
      glw.resize(800, 600)                                    # reduce the SubWindow 
      +

      Discussion

      +

      See forum-thread here. +

      +

      Code

      +

      The icon for you toolbar Macro Copy3DViewToClipboard.png +

      Copy the macro to Gist Macro_Copy3DViewToClipboard.FCMacro +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Macro_Copy3DViewToClipboard.png b/localwiki/Macro_Copy3DViewToClipboard.png new file mode 100644 index 0000000..1d5b076 Binary files /dev/null and b/localwiki/Macro_Copy3DViewToClipboard.png differ diff --git a/localwiki/Macro_Corner_shapes_wizard.html b/localwiki/Macro_Corner_shapes_wizard.html new file mode 100644 index 0000000..992b4f6 --- /dev/null +++ b/localwiki/Macro_Corner_shapes_wizard.html @@ -0,0 +1,235 @@ +Macro Corner shapes wizard

      Macro Corner shapes wizard

      + +
      + + + + + + + + + + + + + + + + + + + + + + + + + + +
      +

      Text-x-python.png Corner shapes wizard

      +
      Description +
      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. +
      Author +
      Nicotuf +
      Links +
      Macros recipes
      How to install macros
      How to customize toolbars +
      Version +
      1.0 +
      Date last modification +
      2011-08-01 +
      +

      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.
      +There is a modified version with changes GUI. +

      CornerShape1.png +


      +

      +
      # -*- coding:utf-8 -*-
      + 
      +#####################################
      +# Importation de fonctions externes :
      + 
      +#from os import *
      +import FreeCAD, FreeCADGui, Part, Draft, math, MeshPart, Mesh, Drawing
      +from PyQt4 import QtGui,QtCore
      +from FreeCAD import Base
      +App=FreeCAD
      +Gui=FreeCADGui
      + 
      +##################################
      +# Défnition Class :
      + 
      +class Corniere:
      +   def __init__(self, obj):
      +      obj.addProperty("App::PropertyLength","L1","Corniere","Largeur 1").L1=20.0
      +      obj.addProperty("App::PropertyLength","L2","Corniere","Largeur 2").L2=20.0
      +      obj.addProperty("App::PropertyLength","e1","Corniere","Epaisseur 1").e1=2.0
      +      #obj.addProperty("App::PropertyLength","e2","Corniere","Epaisseur 2").e2=2.0
      +      obj.addProperty("App::PropertyLength","Longueur","Corniere","Longueur").Longueur=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.Longueur)
      +      S2=Part.makeBox(fp.L1-fp.e1,fp.L2-fp.e1,fp.Longueur,P1)
      +      fp.Shape=S1.cut(S2)   
      + 
      +##################################
      +# Défnition locale de fonctions :
      + 
      + 
      +def proceed():
      +   QtGui.qApp.setOverrideCursor(QtCore.Qt.WaitCursor)
      + 
      +   if FreeCAD.ActiveDocument==None:
      +      FreeCAD.newDocument("Corniere")
      + 
      +   oldDocumentObjects=App.ActiveDocument.Objects
      + 
      +   try:
      +      QL1 = float(l1.text())   
      +      QL2 = float(l2.text())
      +      Qe = float(l3.text())
      +      QLongueur = float(l4.text())
      +   except:
      +      FreeCAD.Console.PrintError("Wrong input! Only numbers allowed...\n")
      + 
      +   Cor=FreeCAD.ActiveDocument.addObject("Part::FeaturePython","Corniere")
      +   Corniere(Cor)
      +   Cor.ViewObject.Proxy=0
      +   Cor.L1=QL1
      +   Cor.L2=QL2
      +   Cor.e1=Qe
      +   Cor.Longueur=QLongueur
      + 
      +   App.ActiveDocument.recompute()
      +   Gui.SendMsgToActiveView("ViewFit")
      + 
      +   QtGui.qApp.restoreOverrideCursor()
      + 
      +   Plan(Cor)
      + 
      +   dialog.hide()
      + 
      +def hide():
      + 
      +   dialog.hide()
      + 
      +def Plan(obj):
      + 
      +   ObjetProjete=obj.Shape
      + 
      +   TailleX=ObjetProjete.BoundBox.XLength
      +   TailleY=ObjetProjete.BoundBox.YLength
      +   TailleZ=ObjetProjete.BoundBox.ZLength
      + 
      +   page = App.activeDocument().addObject('Drawing::FeaturePage','Page')
      +   page.Template = App.getResourceDir()+'Mod/Drawing/Templates/A3_Landscape.svg'   
      +   vueprofil = App.activeDocument().addObject('Drawing::FeatureViewPart','VueProfil')
      +   vueprofil.Source = obj
      +   vueprofil.Direction = (0.0,0.0,1.0)
      +   vueprofil.Scale = 1.0
      +   vueprofil.X = 50.0
      +   vueprofil.Y = 50.0
      +   page.addObject(vueprofil)
      + 
      +   vuegauche = App.activeDocument().addObject('Drawing::FeatureViewPart','Vuegauche')
      +   vuegauche.Source = obj
      +   vuegauche.Direction = (-1.0,0.0,0.0)
      +   vuegauche.ShowHiddenLines = True
      +   vuegauche.Scale = 1.0
      +   vuegauche.Rotation = 180.0
      +   vuegauche.X = 50.0+TailleX/2+TailleX
      +   vuegauche.Y = 50.0
      +   page.addObject(vuegauche)
      + 
      +   vuedessus = App.activeDocument().addObject('Drawing::FeatureViewPart','Vuedessus')
      +   vuedessus.Source = obj
      +   vuedessus.Direction = (0.0,-1.0,0.0)
      +   vuedessus.ShowHiddenLines = True
      +   vuedessus.Scale = 1.0
      +   vuedessus.Rotation = 180.0
      +   vuedessus.X = 50.0+TailleX/2+TailleX
      +   vuedessus.Y = 50.0+TailleX/2+TailleY+TailleX
      +   page.addObject(vuedessus)
      + 
      +   vueiso = App.activeDocument().addObject('Drawing::FeatureViewPart','VueIso')
      +   vueiso.Source = obj
      +   vueiso.Direction = (-1.0,-1.0,0.5)
      +   vueiso.Scale = 1.0
      +   vueiso.ShowSmoothLines = True
      +   vueiso.X = TailleZ+TailleX/2
      +   vueiso.Y = 7*TailleZ+3*TailleY
      +   page.addObject(vueiso)
      + 
      + 
      +   App.activeDocument().recompute()
      + 
      +   PageFile = open(page.PageResult,'r')
      +   OutFile = open('temp.svg','w')
      +   OutFile.write(PageFile.read())
      +   del OutFile,PageFile
      + 
      + 
      +dialog = QtGui.QDialog()
      +dialog.resize(200,200)
      +dialog.setWindowTitle("Corniere")
      +la = QtGui.QVBoxLayout(dialog)
      + 
      +e1 = QtGui.QLabel("Dimensions de la corniere")
      +commentFont=QtGui.QFont("Arial",10,True)
      +e1.setFont(commentFont)
      +la.addWidget(e1)
      + 
      +t1 = QtGui.QLabel("L1")
      +la.addWidget(t1)
      +l1 = QtGui.QLineEdit()
      +l1.setText("20")
      +la.addWidget(l1)
      + 
      +t2 = QtGui.QLabel("L2")
      +la.addWidget(t2)
      +l2 = QtGui.QLineEdit()
      +l2.setText("20")
      +la.addWidget(l2)
      + 
      +t3 = QtGui.QLabel("e")
      +la.addWidget(t3)
      +l3 = QtGui.QLineEdit()
      +l3.setText("2")
      +la.addWidget(l3)
      + 
      +t4 = QtGui.QLabel("Longueur")
      +la.addWidget(t4)
      +l4 = QtGui.QLineEdit()
      +l4.setText("300")
      +la.addWidget(l4)
      + 
      +okbox = QtGui.QDialogButtonBox(dialog)
      +okbox.setOrientation(QtCore.Qt.Horizontal)
      +okbox.setStandardButtons(QtGui.QDialogButtonBox.Cancel 
      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Macro_Creating_faces_from_a_DXF_file.html b/localwiki/Macro_Creating_faces_from_a_DXF_file.html new file mode 100644 index 0000000..36f9068 --- /dev/null +++ b/localwiki/Macro_Creating_faces_from_a_DXF_file.html @@ -0,0 +1,98 @@ +Macro Creating faces from a DXF file

      Macro Creating faces from a DXF file

      + +
      + + + + + + + + + + + + + + + + + + + + + + + + + + +
      +

      Text-x-python.png Creating faces from a DXF file

      +
      Description +
      This macro create face from a DXF file. +
      Author +
      shoogen +
      Links +
      Macros recipes
      How to install macros
      How to customize toolbars +
      Version +
      01.00 +
      Date last modification +
      2014-10-29 +
      +

      + +
      +


      +

      +

      Description

      +

      This macro create face from a DXF file, the "Layer" are recognized separate and trained in groups. +

      There must be groups in the file. +

      +

      Uses

      +

      Launch the macro all objects are analyzed and transformed into faces. +

      Note: an unclosed object return an error +

      +

      Script

      +

      Macro Creating faces from a DXF file.FCMacro +

      +
      import FreeCAD,Part,OpenSCAD2Dgeom
      +doc = App.ActiveDocument
      +for group in doc.findObjects('App::DocumentObjectGroup'):
      +    try:
      +        edges=sum((obj.Shape.Edges for obj in group.Group \
      +                if hasattr(obj,'Shape')),[])
      +        face = OpenSCAD2Dgeom.edgestofaces(edges)
      +        faceobj = doc.addObject('Part::Feature','face_%s' % group.Name)
      +        faceobj.Label = 'face_%s' % group.Label
      +        faceobj.Shape = face
      +    except Part.OCCError: # Exception: # 
      +        FreeCAD.Console.PrintError('Error in Group %s (%s)' % (group.Name,group.Label)+"\n") 
      +

      Link

      +

      Forum Creating faces from a DXF file +

      Here an example Generate 3D solid from intersection of three imported 2D +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Macro_Cross_Section_02.png b/localwiki/Macro_Cross_Section_02.png new file mode 100644 index 0000000..a70011d Binary files /dev/null and b/localwiki/Macro_Cross_Section_02.png differ diff --git a/localwiki/Macro_Cross_Section_03.gif b/localwiki/Macro_Cross_Section_03.gif new file mode 100644 index 0000000..71546af Binary files /dev/null and b/localwiki/Macro_Cross_Section_03.gif differ diff --git a/localwiki/Macro_Cut_Circle.html b/localwiki/Macro_Cut_Circle.html new file mode 100644 index 0000000..b59dc90 --- /dev/null +++ b/localwiki/Macro_Cut_Circle.html @@ -0,0 +1,153 @@ +Macro Cut Circle

      Macro Cut Circle

      + +
      + + + + + + + + + + + + + + + + + + + + + + + + + + +
      +

      Text-x-python.png Macro Cut Circle

      +
      Description +
      Cut a circle or arc in x arcs. +
      Author +
      mario52 +
      Links +
      Macros recipes
      How to install macros
      How to customize toolbars +
      Version +
      00.02 +
      Date last modification +
      2015-03-09 +
      +

      + +
      +


      +

      +

      Description

      +

      This macro cut a circle(s) or arc(s) in multiple arcs, the arcs can be coloured alternately to distinguish. +


      +CutCircle +

      +
      +

      Use

      +

      Copy the macro cutCirle complete in the Python console FreeCAD select the circle(s) and (or) arc(s) type in the console: +

      +
      cutCircle(5, 1)  # here with 5 arcs and coloured
      +cutCircle(4)     # 
      +

      to see the circles and arcs cut here in the example 5 contiguous arcs. +

      The original object is not deleted. +

      +

      Script

      +

      Macro_Cut_Circle.FCMacro +

      +
      __title__= "cutCircle"
      +__author__= "Mario52"
      +__date__= "09/03/2015"
      +__version__= "00.02"
      +
      +# selection circle(s) (circles and arcs)
      +# give number of cut, biColor 0/1
      +# cut the circle to x arcs
      +# if biColor is <> 0 the arcs are colored alternately Red White Red White ....
      +# 
      +
      +import Draft
      +global biscolor ; biscolor = 0
      +def cutCircle(number = 2, biColor = 0):
      +    global biscolor
      +    def defbiColor(objet):
      +        global biscolor
      +        if biscolor == 0:
      +            FreeCADGui.ActiveDocument.getObject(objet.Name).LineColor = (1.0,0.0,0.0) # 255 = 1 (10 = (1/255 * 10 ))
      +            biscolor = 1
      +        else:
      +            FreeCADGui.ActiveDocument.getObject(objet.Name).LineColor = (1.0,1.0,1.0) # 255 = 1 (10 = (1/255 * 10 ))
      +            biscolor = 0
      +    selection = FreeCADGui.Selection.getSelection()
      +    for piece in selection:
      +        nom = piece.Name
      +        if (nom[:6] == "Circle") or (nom[:8] == "Cylinder"):
      +            circonference = piece.Shape.Length
      +            rayon = piece.Radius
      +            placem = piece.Placement
      + 
      +            if (nom[:8] == "Cylinder"):
      +                pivot0 = float(piece.Angle/number)
      +                FreeCAD.Console.PrintMessage("Cylinder"+"\n")
      +            else:
      +                pivot0 = float(360/number)
      +                FreeCAD.Console.PrintMessage("Circle"+"\n")
      +            pivot1 = 0.0
      +            for i in range(number):
      +                cercle = Draft.makeCircle(radius=rayon,placement=placem,face=False,startangle=(pivot1),endangle=(pivot0+pivot1),support=None)
      +                if biColor != 0:
      +                    defbiColor(cercle)
      +                pivot1 += pivot0
      +        elif nom[:3] == "Arc":
      +            FreeCAD.Console.PrintMessage("Arc"+"\n")
      +            circonference = piece.Shape.Length
      +            rayon = piece.Radius
      +            placem = piece.Placement
      +            First = float(piece.FirstAngle)
      +            Last  = float(piece.LastAngle)
      +            pivot0 = abs((First - Last) / number)
      +            pivot1 = 0.0
      +            for i in range(number):
      +                cercle = Draft.makeCircle(radius=rayon,placement=placem,face=False,startangle=(pivot1+First),endangle=(pivot0+pivot1+First),support=None)
      +                if biColor != 0:
      +                    defbiColor(cercle)
      +                pivot1 += pivot0 
      +

      Project

      +

      Cut circle to cylinder +

      +

      Version

      +

      ver 00.02 09/03/2015 : adding create arcs coloured altenat alternately Red White Red White .... or not +

      ver 00.01 24/02/2015 : +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Macro_Cut_Line.html b/localwiki/Macro_Cut_Line.html new file mode 100644 index 0000000..99bfb21 --- /dev/null +++ b/localwiki/Macro_Cut_Line.html @@ -0,0 +1,160 @@ +Macro Cut Line

      Macro Cut Line

      + +
      + + + + + + + + + + + + + + + + + + + + + + + + + + +
      +

      Text-x-python.png Macro Cut Line

      +
      Description +
      Cut a line giving as an argument number cut, create line, bicolor, create point. +
      Author +
      mario52 +
      Links +
      Macros recipes
      How to install macros
      How to customize toolbars +
      Version +
      1.0 +
      Date last modification +
      2015-03-08 +
      +

      + +
      +


      +

      +

      Description

      +

      This small macro cut a line and create a points , lines , two colours of line. +

      +
      cutLine
      +
      +

      Use

      +

      Can be used from the Freecad macro editor. +

      If the macro is copied in the Python console, you can you can use it by: +

      +
      cutLine(4, createLine = 1, biColor = 1, createPoint = 0) 
      +
      • 4 : number cuts
      • +
      • createPoint : create points or not (0) (Defaut 1)
      • +
      • createLine : create line (>0) or not (0) (Defaut 0)
      • +
      • biColor : create line biColor (>0) or not (0) (Defaut 0)
      +


      +you can change the default values in the macro. +

      With bisColor the lines on the original line is created by a white line red line white line .... the colors are modifiable in the code, line 19 and 22. +

      +

      Script

      +

      Macro_cutLine.FCMacro +

      +
      #################################################################
      +# http://forum.freecadweb.org/viewtopic.php?f=3&t=4217&hilit=discretize
      +
      +__title__   = "cutLine"
      +__author__  = "Mario52"
      +__version__ = "00.01"
      +__date__    = "08/03/2015"
      +
      +import Draft, Part
      +def cutLine(numberOfPoints = 2, createPoint = 1, createLine = 0, biColor = 0):           # create a points of forme
      +
      +    def createLines(numberOfPoints, points, biColor):                                        # create line
      +        biscolor = 0
      +        for lin in range(numberOfPoints-1):
      +            creaLine = [FreeCAD.Vector(points[lin]),FreeCAD.Vector(points[lin+1])]
      +            wire = Draft.makeWire(creaLine,closed=False,face=False,support=None)
      +            if biColor != 0:                                                                 # biColor 
      +                if biscolor == 0:
      +                    FreeCADGui.ActiveDocument.getObject(wire.Name).LineColor = (1.0,0.0,0.0) # 255 = 1 (10 = (1/255 * 10 ))
      +                    biscolor = 1
      +                else:
      +                    FreeCADGui.ActiveDocument.getObject(wire.Name).LineColor = (1.0,1.0,1.0) # 255 = 1 (10 = (1/255 * 10 ))
      +                    biscolor = 0
      +    try:
      +        points = []
      +        points[:] = []
      +        selectionObjects = FreeCADGui.Selection.getSelectionEx()         # getSelectionEx
      +        numberOfPoints += 1
      +        for selection in selectionObjects:
      +            compteur = pas = 0
      +            for selectedEdge in selection.SubObjects:
      +#                    FreeCAD.Console.PrintMessage(selectionObjects[0].SubElementNames[compteur] + "\n")                   
      +                    print selectionObjects[0].SubElementNames[compteur]  # getSelectionEx
      +                    compteur += 1                                              
      +                    points = selectedEdge.discretize(numberOfPoints)   
      +                    if createLine != 0:
      +                        createLines(numberOfPoints, points, biColor)
      +                    for p in points:
      +                        if createPoint != 0:
      +                            Draft.makePoint( p.x, p.y, p.z)
      +#                        FreeCAD.Console.PrintMessage(str(compteur)+" X"+ str(p.x)+" Y"+ str(p.y)+ " Z"+ str(p.z) + "\n")
      +                        print compteur," X", p.x, " Y", p.y, " Z", p.z
      +                    pas = 1                                              #
      +
      +            if pas == 0:                                                 # the not SubObjects
      +                selectionObjects = FreeCADGui.Selection.getSelection()   # select all elements
      +#                FreeCAD.Console.PrintMessage(selectionObjects[0].Name + "\n")
      +                print selectionObjects[0].Name                           # getSelection()
      +                compteur = 0
      +                for ii in enumerate(selectionObjects[0].Shape.Edges): 
      +                    compteur += 1
      +                    points = ii[1].discretize(numberOfPoints)            # discretize the element
      +                    for p in points:
      +                        if createPoint != 0:
      +                            Draft.makePoint( p.x, p.y, p.z)              # create points
      +#                        FreeCAD.Console.PrintMessage(str(compteur)+" X"+ str(p.x)+" Y"+ str(p.y)+ " Z"+ str(p.z) + "\n")
      +                        print compteur, " X", p.x, " Y", p.y, " Z", p.z  # list and display the coordinates
      +                    if createLine != 0:
      +                        createLines(numberOfPoints, points, biColor)
      +    except:
      +#        FreeCAD.Console.PrintError("Error" + "\n" + "Give : cutLine(numberOfPoints = 2, createPoint = 1, createLine = 0, biColor = 0)"+"\n")
      +        print "Error : Give cutLine(numberOfPoints = 2, createPoint = 1, createLine = 0, biColor = 0)"
      +
      +
      +#cutLine(2, createLine = 1, biColor = 1, createPoint = 0) 
      +

      Links

      +

      this function use the function discretize the original code +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Macro_DXF_To_Shape_00.png b/localwiki/Macro_DXF_To_Shape_00.png new file mode 100644 index 0000000..e32ff94 Binary files /dev/null and b/localwiki/Macro_DXF_To_Shape_00.png differ diff --git a/localwiki/Macro_DXF_to_Face_and_Sketch.html b/localwiki/Macro_DXF_to_Face_and_Sketch.html new file mode 100644 index 0000000..4912a72 --- /dev/null +++ b/localwiki/Macro_DXF_to_Face_and_Sketch.html @@ -0,0 +1,303 @@ +Macro DXF to Face and Sketch

      Macro DXF to Face and Sketch

      + +
      + + + + + + + + + + + + + + + + + + + + + + + + + + +
      +

      Text-x-python.png DXF to Face and Sketch

      +
      Description +
      This macro create face and sketch from a DXF file. +
      Author +
      shoogen, easyw-fc +
      Links +
      Macros recipes
      How to install macros
      How to customize toolbars +
      Version +
      02.00 +
      Date last modification +
      2017-10-23 +
      +

      + +
      +


      +

      +

      Description

      +

      This macro converts selected elements of imported dxf to face and sketch. +

      It can be used also to convert 'Shape2DView' to Sketch and it works also if BSPlines are present. +

      +

      Uses

      +
      • Import a DXF file
      • +
      • Select the items to be processed
      • +
      • Launch the macro, all selected objects are analysed and transformed into faces and sketches.
      +

      Options

      +
      • Change create_face=True or create_sketch=True to False to generate only one item
      +

      Script

      +

      Macro DXF to Face and Sketch.FCMacro +

      +
      ##    Select the items to be processed
      +##    Launch the macro, all selected objects are analyzed and transformed into faces and sketches.
      +##    change create_face=True or create_sketch=True to False to generate only one item
      +## todo: fix closed curves for bsplines method
      +
      +import FreeCAD,Part,Path
      +from PathScripts import PathUtils
      +
      +import sys, os
      +#sys.path.append('C:\Cad\Progetti_K\3D-FreeCad-tools/')
      +#sys.path.append(os.path.realpath(__file__)) #workaround to test OpenSCAD2DgeomMau
      +#import OpenSCAD2DgeomMau #OpenSCAD2Dgeom
      +#reload(OpenSCAD2DgeomMau)
      +import OpenSCAD2Dgeom
      +
      +import PySide
      +from PySide import QtGui, QtCore
      +
      +
      +import DraftGeomUtils
      +import Draft
      +from DraftGeomUtils import geomType
      +
      +create_face=True
      +create_sketch=True
      +dqd = 0.02 #discretize(QuasiDeflection=d) => gives a list of points with a maximum deflection 'd' to the edge (faster)
      +
      +
      +def clear_console():
      +    #clearing previous messages
      +    mw=FreeCADGui.getMainWindow()
      +    c=mw.findChild(QtGui.QPlainTextEdit, "Python console")
      +    c.clear()
      +    r=mw.findChild(QtGui.QTextEdit, "Report view")
      +    r.clear()
      +
      +def shape2Sketch(shape):
      +    # replace shape.edges with arcs
      +    newEdges = PathUtils.cleanedges(shape.Edges,0.1)
      +    wire = Part.Wire([Part.Edge(i) for i in newEdges])
      +    sketch = Draft.makeSketch(wire,autoconstraints=True,delete=True)
      +    return sketch
      +
      +def Discretize(shape, addToName=None):
      +    ##http://forum.freecadweb.org/viewtopic.php?f=12&t=16336#p129468
      +    ##Discretizes the edge and returns a list of points.
      +    ##The function accepts keywords as argument:
      +    ##discretize(Number=n) => gives a list of 'n' equidistant points
      +    ##discretize(QuasiNumber=n) => gives a list of 'n' quasi equidistant points (is faster than the method above)
      +    ##discretize(Distance=d) => gives a list of equidistant points with distance 'd'
      +    ##discretize(Deflection=d) => gives a list of points with a maximum deflection 'd' to the edge
      +    ##discretize(QuasiDeflection=d) => gives a list of points with a maximum deflection 'd' to the edge (faster)
      +    ##discretize(Angular=a,Curvature=c,[Minimum=m]) => gives a list of points with an angular deflection of 'a'
      +    ##and a curvature deflection of 'c'. Optionally a minimum number of points
      +    ##can be set which by default is set to 2. 
      +
      +    global dqd
      +
      +    # lng=(abs(FreeCAD.ActiveDocument.getObject(skt_name).Shape.BoundBox.XLength)+abs(FreeCAD.ActiveDocument.getObject(skt_name).Shape.BoundBox.YLength))
      +    # dv=int(dvm*lng) #discretize auto setting
      +    # #dv=int(0.5*lng) #discretize auto setting COARSE for testing
      +    # #print dv
      +    # if dv < 20:
      +    #     dv=20
      +    #b=FreeCAD.ActiveDocument.getObject(skt_name)
      +    #l=b.Shape.copy().discretize(dv)
      +    #l=b.Shape.copy().discretize(QuasiDeflection=0.02)
      +    l=shape.copy().discretize(QuasiDeflection=dqd)
      +    f=Part.makePolygon(l)
      +    Part.show(f)
      +    sh_name=FreeCAD.ActiveDocument.ActiveObject.Name
      +    if addToName is None:
      +        Draft.makeSketch(FreeCAD.ActiveDocument.ActiveObject,autoconstraints=True)
      +    else:
      +        Draft.makeSketch(FreeCAD.ActiveDocument.ActiveObject,autoconstraints=True, addTo=addToName)
      +    s_name=FreeCAD.ActiveDocument.ActiveObject.Name
      +    FreeCAD.ActiveDocument.removeObject(sh_name)
      +    #FreeCAD.ActiveDocument.removeObject(skt_name)
      +    FreeCAD.ActiveDocument.recompute() 
      +    return s_name
      +    #stop
      +
      +def WireDiscretize(wire):
      +    ##http://forum.freecadweb.org/viewtopic.php?f=12&t=16336#p129468
      +    ##Discretizes the edge and returns a list of points.
      +    ##The function accepts keywords as argument:
      +    ##discretize(Number=n) => gives a list of 'n' equidistant points
      +    ##discretize(QuasiNumber=n) => gives a list of 'n' quasi equidistant points (is faster than the method above)
      +    ##discretize(Distance=d) => gives a list of equidistant points with distance 'd'
      +    ##discretize(Deflection=d) => gives a list of points with a maximum deflection 'd' to the edge
      +    ##discretize(QuasiDeflection=d) => gives a list of points with a maximum deflection 'd' to the edge (faster)
      +    ##discretize(Angular=a,Curvature=c,[Minimum=m]) => gives a list of points with an angular deflection of 'a'
      +    ##and a curvature deflection of 'c'. Optionally a minimum number of points
      +    ##can be set which by default is set to 2. 
      +
      +    global dqd
      +
      +    l=wire.copy().discretize(QuasiDeflection=dqd)
      +    f=Part.makePolygon(l)
      +    Part.show(f)
      +    sh_name=FreeCAD.ActiveDocument.ActiveObject.Name
      +    FreeCAD.ActiveDocument.recompute() 
      +    
      +    return sh_name
      +    #stop
      +    
      +    
      +#creating face from dxf
      +doc = App.ActiveDocument
      +clear_console()
      +
      +if FreeCADGui.Selection.getSelection():
      +
      +    try:
      +        edges=sum((obj.Shape.Edges for obj in \
      +        FreeCADGui.Selection.getSelection() if hasattr(obj,'Shape')),[])
      +        for edge in edges:
      +            print "geomType ",DraftGeomUtils.geomType(edge)
      +        face = OpenSCAD2Dgeom.edgestofaces(edges)
      +        #face = OpenSCAD2DgeomMau.edgestofaces(edges)
      +        face.check() # reports errors
      +        face.fix(0,0,0)
      +        faceobj = doc.addObject('Part::Feature','face_%s' % "dxf")
      +        faceobj.Label = 'face_%s' % "dxf"
      +        faceobj.Shape = face
      +        for obj in FreeCADGui.Selection.getSelection():
      +            Gui.ActiveDocument.getObject(obj.Name).Visibility=False   
      +        #creating sketch from face from dxf
      +        #wires,_faces = Draft.downgrade(FreeCADGui.Selection.getSelection(),delete=False)
      +        if create_sketch:
      +            if create_face:
      +                wires,_faces = Draft.downgrade(faceobj,delete=False)
      +            else:
      +                wires,_faces = Draft.downgrade(faceobj,delete=True)
      +            if 0: #try:
      +                sketch = Draft.makeSketch(wires[0:1])
      +                sketch.Label = "Sketch_dxf"
      +                for wire in wires[1:]:
      +                    Draft.makeSketch([wire],addTo=sketch)
      +                for wire in wires:
      +                    FreeCAD.ActiveDocument.removeObject(wire.Name)
      +            else: #except:
      +                FreeCAD.Console.PrintWarning("\nConverting Bezier curves to Arcs\n")
      +                #FreeCAD.ActiveDocument.removeObject(FreeCAD.ActiveDocument.ActiveObject.Name)
      +                
      +                #print 
      +                sketchesList=[]
      +                #for wire in wires:
      +                #    for e in wire.Shape.Edges:
      +                #        if geomType(e) == "BSplineCurve" or geomType(e) == "BezierCurve":
      +                #        #if 'spline' in e.Curve:
      +                #            sk_name = Discretize(e)
      +                #            sketchesList.append(sk_name)
      +                #        else:
      +                #            sketch = Draft.makeSketch(Part.Wire(e))
      +                #            sketchesList.append(sketch.Name)
      +                #print sketchesList
      +                
      +                newShapeList = []
      +                newShapes = []
      +                for wire in wires:
      +                    for e in wire.Shape.Edges:
      +                        if geomType(e) == "BSplineCurve" or geomType(e) == "BezierCurve":
      +                        #if 'spline' in e.Curve:
      +                            w = Part.Wire(e)
      +                            w_name =WireDiscretize(w)
      +                            newShapeList.append(w_name)
      +                            wn=FreeCAD.ActiveDocument.getObject(w_name)
      +                            newShapes.append(wn)
      +                        else:
      +                            w = Part.Wire(e)
      +                            Part.show(w)
      +                            newShapes.append(w)
      +                            w_name = FreeCAD.ActiveDocument.ActiveObject.Name
      +                            newShapeList.append(w_name)
      +                            
      +                #print newShapes
      +                sketch = Draft.makeSketch(newShapes[0])
      +                FreeCAD.ActiveDocument.ActiveObject.Label="Sketch_dxf"
      +                for w in newShapes[1:]:
      +                    Draft.makeSketch([w],addTo=sketch)    
      +                for wire in wires:
      +                    FreeCAD.ActiveDocument.removeObject(wire.Name)
      +                for w_name in newShapeList:
      +                    FreeCAD.ActiveDocument.removeObject(w_name)
      +                
      +                #stop
      +                #WireDiscretize(wire)
      +                
      +                
      +                #stop
      +                #sk_name=FreeCAD.ActiveDocument.ActiveObject.Name
      +                #skObj=FreeCAD.ActiveDocument.getObject(sk_name)
      +                #for wire in wires[1:]:
      +                #    Discretize(wire.Shape,skObj)
      +                    
      +                #for wire in wires:
      +                #    FreeCAD.ActiveDocument.removeObject(wire.Name)
      +                    
      +                #for wire in wires[1:]:
      +                #    Discretize(wire.Shape,sketch)
      +                #for wire in wires:
      +                #    FreeCAD.ActiveDocument.removeObject(wire.Name)
      +                #for wire in wires:
      +                #    FreeCAD.ActiveDocument.removeObject(wire.Name)
      +                #sketch = shape2Sketch(face)
      +                #sketch = Discretize(FreeCAD.ActiveDocument.getObject(faceobj.Name).Shape)
      +                #sketch = Discretize(FreeCAD.ActiveDocument.getObject(f1.Name))
      +                
      +    except Part.OCCError: # Exception: #
      +        FreeCAD.Console.PrintError('Error in dxf %s (%s)' % (faceobj.Name,faceobj.Label)+"\n")
      +else:
      +    #FreeCAD.Console.PrintError("Select elements from dxf imported file\n")
      +    FreeCAD.Console.PrintWarning("Select elements from dxf imported file\n") 
      +

      Link

      + +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Macro_DeepCopy.html b/localwiki/Macro_DeepCopy.html new file mode 100644 index 0000000..5f01a88 --- /dev/null +++ b/localwiki/Macro_DeepCopy.html @@ -0,0 +1,74 @@ +Macro DeepCopy

      Macro DeepCopy

      + +
      + + + + + + + + + + + + + + + + + + + + + + + + + + +
      +

      Macro DeepCopy.png DeepCopy

      +
      Description +
      Make a compound out of a part with a copy of all its shapes +
      Author +
      galou_breizh +
      Links +
      Macros recipes
      How to install macros
      How to customize toolbars +
      Version +
      1.0 +
      Date last modification +
      2018-03-16 +
      +

      Contents

      + +
      + +
      +


      +

      +

      Description

      +

      Select a part in the tree, run the macro and it will create a compound with a copy of all its shapes. The part hierarchy is lost as well as all the special functionalities of the children of the original part. For example subparts, bodies, sketches, ... will be lost and their shape will be copied. +

      code on github +


      +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Macro_Delta_xyz.html b/localwiki/Macro_Delta_xyz.html new file mode 100644 index 0000000..0b78667 --- /dev/null +++ b/localwiki/Macro_Delta_xyz.html @@ -0,0 +1,149 @@ +Macro Delta xyz

      Macro Delta xyz

      + +
      + + + + + + + + + + + + + + + + + + + + + + + + + + +
      +

      Text-x-python.png Macro Delta xyz

      +
      Description +
      Gives the Delta values and distance between 2 points. +
      Author +
      Mario52 +
      Links +
      Macros recipes
      How to install macros
      How to customize toolbars +
      Version +
      0.1 +
      Date last modification +
      2013-11-29 +
      +

      + +
      +


      +

      Gives the Delta values and distance between 2 points. +

      +

      How to use

      +
      1. Start the macro
      2. +
      3. Select the first point in 3D view
      4. +
      5. Select the second point in 3D view
      6. +
      7. Click in ComboView to quit
      +


      +

      +
      DeltaXYZ.png
      +
      +


      +

      +

      Script

      +

      Macro_Delta_xyz.py +

      +
      # -*- coding: utf-8 -*-
      +#Delta x y z Click in ComboView to quit
      +import Draft, Part
      +import math,FreeCAD
      +from FreeCAD import Base
      +
      +global positionX1 ;positionX1 = 0.0
      +global positionY1 ;positionY1 = 0.0
      +global positionZ1 ;positionZ1 = 0.0
      +global positionX2 ;positionX2 = 0.0
      +global positionY2 ;positionY2 = 0.0
      +global positionZ2 ;positionZ2 = 0.0
      +global pas        ;pas        = 0
      +
      +def sub(first, other): 
      +"sub(Vector,Vector) - subtracts second vector from first one"
      +if isinstance(first,FreeCAD.Vector) and isinstance(other,FreeCAD.Vector):
      +return FreeCAD.Vector(first.x-other.x, first.y-other.y, first.z-other.z)
      +def length(first):
      +"lengh(Vector) - gives vector length"
      +if isinstance(first,FreeCAD.Vector):
      +return math.sqrt(first.x*first.x + first.y*first.y + first.z*first.z)
      +def dist(first, other):
      +"dist(Vector,Vector) - returns the distance between both points/vectors"
      +if isinstance(first,FreeCAD.Vector) and isinstance(other,FreeCAD.Vector):
      +return length(sub(first,other))
      +
      +class SelObserver:
      +    def addSelection(self,document, object, element, position):  # Sélection
      +        global pas
      +        global positionX1
      +        global positionY1
      +        global positionZ1
      +        global positionX2
      +        global positionY2
      +        global positionZ2
      +        pas+=1
      +        if pas==1:
      +            positionX1 = position[0]
      +            positionY1 = position[1]
      +            positionZ1 = position[2]
      +            App.Console.PrintMessage("Begin    : X1 "+str(positionX1)+" Y1: "+str(positionY1)+" Z1: "+str(positionZ1)+"\n")    
      +        else:
      +            positionX2 = position[0]
      +            positionY2 = position[1]
      +            positionZ2 = position[2]
      +            App.Console.PrintMessage("End      : X2 "+str(positionX2)+" Y2: "+str(positionY2)+" Z2: "+str(positionZ2)+"\n")    
      +            App.Console.PrintMessage("Delta X  : "+str(abs(positionX1-positionX2))+"\n")    
      +            App.Console.PrintMessage("Delta Y  : "+str(abs(positionY1-positionY2))+"\n")    
      +            App.Console.PrintMessage("Delta Z  : "+str(abs(positionZ1-positionZ2))+"\n")    
      +            v1=FreeCAD.Vector(positionX1,positionY1,positionZ1)
      +            v2=FreeCAD.Vector(positionX2,positionY2,positionZ2)
      +            App.Console.PrintMessage("Distance : "+str(dist(v1,v2))+"\n")
      +            App.Console.PrintMessage("------------------------"+"\n")    
      +            pas=0
      +
      +    def removeSelection(self,document, object, element): # Delete the selected object
      +        App.Console.PrintMessage("removeSelection"+"\n")
      +    def setSelection(self,document):                     # Selection in ComboView
      +        FreeCADGui.Selection.removeObserver(s)           # Uninstalls the resident function
      +        App.Console.PrintMessage("removeObserver"+"\n")
      +
      +pas = 0
      +s=SelObserver()
      +FreeCADGui.Selection.addObserver(s)          # install the function mode resident 
      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Macro_Draft_Circle_3_Points.html b/localwiki/Macro_Draft_Circle_3_Points.html new file mode 100644 index 0000000..aabf7b1 --- /dev/null +++ b/localwiki/Macro_Draft_Circle_3_Points.html @@ -0,0 +1,354 @@ +Macro Draft Circle 3 Points

      Macro Draft Circle 3 Points

      + +
      + + + + + + + + + + + + + + + + + + + + + + + + + + +
      +

      Macro Draft Circle 3 Points.png Macro Draft Circle 3 Points

      +
      Description +
      Creates a circle from 3 selected points. +
      Author +
      Mario52 +
      Links +
      Macros recipes
      How to install macros
      How to customize toolbars +
      Version +
      01.00 +
      Date last modification +
      2013-03-11 +
      +

      + +
      +


      +

      +

      Description

      +

      This macro creates a circle on 3 selected points. The points can be objects such as cubes, cylinder, then selected coordinates will be the centre of these forms. +

      Circle built on 3 selected points +

      +
      +


      +

      +

      Use

      +

      Select 3 points, or forms in the 3D view and run the macro.
      +If the shape is a line, the coordinate will be the center of the line. +

      +

      Options

      +

      If the selected objects are on different planes, (xy Z10, xy Z2, xy Z5) the circle will be built on the map x,y Z=0.
      +If all of the selected objects have their equal Z coordinates (xy Z5, xy Z5, xy Z5), circle will be built to the plan x,y Z=5. +

      +

      Script

      +

      Draft_Circle_3_Points.FCMacro +

      +
      # -*- coding: utf-8 -*-
      +# créer un cercle à partir de 3 points sélectionnés sur le plan X,Y
      +# 04/03/2013
      +# la formule provient de
      +# http://www-obs.univ-lyon1.fr/labo/fc/Ateliers_archives/ateliers_2005-06/cercle_3pts.pdf
      +# lire la note dans le pdf, sur l'ordre de sélection des points,
      +# si la formule renvoie une erreur (exemple les 3 points dans le même alignement)
      +#
      +import Draft, Part, FreeCAD, math, PartGui, FreeCADGui
      +from math import sqrt, pi, sin, cos
      +from FreeCAD import Base
      +
      +# prendre les objets sélectionnés
      +sel = FreeCADGui.Selection.getSelection()
      +i=0
      +centreX=0
      +centreY=0
      +rayon=0
      +# S'il y a 3 points sélectionnés alors..
      +if len(sel)==3 :
      +i=0
      +ta=[0,0,0,0,0,0,0,0,0]
      +for obj in sel:
      +x=(obj.Shape.BoundBox.Center)
      +ta[i+0]=(x.x)
      +ta[i+1]=(x.y)
      +ta[i+2]=(x.z)
      +i=i+3
      +# Affectation des variables
      +x_point_1=ta[0]
      +y_point_1=ta[1]
      +z_point_1=ta[2]
      +
      +x_point_2=ta[3]
      +y_point_2=ta[4]
      +z_point_2=ta[5]
      +
      +x_point_3=ta[6]
      +y_point_3=ta[7]
      +z_point_3=ta[8]
      +# Calcul des coordonnées du centre du cercle
      +centreX =((x_point_3**2-x_point_2**2+y_point_3**2-y_point_2**2)/(2*(y_point_3-y_point_2))-(x_point_2**2-x_point_1**2+y_point_2**2-y_point_1**2)/(2*(y_point_2-y_point_1)))/((x_point_3-x_point_2)/(y_point_3-y_point_2)-(x_point_2-x_point_1)/(y_point_2-y_point_1))
      +centreY =-(x_point_2-x_point_1)/(y_point_2-y_point_1)*centreX+(x_point_2**2-x_point_1**2+y_point_2**2-y_point_1**2)/(2*(y_point_2-y_point_1))
      +rayon =sqrt((x_point_1-centreX)**2+(y_point_1-centreY)**2)
      +# Définition de la coordonnée Z
      +# Si toutes les coordonnées Z sont égales le centreZ s'aligne à la coordonnée Z
      +if z_point_1==z_point_2 and z_point_2==z_point_3:
      +centreZ=z_point_1
      +else:
      +# Si une coordonnée est différente alors Z=0
      +centreZ=0
      +# Création du cercle
      +pl=FreeCAD.Placement()
      +pl.Rotation.Q=(0.0,-0.0,-0.0,1.0)
      +pl.Base=FreeCAD.Vector(centreX,centreY,centreZ)
      +Draft.makeCircle((rayon),placement=pl,face=False,support=None)
      +# Affiche le résultat dans la Vue rapport de FreeCAD
      +FreeCAD.Console.PrintMessage("Coordonnée X : "+str(centreX)+"\r\n")
      +FreeCAD.Console.PrintMessage("Coordonnée Y : "+str(centreY)+"\r\n")
      +FreeCAD.Console.PrintMessage("Coordonnée Z : "+str(centreZ)+"\r\n")
      +FreeCAD.Console.PrintMessage("Rayon        : "+str(rayon  )+"\r\n")
      +else:
      +# Si la condition n'est pas remplie, recommencer
      +FreeCAD.Console.PrintError("Sélectionnez 3 points et recommencez\r\n")
      +

      Improved version

      +

      In addition to the previous features, this example is used to align an orthogonal circle on each shape in the selection, and the plan "'XY, YZ, XZ ' ' chosen.
      +The circle takes the color of the axis dedicated regardless of current color, and the center point of the circle is drawn (option O/N). +

      +
      + +
      +
      +

      The settings to change. +

      +
      # Change the values here below
      +# mode by default vueChoix = 0 and alignerSur = 0
      +vueChoix=0# choice of the top view = 1 XY, view Front = 2 ZX, Right view = 3 ZY
      +alignerSur=0# Aligns the circle shaped the choice (1,2 or 3) or Z = 0
      +afficherPoint=1# Displays the center point of the circle
      +
      # -*- coding: utf-8 -*-
      +# créer un cercle à partir de 3 points séléctionnés
      +# avec comme options le cercle peut être construit sur un plans au choix
      +# à la coordonnée d'une des trois formes sélectionnées au choix
      +# et création du point central O/N
      +# 04/03/2013
      +# la formule provient de
      +# http://www-obs.univ-lyon1.fr/labo/fc/Ateliers_archives/ateliers_2005-06/cercle_3pts.pdf
      +# lire la note dans le pdf, sur l'ordre de sélection des points,
      +# si la formule renvoie une erreur (exemple les 3 points dans le même alignement)
      +#
      +import Draft, Part, FreeCAD, math, PartGui, FreeCADGui
      +from math import sqrt, pi, sin, cos
      +from FreeCAD import Base
      +from PyQt4 import QtCore, QtGui
      +
      +def errorDialog(msg):
      +    # Create a simple dialog QMessageBox
      +    # The first argument indicates the icon used: one of QtGui.QMessageBox.{NoIcon, Information, Warning, Critical, Question} 
      +diag = QtGui.QMessageBox(QtGui.QMessageBox.Critical,u"Error Message",msg)
      +diag.setWindowModality(QtCore.Qt.ApplicationModal)
      +diag.exec_()
      +
      +def affiche(x,y,z,rayon,r,v,b,afficherPoint):
      +pl.Base=FreeCAD.Vector(x,y,z)
      +Draft.makeCircle((rayon),placement=pl,face=False,support=None)
      +FreeCADGui.activeDocument().activeObject().LineColor = (r,v,b)
      +if afficherPoint==1:
      +Draft.makePoint(x,y,z)
      +diag = QtGui.QMessageBox(QtGui.QMessageBox.Information,u"Coordinates",u"Coordinates X : "+str(x)+"\r\n"+u"Coordinates Y : "+str(y)+"\n"+u"Coordinates Z : "+str(z)+"\nRayon\t     : "+str(rayon))
      +diag.setWindowModality(QtCore.Qt.ApplicationModal)
      +diag.exec_()
      +
      +# prendre les objets selectionnes
      +sel = FreeCADGui.Selection.getSelection()
      +i=0
      +centreX=0;centreY=0;rayon=0
      +
      +# S'il y a 3 points sélectionnés alors..
      +if len(sel)==3 :
      +i=0
      +ta=[0,0,0,0,0,0,0,0,0]
      +for obj in sel:
      +x=(obj.Shape.BoundBox.Center)
      +ta[i+0]=(x.x)
      +ta[i+1]=(x.y)
      +ta[i+2]=(x.z)
      +i=i+3
      +# Change the values here below
      +# mode by default vueChoix = 0 and alignerSur = 0
      +vueChoix=0# choice of the top view = 1 XY, view Front = 2 ZX, Right view = 3 ZY
      +alignerSur=0# Aligns the circle shaped the choice (1,2 or 3) or Z = 0
      +afficherPoint=1# Displays the center point of the circle
      +
      +    # Affectation des variables
      +if vueChoix==3:# View of right ZY (Red)
      +   z_point_1=ta[0]
      +x_point_1=ta[1]
      +y_point_1=ta[2]
      +
      +z_point_2=ta[3]
      +x_point_2=ta[4]
      +y_point_2=ta[5]
      +
      +z_point_3=ta[6]
      +x_point_3=ta[7]
      +y_point_3=ta[8]
      +
      +elif vueChoix==2:# Front view ZX (Green)
      +   y_point_1=ta[0]
      +z_point_1=ta[1]
      +x_point_1=ta[2]
      +
      +y_point_2=ta[3]
      +z_point_2=ta[4]
      +x_point_2=ta[5]
      +
      +y_point_3=ta[6]
      +z_point_3=ta[7]
      +x_point_3=ta[8]
      +
      +else:# Top view XY (blue)
      +   x_point_1=ta[0]
      +y_point_1=ta[1]
      +z_point_1=ta[2]
      +
      +x_point_2=ta[3]
      +y_point_2=ta[4]
      +z_point_2=ta[5]
      +
      +x_point_3=ta[6]
      +y_point_3=ta[7]
      +z_point_3=ta[8]
      +
      +    # Calculation of coordinates of the center of the circle
      +try:
      +centreX =((x_point_3**2-x_point_2**2+y_point_3**2-y_point_2**2)/(2*(y_point_3-y_point_2))-(x_point_2**2-x_point_1**2+y_point_2**2-y_point_1**2)/(2*(y_point_2-y_point_1)))/((x_point_3-x_point_2)/(y_point_3-y_point_2)-(x_point_2-x_point_1)/(y_point_2-y_point_1))
      +centreY =-(x_point_2-x_point_1)/(y_point_2-y_point_1)*centreX+(x_point_2**2-x_point_1**2+y_point_2**2-y_point_1**2)/(2*(y_point_2-y_point_1))
      +rayon =sqrt((x_point_1-centreX)**2+(y_point_1-centreY)**2)
      +except:
      +errorDialog(u"Impossible calculation too aligned elements")
      +else:
      +#finally: sera TOUJOURS exécuté
      +   # Definition of the coordinate Z
      +centreZ=0
      +    # Création du cercle
      +pl=FreeCAD.Placement()
      +if vueChoix==1:# Plan XY Dessus
      +pl.Rotation.Q=(0,0,0,1.0)
      +if alignerSur==1:
      +affiche(centreX,centreY,z_point_1,rayon,0.0,0.0,1.0,afficherPoint)
      +elif alignerSur==2:
      +affiche(centreX,centreY,z_point_2,rayon,0.0,0.0,1.0,afficherPoint)
      +elif alignerSur==3:
      +affiche(centreX,centreY,z_point_3,rayon,0.0,0.0,1.0,afficherPoint)
      +elif vueChoix==2: # Plan XZ Face
      +pl.Rotation.Q=(1,0,0,1.0)
      +if alignerSur==1:
      +affiche(centreY,z_point_1,centreX,rayon,0.0,1.0,0.0,afficherPoint)
      +elif alignerSur==2:
      +affiche(centreY,z_point_2,centreX,rayon,0.0,1.0,0.0,afficherPoint)
      +elif alignerSur==3:
      +affiche(centreY,z_point_3,centreX,rayon,0.0,1.0,0.0,afficherPoint)
      +elif vueChoix==3: # Plan YZ Droite
      +pl.Rotation.Q=(0,1,0,1.0)
      +if alignerSur==1:
      +affiche(z_point_1,centreX,centreY,rayon,1.0,0.0,0.0,afficherPoint)
      +elif alignerSur==2:
      +affiche(z_point_2,centreX,centreY,rayon,1.0,0.0,0.0,afficherPoint)
      +elif alignerSur==3:
      +affiche(z_point_3,centreX,centreY,rayon,1.0,0.0,0.0,afficherPoint)
      +else:# modifier pour avoir XYZ
      +# si les coordonnées Z sont égales alors le cercle s'aligne à Z
      +if z_point_1==z_point_2 and z_point_2==z_point_3:
      +centreZ=z_point_1
      +affiche(centreX,centreY,z_point_1,rayon,0.0,0.0,0.0,afficherPoint)
      +else:
      +        # Si une coordonnée est différente alors Z=0
      +affiche(centreX,centreY,0,rayon,0.0,0.0,0.0,afficherPoint)
      +
      +else:
      +    # Si la condition n'est pas remplie, recommencer
      +errorDialog(u"Select 3 points and repeat")
      +#FreeCAD.Console.PrintError("Select 3 points and repeatr\n")
      +

      Anaglyphe

      +

      Here an Anaglyph view that allows you to see two different positions of the view by using glasses with filters red and Cyan Anaglyph Tango.png.
      +Watch alternately with the left eye and the right eye to see the views separately. +

      +
      +

      Anaglyphe +

      +
      +
      +


      +

      +

      Credits

      +

      The genesis of the macro Draft Circle 3 Points on the forum (PYTHON) coordonnées d'un point helped flachyjoe thanks.
      +The formula comes from cercle_3pts.pdf and used with the kind permission of its author. +

      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Macro_Draft_Circle_3_Points_3D.html b/localwiki/Macro_Draft_Circle_3_Points_3D.html new file mode 100644 index 0000000..6b3a081 --- /dev/null +++ b/localwiki/Macro_Draft_Circle_3_Points_3D.html @@ -0,0 +1,177 @@ +Macro Draft Circle 3 Points 3D

      Macro Draft Circle 3 Points 3D

      + +
      + + + + + + + + + + + + + + + + + + + + + + + + + + +
      +

      Macro Draft Circle 3 Points.png Macro Draft Circle 3 Points 3D

      +
      Description +
      Creates a circle from 3 selected points in the space. +
      Author +
      galou_breizh +
      Links +
      Macros recipes
      How to install macros
      How to customize toolbars +
      Version +
      01.00 +
      Date last modification +
      2013-03-16 +
      +

      + +
      +


      +

      This macro creates a circle on 3 selected points in the space. The points can be objects such as cubes, cylinder, then selected coordinates will be the centre of these forms. +


      +Macro Draft Circle 3 Points 3D.png +

      +
      +


      +

      +

      Use

      +

      Select 3 points, or forms in the 3D view and run the macro.
      +If the shape is a line, the coordinate will be the center of the line. +

      +

      Limits

      +

      The order of selection of fear forms influencing the AXIS angle and reverse the inclination of the circle. In this case, reverse or change the order of selection of the shapes.
      +The coordinates X, Y, Z of value 0 or alignment not allowing not calculating, can return a division by zero error, and translated as "The three points are aligned" +

      +

      Script

      +
      # -*- coding: utf-8 -*-
      +# Create a circle from 3 points selected on the X, Y, Z map
      +# 04/03/2013
      +# From http://en.wikipedia.org/wiki/Circumscribed_circle
      +
      +# 08/08/2014 PyQt4 and PySide
      +
      +#OS: Windows Vista
      +#Word size: 32-bit
      +#Version: 0.14.3700 (Git)
      +#Branch: releases/FreeCAD-0-14
      +#Hash: 32f5aae0a64333ec8d5d160dbc46e690510c8fe1
      +#Python version: 2.6.2
      +#Qt version: 4.5.2
      +#Coin version: 3.1.0
      +#SoQt version: 1.4.1
      +#OCC version: 6.5.1
      +
      +try:
      +    import PyQt4
      +    from PyQt4 import QtCore, QtGui
      +except Exception:
      +    import PySide
      +    from PySide import QtCore, QtGui
      +from math import pi, asin
      +import Draft, FreeCAD, FreeCADGui
      +from FreeCAD import Base
      +
      +def errorDialog(msg):
      +    # Create a simple dialog QMessageBox
      +    # The first argument indicates the icon used: one of QtGui.QMessageBox.{NoIcon, Information, Warning, Critical, Question} 
      +    diag = QtGui.QMessageBox(QtGui.QMessageBox.Critical,u"Error Message",msg)
      +    diag.setWindowModality(QtCore.Qt.ApplicationModal)
      +    diag.exec_()
      +
      +def affiche(x,y,z,r,angle):
      +    diag = QtGui.QMessageBox(QtGui.QMessageBox.Information,u"Coordinates",u"Coordinate X : "+str(x)+"\r\n"+u"Coordinate Y : "+str(y)+"\n"+u"Coordinate Z : "+str(z)+"\nRadius\t   : "+str(r)+"\nAngle\t   : "+str(angle))
      +    diag.setWindowModality(QtCore.Qt.ApplicationModal)
      +    diag.setWindowModality(QtCore.Qt.NonModal)
      +    diag.exec_()
      +
      +# objects selected
      +sel = FreeCADGui.Selection.getSelection()
      +# If there are 3 selected points so...
      +if len(sel)==3 :
      +    # Assignment of variables
      +    P1 = sel[0].Shape.BoundBox.Center
      +    P2 = sel[1].Shape.BoundBox.Center
      +    P3 = sel[2].Shape.BoundBox.Center
      +
      +    P1P2 = (P2 - P1).Length
      +    P2P3 = (P3 - P2).Length
      +    P3P1 = (P1 - P3).Length
      +
      +    # Circle radius.
      +    l = ((P1 - P2).cross(P2 - P3)).Length
      +    try:
      +        #if l < 1e-8:
      +        #    errorDialog("The three points are aligned")
      +        r = P1P2 * P2P3 * P3P1 / 2 / l
      +    except:
      +        errorDialog("The three points are aligned")
      +    else:
      +        # Sphere center.
      +        a = P2P3**2 * (P1 - P2).dot(P1 - P3) / 2 / l**2
      +        b = P3P1**2 * (P2 - P1).dot(P2 - P3) / 2 / l**2
      +        c = P1P2**2 * (P3 - P1).dot(P3 - P2) / 2 / l**2
      +        P1.multiply(a)
      +        P2.multiply(b)
      +        P3.multiply(c)
      +        PC = P1 + P2 + P3
      +
      +        # Creation of a circle
      +        pl = Base.Placement()
      +        v = (P1 - P2).cross(P3 - P2)
      +        v.normalize()
      +        axis = Base.Vector(0, 0, 1).cross(v)
      +        angle = asin(axis.Length) * 180 / pi
      +        axis.normalize()
      +        pl = Base.Placement(PC, axis, angle)
      +        Draft.makeCircle(r, placement=pl, face=False, support=None)
      +        # Displays the result in the windows
      +        affiche((PC.x),(PC.y),(PC.z),r,angle)
      +        # Displays the result in the FreeCAD report view
      +        #FreeCAD.Console.PrintMessage("Coordinate X : "+str(PC.x)+"\n")
      +        #FreeCAD.Console.PrintMessage("Coordinate Y : "+str(PC.y)+"\n")
      +        #FreeCAD.Console.PrintMessage("Coordinate Z : "+str(PC.z)+"\n")
      +        #FreeCAD.Console.PrintMessage("Radius       : "+str(r)+"\n")
      +        #FreeCAD.Console.PrintMessage("Angle        : "+str(angle)+"\n")
      +else:
      +    # If the condition is not met, repeat
      +    #FreeCAD.Console.PrintError("Select 3 points and repeat\n")
      +    errorDialog("Select 3 points and repeat\n")
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Macro_Draw_2D_Function.html b/localwiki/Macro_Draw_2D_Function.html new file mode 100644 index 0000000..85a3590 --- /dev/null +++ b/localwiki/Macro_Draw_2D_Function.html @@ -0,0 +1,102 @@ +Macro Draw 2D Function

      Macro Draw 2D Function

      + +
      + + + + + + + + + + + + + + + + + + + + + + + + + + +
      +

      Text-x-python.png Draw 2D Function

      +
      Description +
      Use it to draw a function described by a "equation" [z=F(x)] (Z-X plane) +
      Author +
      unknown +
      Links +
      Macros recipes
      How to install macros
      How to customize toolbars +
      Version +
      1.0 +
      Date last modification +
      2011-08-01 +
      +

      Contents

      + +
      + +
      +


      +

      Use it to draw a function described by a "equation" [z=F(x)] (Z-X plane) The example done here generate a parabol.
      +Has no dialog. Needs to be defined :
      +F = variable used in the function,
      +X = initial value of x,
      +Nb = Number of step,
      +Z = function express with x
      +ZZ = function express with xx
      +


      +

      +
      # F = variable used in the function,
      +# X = initial value of x,
      +# Nb = Number of step,
      +# Z = function express with x
      +# ZZ = function express with xx
      +
      +import FreeCAD, FreeCADGui, Part
      +import math
      +F=800
      +X=-500
      +Nb=10
      +Step=1000/Nb
      +Y=0
      +for I in range(Nb):
      +XX=X+Step 
      + Z=X*X/(4*F)
      + ZZ=XX*XX/(4*F)
      + if I==0:
      + print "Le test est vrai !"
      + nomme=Part.makeLine((X,Y,Z),(XX,Y,ZZ))
      + WWire=Part.Wire([nomme])
      + else :
      + print "Le test est 2 !"
      + nomme=Part.makeLine((X,Y,Z),(XX,Y,ZZ))
      + WWire=Part.Wire([WWire,nomme])
      + X=XX 
      + 
      +Part.show(WWire) 
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Macro_Draw_Parametric_2D_Function.html b/localwiki/Macro_Draw_Parametric_2D_Function.html new file mode 100644 index 0000000..5d66176 --- /dev/null +++ b/localwiki/Macro_Draw_Parametric_2D_Function.html @@ -0,0 +1,123 @@ +Macro Draw Parametric 2D Function

      Macro Draw Parametric 2D Function

      + +
      + + + + + + + + + + + + + + + + + + + + + + + + + + +
      +

      Text-x-python.png Macro Draw Parametric 2D Function

      +
      Description +
      Draws 2-dimensional, parametric and optionally polar equations. +
      Author +
      T4b +
      Links +
      Macros recipes
      How to install macros
      How to customize toolbars +
      Version +
      1.0 +
      Date last modification +
      2012-08-30 +
      +

      + +
      DrawParametric2DFunction +

      Description

      +

      Draws 2-dimensional, parametric and optionally polar equations. +

      +

      Limitations

      +

      Still has some bugs and misses some features. Documentation is in the docstrings. +

      +

      Use

      +

      Type : +

      +
      #Example usage:
      +draw2Dfunction(xFunction="0.5*n", yFunction="-0.75*n", n=0, nd=-math.pi, step=50, pol=1) 
      +

      Script

      +

      Macro_drawParametric2DFunction.FCMacro +

      +
      import FreeCAD, FreeCADGui, Part
      +import math
      +
      +def evalFunction(suppliedFunction, n):
      +"""This function uses eval to evaluate suppliedFunction.
      +
      +It does in no way check whether suppliedFunction is evil, thus it is itself evil!
      +"""
      +return eval(suppliedFunction)
      +
      +def draw2Dfunction(xFunction="n", yFunction="n", n=-5, nd=10, step=10, z=0, pol=0):
      +"""Draws 2-dimensional mathemathical functions
      +
      +The function is drawn for n's between n and n+nd, in steps of 1/step, on the z-coordinate z.
      +Equations for x and y can be given (xFunction and yFunction arguments), they default to n.
      +
      +If pol=1 then x is interpreted as r and y is interpreted as t.
      +"""
      +nStart=n
      +while math.fabs(n-nd)-1.0/step>0:
      +print "n: " + str(n)
      +x=evalFunction(xFunction, n)
      +y=evalFunction(yFunction, n)
      +nNext=n+math.copysign(1,nd-n)/step 
      +print "nNext: " + str(nNext)
      +xNext=evalFunction(xFunction, nNext)
      +yNext=evalFunction(yFunction, nNext)
      +if pol==0:
      +nextSeg=(x,y,z),(xNext,yNext,z)
      +else:
      +nextSeg=(x*math.cos(y),x*math.sin(y),z),(xNext*math.cos(yNext),xNext*math.sin(yNext),z)
      +print "nextSeg: " + str(nextSeg)
      +nomme=Part.makeLine(*nextSeg)
      +if n==nStart:
      +WWire=Part.Wire([nomme])
      +else:
      +WWire=Part.Wire([WWire,nomme])
      +n=nNext
      +Part.show(WWire)
      +#Example usage:
      +draw2Dfunction(xFunction="0.5*n", yFunction="-0.75*n", n=0, nd=-math.pi, step=50, pol=1) 
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Macro_Dump_Objects.html b/localwiki/Macro_Dump_Objects.html new file mode 100644 index 0000000..fc14760 --- /dev/null +++ b/localwiki/Macro_Dump_Objects.html @@ -0,0 +1,407 @@ +Macro Dump Objects

      Macro Dump Objects

      + +
      + + + + + + + + + + + + + + + + + + + + + + + + + + +
      +

      Macro Dump Objects.png Macro Dump Objects

      +
      Description +
      This macro generates a listing of all objects in the current document - the list can be in a window or on the Report view. +
      Author +
      Piffpoof +
      Links +
      Macros recipes
      How to install macros
      How to customize toolbars +
      Version +
      1.0 +
      Date last modification +
      2015-03-02 +
      +

      + +
      +


      +

      When developing complex object models it is easy to loose track of exactly which objects are present as some may be hidden, obscured or transparent. Additionally with a large number of objects a naming system becomes necessary to keep track of the objects. +

      DumpObjectsScreenSnapshot.jpg +

      +

      Description

      +

      The Dump Object code takes the current document and enumerates all the objects. A report is then generated listing each object, then a summary giving the total number of instances of each Class, followed by the total number of Classes and finally the total number of objects. The output may be directed to the Report view or to a window. The window is non-modal and will stay open until closed by the user. Each window has the time of the object dump in it's title bar, so the contents of multiple windows can be compared, say before and after a piece of code running. +

      The default operation lists all objects, optionally the placement of each object can be listed. Also for Sketches, each segment of the Geometry can be listed. +

      +

      Installation

      +

      All the code for dumpObject.FCMacro is in one macro. So installation is comprised of copying the code to the appropriate Macro directory and invoking dumpObject from the Macro menu. Alternatively it may be run from the console. +

      + +

      Usage

      +

      Select the document you wish to dump objects for, then start the macro from one of: +

      +
      • the Macro menu
      • +
      • from the Python console
      • +
      • from a Toolbar
      +

      Depending on the parameters selected in the first window, the report will be displayed on the Report view or in a window. +The information will show all objects in the current document. Some of the benefits to be expected are the detection of: +

      +
      • irregularities in object names (e.g. spelling errors or default names generated by FreeCAD)
      • +
      • duplicate objects
      • +
      • objects with duplicate names (where FreeCAD has had to make the second object name unique)
      • +
      • unexpected objects
      • +
      • unexpected object Placements (when the Show Positions option is selected)
      • +
      • unexpected segments in the Sketch Geometry (when the Show Sketcher Segments option is selected)
      +

      User Interface

      +

      The first window will take input which configures the Object Dump: +

      DumpObjectsGui1.jpg +


      +The second window will be the report on the objects in the current document: +


      +DumpObjectsGui2.jpg +

      +

      Options

      +
      • output may be directed to one of: +
        • the Report view
        • +
        • a non-modal window
      • +
      • segments in the Geometry for each Sketch may be listed
      • +
      • Placement specifics may be listed for objects
      +

      Remarks

      +

      Although tested with many object types in FreeCAD, there probably are some objects that it does not expect, in that case it should list them generically. +

      +

      Links

      +

      none (so far) +

      +

      Script

      +
      #
      +#Dump Object
      +#                       v 0.2 - added report to CSV file
      +#                       v 0.1 - added report to window
      +#                       v 0.0 - report to Report view
      +#
      +#***********************************************************************************
      +# routine to dump object space for Geometric model in the currently active file
      +#
      +# import statements
      +from PySide import QtGui, QtCore
      +from datetime import datetime# datestamp on output window
      +from os.path import expanduser# output directory for CSV
      +
      +# UI Class definitions
      +
      +class configureMacro(QtGui.QDialog):
      +""""""
      +def __init__(self):
      +super(configureMacro, self).__init__()
      +self.initUI()
      +def initUI(self):
      +self.result= None
      +# set up display only field for selected path type
      +self.cbss= QtGui.QCheckBox("Show Sketcher Segments?", self)
      +self.cbss.move(20,20)
      +self.cbp= QtGui.QCheckBox("Show Positions?", self)
      +self.cbp.move(220,20)
      +self.pathTypeLbl= QtGui.QLabel("Select Report Destination:", self)
      +self.pathTypeLbl.move(20, 70)
      +# cancel button
      +cancelButton = QtGui.QPushButton('Cancel', self)
      +cancelButton.clicked.connect(self.onCancel)
      +cancelButton.move(10, 100)
      +# button #1
      +button1 = QtGui.QPushButton(choice1, self)
      +button1.clicked.connect(self.onBtn1)
      +button1.move(120, 100)
      +# button #2
      +button2 = QtGui.QPushButton(choice2, self)
      +button2.clicked.connect(self.onBtn2)
      +button2.move(235, 100)
      +# button #3
      +button3 = QtGui.QPushButton(choice3, self)
      +button3.clicked.connect(self.onBtn3)
      +button3.move(327, 100)
      +# define windowxLoc,yLoc,xDim,yDim
      +self.setGeometry(250, 250, 435, 150)
      +self.setWindowTitle("Select a Report Destination")
      +self.setWindowFlags(QtCore.Qt.WindowStaysOnTopHint)
      +self.show()
      +def onCancel(self):
      +self.result = "cancelled"
      +self.close()
      +def onBtn1(self):
      +self.result = choice1
      +self.close()
      +def onBtn2(self):
      +self.result = choice2
      +self.close()
      +def onBtn3(self):
      +self.result = choice3
      +self.close()
      +
      +class DisplayText(QtGui.QWidget):
      +""""""
      +def __init__(self, textToDisplay):
      +self.text = textToDisplay
      +super(DisplayText, self).__init__()
      +self.initUI(textToDisplay)
      +def initUI(self, textToDisplay):
      +"""Constructor"""
      +self.textToDisplay = textToDisplay
      +# some window dimensions
      +self.windowHome = screenWidth * 0.05
      +self.windowWidth = screenWidth * 0.9
      +self.windowHeight = 400
      +self.fieldMargin = 40
      +# some column titles
      +columnLabels = QtGui.QLabel(formatPrintLine("Type / WB","Shape","User Supplied Label","Name"))
      +columnLabels.setFont('Courier')
      +# set up text editing widget
      +text_editor = QtGui.QTextEdit(self)
      +#self.setCentralWidget(self.text_editor)
      +text_editor.setFont('Courier')
      +text_editor.setLineWrapMode(QtGui.QTextEdit.NoWrap)
      +text_editor.move(self.fieldMargin,self.fieldMargin)
      +text_editor.move(0,self.fieldMargin)
      +text_editor.resize(self.windowWidth-(2*self.fieldMargin),self.windowHeight-(2*self.fieldMargin))
      +text_editor.resize(self.windowWidth,self.windowHeight-(2*self.fieldMargin))
      +text_editor.append(self.textToDisplay)
      +# set up the layout
      +vBox = QtGui.QVBoxLayout()
      +vBox.addWidget(columnLabels)
      +vBox.addWidget(text_editor)
      +self.setLayout(vBox)
      +# define windowxLoc,yLoc,xDim,yDim
      +self.setGeometry(self.windowHome, self.windowHome, self.windowWidth, self.windowHeight)
      +self.setWindowTitle("Object Dump of '" + FreeCADGui.ActiveDocument.Document.Label + "' at " + str(datetime.now()))
      +self.show()
      +#----------------------------------------------------------------------
      +def onOk(self):
      +self.close()
      +
      +# Class definitions
      +
      +# Function Definitions
      +
      +def countObjects():
      +printList = list()
      +objectTypeTable = {}
      +# build up dictionary of different classes and keep a count
      +for obj in FreeCAD.ActiveDocument.Objects:
      +if objectTypeTable.has_key(obj.TypeId):
      +objectTypeTable[obj.TypeId] = objectTypeTable[obj.TypeId]+1
      +else:
      +objectTypeTable[obj.TypeId] = 1
      +wb = obj.TypeId[0:obj.TypeId.find("::")]
      +shape = obj.TypeId[obj.TypeId.find("::")+2:]
      +#print wb + "---" + shape
      +placementString = ""
      +if obj.TypeId == "Sketcher::SketchObject":
      +printList.append(formatPrintLine("Sketch", "", str(obj.Label)))
      +if showSketcherSegmentsFlag:
      +for i in obj.Geometry:
      +printList.append(formatPrintLine("", " -segment", str(i)))
      +elif wb == "Part":
      +if showPlacementFlag:
      +placementString = str(obj.Placement)
      +if shape in ("Cylinder", "Cut", "Box", "Fuse", "Loft", "Feature", "FeaturePython", "Part2DObjectPython"):
      +printList.append(formatPrintLine(wb, shape, str(obj.Label), str(obj.Name)))
      +else: # print shapes not in list above
      +printList.append(formatPrintLine(str(obj.TypeId), "", str(obj.Label), str(obj.Name)))
      +elif wb == "PartDesign":
      +if showPlacementFlag:
      +placementString = str(obj.Placement)
      +if shape in ("Pad", "Feature", "Fillet", "Part2DObjectPython"):
      +printList.append(formatPrintLine(wb, shape, str(obj.Label), str(obj.Name)))
      +else: # print shapes not in list above
      +printList.append(formatPrintLine(str(obj.TypeId), "", str(obj.Label), str(obj.Name)))
      +elif obj.TypeId == "App::DocumentObjectGroup":
      +printList.append(formatPrintLine("Group", "", str(obj.Label)))
      +elif obj.TypeId == "Image::ImagePlane":
      +printList.append(formatPrintLine(wb, shape, str(obj.Label), str(obj.Name)))
      +else: # print workbench shapes not in lists above
      +printList.append(formatPrintLine(str(obj.TypeId), str(obj.Label), str(obj.Name)))
      +if showPlacementFlag and len(placementString)!=0:
      +printList.append(formatPrintLineMax("", " -placement", placementString))
      +
      +printList.append("")
      +printList.append(summarySeparator)
      +from collections import OrderedDict
      +sortedByTags = OrderedDict(sorted(objectTypeTable.items(), key=lambda x: x[1], reverse=True))
      +for k, v in sortedByTags.items():
      +printList.append(formatPrintLineSum(k,v))
      +printList.append("")
      +objectClassCount = 0; objectTotalCount = 0
      +for i in objectTypeTable:
      +objectTotalCount = objectTotalCount + objectTypeTable[i]
      +objectCLassCount = len(objectTypeTable)
      +printList.append(formatPrintLineSum("Object Class Total is ", str(objectCLassCount)))
      +printList.append(formatPrintLineSum("Object Total is ", str(objectTotalCount)))
      +printList.append(summarySeparator)
      +return printList
      +
      +def formatPrintLineSum(a,b):
      +return printLineFormatter(2, a, str(b), "", "")
      +
      +def formatPrintLineMax(a,b,c):
      +return printLineFormatter(1, a, b, "", "")
      +
      +def formatPrintLine(a,b,c, *args):
      +d = ""
      +if len(args)==1:
      +d = args[0]
      +return printLineFormatter(0, a, b, c, d)
      +
      +def printLineFormatter(flag,a,b,c,d):
      +# flag = 0standard print, spread values over 4 columns
      +# flag = 1printing verbose things like Sketch details or Placements, combine columns 3 & 4
      +# flag = 2printing the summary lines, combine columns 1 & 2
      +suffix = ""
      +if csvFlag:
      +pfs2 = printFormatString2csv
      +pfs3 = printFormatString3csv
      +pfs4 = printFormatString4csv
      +else:
      +pfs2 = printFormatString2
      +pfs3 = printFormatString3
      +pfs4 = printFormatString4
      +if flag==0:
      +aa = a[:f1]
      +bb = b[:f2]
      +cc = c[:f3]
      +dd = d[:f4]
      +return pfs4.format(aa,bb,cc,dd)
      +elif flag==1:
      +aa = a[:f1]
      +bb = b[:f2]
      +cc = c[:f3+f4]
      +dd = d[:f4]
      +return pfs3.format(aa,bb,cc)
      +else:
      +aa = a[:f1+f2]
      +bb = b[:f3+f4]
      +return pfs2.format(aa,bb)
      +
      +# Constant definitions
      +# set some field widths
      +screenWidth = QtGui.QDesktopWidget().screenGeometry().width()
      +global f1, f2, f3, f4
      +# f1 = 15; f2 = 25; f3 = 45; f4 = 25 # 110 columns in 1000 pixels
      +f1 = 15*screenWidth/1000; f2 = 25*screenWidth/1000; f3 = 45*screenWidth/1000; f4 = 25*screenWidth/1000
      +# and some print format strings
      +global printFormatString2, printFormatString3, printFormatString4
      +global printFormatString2csv, printFormatString3csv, printFormatString4csv
      +printFormatString2 = "{0:<"+str(f1+f2)+"} {1:<"+str(f3)+"}"
      +printFormatString2csv = "{0}, {1}"
      +printFormatString3 = "{0:<"+str(f1)+"} {1:<"+str(f2)+"} {2:<"+str(f3+f4)+"}"
      +printFormatString3csv = "{0}, {1}, {2}"
      +printFormatString4 = "{0:<"+str(f1)+"} {1:<"+str(f2)+"} {2:<"+str(f3)+"} {3:<"+str(f4)+"}"
      +printFormatString4csv = "{0}, {1}, {2}, {3}"
      +# some button labels that are checked in the code
      +global choice1, choice2, choice3, csvFlag
      +choice1 = "Report View"; choice2 = "CSV File"; choice3 = "Window"
      +csvFlag = False
      +summarySeparator = "======================================================="
      +summarySeparatorCsv = "-------------------------------------------------------"
      +# code ***********************************************************************************
      +if FreeCAD.ActiveDocument != None:
      +# ask if to window or to Report View...
      +form = configureMacro()
      +form.exec_()
      +showSketcherSegmentsFlag = False
      +if form.cbss.isChecked():
      +showSketcherSegmentsFlag = True
      +showPlacementFlag = False
      +if form.cbp.isChecked():
      +showPlacementFlag = True
      +if form.result == choice2:
      +csvFlag = True
      +showSketcherSegmentsFlag = False
      +showPlacementFlag = False
      +summarySeparator = summarySeparatorCsv
      +printList = countObjects()
      +if form.result == choice1: # report to Report View
      +mainWindow = FreeCADGui.getMainWindow()
      +dockWidgets = mainWindow.findChildren(QtGui.QDockWidget)
      +reportViewFlag = False
      +for dw in dockWidgets:
      +if dw.objectName() == "Report view":
      +reportViewFlag = True
      +if reportViewFlag:
      +print printFormatString4.format("", "", "(User Supplied)", "")
      +print printFormatString4.format("Type", "Shape", "Label", "Name")
      +print ""
      +for line in printList:
      +print line + "\n"
      +else:
      +QtGui.QMessageBox.information(None,"","Please use 'Menu->View->Views->Report view' to open the 'Report view'")
      +if form.result == choice2: # report to CSV file
      +filePath = QtGui.QFileDialog.getSaveFileName(parent=None,caption="Save CSV file as",dir=expanduser("~"),filter="*.csv")
      +file = open(filePath[0],"w")
      +for line in printList:
      +file.write(line + "\n")
      +file.close()
      +if form.result == choice3: # report to window
      +#----------------------------------------------------------------------
      +longPrintLine = ""
      +for line in printList:
      +longPrintLine = longPrintLine + line + "\n"
      +form = DisplayText(longPrintLine)
      +#
      +#OS: Mac OS X
      +#Word size: 64-bit
      +#Version: 0.14.3703 (Git)
      +#Branch: releases/FreeCAD-0-14
      +#Hash: c6edd47334a3e6f209e493773093db2b9b4f0e40
      +#Python version: 2.7.5
      +#Qt version: 4.8.6
      +#Coin version: 3.1.3
      +#SoQt version: 1.5.0
      +#OCC version: 6.7.0
      +#
      +#thus ends the macro... 
      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Macro_Duplicate_Selection.html b/localwiki/Macro_Duplicate_Selection.html new file mode 100644 index 0000000..c878bea --- /dev/null +++ b/localwiki/Macro_Duplicate_Selection.html @@ -0,0 +1,133 @@ +Macro Duplicate Selection

      Macro Duplicate Selection

      + +
      + + + + + + + + + + + + + + + + + + + + + + + + + + +
      +

      Text-x-python.png Macro Duplicate Selection

      +
      Description +
      This macro testing if one selection are duplicate. +
      Author +
      Mario52 +
      Links +
      Macros recipes
      How to install macros
      How to customize toolbars +
      Version +
      00.00 +
      Date last modification +
      2016-06-06 +
      +

      + +
      +


      +

      +

      Description

      +

      This macro testing if one selection are duplicate , select the object IN THE 3D VIEW the "ForbiddenCursor" stay if the or one selection is duplicate, the macro stay resident. +

      +

      How to use

      +

      Run the macro, the macro stay resident in memory. +

      Select yours objects selected is duplicate the cursor mouse ere displayed "ForbiddenCursor" +

      +

      Script

      +

      Macro_Duplicate_Selection.FCMacro +

      +
      # -*- coding: utf-8 -*-
      +import FreeCADGui
      +import PySide
      +from PySide import QtGui ,QtCore
      +from PySide.QtGui import *
      +from PySide.QtCore import *
      +
      +__title__   = "Macro_Duplicate_Selection"
      +__author__  = "Mario52"
      +__url__     = "http://www.freecadweb.org/index-fr.html"
      +__version__ = "00.00"
      +__date__    = "06/06/2016"
      +
      +__Help__    = "Start the macro select the object IN THE 3D VIEW the ForbiddenCursor stay if the selection is duplicate"
      +
      +def selectionObject():
      +    sel = FreeCADGui.Selection.getSelection() 
      +    x  = []
      +    del x[:]
      +    for a in range(len(sel)):
      +       x.append(sel[a].Name)
      +    doublet = 0
      +    for i in range(len(sel)):
      +        for ii in range((i+1),len(sel)):
      +            if x[i] == x[ii]:
      +                doublet = 1
      +                break
      +    if doublet == 1:
      +        QtGui.QApplication.setOverrideCursor(QtGui.QCursor(QtCore.Qt.ForbiddenCursor))
      +#        FreeCAD.Console.PrintError("HELP "+sel[-1].Name+" duplicate selection"+"\n")
      +    else:
      +        QtGui.QApplication.setOverrideCursor(QtGui.QCursor(QtCore.Qt.ArrowCursor))
      +
      +class SelObserver:
      +    def addSelection(self,doc,obj,sub,pnt):   # Selection
      +        selectionObject()
      +    def removeSelection(self,doc,obj,sub):    # Effacer l'objet salectionne
      +        selectionObject()
      +    def setPreselection(self, doc, obj, sub):
      +        selectionObject()
      +    def clearSelection(self,doc):             # Si clic sur l'ecran, effacer la selection
      +        selectionObject()
      +#    def setSelection(self,doc):               # Selection dans Combo View pour quitter la fonction
      +#        App.Console.PrintMessage("Fin Macro_Duplicate"+"\n")
      +#        QtGui.QApplication.setOverrideCursor(QtGui.QCursor(QtCore.Qt.ArrowCursor))
      +#        FreeCADGui.Selection.removeObserver(s)# desinstalle la fonction residente
      +
      +s=SelObserver()
      +FreeCADGui.Selection.addObserver(s)    # installe la fonction en mode resident 
      +

      Links

      +

      The forum discussion Duplicate Objects when more than one face selected +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Macro_Dxf_To_Shape.html b/localwiki/Macro_Dxf_To_Shape.html new file mode 100644 index 0000000..528c4dd --- /dev/null +++ b/localwiki/Macro_Dxf_To_Shape.html @@ -0,0 +1,117 @@ +Macro Dxf To Shape

      Macro Dxf To Shape

      + +
      Documentation not finished, not translate thanks
      +


      +

      + + + + + + + + + + + + + + + + + + + + + + + + + + + +
      +

      Macro Dxf To Shape.png Macro Dxf To Shape

      +
      Description +
      Macro utility for create unique wire with many wires macro. +
      Author +
      Mario52 +
      Links +
      Macros recipes
      How to install macros
      How to customize toolbars +
      Version +
      01.00 +
      Date last modification +
      2016-11-21 +
      +

      + +
      +


      +

      +

      Description

      +

      Macro utility for create unique wire with many wires, the type wire created is selected to MakeWire, Bspline, BsplineCurve, BsplineCurve + Arc, Polygon, Bezier curve. +

      +

      Use

      +

      Principe : +

      +
      • downgrade the compound line for work with single line
      • +
      • first line discretize the line (precision on choice)
      • +
      • the linetest is created on choice MakeWire, Bspline, BsplineCourve, Polygon, BezCurve (display the orientation
      +

      Begin - End (Reversed Forward) +

      +
      • test is good .. then Save DataT coordinates in file (and Del Test If you want)
      • +
      • second line same first line and accord end to begin ....
      • +
      • test is good .. then Save DataT coordinates in file (and Del Test If you want)
      • +
      • ...... tests finished
      • +
      • Read DataT saved in on unique wire with the type line selected
      +

      you can also test one sweep, force reverse, close wire, create points, cloud ... +

      you can also Save the file in disk +

      ( Save DataT, Read DataT, Reset DataT Are the Temporary working file) +


      +

      +
      +

      Macro_Dxf_To_Shape +

      +
      +


      +

      +

      Script

      +

      The icon for you toolBar Macro Dxf To Shape.png copy in same directory to the macro +

      How to Customize Toolbars, How to install macros +

      The script to github Macro_DXF_to_Shape.FCMacro +

      +

      Example

      +

      Here convert Wire (multi lines) in BsplineCurve +

      Macro Dxf To Shape Convert Wire To BSplineCurve.gif +

      here with selected face +

      Macro Dxf To Shape Convert Wire To BSplineCurve02.gif +

      +

      Links

      +

      Mes macros sur Github +

      +

      Version

      +
      • 21/11/2016 ver 00.00 :
      + + + +
      + +
      +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Macro_Dxf_To_Shape.png b/localwiki/Macro_Dxf_To_Shape.png new file mode 100644 index 0000000..32ab26d Binary files /dev/null and b/localwiki/Macro_Dxf_To_Shape.png differ diff --git a/localwiki/Macro_Dxf_To_Shape_Convert_Wire_To_BSplineCurve.gif b/localwiki/Macro_Dxf_To_Shape_Convert_Wire_To_BSplineCurve.gif new file mode 100644 index 0000000..0d4f4be Binary files /dev/null and b/localwiki/Macro_Dxf_To_Shape_Convert_Wire_To_BSplineCurve.gif differ diff --git a/localwiki/Macro_Dxf_To_Shape_Convert_Wire_To_BSplineCurve02.gif b/localwiki/Macro_Dxf_To_Shape_Convert_Wire_To_BSplineCurve02.gif new file mode 100644 index 0000000..55f5403 Binary files /dev/null and b/localwiki/Macro_Dxf_To_Shape_Convert_Wire_To_BSplineCurve02.gif differ diff --git a/localwiki/Macro_Easy_cutouts_for_Enclosure_Design.html b/localwiki/Macro_Easy_cutouts_for_Enclosure_Design.html new file mode 100644 index 0000000..c22aefc --- /dev/null +++ b/localwiki/Macro_Easy_cutouts_for_Enclosure_Design.html @@ -0,0 +1,322 @@ +Macro Easy cutouts for Enclosure Design

      Macro Easy cutouts for Enclosure Design

      + +
      + + + + + + + + + + + + + + + + + + + + + + + + + + +
      +

      Macro Easy cutouts for Enclosure Design icon.png Easy cutouts for Enclosure Design

      +
      Description +
      This macro makes Cutouts for Enclosures in a very handy way +
      Author +
      maurice +
      Links +
      Macros recipes
      How to install macros
      How to customize toolbars +
      Version +
      0.25 +
      Date last modification +
      2016-11-26 +
      +

      + +
      +


      +

      +

      Description

      +

      This macro makes Cutouts for Enclosures in a very handy way +
      +Just select a face of the object that is the base for the cutout and the macro will create a clone of the external outline with a margin of 0.5mm (set in the macro) +
      here a demo with an Arduino Uno enclosure +

      +
      +

      Easy-cutouts.gif +

      +
      +


      +

      +

      Use

      +

      Just select a face of the object that is the base for the cutout and the macro will create a clone of the external outline with a margin of 0.5mm (set in the macro) +

      +

      Script

      +

      The Icon for you ToolBar Macro Easy cutouts for Enclosure Design icon.png +

      Macro_Center Faces of Parts.FCMacro +


      +

      +
      # -*- coding: utf-8 -*-
      +# clone, enlarge & center clone-obj to selected obj
      +#
      + 
      +__title__   = "Clone-Enlarge-Center Face for cutouts"
      +__author__  = "maurice"
      +__url__     = "kicad stepup"
      +__version__ = "0.25"
      +__date__    = "11.2016"
      +
      +import FreeCAD, FreeCADGui, Draft, Part, DraftTools
      +from FreeCAD import Base
      +
      +
      +def say(msg):
      +    FreeCAD.Console.PrintMessage(msg)
      +    FreeCAD.Console.PrintMessage('\n')
      +
      +def sayw(msg):
      +    FreeCAD.Console.PrintWarning(msg)
      +    FreeCAD.Console.PrintWarning('\n')
      + 
      +def getNormal(self):
      +    return self.Object.Shape.Faces[0].normalAt(0,0)
      +
      +#Init        
      +if Gui.ActiveDocument <> None:
      +    #say (Gui.ActiveDocument)
      +
      +    cx = 1  # center x -> 1  
      +    cy = 1  # center y -> 1 
      +    cz = 1  # center z -> 1 
      +    
      +    # scaleX = 1.1 # scale factor for Clone
      +    # scaleY = 1.1 # scale factor for Clone
      +    # scaleZ = 1.1 # scale factor for Clone
      +    
      +    margin = 0.5 #margin in mm
      +    extrudeLenght = 10 #10mm    
      +    #selEx = FreeCADGui.Selection.getSelectionEx()
      +    sel = FreeCADGui.Selection.getSelection()
      +    
      +    #print sel[0].Label
      +    #objs = [selobj.Object for selobj in selEx]
      +    selF = FreeCADGui.Selection.getSelectionEx()
      +    
      +    #if len(Gui.Selection.getSelectionEx()[0].SubElementNames) <1:
      +    #    stop
      +    
      +    if len(sel) > 0:
      +        FreeCADGui.Selection.removeSelection(sel[0])
      +    #for o in FreeCADGui.ActiveDocument.getObjects():
      +    #    FreeCADGui.Selection.removeSelection(o.Name)
      +    coords = []
      +    j = 0
      +    #if len(sel) == 1: # only 1 object selected
      +    #if len(selF) == 1: # only 1 object selected
      +    if len(sel) > 0:
      +        if len(selF[0].SubElementNames) ==1:
      +            f_names=[]
      +            f = Draft.makeFacebinder(selF)
      +            f1=App.ActiveDocument.getObject(f.Name)
      +            face=0
      +            try:
      +                norm = f1.Shape.Faces[0].normalAt(0,0)
      +                say (norm)
      +                face=1
      +            except:
      +                App.Console.PrintMessage("Select ONLY one single Face of object!"+"\n")
      +                # stop
      +            if face==1:
      +                l = Draft.downgrade(f,delete=False)
      +                k = 0; bbM = 0
      +                for o in l:
      +                    for w in o:
      +                        #print w.Name
      +                        f_names.append (w.Name)
      +                        say(w.Name)
      +                        if "Facebinder" not in w.Name:
      +                            bb=w.Shape.BoundBox
      +                            bbX=float(bb.XLength)
      +                            bbY=float(bb.YLength)
      +                            bbZ=float(bb.ZLength)
      +                            say (str(bbX)+";"+str(bbY)+";"+str(bbZ))
      +                            if bbX > bbM:
      +                                bbM = bbX; m = k
      +                            if bbY > bbM:
      +                                bbM = bbY; m = k
      +                            if bbZ > bbM:
      +                                bbM = bbZ; m = k
      +                        k=k+1
      +                print f_names
      +                k = 0
      +                #f_names=[]
      +                for o in l:
      +                    for w in o:
      +                        say(w.Name)
      +                        #f_names.append (w.Name)
      +                        if k!=m:
      +                            say ( "deleting "+f_names[k] )
      +                            FreeCAD.ActiveDocument.removeObject(f_names[k])
      +                        else:
      +                            FreeCADGui.ActiveDocument.getObject(f_names[k]).Visibility=False
      +                            f = FreeCAD.ActiveDocument.addObject('Part::Extrusion', 'Extrude_for_cut')
      +                            f = FreeCAD.ActiveDocument.getObject(f.Name)
      +                            f.Base = FreeCAD.ActiveDocument.getObject(f_names[k])
      +                            f.Dir = norm * extrudeLenght * -1
      +                            f.Solid = (True)
      +                            f.TaperAngle = (0)
      +                        k=k+1        
      +                #FreeCAD.ActiveDocument.removeObject(f_names[len(l)])
      +                say( f_names )
      +                say( f_names[m] )
      +                say( bbM )
      +                
      +                FreeCADGui.Selection.addSelection(FreeCAD.ActiveDocument.getObject(f.Name))
      +                FreeCAD.ActiveDocument.recompute()
      +                
      +                sel = FreeCADGui.Selection.getSelection()   
      +                #objs = [selobj.Object for selobj in selEx]
      +                
      +                coords = []
      +                j = 0
      +                s = sel[0].Shape
      +                
      +                bb=s.BoundBox
      +                
      +                bbX=float(bb.XLength)
      +                bbY=float(bb.YLength)
      +                bbZ=float(bb.ZLength)
      +                # boundBox
      +                boundBox_ = s.BoundBox
      +                
      +                a = str(boundBox_)
      +                a,b = a.split('(')
      +                c = b.split(',')
      +                oripl_X = float(c[0])
      +                oripl_Y = float(c[1])
      +                oripl_Z = float(c[2])
      +                coords.append ([oripl_X+bbX/2, oripl_Y+bbY/2, oripl_Z+bbZ/2])
      +                App.Console.PrintMessage(str(boundBox_)+"\r\n")
      +                App.Console.PrintMessage("BBox           : "+str(bbX)+" x "+str(bbY)+" x "+str(bbZ)+"\r\n")
      +                App.Console.PrintMessage("Base Pos       : "+str(oripl_X)+" x "+str(oripl_Y)+" x "+str(oripl_Z)+"\r\n")
      +                App.Console.PrintMessage("Center Pos     : "+str(oripl_X+bbX/2)+" x "+str(oripl_Y+bbY/2)+" x "+str(oripl_Z+bbZ/2)+"\r\n")
      +                App.Console.PrintMessage("Coords         : "+str(coords[j])+"\r\n")
      +            
      +                #objC = FreeCAD.ActiveDocument.addObject('Part::AttachableObjectPython', 'Clone_for_cut')
      +                #objC = FreeCAD.ActiveDocument.getObject(objC.Name)
      +                objC=Draft.clone(sel)
      +                if bbX!=0:
      +                    scaleX = (bbX + 2*margin) / bbX
      +                else:
      +                    scaleX = 1
      +                if bbY!=0:
      +                    scaleY = (bbY + 2*margin) / bbY
      +                else:
      +                    scaleY = 1
      +                if bbZ!=0:
      +                    scaleZ = (bbZ + 2*margin) / bbZ
      +                else:
      +                    scaleZ = 1
      +                objC.Scale = (scaleX,scaleY,scaleZ)
      +                #Draft.scale(objC,delta=App.Vector(scaleX,scaleY,scaleZ),center=App.Vector(0,0,0),copy=True,legacy=True)
      +                
      +                oL = sel[0].Label + "_enlarged"
      +                objC.Label = oL
      +                FreeCADGui.Selection.addSelection(objC)
      +                
      +                FreeCAD.ActiveDocument.recompute()
      +            
      +                selEx = FreeCADGui.Selection.getSelectionEx()
      +                objs = [selobj.Object for selobj in selEx]
      +                coords = []
      +                j = 0
      +                if len(objs) >= 1:
      +                    for obj in objs:
      +                        #s = objs[0].Shape
      +                        s = obj.Shape
      +                        
      +                        # boundBox
      +                        boundBox_ = s.BoundBox
      +                        boundBoxLX = boundBox_.XLength
      +                        boundBoxLY = boundBox_.YLength
      +                        boundBoxLZ = boundBox_.ZLength
      +                        
      +                        a = str(boundBox_)
      +                        a,b = a.split('(')
      +                        c = b.split(',')
      +                        oripl_X = float(c[0])
      +                        oripl_Y = float(c[1])
      +                        oripl_Z = float(c[2])
      +                        coords.append ([oripl_X+boundBox_.XLength/2, oripl_Y+boundBox_.YLength/2, oripl_Z+boundBox_.ZLength/2])
      +                        App.Console.PrintMessage(str(boundBox_)+"\r\n")
      +                        App.Console.PrintMessage("BBox           : "+str(boundBox_.XLength)+" x "+str(boundBox_.YLength)+" x "+str(boundBox_.ZLength)+"\r\n")
      +                        App.Console.PrintMessage("Base Pos       : "+str(oripl_X)+" x "+str(oripl_Y)+" x "+str(oripl_Z)+"\r\n")
      +                        App.Console.PrintMessage("Center Pos     : "+str(oripl_X+boundBox_.XLength/2)+" x "+str(oripl_Y+boundBox_.YLength/2)+" x "+str(oripl_Z+boundBox_.ZLength/2)+"\r\n")
      +                        App.Console.PrintMessage("Coords         : "+str(coords[j])+"\r\n")
      +                        if j>0:
      +                            if cx==1:
      +                                coordNx=coords[0][0]-coords[j][0]
      +                            else:
      +                                coordNx=0
      +                            if cy==1:
      +                                coordNy=coords[0][1]-coords[j][1]
      +                            else:
      +                                coordNy=0
      +                            if cz==1:
      +                                coordNz=coords[0][2]-coords[j][2]
      +                            else:
      +                                coordNz=0
      +                            obj.Placement.move(App.Vector(coordNx,coordNy,coordNz))
      +                            App.Console.PrintMessage("Moved     : "+str(coordNx)+" "+str(coordNy)+" "+str(coordNz)+"\r\n")
      +                        j=j+1
      +                    
      +                        App.Console.PrintMessage("_____________________"+"\r\n")
      +                        
      +                    FreeCADGui.Selection.removeSelection(objs[0])
      +                    FreeCADGui.ActiveDocument.getObject(objs[0].Name).Visibility=False
      +                    FreeCADGui.ActiveDocument.getObject(objs[1].Name).Transparency=70
      +                    App.ActiveDocument.recompute() 
      +            
      +        else:
      +            App.Console.PrintMessage("Select ONLY one single Face of object!"+"\n")
      +    else:
      +        App.Console.PrintMessage("Select ONLY one single Face of object!"+"\n")
      +else:
      +    sayw("no document to work with")   
      +    #http://forum.freecadweb.org/viewtopic.php?t=4625 
      +

      Link

      +

      Forum : Easy cutouts for Enclosure Design Macro +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Macro_Easy_cutouts_for_Enclosure_Design_icon.png b/localwiki/Macro_Easy_cutouts_for_Enclosure_Design_icon.png new file mode 100644 index 0000000..140aabc Binary files /dev/null and b/localwiki/Macro_Easy_cutouts_for_Enclosure_Design_icon.png differ diff --git a/localwiki/Macro_EdgesToArc.html b/localwiki/Macro_EdgesToArc.html new file mode 100644 index 0000000..bb1e9bd --- /dev/null +++ b/localwiki/Macro_EdgesToArc.html @@ -0,0 +1,135 @@ +Macro EdgesToArc

      Macro EdgesToArc

      + +
      + + + + + + + + + + + + + + + + + + + + + + + + + + +
      +

      Text-x-python.png EdgesToArc

      +
      Description +
      Replaces the selected Edges by a circular Arc if possible. Useful for restoring discretized arcs. +
      Author +
      Jreinhardt +
      Links +
      Macros recipes
      How to install macros
      How to customize toolbars +
      Version +
      1.0 +
      Date last modification +
      2014-01-02 +
      +

      Contents

      + +
      + +
      +


      +

      Sometimes one encounters wires that contain arcs that are made up of small straight segments. This often happens when working with files from other programs. This macro makes it relatively easy to convert these discretized arcs back to circular arcs. This reduces the file size and makes the file more manageable. +

      To use this macro, you have to break down the wire into individual edges using the Draft Downgrade.png Draft Downgrade function. Then just select the segments that you want to replace by an circular arc and execute the macro. You need at least two segments. +

      The macro will check whether the segments all lie on a common circle and will abort if this is not the case. Otherwise it will create the arc and remove the segments. +

      Because of small inaccuracies in the calculations, the Draft Upgrade.png Draft Upgrade function can sometimes fail to recombine the other edges and the arcs back into a wire. In this case the Macro_SuperWire provides a more robust way to do this. +


      +

      +
      import Draft
      +import FreeCADGui, FreeCAD
      +from FreeCAD import Base, Console
      +from math import atan2, pi, fabs
      +
      +#This macro replaces a number of edges approximating a circular arc by a proper circular arc.
      +#It might be necessary to use the superwire macro to recombine the edges back to a wire, because of small errors in the calculations.
      +
      +sel = FreeCADGui.Selection.getSelection()
      +if len(sel) < 2:
      +    Console.PrintError("Too few edges are selected\n")
      +edges = [s.Shape for s in sel]
      +
      +start_vertices = []
      +end_vertices = []
      +for edge in edges:
      +    start_vertices.append(edge.Vertexes[0].Point)
      +    end_vertices.append(edge.Vertexes[1].Point)
      +vertices = start_vertices + end_vertices
      +
      +start,end,middle = None,None,None
      +
      +#find start and end points
      +for edge in edges:
      +    is_start = True
      +    is_end = True
      +    for point in end_vertices:
      +        if edge.Vertexes[0].Point.distanceToPoint(point) < 1e-8:
      +            is_start = False
      +
      +    for point in start_vertices:
      +        if edge.Vertexes[1].Point.distanceToPoint(point) < 1e-8:
      +            is_end = False
      +    if is_start:
      +        start = edge.Vertexes[0].Point
      +    if is_end:
      +        end = edge.Vertexes[1].Point
      +
      +#find middle point, at least not too far away from the middle
      +
      +for v in vertices:
      +    ratio = v.distanceToPoint(start)/v.distanceToPoint(end)
      +    if ratio > 0.5 and ratio < 2.:
      +        middle = v
      +        break
      +
      +if middle is None:
      +    Console.PrintError("Could not find suitable middle point\n")
      +
      +arc = Part.ArcOfCircle(start,middle,end)
      +
      +#Check circularity
      +circular = True
      +for v in vertices:
      +    if fabs(v.distanceToPoint(arc.Center) - arc.Radius) > 1e-6:
      +        Console.PrintError("Edges do not approximate a circular arc\n")
      +        circular = False
      +        break
      +
      +if circular:
      +        Part.show(arc.toShape())
      +        for shape in sel:
      +            FreeCAD.ActiveDocument.removeObject(shape.Name) 
      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Macro_Ellipse-Center%2B2Points.html b/localwiki/Macro_Ellipse-Center%2B2Points.html new file mode 100644 index 0000000..30f536d --- /dev/null +++ b/localwiki/Macro_Ellipse-Center%2B2Points.html @@ -0,0 +1,98 @@ +Macro Ellipse-Center%2B2Points

      Macro Ellipse-Center%2B2Points

      + +
      + + + + + + + + + + + + + + + + + + + + + + + + + + +
      +

      Text-x-python.png Macro Ellipse-Center+2Points

      +
      Description +
      Makes an ellipse by selecting three points (in this order): centre, major radius and minor radius +
      Author +
      Eriossoltero +
      Links +
      Macros recipes
      How to install macros
      How to customize toolbars +
      Version +
      01.00 +
      Date last modification +
      2016-12-25 +
      +

      + +
      +


      +

      Makes an ellipse by selecting three points (in this order): centre, major radius and minor radius +


      +EllipseCenter2Point.png +

      +
      +
      # Macro Begin: Ellipse-Center+2Points.FCMacro +++++++++++++++++++++++++++++++++++++++++++++++++
      +# http://freecad-tutorial.blogspot.com/2011/12/engine-9-poly-v-belt.html
      +import Part, FreeCAD, math, PartGui, FreeCADGui
      +from FreeCAD import Base
      +
      +# get the selected objects, with first selection for the trajectory and second for the section
      +# Adapted from:
      +# http://freecad-tutorial.blogspot.com/2011/12/engine-9-poly-v-belt.html
      +s = FreeCADGui.Selection.getSelection()
      +try:
      +sel1=s[0].Shape
      +sel2=s[1].Shape
      +sel3=s[2].Shape
      +except:
      +print "Wrong selection"
      +
      +pt_center = sel1.Point
      +pt_radmay = sel2.Point
      +pt_radmen = sel3.Point
      +
      +# create Part object in the current document
      +myObject=App.ActiveDocument.addObject("Part::Feature","Ellipse")
      +
      +# create a shape and assign it to the current document
      +ellipse = Part.Ellipse(pt_radmay, pt_radmen, pt_center)
      +myObject.Shape = ellipse.toShape()
      +# Macro End: Ellipse-Center+2Points.FCMacro +++++++++++++++++++++++++++++++++++++++++++++++++ 
      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Macro_Extract_Wires_from_Mesh.html b/localwiki/Macro_Extract_Wires_from_Mesh.html new file mode 100644 index 0000000..bd57f93 --- /dev/null +++ b/localwiki/Macro_Extract_Wires_from_Mesh.html @@ -0,0 +1,97 @@ +Macro Extract Wires from Mesh

      Macro Extract Wires from Mesh

      + +
      + + + + + + + + + + + + + + + + + + + + + + + + + + +
      +

      Text-x-python.png Macro Extract Wires from Mesh

      +
      Description +
      Extracts boundary wires from selected meshes +
      Author +
      Yorik +
      Links +
      Macros recipes
      How to install macros
      How to customize toolbars +
      Version +
      1 +
      Date last modification +
      2016-12-17 +
      +

      + +
      +


      +

      +

      Description

      +

      Finds boundary wires in selected mesh objects. Boundary wires are formed from all the edges found in the mesh that are shared by only one face, that is, they are "border" edges. The found wires get added to the document (one compound per mesh object), while the mesh itself gets hidden. +

      +

      Script

      +
      #!/usr/bin/python
      +
      +# This macro will extract wires from selected meshes
      +# The result is a new Part Compound containing wires, one per original mesh object
      +# The selected meshes will be hidden but still selected after the operation.
      +# Warning, it takes a bit of time...
      +
      +import FreeCAD,FreeCADGui,Part,Draft,DraftGeomUtils,Mesh
      +for obj in FreeCADGui.Selection.getSelection():
      +    if obj.isDerivedFrom("Mesh::Feature"):
      +        shape = Part.Shape()
      +        shape.makeShapeFromMesh(obj.Mesh.Topology,0.1)
      +        edges = []
      +        lut = {}
      +        for f in shape.Faces:
      +            for e in f.Edges:
      +                lut.setdefault(e.hashCode(),[]).append(e)
      +        for k,v in lut.items():
      +            if len(v) == 1:
      +                edges.extend(v)
      +        if edges:
      +            wires = DraftGeomUtils.findWires(edges)
      +            if wires:
      +                Part.show(Part.makeCompound(wires))
      +                obj.ViewObject.hide() 
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Macro_FCCamera.html b/localwiki/Macro_FCCamera.html new file mode 100644 index 0000000..c962a1f --- /dev/null +++ b/localwiki/Macro_FCCamera.html @@ -0,0 +1,273 @@ +Macro FCCamera

      Macro FCCamera

      + +
      + + + + + + + + + + + + + + + + + + + + + + + + + + +
      +

      FCCamera 00.png Macro FCCamera

      +
      Description +
      This macro can rotate the screen in a defined angle and the defined axis and creates a plan to face the screen. +
      Author +
      Mario52 +
      Links +
      Macros recipes
      How to install macros
      How to customize toolbars +
      Version +
      0.7 +
      Date last modification +
      2018-01-03 +
      +

      + +
      +


      +

      +

      Description

      +

      This macro can rotate the screen in a defined angle and the defined axis and creates a plan to face the screen to create a form in the specified plan positions the selected face facing the screen, to detect the position of the camera, align view to face or to axis, align the object to view. +

      +

      How to use

      +

      Use is easy, +

      +
      FCCamera
      +

      Camera of Axis: The dialog box to enter the rotation value angle in degrees. +

      Angle rotation Axis in degrees: Select the rotation axis X Y or Z. +

      Axe of rotation +

      +
      • FCCamera 01.png Accept the rotation : Accept the rotation give to angle selected
      +

      Virtual +

      +
      • FCCamera 02.png Detect camera orientation : Detect the camera orientation and print in report view. The returned value is the value provided by the function getCameraOrientation().
      +

      Align view to face selected +

      +
      • FCCamera 03.png To Face. : Align the view to the selected face. Click and repeat the click for NormalAt : "(0,0,1) (0,0,-1) (0,1,0) (0,-1,0) (1,0,0) (-1,0,0)"
      +
      • FCCamera 04.png To Axis. : Align the view to Axis face selected. Click and repeat the click for Surface Axis : "(0,0,1) (0,0,-1) (0,1,0) (0,-1,0) (1,0,0) (-1,0,0)"
      +
      • FCCamera 05.png Align object to view. : Align the object selected to the actual view. The changed values are : Rotation Axis((X, Y, Z), Angle) Same Euler angles : Yaw, Pitch, Roll, The Translation is not modify.
      +
      • FCCamera 06.png Create plane of view. : A circular plane is created facing the screen to mouse click coordinates on an object. The radius of the plane is equal to the maximum dimension of BoundBox. If no object is selected, the plane is created to 0, 0, 0 coordinates with a radius of 20 mm. The radius is modifiable to line 515:
      +
      rayon = 20                            # Radius of plane 
      +
      • FCCamera 07.png Reset. : Reset all values.
      • +
      • FCCamera 00.png Photo. : Section save the screen rotation an image in angle value
      • +
      • FCCamera 08.png Quit. : Quit FCCamera.
      +

      Section Photo

      +
      FCCamera
      +
      +


      +

      +
      • ComboBox Actual  : choice your screen definition for the image format +
        • Available (pre-defined): +
          • "Actual" (definition actual of screen)
          • +
          • "Icon 16 x 16"
          • +
          • "Icon 32 x 32"
          • +
          • "Icon 64 x 64"
          • +
          • "Icon 128 x 128"
          • +
          • "CGA 320 x 200"
          • +
          • "QVGA 320 x 240"
          • +
          • "VGA 640 x 480"
          • +
          • "SVGA 800 x 600"
          • +
          • "XGA 1024 x 768"
          • +
          • "XGA+ 1152 x 864"
          • +
          • "SXGA 1280 x 1024"
          • +
          • "SXGA+ 1400 x 1050"
          • +
          • "UXGA 1600 x 1200"
          • +
          • "QXGA 2048 x 1536"
          • +
          • "Free"
      +
      • SpinBox X and Y
      +
      • ComboBox Format image +
        • Available : +
          • "BMP *.bmp"
          • +
          • "ICO *.ico"
          • +
          • "JPEG *.jpeg"
          • +
          • "JPG *.jpg"
          • +
          • "PNG *.png" (by default)
          • +
          • "PPM *.ppm"
          • +
          • "TIF *.tif"
          • +
          • "TIFF *.tiff"
          • +
          • "XBM *.xbm"
          • +
          • "XPM *.xpm"
      +
      • Line 1 : Number image calculated by the angle give (ex: angle 60 degrees = 360 (complete rotation) / 60 (angle) = 6 images
      +
      • Line 2 : The definition of screen used
      +
      • Background image : +
        • Actual : save image with the screen colour actual
        • +
        • White : save image with the screen colour white
        • +
        • Black : save image with the screen colour black
      +
      • FCCamera 00.png Launch : Open the file window , give the name and the path
      • +
      • FCCamera 07.png Reset : Reset the default value
      • +
      • FCCamera 00.png Return : Quit the photo panel and return to FCCamera panel
      +

      Icons

      +

      Download the file image and copy in your macro repertory. +

      Click the image, in the new window position the mouse over the image, click the right mouse and do "Save target as ..." +

      The path of icons is displayed in the View report +

      ex: Path locality to FCCamera.....images.png [ C:\Users\xx\AppData\Roaming\FreeCAD\ ] +

      You can change the path by changing the path in the line 165 +

      Icons program : +

      +
      + +
      +

      Logo FCCamera Accept Detect To Face +To Axis Align Object to View Create plane Reset +Quit +

      +
      +

      Icons tableau : +Axis X +Axis Y +Axis Z +Direction Axis +


      +

      +

      Links

      +

      Related Links with FCCamera +

      Macro Rotate View, Macro Align Object to View, Macro Align Face Object to View, Macro WorkFeatures +

      Discussion Forum MACRO:Work Feature 2014_12 +

      +

      Script

      +

      Download the macro to Gist Macro FCCamera.FCMacro +

      +

      Examples

      +

      How to place an angle hole

      +
      + +
      +
      + +
      +
      + +
      +

      The same result can be achieved by creating a plan in the corner gave the mouse click position and a sketch. +

      +
      + +
      +

      Version

      +
      • ver 07 (03/01/2018): add photo panel and rotation to axis selected (wire, edge, line )
      +
      • ver 0.6 (13/12/2016): new system for search the macro path directly in the preferences
      +
      #path = FreeCAD.ConfigGet("AppHomePath")
      +#path = FreeCAD.ConfigGet("UserAppData")
      +#path = "your path"
      +param = FreeCAD.ParamGet("User parameter:BaseApp/Preferences/Macro")# macro path
      +path = param.GetString("MacroPath","") + "/"                        # macro path
      +path = path.replace("\\","/")
      +App.Console.PrintMessage("Path locality to FCCamera.....images.png [ " + path + " ]"+"\n")
      +
      +
      • ver 0.5 06/09/2016: correct name "FCCamera_Axis_rotation_X.png" in reset block
      +
      • ver 0.4 28/02/2016 : add display all camera detection and the Direction
      +
      • ver 0.3 18/03/2015 : modify line 492 replace "pl.Base = App.Vector(0,0,0)" to "pl.Base = sel[0].Placement.Base" now no longer moves the form at point (0,0,0) and leaves has the coordinates
      +
      • ver 0.2 25/02/2015 : correct names files in for compatibility Linux (case sensitive) thanks microelly2
      +


      +

      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Macro_FCCamera_00.png b/localwiki/Macro_FCCamera_00.png new file mode 100644 index 0000000..9677a16 Binary files /dev/null and b/localwiki/Macro_FCCamera_00.png differ diff --git a/localwiki/Macro_FCCamera_00b.png b/localwiki/Macro_FCCamera_00b.png new file mode 100644 index 0000000..8c3a938 Binary files /dev/null and b/localwiki/Macro_FCCamera_00b.png differ diff --git a/localwiki/Macro_FCCamera_Align_To_Face.gif b/localwiki/Macro_FCCamera_Align_To_Face.gif new file mode 100644 index 0000000..a9b1e33 Binary files /dev/null and b/localwiki/Macro_FCCamera_Align_To_Face.gif differ diff --git a/localwiki/Macro_FCCircularText.html b/localwiki/Macro_FCCircularText.html new file mode 100644 index 0000000..2c5d931 --- /dev/null +++ b/localwiki/Macro_FCCircularText.html @@ -0,0 +1,788 @@ +Macro FCCircularText

      Macro FCCircularText

      (Redirected from Macro FCCircularText)
      + +
      + + + + + + + + + + + + + + + + + + + + + + + + + + +
      +

      FCCircularTextButtom.png Macro Circular Text

      +
      Description +
      This macro creates a text around a cylinder. +
      Author +
      Mario52 +
      Links +
      Macros recipes
      How to install macros
      How to customize toolbars +
      Version +
      0.13 +
      Date last modification +
      2018-01-30 +
      +

      + +
      +


      +

      +

      Description

      +

      This macro writes a text, standing or flat, circumferential or helical in the manner of Trajan Column and creates a clock with Arabic numerals 1 2 3 ... or Roman I II III ... (inspired to Macro to Create Clock Face to cblt2l) +


      +texte 360 degrees +

      +

      Utilisation

      +

      Principle: The options that are not useful for the selected function are dimmed so inaccessible. +

      A function can gray out options if they are not for him. +

      Launch the macro folder FcString for created characters and a file FcClock for created clocks. +

      All the characters are and remain independent. When creating extrusions nothing is deleted. If Compound is created with Run Comp is copied out of the folder. +

      The options are shaded by default and are active in all functions if they are checked : +

      +
      • Extrude Char.
      • +
      • Placement.
      • +
      • SP. inclination.
      +

      Except for one Clock Service Placement box Z is activated and moves the text in the direction Z to place the text on the support surface. +

      +

      Presentation

      +

      Overview +

      GUI +

      +
      +


      +

      +

      First section

      +
      FCCircularText 07.png
      +
      +


      +

      +
      • TextEdit window that lets you copy the text to display (click on the Reset allows to know the number of the input string that is displayed in the window title)
      • +
      • The Reverse to reverse the text
      • +
      • The New Font to select a new font to use +
        • Default ARIAL.TTF
      +

      Second Section

      +

      Configuring characters in FCCircularText +

      +
      FCCircularText 08.png
      +
      +


      +

      +

      First zone

      +

      Your choice : +

      +
      FCCircularText 09.png
      +
      + +
      +
      +


      +

      +
      FCCircularText 24.png
      +
      • Mode Stand or Mode Flat : The text will be placed standing or flat (same as clock) options Outdoor and Indoor are reversed.
      +
      +


      +

      +
      + +
      +
      + +
      +

      Second area

      +

      This section allows you to configure the overall behavior of characters in all the choices available but with some variation. +If the command is not used in the option chosen, it will be grayed out. +

      +
      FCCircularText 10.png
      +
      • Radius of circle : Radius of the circle. (Default 10)
      • +
      • Size character  : Character height. (Default 2)
      • +
      • Begin angle  : Starting angle of the first character in the circle. (Default 0 °)
      • +
      • End angle  : Angle end of the last character of the text. (Default 360)
      • +
      • Correction angle : Character correction angle to make it tangent to the circle. (Default 10 °)
      • +
      • Correction radius: Fixed the radius of the circle characters (optional). (Default 0.15)
      • +
      • +
      • Pivot Character : Pivot the character on himself. (Inactive Default)
      • +
      • Extrude Char  : Checkbox extrusion characters. (Inactive Default)
      • +
      • Placement  : Text placement in the 3D view. (Inactive Default)
      • +
      • Sp. inclination  : Inclination of characters in three axes X, Y and Z (example to cover such a cone). (Inactive Default)
      +
      +


      +

      +

      Outdoor

      +

      Default mode. The text is written on the outside of the circumference of the circle. +

      +
      + +
      +

      Indoor

      +

      The text is written on the inner side of the circumference of the circle +

      +
      + +
      +

      Helix

      +

      The text is entered on the outer circumference of a helix. +

      +
      + +
      +
      FCCircularText 11.png
      +
      • The helix area is grayed out by default.
      +
      +
      FCCircularText 14.png
      +
      • All characters configuration options are available.
      • +
      • Step of helix which corresponds to the pitch of the helix turns and displays 2 (character height) by default.
      • +
      • Char. per turn activates and displays 10 by default, which corresponds to 10 characters per helical turn.
      +
      +
      FCCircularText 15.png
      +
      • If Step of helix (helix pitch) is zero, Spinboxes Base Helix and End Helix are activated.
      • +
      • Base Helix provides the basis for starting the helix (even Placement Z). If 'Placement Z' is different from zero, the starting point is added to Z Placement
      • +
      • End Helix End of the helix pitch of the helix will be calculated relative to the height and the number of characters per helical turn.
      +


      +

      +

      Clock

      +

      The figures are part of a circle with Arabic numerals or Romans. +

      +
      + +
      +
      FCCircularText 12.png
      +
      • By default, the section is grayed.
      +
      +
      FCCircularText 16.png
      +
      • When the selection is made, the following functions get dark and are usable: +
        1. Begin angle.
        2. +
        3. End angle.
        4. +
        5. Correction angle.
        6. +
        7. Correction radius.
        8. +
        9. The buttom Mode Stand or Mode Flat.
      • +
      • The area Clock is activated.
      +
      +


      +

      +
      FCCircularText 19.png
      +
      • Radius of support : If a value is given, support will be created (default 0).
      • +
      • If Support number face is different from zero a support is created. (If Extrude support = zero then a face is created). +
        • 1 = A circle is created (circle appears).
        • +
        • 2 = A rectangle is created (length = (Radius of media * 1.5) width = Radius of support) (Rectangle appears).
        • +
        • 3 = A triangle is created (circumscribed) (Triangle appears).
        • +
        • 4 = A square is created (Radius of support) (Square appears).
        • +
        • 5 = A polygon with the number of faces displayed (circumscribed) (Polygon appears).
      • +
      • Extrude support is activated and an extrusion dimension can be given.
      +
      +


      +

      +
      FCCircularText 17.png
      FCCircularText 38.png +
      +
      FCCircularText 18.png
      FCCircularText 37.png +
      +


      +

      +
      • If Support number face is equal to zero there is no support.
      • +
      • Mode Roman : The writing will be in Roman figures I II III IIII V VI VII VIII IX X XI XII
      • +
      • Axial  : The figures will be written axially.
      +

      Commands

      +

      FCCircularText 13.png +

      +
      +


      +

      +
      • Exit  : Leaves the macro.
      • +
      • Reset  : Reset all values and displays the number of characters displayed in the window.
      • +
      • Run Comp : Launches the macro and creates a Compount object of all characters.
      • +
      • Run  : Launches the macro
      +

      Launch the macro folder FcString for created characters and a file FcClock for created clocks. +

      +

      Script

      +

      Download the script : +

      - on github Macro_FCCircularText.FCMacro ver 0.13 09/08/2016 +

      - at the forum Extrude from curved surface of cylinder +

      The button icon: +

      - in .PNG FCCircularTextButtom.png +

      - in .SVG FCCircularTextButtom.svg +

      (See Customize_Toolbars for more) +

      +

      Example

      +
      + +
      +


      +

      +
      + +
      +


      +


      +

      +
      + +
      +


      +


      +

      +
      + +
      +


      +


      +

      +
      + +
      +


      +


      +

      +
      + +
      +


      +

      +

      Example onto Ellipse

      +
      + +
      +


      +

      +
      + +
      +


      +

      +
      + +
      +


      +

      +
      + +
      +


      +

      +
      + +
      +


      +Mode relief: +

      +
      + +
      +


      +

      +
      + +
      +


      +

      +
      + +
      +


      +

      +
      + +
      +


      +

      +

      Little bug

      +

      It is possible that two characters overlap, here a small remedy with Macro_Rotate_To_Point +
      +

      +
      + +
      +


      +

      (not fully developed) +

      Planned : +

      Writing on a path circular text of position object selected. +

      (PS : it is possible that an error is made between version 2 Please wait for the next or return to the previous version thank you) +

      +

      Currently:

      +
      • ver 0.13 30/01/2018 add feature Pivot for rotate the character on himself
      +
      • ver 0.13 09/08/2016 replace the button "New font" to "fontComboBox" cause , with Windows 10 the window Font stay empty the files are hidden
      +
      • ver 0.12 03/07/2016 optimize the code for accept the decimal number in determination angle
      +

      replace the line +

      +
      for angleTr in range(debut,rotation,((rotation-debut)/nombre)): 
      +

      to +

      +
      for angleTrFloat in range((debut*10000),(rotation*10000),int((round(((float(rotation)-float(debut))/float(nombre)),4)*10000)) ):    # pour 4 decimales
      +                angleTr = (float(angleTrFloat)/10000) 
      +
      • ver 0.10 17/05/2015 adding lines 1365, 1366 only created more clock face ?? ()
      +
      supp.MakeFace = True
      +            App.activeDocument().recompute() 
      +
      • ver 0.9 11/05/2015 thank you NormandC for testing
      +

      replace +

      +
      self.DS_InclinaisonX.setSuffix(" X°")
      +        self.DS_InclinaisonY.setSuffix(" Y°")
      +        self.DS_InclinaisonZ.setSuffix(" Z°") 
      +

      to +

      +
      self.DS_InclinaisonX.setSuffix(unicode(" X°"))
      +        self.DS_InclinaisonY.setSuffix(unicode(" Y°"))
      +        self.DS_InclinaisonZ.setSuffix(unicode(" Z°")) 
      +
      • ver 0.8 10/05/2015 replace "String=texte[ii2]" to "String=unicode(texte[ii2])" line 1290. cause "TypeError: Property 'FontFile': type must be str or unicode, not QString"
      +
      # ver 0.8 10/05/2015 /_ # testing with OS :
      +##################################################################################################
      +# OS: Ubuntu 14.04.1 LTS                          # OS: Ubuntu 14.04.2 LTS
      +# Platform: 32-bit                                # Word size of OS: 32-bit
      +# Version: 0.14.2935 (Git)                        # Word size of FreeCAD: 32-bit
      +# Branch: master                                  # Version: 0.16.4928 (Git)
      +# Hash: eab159b6ee675012bf79de838c206a311e911d85  # Branch: master
      +# Python version: 2.7.6                           # Hash: d8f63bcfd10301f3d1e141cced4370f0782238d0
      +# Qt version: 4.8.6                               # Python version: 2.7.6
      +# Coin version: 4.0.0a                            # Qt version: 4.8.6
      +# SoQt version: 1.6.0a                            # Coin version: 4.0.0a
      +# OCC version: 6.7.0                              # OCC version: 6.8.0.oce-0.17
      +##################################################################################################
      +# OS: Windows Vista                               # OS: Windows Vista
      +# Word size of OS: 32-bit                         # Word size of OS: 32-bit
      +# Word size of FreeCAD: 32-bit                    # Word size of FreeCAD: 32-bit
      +# Version: 0.15.4527 (Git)                        # Version: 0.15.4671 (Git)
      +# Branch: master                                  # Branch: releases/FreeCAD-0-15
      +# Hash: 0da2e4c45a9a259c26abd54c2a35393e1c15696f  # Hash: 244b3aef360841646cbfe80a1b225c8b39c8380c
      +# Python version: 2.7.8                           # Python version: 2.7.8
      +# Qt version: 4.8.6                               # Qt version: 4.8.6
      +# Coin version: 4.0.0a                            # Coin version: 4.0.0a
      +# OCC version: 6.7.1                              # OCC version: 6.8.0.oce-0.17
      +################################################################################################## 
      +
      • ver 0.7 02/02/2015 suppression 2 str App.Console.PrintMessage(str(PolicePath)+"\n") to App.Console.PrintMessage((PolicePath)+"\n") that caused an error with the characters above 128 in the police path.
      • +
      • ver 0.6 23/11/2014 corrected "texte = unicode(self.textEdit.toPlainText())" now accept "'éèà@..."
      • +
      • ver 0.5 19/11/2014 Gui
      • +
      • ver 0.4 10/10/2014 add variable "rotation" in the loop (for i in range(0,rotation,(rotation/nombre)): # 360 a parametrer)
      • +
      • ver 0.4 27/08/2014 correction error of de radius (exterieur=0, debout=1)
      • +
      • ver 0.3 26/08/2014 add creation text of flat curve
      • +
      • ver 0.2 26/08/2014 add creation text of internal curve
      • +
      • ver 0.1
      +

      (2537) +

      +

      Links

      +

      To comment on the Extrude from curved surface of cylinder +

      +
      +
      +

      +

      + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Macro_FCConvertLines.html b/localwiki/Macro_FCConvertLines.html new file mode 100644 index 0000000..02e7e87 --- /dev/null +++ b/localwiki/Macro_FCConvertLines.html @@ -0,0 +1,264 @@ +Macro FCConvertLines

      Macro FCConvertLines

      (Redirected from Macro FCConvertLines)
      + +
      + + + + + + + + + + + + + + + + + + + + + + + + + + +
      +

      Macro FCConvertLines.png Macro FC Convert Lines

      +
      Description +
      This macro convert the object line, wire in line Dash, DashDot or DashDotDot with the dimensions given. +

      . +

      +
      Author +
      mario52 +
      Links +
      Macros recipes
      How to install macros
      How to customize toolbars +
      Version +
      00.07 +
      Date last modification +
      2017-05-13 +
      +

      + +
      +


      +

      +

      Description

      +

      This macro convert the object line, wire in line Dash, DashDot, DashDotDot, ZigZag, Hand with the dimensions given. +

      +
      ConvertLines Dash, Dash dot, Dash dot dot
      +
      +

      Use

      +

      Copy the macro in your macros folder and launch +FCConvertLines Gui +

      +
      FCConvertLines Gui
      +
      +

      First section : +

      Cut line (Checked by default) +

      +
      FCConvertLines
      +
      • Select one or more lines in the 3D View
      • +
      • SpinBox : for enter number Cuts or cut to length ... (Default number cut suffix displayed "x Cut")
      • +
      • Create L. : if this checkbox is checked the line is created
      • +
      • Dimension : if this checkbox is checked the number tipped is on length the definition change by tree decimal and the suffix displayed is "x.000 Dim"
      • +
      • Bicolor : if this checkbox is checked the lines created are colored alternately Red White if is not checked the color is the color defined with the button Color
      • +
      • Points : if this checkbox is checked one point is created and the color is the color defined Bicolor or * The options Options lines are available
      +

      Color +

      +
      +


      +Second section : +

      Type line : Dash +

      +
      FCConvertLines
      +
      • The screen at the bottom of the macro change in line Dash
      • +
      • Select one or more lines in the 3D View
      • +
      • Line A : dimension of the dash (see A in the screen)
      • +
      • Space B : dimension of the space (see B in the screen)
      • +
      • The lines have created the configuration specifications set in options lines
      +
      +

      Third section : +

      Type line : DashDot +

      +
      FCConvertLines
      +
      • The screen at the bottom of the macro change in line DashDot
      • +
      • Select one or more lines in the 3D View
      • +
      • Line A : dimension of the dash (see A in the screen)
      • +
      • Space B : dimension of the space (see B in the screen) (May be different D)
      • +
      • Line 2 C : dimension of the dash (see C in the screen)
      • +
      • Space 2 D : dimension of the space (see D in the screen) (May be different B)
      +
      +

      Fourth section : +

      Type line : DashDotDot +

      +
      FCConvertLines
      +
      • The screen at the bottom of the macro change in line DashDotDot
      • +
      • Select one or more lines in the 3D View
      • +
      • Line A : dimension of the dash (see A in the screen)
      • +
      • Space B : dimension of the space (see B in the screen)
      • +
      • Line 2 C : dimension of the dash (see C in the screen)
      • +
      • Space 2 D : dimension of the space (see D in the screen)
      +
      +

      Fifth section : +

      Type line : ZigZag +

      +
      FCConvertLines
      +
      • The screen at the bottom of the macro change in line ZigZag
      • +
      • This line are created
      • +
      • Number heads : number of heads for the total line
      • +
      • _____140.0_____ : The length total of the line are calculate in real time and displayed in this window
      • +
      • Begin A : dimension of begin line until first head, this section line hare same in the end line (see A in the screen)
      • +
      • Dimension B : dimension between the end and begin head (see B in the screen)
      • +
      • Gap C : dimension of the head (see C in the screen)
      • +
      • Height D : height dimension of the the head (see D in the screen)
      • +
      • Number E : number of heads contiguous (see E in the screen)
      • +
      • The options Plane and Options lines are available
      +
      +

      Sixth section : +

      Type line : Hand +

      +
      FCConvertLines
      +
      • This line are created
      • +
      • Length A : The length total of the line (see A in the screen)
      • +
      • Height B : Height of the line (see B in the screen)
      • +
      • Wave : compression or uncompress of the wave (see Wave in the screen)
      • +
      • The options Plane and Options lines are available
      +
      +

      Seventh section : +

      Options line : +

      +
      FCConvertLines
      +

      This options are available for all menu +

      +
      • __2,00 Width__ : dimension of the width of the line(s)
      • +
      • __2,00 Point S__ : dimension of the points of the line(s)
      • +
      • Color : color of the line(s) this button are colored with the color selected (if the checkbox "Bicolor" in the menu "Cut line" is checked this option are not used for this menu)
      +
      +

      Eighth section : +

      Option Plane +

      This option are available only for "ZigZag" and "Hand" +

      +
      FCConvertLines
      +
      • XY : Plane XY
      • +
      • YZ : Plane YZ
      • +
      • XZ : Plane XZ
      +
      +

      Ninth section : +

      Button +

      +
      FCConvertLines
      +
      +
      • Save type : the line configured is saved in one file (one file for one type line). While saving a file header is predetermined depending on the chosen menu (example : Dash is saved, in the save window is displayed "Dash_.FCConvertL" you can modify to "Dash_my_config_10.FCConvertL" or the name you want... this method allow sharpens clear)
      • +
      • Load type : load one file configured
      • +
      • Name type line________________ : name of the type configured this name is saved in the file
      • +
      • Reset : reset the data's in the original configuration
      • +
      • Create Comp : this button create on compound with the lines created (ten lines selected = one compound)
      • +
      • Create : create the lines separately (ten lines selected = ten lines created)
      • +
      • Quit : quit the macro
      +
      +


      +

      +

      The files to copy in your directory with the macro (10 files images)

      +

      The icon for the toolBar +

      +
      Macro_FCConvertLines
      +
      +

      Title +

      +
      ConvertLines_Title
      +
      +

      Line Dash : +

      +
      ConvertLines_Dash
      +
      +

      Line DashDot : +

      +
      ConvertLines Dash dot
      +
      +

      Line DashDotDot : +

      +
      ConvertLines Dash dot dot
      +
      +

      Line Zigzag : +

      +
      ConvertLines_Zigzag
      +
      +

      Line Hand : +

      +
      ConvertLines_Hand
      +
      +

      View : +

      +
      +

      ConvrtLines_View-front ConvrtLines_View-right ConvrtLines_View-right +

      +
      +

      Script

      +

      Copy the macro Macro_FCConvertLines.FCMacro in your macros folder +

      the script on Gist Macro_FCConvertLines.FCMacro +

      +

      Examples

      +

      Example dot, dash dot, dash dot, dash dot dot +

      +
      Macro FCConvertLines 11b.png
      +
      +

      Example hand, zigzag +

      +
      Macro FCConvertLines 11.png
      +
      +

      Example hand +

      +
      Macro FCConvertLines 012.png
      +

      All lines created the configuration specifications set in this Option lines +

      +
      +

      Example hand can make beautiful sine wave or totally anarchic +

      +
      Macro FCConvertLines 013.png
      +
      +


      +Example convert ShapeString to sketch (the curves hare not authorized for convert Shape to Sketch) +

      +
      ShapeString To Sketch.gif
      +
      +


      +

      +

      Version

      +

      ver 00.07 13/05/2017 correct bug after create "Alternate ...." the dimension of lines stay with the dimension alternative and not restitution the desired dimensions +

      ver 00.06 20/02/2017 correction of precision cut (replace "numberOfPoints = longueur" to "numberOfPoints = (longueur + 1)") +

      ver 00.05 11/01/2017 replace de search method macro path +

      ver 00.04 05/09/2016 setPointSize(8.0) +

      ver 00.02 18/02/2016 +

      ver 00.01 19/01/2016 +

      ver 00.00 19/01/2016 +

      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Macro_FCConvertLines.png b/localwiki/Macro_FCConvertLines.png new file mode 100644 index 0000000..7f32abd Binary files /dev/null and b/localwiki/Macro_FCConvertLines.png differ diff --git a/localwiki/Macro_FCConvertLines_01.png b/localwiki/Macro_FCConvertLines_01.png new file mode 100644 index 0000000..47e3044 Binary files /dev/null and b/localwiki/Macro_FCConvertLines_01.png differ diff --git a/localwiki/Macro_FCConvertLines_012.png b/localwiki/Macro_FCConvertLines_012.png new file mode 100644 index 0000000..a873850 Binary files /dev/null and b/localwiki/Macro_FCConvertLines_012.png differ diff --git a/localwiki/Macro_FCConvertLines_02.png b/localwiki/Macro_FCConvertLines_02.png new file mode 100644 index 0000000..c856208 Binary files /dev/null and b/localwiki/Macro_FCConvertLines_02.png differ diff --git a/localwiki/Macro_FCConvertLines_03.png b/localwiki/Macro_FCConvertLines_03.png new file mode 100644 index 0000000..6618d32 Binary files /dev/null and b/localwiki/Macro_FCConvertLines_03.png differ diff --git a/localwiki/Macro_FCConvertLines_04.png b/localwiki/Macro_FCConvertLines_04.png new file mode 100644 index 0000000..6d1d351 Binary files /dev/null and b/localwiki/Macro_FCConvertLines_04.png differ diff --git a/localwiki/Macro_FCConvertLines_05.png b/localwiki/Macro_FCConvertLines_05.png new file mode 100644 index 0000000..d44195c Binary files /dev/null and b/localwiki/Macro_FCConvertLines_05.png differ diff --git a/localwiki/Macro_FCConvertLines_06.png b/localwiki/Macro_FCConvertLines_06.png new file mode 100644 index 0000000..a3307af Binary files /dev/null and b/localwiki/Macro_FCConvertLines_06.png differ diff --git a/localwiki/Macro_FCConvertLines_07.png b/localwiki/Macro_FCConvertLines_07.png new file mode 100644 index 0000000..6c595ee Binary files /dev/null and b/localwiki/Macro_FCConvertLines_07.png differ diff --git a/localwiki/Macro_FCConvertLines_08.png b/localwiki/Macro_FCConvertLines_08.png new file mode 100644 index 0000000..8561e8e Binary files /dev/null and b/localwiki/Macro_FCConvertLines_08.png differ diff --git a/localwiki/Macro_FCConvertLines_09.png b/localwiki/Macro_FCConvertLines_09.png new file mode 100644 index 0000000..5aae327 Binary files /dev/null and b/localwiki/Macro_FCConvertLines_09.png differ diff --git a/localwiki/Macro_FCConvertLines_10.png b/localwiki/Macro_FCConvertLines_10.png new file mode 100644 index 0000000..5758fd4 Binary files /dev/null and b/localwiki/Macro_FCConvertLines_10.png differ diff --git a/localwiki/Macro_FCConvertLines_Dash.png b/localwiki/Macro_FCConvertLines_Dash.png new file mode 100644 index 0000000..778e0b5 Binary files /dev/null and b/localwiki/Macro_FCConvertLines_Dash.png differ diff --git a/localwiki/Macro_FCConvertLines_DashDot.png b/localwiki/Macro_FCConvertLines_DashDot.png new file mode 100644 index 0000000..1338a60 Binary files /dev/null and b/localwiki/Macro_FCConvertLines_DashDot.png differ diff --git a/localwiki/Macro_FCConvertLines_DashDotDot.png b/localwiki/Macro_FCConvertLines_DashDotDot.png new file mode 100644 index 0000000..facb9be Binary files /dev/null and b/localwiki/Macro_FCConvertLines_DashDotDot.png differ diff --git a/localwiki/Macro_FCConvertLines_Hand.png b/localwiki/Macro_FCConvertLines_Hand.png new file mode 100644 index 0000000..45dd079 Binary files /dev/null and b/localwiki/Macro_FCConvertLines_Hand.png differ diff --git a/localwiki/Macro_FCConvertLines_Title.png b/localwiki/Macro_FCConvertLines_Title.png new file mode 100644 index 0000000..1d99755 Binary files /dev/null and b/localwiki/Macro_FCConvertLines_Title.png differ diff --git a/localwiki/Macro_FCConvertLines_Zigzag.png b/localwiki/Macro_FCConvertLines_Zigzag.png new file mode 100644 index 0000000..f4acd10 Binary files /dev/null and b/localwiki/Macro_FCConvertLines_Zigzag.png differ diff --git a/localwiki/Macro_FCConvrtLines_View-front.png b/localwiki/Macro_FCConvrtLines_View-front.png new file mode 100644 index 0000000..70b6ee9 Binary files /dev/null and b/localwiki/Macro_FCConvrtLines_View-front.png differ diff --git a/localwiki/Macro_FCConvrtLines_View-right.png b/localwiki/Macro_FCConvrtLines_View-right.png new file mode 100644 index 0000000..ee62529 Binary files /dev/null and b/localwiki/Macro_FCConvrtLines_View-right.png differ diff --git a/localwiki/Macro_FCConvrtLines_View-top.png b/localwiki/Macro_FCConvrtLines_View-top.png new file mode 100644 index 0000000..74382e3 Binary files /dev/null and b/localwiki/Macro_FCConvrtLines_View-top.png differ diff --git a/localwiki/Macro_FCCreaLoft.html b/localwiki/Macro_FCCreaLoft.html new file mode 100644 index 0000000..3a4590e --- /dev/null +++ b/localwiki/Macro_FCCreaLoft.html @@ -0,0 +1,111 @@ +Macro FCCreaLoft

      Macro FCCreaLoft

      (Redirected from Macro FCCreaLoft)
      + +
      + + + + + + + + + + + + + + + + + + + + + + + + + + +
      +

      FCCreaLoft.png Macro Loft

      +
      Description +
      Creates a loft wit wires selected. +
      Author +
      Mario52 +
      Links +
      Macros recipes
      How to install macros
      How to customize toolbars +
      Version +
      00.03 +
      Date last modification +
      2016-02-09 +
      +

      + +
      +


      +

      +

      Description

      +

      specially written for easy lofting with lines generated by the Macro Texture (but may be suitable and used for common lofts)
      +

      Texture_001_Logo +

      +
      +


      +

      +

      Use

      +

      Copy the macro and the icon in your macro directory. +

      +
      • Sort : Sort the data entries.
      • +
      • Reverse : Reverse the order of data.
      • +
      • Reset / Upgrade: This button as many function: +
        1. If any selection in 3Dview this button Upgrade is displayed.
          Select your object in the 3Dview or in the Combo view and click this button for upgrade the data in the macro, the button changes in Reset.
        2. +
        3. If one or many object(s) are selected before the run macro this button Reset is displayed.
          Alls objects selected are displayed in the macro window.
          After having Sort or Reverse the data displayed, this button Reset is used to return to the original order.
          If you click in the 3DView or unselected all objects this button is used for reset to macro.
          If you adding one or more object(s) in the list this button is used.
      • +
      • Select all : Select all objects in the document.
      • +
      • SpinBox : Increment the jump x Elements (Default 1 all objects are used).
      • +
      • Quit : Quit the macro.
      • +
      • CheckBox If the CheckBox is checked the work progress is displayed if not only the ProgressBar work (this method is faster) (Checked by default).
      • +
      • Launch the Lofting : Launch the Lofting and reset the macro. The number of selection are displayed and the real number lofted if the spinBox "jump" is used
      +

      The interface

      +
      FCCreaLoft002
      +
      +

      Script

      +

      The icons for you toolBar FCCreaLoft.png +

      Download the macro to Gist Macro_FCCreaLoft.FCMacro +

      +

      Links

      +

      The forum discussion Texture +

      The Macro Texture +

      +

      Version

      +

      ver 00.00 : 06/02/2016 +

      ver 00.02 : 09/02/2016 : Add button "Select all" and little option displayed in the button Launch (number selections) and (real number loft) +

      ver 00.03 : 09/02/2016 : minor (display on button) +

      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Macro_FCCreaLoft_01.png b/localwiki/Macro_FCCreaLoft_01.png new file mode 100644 index 0000000..e7bd934 Binary files /dev/null and b/localwiki/Macro_FCCreaLoft_01.png differ diff --git a/localwiki/Macro_FCGear.html b/localwiki/Macro_FCGear.html new file mode 100644 index 0000000..b6470fa --- /dev/null +++ b/localwiki/Macro_FCGear.html @@ -0,0 +1,105 @@ +Macro FCGear

      Macro FCGear

      + +
      + + + + + + + + + + + + + + + + + + + + + + + + + + +
      +

      Gearworkbech.png Macro FCGear

      +
      Description +
      Additional Workbench to create different types of gears. +
      Author +
      looooo +
      Links +
      Macros recipes
      How to install macros
      How to customize toolbars +
      Version +
      1.0 +
      Date last modification +
      2015-10-27 +
      +

      + +
      +


      +

      +

      Description

      +

      Additional Workbench to create different types of gears, involute gear, involute rack, cycloide gear, bevel gear. +


      +

      FCGear +

      +
      +


      +

      +

      Install

      + +

      Note: +

      +
      • if you download zip,unzip,and
      • +
      • just copy the whole outermost directory FCGear into /freecad/Mod +
        • in Windows must show hidden files, otherwise Mod is hidden
        • +
        • in Linux usually Mod path is usr/lib/freecad/Mod. You must open .Mod as administrator and you must give access permissions to all files of "gear". You can also copy to the local Mod: ~/.FreeCAD/Mod
      • +
      • since FCGear requires "NUMPY", which is only included since FreeCAD 0.15.4671, it won't run on older versions of FreeCAD
      +

      Create a gear

      +
      • go to the gear workbench
      • +
      • click on gear symbol
      • +
      • change parameters
      +


      +InvolutegearFCGear_involutegear_par +Involuterack.FCGear_involuterack_par +

      CycloidegearFCGear_cycloide_par +BevelgearFCGear_bevel_par +


      +

      +

      Links

      + +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Macro_FCInfo.html b/localwiki/Macro_FCInfo.html new file mode 100644 index 0000000..795cd6f --- /dev/null +++ b/localwiki/Macro_FCInfo.html @@ -0,0 +1,335 @@ +Macro FCInfo

      Macro FCInfo

      + +
      + + + + + + + + + + + + + + + + + + + + + + + + + + +
      +

      FCInfo.png Macro FCInfo

      +
      Description +
      Gives a series of information on the form. +
      Author +
      Mario52 +
      Links +
      Macros recipes
      How to install macros
      How to customize toolbars +
      Version +
      1.20 +
      Date last modification +
      29/01/2018 +
      +

      + +
      +


      +

      Gives a series of informations about the selected shape and can display a conversion of length, inclination (degrees, radians, grades, pourcent) shape, surface, volume and the weight of the form in the density selected in different units of quantities international and Anglo-Saxon. +


      +FCInfo +

      +

      Utilisation

      +

      Select an object or launch the application and select an object, and a series of informations appear. +His calculations based on unity of FreeCAD, which is the mm to each new selection, the length unit always comes back on mm and angle on decimal degrees. +

      +
      upper window
      lower window +
      +

      Sector 1: Document +

      +
      • Document name
      • +
      • Label of the object
      • +
      • Internal Name of the object
      • +
      • Sub element name of the object
      • +
      • Type of the object
      +

      Sector 2: Coordinates click mouse +

      +
      • Coordinates X,Y and Z click to mouse
      • +
      • The button create on point, axis, plane, copy vector axis form FreeCAD.Vector(-24.0, 240.0, 7.0)
      +

      Sector 3: Value +

      +
      • Length of the object if the object is a face perimeter is displayed unit size can be selected :
        km, hm, dam, m, dm, cm, mm, µm, nm, pm, fm, inch, link, foot, yard, perch, chain, furlong, mile, league, nautique. If the object is circle one second lineEdit is open ans display the radius of circle.
      • +
      • Perimeter of the shape
      +

      Sector 4: Vertexes and details +

      +
      • CheckBox for for search or not all details of the object if is not checked only the principal value are displayed.
      • +
      • Vertexes and details of the shape (compt_Edge), (compt_Faces), (compt_Vector of the Face)
        max 200 lines in the table, if there are more than 200 lines it appears (!+ 200) and the number of lines
        (full details can save be the Save button in a file in CSV format and can be viewed the file in spreadsheet with the Read or by an external spreadsheet as LibreOffice OpenOffice or other)
      +

      Sector 5: Inclination +

      +
      • Inclinations of the object can be displayed in:
      • +
      • decimal degree, ex: 174.831872611°
      • +
      • degree minute seconde, ex: 174° 49' 54.741401''
      • +
      • radian, ex: 3.05139181449 rad
      • +
      • grade, ex: 194.257636235 gon
      • +
      • pourcent ex: 30° = 57.74%
      • +
      • Inclinations in planes XY, YZ, ZX and their coordinates
      • +
      • Direction object, give the direction of object the calculate is : coord_1 - coord_2 = direction (or reverse) +
        • Line this button create a line in direction of the object
      • +
      • ValueAt, returns the 3D vector corresponding to a parameter value.
      +

      Sector 6: Surface and Volume +

      +
      • Surface of the form displayed unit size can be selected
      • +
      • Surface of the face displayed unit size can be selected
      • +
      • Volume of the form displayed unit size can be selected
      • +
      • density of the material in kg by dm3
        (the "spinBox" is set to 7,5 kg, average density of steel. If you want a different default value, change the value of the density, line 204)
      • +
      • The gram buttom unit mass can be chosen :
        ton,quintal, kg, hg, dag, gram, dg, cg, mg, µg, ng, pg, fg, gr (grain), dr (drachm), oz (once), oz t (once troy),
        lb t (livre troy), lb (livre av), st (stone), qtr (quarter), cwt (hundredweight), tonneau fr, ct
      • +
      • weight of the form displayed unit mass can be selected
      +

      Sector 7: BoundBox +

      +
      • BoundBox extreme dimensions of the shape
      +

      Sector 8: Center of: +

      +
      • Center of the shape and these coordinates XYZ
      • +
      • Center of mass and these coordinates XYZ
      • +
      • The button create on point, axis, plane, copy vector axis form FreeCAD.Vector(-24.0, 240.0, 7.0)
      +

      Sector 9: Inertia +

      +
      • Moment of inertia and these coordinates length and weigth
      • +
      • The button create on point, axis, plane, copy vector axis form FreeCAD.Vector(-24.0, 240.0, 7.0) +
        • action line 1 : x1, y1, z1
        • +
        • action line 2 : x2, y2, z2
        • +
        • action line 3 : x3, y3, z3
        • +
        • action 4 diagonal : x1, y2, z3
      +

      same for length and weigth +

      +
      • Determinant 1  : computes the determinant of the matrix scientific value
      • +
      • Determinant 2  : computes the determinant of the matrix decimal value
      +

      Section 10: SpreadSheet +

      +
      • Read : read the data in a spreadsheet saved .FCInfo or txt, asc, csv
      • +
      • Save : save the data in disk in the form selected below .FCInfo or txt, asc, csv
      • +
      • Tabulation : the separator is Tabulation
      • +
      • Comma : the separator is Comma
      • +
      • Semicolon : the separator is Semicolon
      • +
      • Space : the separator is Space
      +

      Option for save or read the spreadSheet with different separator, Tabulation, Comma, Semicolon, Space
      +The Tabulation are the separator for the FreeCAD spreadSheet module
      +The number of this four separator are calculate for help if unknown
      +The COMMA are the old (01.16 and before) separator of the FCInfo macro
      +Now for compatibility with the FreeCAD spreadSheet and since 01.17 version the TABULATION is the separator by default
      +If you want to convert your old FCInfo spreadsheet : Open it in FCInfo and save it with the Tabulation option checked +

      Section 11: Main +

      +
      • CheckBox Clip Board  : if checked the coordinates are saved in clipBoard form : FreeCAD.Vector(-24.0, 240.0, 7.0)
      • +
      • CheckBox Point  : if checked one point is created in the coordinate displayed form : FreeCAD.Vector(-24.0, 240.0, 7.0)
      • +
      • CheckBox Axis  : if checked one axis is created in the coordinate displayed form : FreeCAD.Vector(-24.0, 240.0, 7.0)
      • +
      • CheckBox Plane  : if checked one axis plane is created in the coordinate displayed form : FreeCAD.Vector(-24.0, 240.0, 7.0)
      • +
      • Ref  : Refresh the display of data in report view
      • +
      • Exit : Exit the macro (you must restart from the tool bar button or menu "View > Panels > FCInfo"
      • +
      • CheckBox 1  : If this CheckBox is checked the informations are displayed in the report view window
      • +
      • CheckBox 2  : If this CheckBox is not checked the window macro are displayed to right (default). If it is checked the window macro are displayed to left
      +

      Once launched macro, the macro remains active and the window remains visible. To exit the macro by pressing Exit. If you leave by the cross, the macro remains in memory and the data appears in the "report view" of FreeCAD. +

      +
      + +
      +
      +


      +

      +

      Options

      +

      The unit used

      +
      Length unit:
      +

      km, hm, dam, m, dm, cm, mm, µm, nm, pm, fm, inch, link, foot, yard, perch, chain, furlong, mile, league, nautique. +

      +
      Angle degrees :
      +
      1. decimal degree, ex: 174.831872611°
      2. +
      3. degree minute seconde, ex: 174° 49' 54.741401''
      4. +
      5. radian, ex: 3.05139181449 rad
      6. +
      7. grade, ex: 194.257636235 gon
      8. +
      9. pourcent ex: 30° = 57.74%
      +

      Understanding of angles in FCInfo display. +

      +
      + +
      +
      +


      +

      +
      Weight unit :
      +

      ton, quintal, kg, hg, dag, gram, dg, cg, mg, µg, ng, pg, fg, gr (grain), dr (drachm), oz (once), oz t (once troy),
      +lb t (livre troy), lb (livre av), st (stone), qtr (quarter), cwt (hundredweight), tonneau fr, ct

      +the "spinBox" is set to 7,5 kg, average density of steel. If you want a different default value, change the value of the density, line 206 +

      +
      global densite       ; densite       = 7.5  # (steel = 7.5 kg par dm3) 
      +

      A file can be created by the button Save. The file is written as a file csv in this way, the data can be studied in a spreadsheet in FreeCAD or Openoffice, LibreOffice... +

      +

      Script

      +

      Copy the contents of the macro in a file named "FCInfo.FCMacro" +

      +
      • Windows: the form is usually " drive:\Users\your_user_name\AppData\Roaming\FreeCAD\ "
      • +
      • Ubuntu: the form is usually " /home/your_user_name/.FreeCAD ".
      +

      Or, directly in the interface of FreeCAD
      +The icon must be in the same directory as the macro.
      +Download image positioning on the icon FCInfo.png FCInfoSpreadsheet.png and then drag the mouse right click "save as" (do not change the name)
      +PS: too long to be contained in the wiki page (for the time being the wiki pages accept only 64 KB) the macro code has been placed in the forum

      +

      +
      +

      There is also FCInfo_Alternate_Linux for only for FreeCAD version 0.13... and PyQt4 +

      +
      +

      There is also a Macro_FCInfo_Alternate_Linux here the code is changed (due to the character display error : ² ³ ° μ ordinal not in range (128)") which posed problems in certain configurations the functions are the same
      +Example : +

      +
      global uniteSs       ; uniteSs       = u"mm²"
      +global uniteVs       ; uniteVs       = u"mm³"
      +global uniteAs       ; uniteAs       = u"°" 
      +

      remplacés par +

      +
      global uniteSs       ; uniteSs       = "mm"+iso8859(unichr(178))
      +global uniteVs       ; uniteVs       = "mm"+iso8859(unichr(179))
      +global uniteAs       ; uniteAs       = iso8859(unichr(176)) 
      +

      Files saved with this version is incompatible with the other version (docked or not) +

      +
      +

      +

      Download the icon file Macro_FCInfo_Icon unzip and copy the icon in the same directory of the macro +

      Dwnload the macro file on gist docked to right +

      + +


      +

      (Or On the forum. )

      +PS: this macro uses getSelection() and the list of object begin to 1 ex: for a box Edge1 to Edge12 +and the code in the console start at 0 ex: for a box Edge[0] to Edge[11]
      +This is normal the counting on arrays/lists inside OpenCascade always starts at 1 and not at 0 +

      +

      Limitations

      +

      Always leave the button Exit. If one exits the program without going through the button Exit the program remains in memory and continues to run and the display will remain in the "view report". You must leave FreeCAD to erase it from memory.
      +Only the first 200 elements of the object are visible in the table if there are more than 200 items in the object a signal will be displayed by "'(! +200)" '. The complete list of data is visible in the file saved by the button Save.
      +

      If the window macro is invisible after the run , see the bottom window : +

      Macro FCInfo 08.png +


      +FCInfo begin 00.gif +

      +
      +


      +project:
      +read the file directly in a table. done
      +matches the "Edges" and their coordinates done
      +Association of a substance to its density
      +inclination on the element rather than the global object done
      +inlay right in the interface of FreeCAD done
      +

      currently:
      +

      +
      • ver 1.20 , 29/01/2018 optimization
      • +
      • ver 1.19 , 20/01/2018 create checkBox for use detection all elements of the object if wanted or not , the macro is faster. Optimisation
      • +
      • ver 1.18 , 19/12/2017 ...
      • +
      • ver 1.17c , 14/12/2017 create plane with coordinate give in one project in other project and replace "FCInfo" by "__title__"
      • +
      • ver 1.17b , 13/12/2017 little correction replace FCTreeView to FCInfo
      • +
      • ver 1.17 , 12/12/2017 add upgrade Moment of inertia mm and kg by pinq FCMacro and moment of inertia of assembly, and create plane, axis, point, and add options separator for spreadsheet
      • +
      • ver 1.16 , 21/06/2017 add control height police (here PointSize 8) and checkbox for position the window to right or left
      • +
      • ver 1.15 , 19/12/2015 suppression PyQt4 option see , add checkBox for editing infos in report view
      • +
      • ver 1.14 , 04/08/2014 replace PyQt4 and PySide and correct tooltip not displayed cause on PySide and add fg
      • +
      • ver 1.13 , 27/07/2014 replace FCInfo_en_Ver_1-12_Docked.FCMacro to FCInfo_en_Ver_1-13_Docked.FCMacro accept PyQt4 and PySide
      • +
      • ver 1.12 , 10/03/2014 adding tooltip
      • +
      • ver 1.11 , 04/03/2014 adding µm, nm, pm, fm, µg, ng, pg, pourcent, fixed of grandeur carat "cd" in "ct", display of the label and internal name, fixed calculation of angles XY YZ ZX could give an error on a compound shape, window dockable in FreeCAD
      • +
      • ver 1.10.b , 19/11/2013 buttons outside the scrollbar and the dimensions of the window blocking
      +

      (ver 1.10 , 18/11/2013 create scrollbar)
      +

      +
      • ver 1.08.b , 10/11/2013 translation units in English, error correction to display the area of the faces listed in the table and replacement of the"print" by "App.Console.PrintMessage"
      +

      ver 1.09 , 04/11/2013 works perfectly on Windows and Linux (cause of errors on Linux the characters : ² ³ ° "ordinal not in range(128)")
      +In a Linux distribution and in the case of an error of "ordinal not in range (128)" an alternative version exists on this page Macro_FCInfo_Alternate_Linux
      +

      +
      • ver 1.08 , 24/10/2013 correction of high top "Faces" and "Edges" displaying 100 objects (in the saved file)
      • +
      • ver 1.07 , 11/10/2013 matches the "Faces" and their coordinates.
      • +
      • ver 1.06 , 22/09/2013 matches the "Edges" and their coordinates, inclination on the element rather than the global object
      • +
      • ver 1.05 , 17/09/2013 added an icon for the spreadsheet, conversion barrel fr, affichage des dimensions overall instead of coordinates.
      • +
      • ver 1.04 , 11/09/2013: read the file directly in a table.
      • +
      • ver 1.03 , 09/09/2013: clearer display in view report and replacement by "typeObject = sel[0].Shape.ShapeType"
      • +
      • ver 1.02 , 7/09/2013 : small updates
      • +
      • ver 1.00 , 6/09/2013
      +

      Links

      +

      You can share your comments on the forum Info Workbench - Help with icons please.
      +Here another post of FCInfo Macro +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Macro_FCInfoGlass.html b/localwiki/Macro_FCInfoGlass.html new file mode 100644 index 0000000..f5cc6b7 --- /dev/null +++ b/localwiki/Macro_FCInfoGlass.html @@ -0,0 +1,261 @@ +Macro FCInfoGlass

      Macro FCInfoGlass

      + +
      + + + + + + + + + + + + + + + + + + + + + + + + + + +
      +

      Macro FCInfoGlass.png Macro FCInfoGlass

      +
      Description +
      Gives a series of information on the form display in the 3D view. +
      Author +
      Mario52 +
      Links +
      Macros recipes
      How to install macros
      How to customize toolbars +
      Version +
      00.05 +
      Date last modification +
      2016-08-28 +
      +

      + +
      +


      +

      Gives a series of informations about the selected shape and can display a directly in the 3D view +


      +FCInfoGlass +

      +
      +

      Utilisation

      +

      Select an object or launch the application and select an object, and a series of informations appear on the 3D View. +

      Modify this line to move the data display in the screen (lines 84, 85) +

      +
      global posiX                 ; posiX                           = 900  # position window coordinate X                   "defaut  = 900"
      +global posiY                 ; posiY                           = 190  # position window coordinate Y                   "defaut  = 190" 
      +
      • 900, 190 = position X, Y upper left corner
      +

      Modify this line for change color (line 92) +

      +
      #######################################################################
      +# Section color                                                       #
      +global colorize              ; colorize                      ="black" # colorize the text choice                       "defaut  = "black"
      +                                                                      # "black" "white" "red" "green" "blue" "yellow" "magenta" "cyan" 
      +

      Examples:

      +

      Availlable : "black" "white" "red" "green" "blue" "yellow" "magenta" "cyan" +

      +
      + +
      +
      +
      + +
      +
      +


      +This section hare switch give value 1 for displayed the info or 0 for not displayed the info +

      Example: +

      is displayed ( = 1 ) +

      +
      global LabelObject     ;LabelObject      = 1 # Label                                          #3  Label Object 
      +

      is not displayed ( = 0 ) +

      +
      global LabelObject     ;LabelObject      = 0 # Label                                          #3  Label Object 
      +

      The section lines 79 to 171 +

      +
      #######################################################################
      +global visualiserWindow      ; visualiserWindow                = 0    # si visualiserWindow = 1 la fenetre est visible (pour test)  "defaut  = 0"
      +                                                                      # if visualiserWindow = 1 the windows is visible (for test)   "default = 0"
      +###Section Configuration ##############################################
      +# Placement window hidden                                             #
      +global posiX                 ; posiX                           = 900  # position window coordinate X                   "defaut  = 900"
      +global posiY                 ; posiY                           = 190  # position window coordinate Y                   "defaut  = 190"
      +#######################################################################
      +global SizeX                 ; SizeX                           = 600  # size window length  (do not modify)            "defaut  = 600"
      +global SizeY                 ; SizeY                           = 600  # size window heigth  (do not modify)            "defaut  = 600"
      +
      +
      +#######################################################################
      +# Section color                                                       #
      +global colorize              ; colorize                      ="black" # colorize the text choice                       "defaut  = "black"
      +                                                                      # "black" "white" "red" "green" "blue" "yellow" "magenta" "cyan"
      +
      +
      +#######################################################################
      +# Section inter                                                       #
      +global mode                  ; mode                            = 1    # mode 1=degrees mode 0=radians                  "defaut  = 1"
      +global arondi                ; arondi                          = 4    # many numbers after the decimal point           "defaut  = 4" 
      +global chaineRemplacement    ; chaineRemplacement              = "_"  # replacement string (1 character)               "defaut  = "_"
      +
      +
      +#######################################################################
      +# section switch 
      +# if switch = 1 then actif (True Displayed) else inactif (False not Displayed)
      +global PrintReportView       ;PrintReportView                  = 1    # Affichage dans la vue rapport                  #0  Displayed ReportView
      +## 
      +global DocumentName          ;DocumentName                     = 1    # Nom du document                                #1  Document Name
      +global InternalName          ;InternalName                     = 1    # Nom interne de l'objet                         #2  Internal Name
      +global LabelObject           ;LabelObject                      = 1    # Label                                          #3  Label Object
      +global ElementName           ;ElementName                      = 1    # Nom de l'element                               #4  Element Name
      +global ObjectType            ;ObjectType                       = 1    # Type d'objet                                   #5  Object Type
      +global LineSeparateTitle     ;LineSeparateTitle                = 1    # ligne de separation des titres ____________    #6  Line Separate of Title
      +
      +## Object subObject 
      +global ObjectLength          ;ObjectLength                     = 1    # longueur Objet ou perimetre si c est une face  #7  Object Length or perimetre if are a face
      +global ObjectCurveRadius     ;ObjectCurveRadius                = 1    # rayon du subObject si arc ou cerle             #8  radius subObject if arc or cirle
      +global ObjectCurveCenter     ;ObjectCurveCenter                = 1    # coordonnees centrale subObject si arc ou cerle #9  coordinates center subObject if arc or cirle
      +
      +## Draft
      +global LineDimension         ;LineDimension                    = 1    # Dimensions Line                                #10  Line Dimension
      +global DWireDimension        ;DWireDimension                   = 1    # Dimensions DWire                               #11  DWire Dimension
      +global CircleDimension       ;CircleDimension                  = 1    # Dimensions Circle                              #12 Circle Dimension
      +global CirclePartDimension   ;CirclePartDimension              = 1    # Dimensions Circle Part                         #13 Circle Part Dimension
      +
      +global ArcDimension          ;ArcDimension                     = 1    # Dimensions Arc                                 #14 Arc Dimension
      +global EllipseDimension      ;EllipseDimension                 = 1    # Dimensions Ellipse                             #15 Ellipse Dimension
      +global EllipsePartDimension  ;EllipsePartDimension             = 1    # Dimensions Ellipse Part                        #16 Ellipse Part Dimension
      +global PolygonDimension      ;PolygonDimension                 = 1    # Dimensions Polygon                             #17 Polygon Dimension
      +global RectangleDimension    ;RectangleDimension               = 1    # Dimensions Rectangle                           #18 Rectangle Dimension
      +global BSplineDimension      ;BSplineDimension                 = 1    # Dimensions BSpline                             #19 BSpline Dimension
      +global PointDimension        ;PointDimension                   = 1    # Dimensions Point                               #20 Point Dimension
      +global BezCurveDimension     ;BezCurveDimension                = 1    # Dimensions BezCurve                            #21 BezCurve Dimension
      +
      +## Solid
      +global CylinderDimension     ;CylinderDimension                = 1    # Dimensions du Cylindre Rayon Hauteur Angle     #22 Cylinder Dimension
      +global BoxDimension          ;BoxDimension                     = 1    # Dimensions du Box Length Width Height          #23 Box Dimension
      +global SphereDimension       ;SphereDimension                  = 1    # Dimensions de la Sphere                        #24 Sphere Dimension
      +global EllipsoidDimension    ;EllipsoidDimension               = 1    # Dimensions Ellipsoid                           #25 Ellipsoid Dimension
      +global ConeDimension         ;ConeDimension                    = 1    # Dimensions du Cone                             #26 Cone Dimension
      +global TorusDimension        ;TorusDimension                   = 1    # Dimensions du Tore                             #27 Torus Dimension
      +
      +## Part
      +global PlanePartDimension    ;PlanePartDimension               = 1    # Dimensions Plan Part                           #28 Plane Part Dimension
      +global PrismPartDimension    ;PrismPartDimension               = 1    # Dimensions Prisme Part                         #29 Prism Part Dimension   
      +global WedgePartDimension    ;WedgePartDimension               = 1    # Dimensions Wedge Part                          #30 Wedge Part Dimension
      +global HelixPartDimension    ;HelixPartDimension               = 1    # Dimensions Helix Part                          #31 Helix Part Dimension
      +global SpiralPartDimension   ;SpiralPartDimension              = 1    # Dimensions Spirale Part                        #32 Spiral Part Dimension
      +global VertexPartDimensio    ;VertexPartDimension              = 1    # Dimensions Vertex Part                         #33 Vertex Part Dimension
      +global LinePartDimension     ;LinePartDimension                = 1    # Dimensions Line Part                           #34 Line Part Dimension
      +global RegularPolygonPartDimension;RegularPolygonPartDimension = 1    # Dimensions RegularPolygon Part                 #35 Regular Polygon Part Dimension
      +
      +## Face
      +global FaceSurface           ;FaceSurface                      = 1    # Surface de la face                             #36 Face Surface
      +global NormalAt              ;NormalAt                         = 1    # Donne la normale (inclinaison)                 #37 normalAt(0,0) Face and edges normalAt(0)
      +global FaceCenter            ;FaceCenter                       = 1    # Center Face (mass)                             #38 Face Center
      +global BoundBoxFaceVol       ;BoundBoxFaceVol                  = 1    # BoundBoxFace Volume                            #39 BoundBox Face Volume
      +global BoundBoxFaceCent      ;BoundBoxFaceCent                 = 1    # BoundBoxFaceCenter                             #40 BoundBox Face Center
      +global BoundBoxFaceCoor      ;BoundBoxFaceCoor                 = 1    # BoundBoxFace coordinates                       #41 BoundBox Face Coordinates
      +
      +## Volume
      +global BounBoxVolumeVol      ;BounBoxVolumeVol                 = 1    # rectangle du BoundBox                          #42 BounBox Volume Volume
      +global BounBoxVolumeCent     ;BounBoxVolumeCent                = 1    # centre de la forme                             #43 BounBox Volume Center
      +global BounBoxVolumeCoor     ;BounBoxVolumeCoor                = 1    # boundinbox (dimensions hors tout)              #44 BounBox Volume Coordinates
      +global VolumeObject          ;VolumeObject                     = 1    # volume                                         #45 Volume Object
      +global CenterMass            ;CenterMass                       = 1    # centre de la masse                             #46 Center Mass object
      +global PlacementForme        ;PlacementForme                   = 1    # placement de la forme                          #47 Placement Forme
      +global LineInclination       ;LineInclination                  = 1    # search inclination XY YZ ZX uniquement lignes  #48 Line Inclination
      +global VertexesObject        ;VertexesObject                   = 1    # Vertexes de l'objet selectionne                #49 Vertexes Object
      +global VertexesForme         ;VertexesForme                    = 0    # Vertexes complet de la forme                   #50 Vertexes Forme
      +                                                                      # peut prendre du temps, depasser la fenetre et donner des donnees incompletes
      +                                                                      # can take time and exceed the window and give data's incompletes
      +### End Section Switch ####################################################################################################################### 
      +

      After a change save the macro and run +

      It is not possible at the moment to leave the function from the macro or scrolling +

      One mouse click on the object display the information of the object, two mouse click select the object complete and displayed alls informations +

      PS: It is also possible that in the Linux environment it is not possible to click or have access to the object within the window displaying the information +

      There are no problems in the Windows environment you can click inside the window and access to the object except the displayed characters +

      this window to view and modify the dimensions, change: +

      visualiserWindow line 81 = 1 +

      the lines 87 and 88 and SizeX SizeY for window dimensions +

      +

      Script

      +

      The icon Macro_FCInfoGlass.FCMacro FCInfoGlass +

      Copy the script on Gits Macro_FCInfoGlass.FCMacro +

      and copy the Macro_FCInfoGlass.FCMacro and the icon in your macro directory. +

      +

      Links

      +

      The discussion on the forum FCInfo Macro +

      My macros on mario52a gists +

      +

      Version

      +

      28/08/2016 Ver 00.05 : add radius with subObjects and center coordinates +

      25/11/2015 Ver 0.04 : add radius with subObjects and normalAT(0,0) +

      31/08/2015 Ver 0.03 : add many informations +

      04/08/2015 Ver 0.02 : add switch and presentation +


      +

      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Macro_FCInfoToMouse.html b/localwiki/Macro_FCInfoToMouse.html new file mode 100644 index 0000000..081f89a --- /dev/null +++ b/localwiki/Macro_FCInfoToMouse.html @@ -0,0 +1,440 @@ +Macro FCInfoToMouse

      Macro FCInfoToMouse

      + +
      + + + + + + + + + + + + + + + + + + + + + + + + + + +
      +

      FCInfoToMouse.png Macro FCInfoToMouse

      +
      Description +
      Provide informations coordinates, length and angles in real time on the mouse. +
      Author +
      Mario52 +
      Links +
      Macros recipes
      How to install macros
      How to customize toolbars +
      Version +
      00.04 +
      Date last modification +
      2018-03-27 +
      +

      + +
      +


      +Provide informations coordinates, length and angles in real time on the mouse in a bubble annotation displayed in the 3D screen +

      FCInfoToMouse +

      +
      +

      Use

      +

      After installing the macro in your macros directory, run the macro annotation is created and the mouse coordinates information is displayed in real time. +

      +
      FCInfoToMouse
      +
      • X, Y, Z : coordinates mouse displayed in the bubble (For the mode "Single" alone this mode is displayed)
      +
      +

      After the first click, the other information is displayed (For the mode "Forced" alone this mode is displayed) +

      +
      FCInfoToMouse
      +
      • X1, Y1, Z1 : first coordinates on click mouse
      • +
      • X2, Y2, Z2 : second coordinates on mouse
      • +
      • L : length between the first mouse click and the current mouse movement
      • +
      • XY, YZ, XZ : angles between the first point and moving the mouse in the plans XY, YZ, XZ
      +
      +

      if the mouse is over an object, the object name appears at the top of the annotation +

      +
      FCInfoToMouse
      +
      +

      Uses the key : +

      SHIFT + Q : for quit FCInfoToMouse, if you leave the macro annotation remains at the current location of the mouse to maintain the information at the point of the mouse. If you want to delete the annotation manually. +

      SHIFT + M : for force display "visualisation complete", mode "single", mode "normal" +

      +
      • The mode single displayed only the coordinates of mouse
      +

      SHIFT + C : for "hidden / visible" +

      SHIFT + D : for "open / close" a spreadSheet in document the coordinate saved to: +

      cell A : x, y, z cell B : x cell C : y cell D : z +


      +At any time, you can change the properties of the annotation by clicking the object FCInfoToMouse in Combo View and click the View tab +

      If you want change the number of decimal change the line 43 (default 4) +

      Example for 6 decimal places: +

      original value +

      +
      global arrondi    ; arrondi    = 4 
      +

      replace to +

      +
      global arrondi    ; arrondi    = 6 
      +

      To make the configuration of the permanent annotation you can change the values in the configuration section lines 104 to 122 +

      +

      Script

      +

      The icon FCInfoToMouse.png FCInfoToMouse for the Customize_ToolsBar +

      Macro_FCInfoToMouse.FCMacro +

      +
      # -*- coding: utf-8 -*-
      +"""
      +***************************************************************************
      +*   Copyright (c) 2016 <mario52>                                          *
      +*                                                                         *
      +*   This file is a supplement to the FreeCAD CAx development system.      *
      +*                                                                         *
      +*   This program is free software; you can redistribute it and/or modify  *
      +*   it under the terms of the GNU Lesser General Public License (LGPL)    *
      +*   as published by the Free Software Foundation; either version 2 of     *
      +*   the License, or (at your option) any later version.                   *
      +*   for detail see the LICENCE text file.                                 *
      +*                                                                         *
      +*   This software is distributed in the hope that it will be useful,      *
      +*   but WITHOUT ANY WARRANTY; without even the implied warranty of        *
      +*   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the         *
      +*   GNU Library General Public License for more details.                  *
      +*                                                                         *
      +*   You should have received a copy of the GNU Library General Public     *
      +*   License along with this macro; if not, write to the Free Software     *
      +*   Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  *
      +*   USA                                                                   *
      +***************************************************************************
      +*           WARNING! All changes in this file will be lost and            *  
      +*                  may cause malfunction of the program                   *
      +***************************************************************************
      +"""
      +# http://forum.freecadweb.org/viewtopic.php?f=22&t=9215
      +# FCInfoToMouse
      +
      +__title__   = "FCInfoToMouse"
      +__author__  = "Mario52"
      +__url__     = "https://www.freecadweb.org/wiki/Macro_FCInfoToMouse"
      +__version__ = "00.04"
      +__date__    = "27/03/2018"
      +#
      +import Draft, Part
      +import math,FreeCAD
      +from FreeCAD import Base
      +import time
      +App = FreeCAD
      +
      +global arrondi    ; arrondi    = 4
      +
      +global objectAnn  ; objectAnn  = "" 
      +global positionX1 ; positionX1 = 0.0
      +global positionY1 ; positionY1 = 0.0
      +global positionZ1 ; positionZ1 = 0.0
      +global force      ; force      = 0
      +global hidden     ; hidden     = 0
      +global coorBegin  ; coorBegin  = ""
      +global pas        ; pas        = 0
      +
      +global spreadSheet; spreadSheet= 0
      +global compteur   ; compteur   = 0 
      +global spread     ; spread     = ""
      +
      +from math import sqrt, pi, sin, cos, asin, acos, atan, atan2, degrees
      +
      +def angle2(vecteur_x1,vecteur_y1,vecteur_x2,vecteur_y2,mode):   #tester getAngle ( Vector )
      +# calcul de l'inclinaison d'une ligne a partir de deux Vecteurs
      +# si "mode" = 1 alors affichage en degres sinon en radian
      +    try:
      +        deltaX = vecteur_x2 - vecteur_x1
      +        deltaY = vecteur_y2 - vecteur_y1
      +        if mode ==1:
      +            angle = degrees(atan2(float(deltaY),float(deltaX))) # degres  (mode = 1)
      +        else:
      +            angle = atan2(float(deltaY),float(deltaX))          # radian  (mode = 0)
      +        return round(angle,arrondi)
      +    except Exception:
      +        None
      +
      +def sub(first, other): 
      +"sub(Vector,Vector) - subtracts second vector from first one"
      +if isinstance(first,FreeCAD.Vector) and isinstance(other,FreeCAD.Vector):
      +return FreeCAD.Vector(first.x-other.x, first.y-other.y, first.z-other.z)
      +
      +def length(first):
      +"lengh(Vector) - gives vector length"
      +if isinstance(first,FreeCAD.Vector):
      +return math.sqrt(first.x*first.x + first.y*first.y + first.z*first.z)
      +
      +def dist(first, other):
      +"dist(Vector,Vector) - returns the distance between both points/vectors"
      +if isinstance(first,FreeCAD.Vector) and isinstance(other,FreeCAD.Vector):
      +return length(sub(first,other))
      +
      +def codeColor(color):
      +    try:
      +        rgb = float((float(color)/255.0))
      +    except Exception:
      +        rgb = 0.0
      +    return rgb
      +
      +
      +doc = FreeCAD.ActiveDocument    
      +if doc == None:
      +    doc = FreeCAD.newDocument()
      +
      +# for modify the configuration : line 104 to 122
      +# PS: if DisplayMode = "Line" and Frame = False the annotation is transparent
      +#
      +##### Configuration  Modify here # Begin #######################################
      +                                                                               #
      +#BackgroundColor :                                                             #
      +red_B           = 0.0                # 0.0 to 255.0                            #
      +green_B         = 84.0               # 0.0 to 255.0                            #
      +blue_B          = 255.0              # 0.0 to 255.0                            #
      +                                                                               #
      +displayMode     = "Line"             # "Line" or "Object"                      #
      +fontName        = "MS Shell Dlg 2"   # "MS Shell Dlg 2" for Windows            #
      +fontSize        = 8.0                # Font size                               #
      +frame           = False              # "False" or "True"                       #
      +justification   = "Left"             # "Left", "Right", "Center"               #
      +                                                                               #
      +#TextColor       :                                                             #
      +red_T           = 255.0              # 0.0 to 255.0                            #
      +green_T         = 255.0              # 0.0 to 255.0                            #
      +blue_T          = 255.0              # 0.0 to 255.0                            #
      +                                                                               #
      +##### Configuration  End End ###################################################
      +
      +v=Gui.activeDocument().activeView()
      +objectAnn = App.ActiveDocument.addObject("App::AnnotationLabel","FCInfoToMouse")# create work annotation
      +objectAnn.LabelText=["Hello FreeCAD World"]
      +
      +FreeCADGui.getDocument(doc.Name).getObject(objectAnn.Label).BackgroundColor = (codeColor(red_B),codeColor(green_B),codeColor(blue_B))   #
      +FreeCADGui.getDocument(doc.Name).getObject(objectAnn.Label).DisplayMode     = displayMode                                               #
      +FreeCADGui.getDocument(doc.Name).getObject(objectAnn.Label).FontName        = fontName                                                  #
      +FreeCADGui.getDocument(doc.Name).getObject(objectAnn.Label).FontSize        = fontSize                                                  #
      +FreeCADGui.getDocument(doc.Name).getObject(objectAnn.Label).Frame           = frame                                                     #
      +FreeCADGui.getDocument(doc.Name).getObject(objectAnn.Label).Justification   = justification                                             #
      +FreeCADGui.getDocument(doc.Name).getObject(objectAnn.Label).TextColor       = (codeColor(red_T),codeColor(green_T),codeColor(blue_T))   #
      +
      +import os, sys, platform
      +global PolicePath;    PolicePath = ""
      +
      +#if platform.system() == "Windows" :
      +#    PolicePath = "C:/Windows/Fonts/ARIAL.TTF"
      +#elif platform.system() == "Linux" :
      +#    PolicePath = "/usr/share/fonts/truetype/ubuntu-font-family/Ubuntu-M.ttf"
      +#elif platform.system() == "Darwin":
      +#    PolicePath = "/Library/Fonts/Arial.ttf"
      +#else:
      +#    PolicePath = "C:/Windows/Fonts/ARIAL.TTF"
      +
      +p=FreeCAD.ParamGet("User parameter:BaseApp/Preferences/Mod/Draft")
      +PolicePath = p.GetString("FontFile")
      +
      +class ViewObserver:
      +    def __init__(self, view):
      +       self.view = view
      +
      +    def logPosition(self, info):
      +        global objectAnn
      +        global positionX1, positionY1, positionZ1
      +        global pas, arrondi
      +        global coorBegin
      +        global force
      +        global hidden
      +        global PolicePath
      +        global spreadSheet
      +        global compteur
      +        global spread
      +
      +######## for testing key ############
      +#        try:                       #
      +#            print info["Key"]      #
      +#            print info["State"]    #
      +##            print ord(info["Key"]) #
      +#        except Exception:          #
      +#            None                   #
      +#####################################
      +
      +        Button1 = 0
      +
      +        try:
      +            if (info["Key"] == "Q") and (info["State"] == "DOWN"):                        # SHIFT + Q for quit
      +                v.removeEventCallback("SoEvent",c)                                        # close event observation
      +                FreeCAD.Console.PrintMessage( "End FCInfoToMouse" + "\n")
      +        except Exception:
      +            None
      +
      +        try:
      +            if (info["Key"] == "M") and (info["State"] == "DOWN"):                        # SHIFT + M for force display
      +                if force == 0:
      +                    force = 1
      +                    FreeCAD.Console.PrintMessage( "Forced " + "\n")
      +                elif force == 1:
      +                    force = 2
      +                    FreeCAD.Console.PrintMessage( "Single " + "\n")
      +                elif force == 2:
      +                    force = 0
      +                    FreeCAD.Console.PrintMessage( "Normal " + "\n")
      +        except Exception:
      +            None
      +
      +        try:
      +            if (info["Key"] == "C") and (info["State"] == "DOWN"):                        # SHIFT + C for hidden / visible annotation OK
      +                if hidden == 0:
      +                    hidden = 1
      +                    FreeCADGui.getDocument(doc.Name).getObject(objectAnn.Label).Visibility = False
      +                    FreeCAD.Console.PrintMessage( "concealed " + "\n")
      +                else:
      +                    hidden = 0
      +                    FreeCADGui.getDocument(doc.Name).getObject(objectAnn.Label).Visibility = True
      +                    FreeCAD.Console.PrintMessage( "visible " + "\n")
      +        except Exception:
      +            None
      +
      +        try:
      +            if (info["Key"] == "D") and (info["State"] == "DOWN"):                        # SHIFT + S for Open spreadSheet
      +                if spreadSheet == 0:
      +                    #spread = FreeCAD.ActiveDocument.getObjectsByLabel(spread.Name)[0]    # for append in existant SpreadSheet
      +                    spread = App.activeDocument().addObject('Spreadsheet::Sheet','MySpreedSheett')
      +                    spreadSheet = 1
      +                    FreeCAD.Console.PrintMessage("SpreadSheet open : " + spread.Name + "\n")
      +                else:
      +                    spreadSheet = 0
      +                    FreeCAD.Console.PrintMessage("SpreadSheet closed" + "\n")
      +                compteur    = 0
      +        except Exception:
      +            None
      +
      +        try:
      +            object2 = ""
      +            object = v.getObjectInfo(v.getCursorPos())                                    # here for object preselected
      +            object2 = object["Object"] + "." + object["Component"]                        # object + component
      +            pnt = FreeCAD.Vector(float(object["x"]),float(object["y"]),float(object["z"]))# vector on position mouse to object
      +#            print "pnt ",pnt
      +        except Exception:
      +            pos = info["Position"]                                                        # if mouse in 3D view
      +            pnt = self.view.getPoint(pos)                                                 # vector detect on mouse position 3D view
      +#            print "pnt ",pnt
      +
      +        try:
      +            if (info["Button"] == "BUTTON1") and (info["State"] == "DOWN"):               # coordinates clic to mouse
      +                positionX1 = round(pnt[0],arrondi)
      +                positionY1 = round(pnt[1],arrondi)
      +                positionZ1 = round(pnt[2],arrondi)
      +                
      +                coorBegin = ""
      +                coorBegin = "X1: "+str(positionX1)+"  Y1: "+str(positionY1)+"  Z1: "+str(positionZ1)
      +                if pas == 0:
      +                    pas = 1
      +                else:
      +                    pas = 0
      +
      +                try:                                                   # spreadSheet
      +                    if spreadSheet == 1:
      +                        compteur += 1
      +                        spread.set("A"+str(compteur) ,  str(positionX1) + ", " + str(positionY1) + ", " + str(positionZ1))
      +                        spread.set("B"+str(compteur) ,  str(positionX1))
      +                        spread.set("C"+str(compteur) ,  str(positionY1))
      +                        spread.set("D"+str(compteur) ,  str(positionZ1))
      +                        App.ActiveDocument.recompute()
      +                        FreeCAD.Console.PrintMessage(str(compteur) + " : " +  str(positionX1) + ", " + str(positionY1) + ", " + str(positionZ1) + "\n")
      +                except Exception:
      +                    None
      +                
      +        except Exception:
      +            None
      +
      +        try:
      +            objectAnn.BasePosition = (pnt[0], pnt[1], pnt[2])
      +            if force == 2:
      +                objectAnn.LabelText = ["X: " + str(round(pnt[0],arrondi)) + " Y: " + str(round(pnt[1],arrondi)) + " Z: " + str(round(pnt[2],arrondi))]
      +            else:
      +                if ((pas == 1) or (force == 1)):
      +                    coorEnd = longueur = angles = ""
      +                    coorEnd = "X2: " + str(round(pnt[0],arrondi)) + "  Y2: " + str(round(pnt[1],arrondi)) + "  Z2: " + str(round(pnt[2],arrondi))
      +                    longueur = "L: " + str(round(dist(FreeCAD.Vector(positionX1,positionY1,positionZ1), FreeCAD.Vector(pnt[0], pnt[1], pnt[2])),12)) # around to 12 decimales
      +                    alphaXY = alphaXY = alphaXZ = 0.0
      +                    alphaXY = str(round(angle2(positionX1,positionY1,pnt[0],pnt[1],1),arrondi))
      +                    alphaYZ = str(round(angle2(positionY1,positionZ1,pnt[1],pnt[2],1),arrondi))
      +                    alphaXZ = str(round(angle2(positionX1,positionZ1,pnt[0],pnt[2],1),arrondi))
      +        
      +                    angles = "XY: " + alphaXY + unichr(176) + "  YZ: " + alphaYZ + unichr(176) + "  XZ: " + alphaXZ + unichr(176)    # unichr(176) = degrees character
      +        
      +                    if object2 == "":
      +                        objectAnn.LabelText = [coorBegin, coorEnd, longueur, angles,]
      +                    else:
      +                        objectAnn.LabelText = [object2, coorBegin, coorEnd, longueur, angles,]
      +                else:
      +                    if object2 == "":
      +                        objectAnn.LabelText = ["X: " + str(round(pnt[0],arrondi)) + " Y: " + str(round(pnt[1],arrondi)) + " Z: " + str(round(pnt[2],arrondi)),]
      +                    else:
      +                        objectAnn.LabelText = [object2, "X: " + str(round(pnt[0],arrondi)) + " Y: " + str(round(pnt[1],arrondi)) + " Z: " + str(round(pnt[2],arrondi))]
      +
      +        except Exception:
      +            FreeCAD.Console.PrintError("End FCInfoToMouse by an error" + "\n")
      +            v.removeEventCallback("SoEvent",c)                                            # close event observation
      +
      +##### Begin ######
      +FreeCAD.Console.PrintMessage("__Welcome to FCInfoToMouse__" + "\n")
      +FreeCAD.Console.PrintMessage("SHIFT + Q : for quit" + "\n")
      +FreeCAD.Console.PrintMessage("SHIFT + M : for force display, mode single, mode normal" + "\n")
      +FreeCAD.Console.PrintMessage("SHIFT + C : for concealed / visible" + "\n")
      +FreeCAD.Console.PrintMessage("SHIFT + D : for create spreadSheet / close spreadSheet" + "\n")
      +FreeCAD.Console.PrintMessage("____________________________" + "\n")
      +
      +pas = 0
      +o = ViewObserver(v)
      +try:
      +    c = v.addEventCallback("SoEvent",o.logPosition)
      +except Exception:
      +    App.ActiveDocument.removeObject(objectAnn.Label)
      +    FreeCAD.Console.PrintMessage( "Not GUI End FCInfoToMouse" + "\n") 
      +

      or to Gists Macro_FCInfoToMouse.FCMacro or the zip Macro_FCInfoToMouse.FCMacro.zip +

      +

      Limitation

      +

      It is possible that the macro does not recognize some keys +

      +

      Links

      +

      The discussion on the forum From autocad to freecad +

      My macros on mario52a gists +

      +

      Version

      +

      27/03/2018 ver 00.04 : add function "Save the coordinate in a spreadSheet key "D" flip/flop on,off +

      24/01/2016 ver 00.03 : add section configuration and replace key "C" to "M" +

      23/01/2016 ver 00.02 : add function "single", replace key "H" to "C" and correct bug +

      02/01/2016 : ver 0.1 +

      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Macro_FCInfoToMouse_01.png b/localwiki/Macro_FCInfoToMouse_01.png new file mode 100644 index 0000000..9ba2960 Binary files /dev/null and b/localwiki/Macro_FCInfoToMouse_01.png differ diff --git a/localwiki/Macro_FCInfoToMouse_02.png b/localwiki/Macro_FCInfoToMouse_02.png new file mode 100644 index 0000000..81a4a55 Binary files /dev/null and b/localwiki/Macro_FCInfoToMouse_02.png differ diff --git a/localwiki/Macro_FCInfo_08.png b/localwiki/Macro_FCInfo_08.png new file mode 100644 index 0000000..681c8d1 Binary files /dev/null and b/localwiki/Macro_FCInfo_08.png differ diff --git a/localwiki/Macro_FCInfo_Alternate_Linux.html b/localwiki/Macro_FCInfo_Alternate_Linux.html new file mode 100644 index 0000000..841a4cf --- /dev/null +++ b/localwiki/Macro_FCInfo_Alternate_Linux.html @@ -0,0 +1,88 @@ +Macro FCInfo Alternate Linux

      Macro FCInfo Alternate Linux

      + +
      + + + + + + + + + + + + + + + + + + + + + + + + + + +
      +

      FCInfo.png Macro FCInfo Alternate Linux

      +
      Description +
      Gives a series of information on the form. +
      Author +
      Mario52 +
      Links +
      Macros recipes
      How to install macros
      How to customize toolbars +
      Version +
      1.12 +
      Date last modification +
      2014-03-05 +
      +

      + +
      +


      +


      +Gives a series of informations about the selected shape and can display a conversion of length, inclination (degrees, radians, grades, pourcent) shape, surface, volume and the weight of the form in the density selected in different units of quantities international and Anglo-Saxon. +


      +The server does not accept for the moment of the more pages of 64 KB and it was impossible to update and restore this page to me. +

      Download the file here : +

      FCInfo_en_Ver_1-12_No_Docked_Ubuntu.FCMacro.zip +

      Or on the forum +

      The difference between the regular version and the version "Ubuntu" in another type of encoding of the characters above + 128 with the procedure
      +PS: this version is derived from the original version, the difference is located at the level of encoding ² ³ ° µ characters that can cause the error "ordinal not in range (128)" on some configurations ? +

      Example : +

      +
      global uniteSs       ; uniteSs       = u"mm²"
      +global uniteVs       ; uniteVs       = u"mm³"
      +global uniteAs       ; uniteAs       = u"°" 
      +

      replace to : +

      +
      global uniteSs       ; uniteSs       = "mm"+iso8859(unichr(178))
      +global uniteVs       ; uniteVs       = "mm"+iso8859(unichr(179))
      +global uniteAs       ; uniteAs       = iso8859(unichr(176)) 
      +

      Files saved with this macro are incompatible with the files of the other versions. +

      Both versions can operate independently of the OS used. +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Macro_FCPropertyMemo_00.png b/localwiki/Macro_FCPropertyMemo_00.png new file mode 100644 index 0000000..90de430 Binary files /dev/null and b/localwiki/Macro_FCPropertyMemo_00.png differ diff --git a/localwiki/Macro_FCPropertyMemo_01.png b/localwiki/Macro_FCPropertyMemo_01.png new file mode 100644 index 0000000..8689e13 Binary files /dev/null and b/localwiki/Macro_FCPropertyMemo_01.png differ diff --git a/localwiki/Macro_FCSpreadSheet_Extract.html b/localwiki/Macro_FCSpreadSheet_Extract.html new file mode 100644 index 0000000..8bd2e41 --- /dev/null +++ b/localwiki/Macro_FCSpreadSheet_Extract.html @@ -0,0 +1,255 @@ +Macro FCSpreadSheet Extract

      Macro FCSpreadSheet Extract

      + +
      + + + + + + + + + + + + + + + + + + + + + + + + + + +
      +

      Macro FCSpreadsheet Extract.png Macro_FCSpreadsheet_Extract

      +
      Description +
      This macro save the data with formulas. +
      Author +
      Mario52 +
      Links +
      Macros recipes
      How to install macros
      How to customize toolbars +
      Version +
      0.1 +
      Date last modification +
      2018-05-05 +
      +

      + +
      +


      +

      +

      Description

      +

      This macro save the spreadsheet data in a csv file with the formula or in a xml file. +

      +

      Use

      +

      Run the macro +

      +

      Script

      +

      The icon for the tool bar to place in the same directory of the macro Macro FCSpreadsheet Extract.png +

      Macro_FCSpreadSheet_Extract.FCMacro +

      +
      # -*- coding: utf-8 -*-
      +from __future__ import unicode_literals
      +"""
      +***************************************************************************
      +*   Copyright (c) 2018 <mario52>                                          *
      +*                                                                         *
      +*   This file is a supplement to the FreeCAD CAx development system.      *
      +*                                                                         *
      +*   This program is free software; you can redistribute it and/or modify  *
      +*   it under the terms of the GNU Lesser General Public License (LGPL)    *
      +*   as published by the Free Software Foundation; either version 2 of     *
      +*   the License, or (at your option) any later version.                   *
      +*   for detail see the LICENCE text file.                                 *
      +*                                                                         *
      +*   This software is distributed in the hope that it will be useful,      *
      +*   but WITHOUT ANY WARRANTY; without even the implied warranty of        *
      +*   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the         *
      +*   GNU Library General Public License for more details.                  *
      +*                                                                         *
      +*   You should have received a copy of the GNU Library General Public     *
      +*   License along with this macro; if not, write to the Free Software     *
      +*   Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  *
      +*   USA                                                                   *
      +***************************************************************************
      +*           WARNING! All changes in this file will be lost and            *  
      +*                  may cause malfunction of the program                   *
      +***************************************************************************
      +"""
      +#
      +__title__   = "FCSpreadSheet_Extract"
      +__author__  = "Mario52"
      +__url__     = "http://www.freecadweb.org/index-fr.html"
      +__Wiki__    = "https://www.freecadweb.org/wiki/index.php?title=Macro_FCSpreadSheet_Extract"
      +__version__ = "00.01"
      +__date__    = "05/05/2018"
      +
      +import PySide
      +import re
      +from PySide import QtGui ,QtCore
      +from PySide.QtGui import *
      +from PySide.QtCore import *
      +import copy
      +
      +path = FreeCAD.ConfigGet("UserAppData")
      +#path = Your path
      +
      +global ESCAPE
      +global tableau
      +global data
      +
      +########## separator 
      +ESCAPE = "\t"           #tabulation    #compatible FC
      +#ESCAPE = ","            #virgule       #compatible FCInfo
      +#ESCAPE = ";"            #point virgule #option
      +#ESCAPE = " "            #espace        #option
      +#ESCAPE = ""             #vide          #option
      +##########
      +
      +def decodeColonne(colonne = "A"):                                  # converti la chaine A ... ZZ en numero de colonne ex: A = 1; AA = 27
      +    colonne  = re.split('[0-9]+', colonne, flags=re.IGNORECASE)[0] # supp the alphanumeric number ex: A2 = A; A12 = A (1A return 0)
      +    try:
      +        if len(colonne) > 1:
      +            return ((ord(colonne[0].upper()) - 64) * 26 ) + (ord(colonne[1].upper()) - 64) # max 2 car (AAAA return 27)
      +        else:
      +            return (ord(colonne.upper()) - 64 )
      +    except Exception:
      +        return 0
      +
      +def decodeOccupation(dataTableau = ""):  # decode the max occupation Colonnes, Lines and give the cell occupation
      +    #
      +    #lineMax, colonneMax, cellsOccupation = decodeOccupation(FreeCAD.ActiveDocument.getObject(str(Sheet.Name)))
      +    #
      +    try:
      +        tyty = unicode(dataTableau.cells.Content, "utf-8")
      +        tyty = tyty.split(">")
      +
      +        ####
      +        cellsOccupation = [] 
      +        cellsSorted     = []                                                 # search the "A1" definition
      +        for i in tyty[1:-2]:                                                 # split les cases dans la chaine XML
      +            i = i[i.find('"')+1:]
      +            i = i[:i.find('"')]
      +#            cellsOccupation.append(i)
      +            cellsOccupation.append(i)
      +        cellsSorted = copy.deepcopy(cellsOccupation)
      +        cellsSorted.sort()
      +
      +        ####
      +        linesMax = 0
      +        for i in cellsSorted:                                                # recherche le max (ligne et colonne)
      +            colonnesMax = re.split('[0-9]+', i, flags=re.IGNORECASE)         # colonne max (AA)
      +            dummy   = int(re.split('[A-Z]+', i, flags=re.IGNORECASE)[1])     # line
      +            if dummy > linesMax:
      +                linesMax = dummy                                             # lines max
      +        del cellsSorted[:]
      +
      +        ####
      +        return linesMax, decodeColonne(colonnesMax[0]), cellsOccupation      # return linesMax , colonnesMax, cellsOccupation
      +
      +    except Exception:
      +        FreeCAD.Console.PrintError("Error data, Enter object <Sheet object> ex:" + "\n")
      +        FreeCAD.Console.PrintError("lineMax, colonneMax, cellsOccupation = decodeOccupation(FreeCAD.ActiveDocument.getObject(str(Sheet.Name)))" + "\n")
      +        return 0, 0, []
      +
      +def caseTableau(ligne = 1, colonne = 1):                                     # calcule et code la case du tableur ex: 1,1 = A1; 7,7 = G7
      +    #
      +    # print caseTableau( 1, 1)
      +    #
      +    if ligne < 1: ligne = 1
      +    if ligne > 16384: ligne = 16384
      +    if colonne < 1: colonne = 1
      +    if colonne > 702: colonne = 702
      +    if (colonne > 26):
      +        if abs(colonne % 26) == 0:
      +            return chr(64 + (abs(colonne / 26) -1)) + chr(90) + str(ligne)
      +        else:
      +            return chr(64 + (abs(colonne / 26))) + chr(64 + (abs(colonne % 26))) + str(ligne)
      +    else:
      +        return chr(colonne + 64) + str(ligne)
      +
      +def saveDataInFile(data = ""):
      +    global tableau
      +
      +    SaveName, Filter = PySide.QtGui.QFileDialog.getSaveFileName(None, "Save a file txt", path, "CSV (*.csv);;XML (*.xml)") # PySide
      +
      +    if (SaveName == ""):
      +        App.Console.PrintMessage("Process aborted"+"\n")
      +    else:
      +        App.Console.PrintMessage("Registration of "+SaveName+"\n")
      +        try:
      +            file = open(SaveName, 'w')
      +            try:
      +                if Filter == "XML (*.xml)":
      +                    ext = "(*.xml)"
      +                    file.write(tableau.cells.Content)          # save XML
      +                else:
      +                    ext = "(*.csv)"
      +                    for i in data:
      +                        file.write(unicode(i).encode("utf-8")) # save CSV
      +            except Exception:
      +                App.Console.PrintError("Error write file "+ext+"\n")
      +            finally:
      +                file.close()
      +        except Exception:
      +            App.Console.PrintError("Error Open file "+SaveName+"\n")
      +
      +##tableau.getContents("A2")                             #lire une celulle
      +##print App.ActiveDocument.Spreadsheet.cells.Content    #lire toutes les celulles # XML
      +
      +try:
      +    for i in FreeCAD.ActiveDocument.Objects:               # search SpreadSheet in all object
      +        obj = FreeCAD.ActiveDocument.getObject(i.Name).TypeId.split("::")[0]
      +        if obj == "Spreadsheet":
      +            tableau = FreeCAD.ActiveDocument.getObject(str(i.Name))
      +            print "Name : ",i.Name," ; Label : ",i.Label
      +            break                                          # quit to the first SpreadSheet
      +    
      +    linesMax    = decodeOccupation(tableau)[0]             # linesMax
      +    colonnesMax = decodeOccupation(tableau)[1]             # colonnesMax
      +    #print decodeOccupation(tableau)[2]                    # display the cells occupied
      +    
      +    print "Number cell : ", linesMax * colonnesMax," (", linesMax," L x ", colonnesMax," C)"
      +    FreeCADGui.updateGui()                                          # rafraichi l'ecran
      +    
      +    dataToSave = []
      +    for i in range(1, linesMax+1):
      +        for ii in range(1, colonnesMax+1):
      +            dataToSave.append(unicode(tableau.getContents(caseTableau(i,ii)), 'utf-8') + ESCAPE)
      +        dataToSave.append("\n")
      +    
      +    saveDataInFile(dataToSave)
      +    del dataToSave[:]
      +    
      +    print "__Fin FCSpreadSheet_Extract__________\n"
      +except Exception:
      +    print "Not SpreadSheet in the document or Error" 
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Macro_FCSpreadsheet_Extract.png b/localwiki/Macro_FCSpreadsheet_Extract.png new file mode 100644 index 0000000..e55d125 Binary files /dev/null and b/localwiki/Macro_FCSpreadsheet_Extract.png differ diff --git a/localwiki/Macro_FCSpringHelixVariable_Example_02.gif b/localwiki/Macro_FCSpringHelixVariable_Example_02.gif new file mode 100644 index 0000000..908ad2f Binary files /dev/null and b/localwiki/Macro_FCSpringHelixVariable_Example_02.gif differ diff --git a/localwiki/Macro_FCSpring_Helix_Variable.gif b/localwiki/Macro_FCSpring_Helix_Variable.gif new file mode 100644 index 0000000..8a95bdc Binary files /dev/null and b/localwiki/Macro_FCSpring_Helix_Variable.gif differ diff --git a/localwiki/Macro_FCSpring_Helix_Variable.html b/localwiki/Macro_FCSpring_Helix_Variable.html new file mode 100644 index 0000000..d697139 --- /dev/null +++ b/localwiki/Macro_FCSpring_Helix_Variable.html @@ -0,0 +1,394 @@ +Macro FCSpring Helix Variable

      Macro FCSpring Helix Variable

      + +
      + + + + + + + + + + + + + + + + + + + + + + + + + + +
      +

      FCSpring Helix Variable.png Macro FCSpring Helix Variable

      +
      Description +
      Creates a spring with helix variable. +
      Author +
      Mario52 +
      Links +
      Macros recipes
      How to install macros
      How to customize toolbars +
      Version +
      01.12 +
      Date last modification +
      2017-04-03 +
      +

      + +
      +


      +

      +

      Description

      +

      This macro creates a spring with customizable, any turn may change the spring configuration can be saved in a file with the extension .FCSpring
      +

      FCSpring Helix Variable +

      +
      +

      Use

      +

      This section is used to configuration the spring +

      Schematic detail of spring configuration +

      Macro TruncateSpring 01.png +

      +
      +

      Gui

      +

      Macro FCSpring Helix Variable 01.png +

      +
      +

      First section, spring configuration

      +
      • Number of coil : Total of coil to spring. Default = 10
      • +
      • Radius of spring : Radius of spring. Default = 20.0
      • +
      • Pitch of spring : Pitch of spring general. Default = 15.0
      • +
      • Precision of turn : Precision of turn the precision correspond the number of point for 1 turn the coil and is calculate : precision (number points) = (pitch / (360/precision)). Default = 5 (72 points)
      • +
      • Spring conical : Give the large diameter of the cone that dimension will always be greater than the radius
      • +
      • Begin : Begin angle of the spring first coil.
      • +
      • End : End angle of the spring last coil.
      • +
      • Ch. : Check box choice for activate the function Begin and End angle of the coil unchecked by default.
        If the function is checked The accuracy is automatically set to 1 (360 points per turn 1 point = 1 degrees)
      +

      Macro FCSpring Helix Variable 02.png +

      +
      +

      Second section, type line

      +
      • BSpline : Type line BSpline.
      • +
      • Wire : Type line Wire.
      • +
      • Points : Check box point if the check box is activate one point is create of on each point.
      • +
      • Reverse : Check box reverse if the check box is activate the spring changes direction
      +

      Macro FCSpring Helix Variable 03.png +

      +
      +

      Third section, selection

      +

      This section is displayed if on object is selected. The type object is displayed in the Text Editor +

      The object can be line, 2 points, circle, wire ... one axis the length of the spring is automatically created +

      Detection : Cylinder (radius), Sphere (radius), Toroid (radius) , Cone (little radius), Circle (radius), Arc (radius), Ellipse (little radius) +

      +
      • Norm. : If one circle is selected Norm not modify the radius of circle (Default) +
        • AdpRa : If the buttom is pressed, the spring is adapted to the detected radius (If a radius is detected )
      • +
      • PMous : If the clic mouse is on one face the spring is createt on this point (Default) +
        • CFace : If the buttom is pressed, the spring is created on the center face selected
      • +
      • Position : If twoo object are selected (first axis, second spring), this checkBox is enabled and you can modify the placement object 2 (spring) along the on object 1 (axis)
      • +
      • Circle : If three points click mouse are selected the Circle button is enabled and it possible to create a circle which can serve as a base for a spring
      • +
      • ... :
      +

      Position (0)(xx)

      +

      (0)(xx) : Number selection(s), length in mm of axis created x 10, egual number of points for shifting the spring of the axis +

      +
      • Begin/End : Position the spring on begin, middle, end axis
      • +
      • RSpr : Reverse the spring of the axis
      • +
      • DoubleSpinBox : Shifting the spring with precision (0.1 mm) along its axis
      • +
      • RCom : Reverse the counter ex: Begin 0 to 10.. or End 0 to 10..
      • +
      • Slider : Position the spring on its axis
      +

      Macro FCSpring Helix Variable 02 2.png +

      +
      +

      Four section, coil special length

      +
      • Numbering of coil : Numbering of coil to modify. (Defaut : none)
      • +
      • Smoothing This checkBox discover one spinBox for determine the grade of smoothing the maximum value is the precision value -1 (this option is still at the prototype stage and the result can be satisfying or completely wrong)
      • +
      • Pitch of coil : Pitch of coil to modify. (Defaut : none)
      • +
      • 15 : If the button is pressed the value of the "Pitch of string" is affected of the "Pitch of coil" (This value is automatically aligned of the value Pitch of string)
      • +
      • Radius of coil : Radius of coil to modify. (Defaut : none)
      • +
      • 20 : If the button is pressed the value of the "Radius of string" is affected of the "Radius of coil" (This value is automatically aligned of the value Radius of string)
      • +
      • Accept the value modified : Button to accept the modification after select the numbering of coil and modify the pitch of coil.
      • +
      • Text edit : This window displayed all coil modified.
      • +
      • C : Clean the text editor
      • +
      • Z : Button "Zoom" enlarge the textedit window
      +

      Macro FCSpring Helix Variable 04.png +

      +
      +

      Commands

      +
      • Load : The Read button open a dialogue box to read a file .FCSpring.
      • +
      • Save : The Save button open a dialogue box to save a file .FCSpring with configuration spring modify or not.
      • +
      • Load Coordinates : Open a dialogue box to read a file .FCSpringCoor (all coordinates of points of the spring).
      • +
      • Save Coordinates : Open a dialogue box to save a file .FCSpringCoor (all coordinates of points of the spring).
      • +
      • Quit : Quit the macro.
      • +
      • Reset : Reset the macro to default configuration.
      • +
      • Launch : Launch the macro and create the spring configured.
      +

      Macro FCSpring Helix Variable 05.png +

      +
      +

      Report view

      +

      The window report view displayed all value modified. +

      Macro FCSpring Helix Variable 06.png +

      +
      +

      Example spring

      +

      Example to spring modified +

      Macro FCSpring Helix Variable 07.png +

      +
      +

      Example Report view

      +

      When the macro is launched full list of turns is displayed in tabular form. +

      Here the data of the spring above and displayed in the Report view +Macro FCSpring Helix Variable 08.png +

      +
      +

      Icon

      +

      Download the file image and copy in your macro repertory. +

      Click the image, in the new window position the mouse over the image, click the right mouse and do "Save target as ..." +

      +ToolBar button
      Button
      +
      +

      Macro icons +

      FCSpring Helix Variable Icon 01.png FCSpring Helix Variable Icon 02.png FCSpring Helix Variable Icon 02b.png FCSpring Helix Variable Icon 03.png FCSpring Helix Variable Icon 03b.png FCSpring Helix Variable Icon 04.png FCSpring Helix Variable Icon 05.png FCSpring Helix Variable Icon 06.png +

      +
      +

      Script

      +

      Macro_FCSpring_Helix_Variable.FCMacro +

      Download the macro to Gist Macro_FCSpring_Helix_Variable +

      +

      Examples

      +
      + +
      +


      +

      +
      + +
      +


      +

      +
      + +
      +


      +

      +
      + +
      +


      +

      +
      + +
      +


      +

      +
      + +
      +


      +

      +
      + +
      +


      +

      +
      + +
      +


      +

      +

      Links

      +

      The forum discussion Try to do a Spring +

      +

      Project

      +

      spring solid truncated +

      soften fittings :done +

      modify diameter to any coil :done +

      +

      Version

      +

      03/04/2017: ver 01.12: correction bug line 2314 add "global ui" +

      11/12/2016: ver 01.11: Adding Position of the spring on a selected object +

      10/09/2016: ver 01.10: Adding Button "Zoom" enlarge the textedit window +

      04/09/2016: ver 01.09: add smoothing +

      16/03/2016: ver 01.08 : correct and add "int()" to debutAngle and finAngle (read file) +

      02/03/2016: ver 01.07 : add option reverse spring +

      08/02/2016: ver 01.06 : correct bug angle cause "modifyAngle = int(file.readline().rstrip('\n\r')) # 9" modifyAngle is int() not char +

      07/01/2015: ver 01.05 : adding "Try ...Except" (data cone) for compatibility with old version +

      07/01/2015: ver 01.04 : adding spring conical and modify the path to "UserAppData" and adding the icone. +

      07/12/2014: ver 01.03 : new version with radius coil adjustable +

      17/11/2014: ver 1.02 : new version with GUI and modification any coil and save or load the data to disk. +

      10/11/2014: (23h20) correction of the modification +

      +
      ligne.Placement = App.Placement(App.Vector(0.0,0.0,0.0), App.Rotation(App.Vector(0,0,1),angleTr), App.Vector(0,0,0)) 
      +

      10/11/2014: modify line 44 : +

      +
      a = FreeCAD.ActiveDocument.Line.Placement=App.Placement(App.Vector(0.0,0.0,0.0), App.Rotation(App.Vector(0,0,1),angleTr), App.Vector(0,0,0)) 
      +

      to +

      +
      ligne = FreeCAD.ActiveDocument.Line.Placement=App.Placement(App.Vector(0.0,0.0,0.0), App.Rotation(App.Vector(0,0,1),angleTr), App.Vector(0,0,0)) 
      +

      6/11/2014 : adding "makeBSpline" and configuration +

      +

      Limitations

      +

      During sweep tests here are the mistakes I have obtained ! +

      +
      + +
      +


      +

      +
      + +
      +


      +

      +
      + +
      +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Macro_FCSpring_Helix_Variable_01.png b/localwiki/Macro_FCSpring_Helix_Variable_01.png new file mode 100644 index 0000000..9d6c4e6 Binary files /dev/null and b/localwiki/Macro_FCSpring_Helix_Variable_01.png differ diff --git a/localwiki/Macro_FCSpring_Helix_Variable_02.png b/localwiki/Macro_FCSpring_Helix_Variable_02.png new file mode 100644 index 0000000..c20622c Binary files /dev/null and b/localwiki/Macro_FCSpring_Helix_Variable_02.png differ diff --git a/localwiki/Macro_FCSpring_Helix_Variable_02_2.png b/localwiki/Macro_FCSpring_Helix_Variable_02_2.png new file mode 100644 index 0000000..8b79e71 Binary files /dev/null and b/localwiki/Macro_FCSpring_Helix_Variable_02_2.png differ diff --git a/localwiki/Macro_FCSpring_Helix_Variable_03.png b/localwiki/Macro_FCSpring_Helix_Variable_03.png new file mode 100644 index 0000000..db70ae2 Binary files /dev/null and b/localwiki/Macro_FCSpring_Helix_Variable_03.png differ diff --git a/localwiki/Macro_FCSpring_Helix_Variable_04.png b/localwiki/Macro_FCSpring_Helix_Variable_04.png new file mode 100644 index 0000000..7286aed Binary files /dev/null and b/localwiki/Macro_FCSpring_Helix_Variable_04.png differ diff --git a/localwiki/Macro_FCSpring_Helix_Variable_05.png b/localwiki/Macro_FCSpring_Helix_Variable_05.png new file mode 100644 index 0000000..3783ba8 Binary files /dev/null and b/localwiki/Macro_FCSpring_Helix_Variable_05.png differ diff --git a/localwiki/Macro_FCSpring_Helix_Variable_06.png b/localwiki/Macro_FCSpring_Helix_Variable_06.png new file mode 100644 index 0000000..176e170 Binary files /dev/null and b/localwiki/Macro_FCSpring_Helix_Variable_06.png differ diff --git a/localwiki/Macro_FCSpring_Helix_Variable_07.png b/localwiki/Macro_FCSpring_Helix_Variable_07.png new file mode 100644 index 0000000..f54475d Binary files /dev/null and b/localwiki/Macro_FCSpring_Helix_Variable_07.png differ diff --git a/localwiki/Macro_FCSpring_Helix_Variable_08.png b/localwiki/Macro_FCSpring_Helix_Variable_08.png new file mode 100644 index 0000000..953cfca Binary files /dev/null and b/localwiki/Macro_FCSpring_Helix_Variable_08.png differ diff --git a/localwiki/Macro_FCTexture.html b/localwiki/Macro_FCTexture.html new file mode 100644 index 0000000..9cf17fc --- /dev/null +++ b/localwiki/Macro_FCTexture.html @@ -0,0 +1,315 @@ +Macro FCTexture

      Macro FCTexture

      (Redirected from Macro FCTexture)
      + +
      + + + + + + + + + + + + + + + + + + + + + + + + + + +
      +

      FCTexture.png Macro Texture

      +
      Description +
      Creates an image 3D from a BMP image. +
      Author +
      Mario52 +
      Links +
      Macros recipes
      How to install macros
      How to customize toolbars +
      Version +
      0.10 +
      Date last modification +
      2016-12-28 +
      +

      + +
      +


      +

      +

      Description

      +

      This small macro allows you to build a project 3D very easily from a bitmap image 256 levels of gray. +

      I hope that this macro will revolutionize the way of thinking the CAD and CNC any image when what can be converted to object 3D without any intervention. +

      Everything becomes possible regardless of the complexity of the image ! +

      The macro Macro Loft for automate the multi loft
      +

      Texture 004 Honda +

      +
      +


      +

      +

      Use

      +

      This macro need an image in 256 gray levels (0-255) therefore before using the macro, convert your image into grayscale (black and white) Lowe. The number of colors is detected automatically, if the image is more than 256 colors another function is expected (to come). Each color (gray level) is regarded as a deep, white (255) the level high and black (0) the lowest level (deep). +

      Configuration is done before the opening of the file, default values are the settings provided to get a project's dimensions: +

      +
      • width of the image in points in the coordinate X,
      • +
      • height of the image in points in the coordinate Y,
      • +
      • depth or thickness of the project leaked 10 mm (in raw mode, on 256 mm) in the coordinate Z.
      +

      The image file unfolds like a scanner x1 x2 x3 ... in 1 mm increments in FreeCAD similarly to the value y of 1 mm at a time. The value of z is given by the value of the color. These values are configurable in the macro. +

      Attention: depending on the size of the image, the project can become very big! for the record an image of 100 px wide and 100 px in height gives 100 x 100 = 10000 points 'and as each point corresponds to a coordinate, so 10000 coordinates XYZ there. +

      +

      The interface

      +
      Texture 002
      +
      • Coordinate
      • +
      • Coordinate X: X coordinate of position of the object, default: 0.
      • +
      • Coordinate Y: Y coordinate of position of the object, default: 0.
      • +
      • Coordinate Z: coordinate Z position of the object, default: 0.
      • +
      • +
      • Stetching
      • +
      • Stetching X: narrowing or enlargement of the length of the object, default: 0.
      • +
      • Stetching Y: narrowing or enlargement of the height of the object, default: 0.
      • +
      • Stetching Z: narrowing or enlargement of the depth of the object, default: 0.
      • +
      • +
      • Inversion
      • +
      • Inversion X: reverse coordinates X image.
      • +
      • Inversion Y: reverse coordinates Y image.
      • +
      • Inversion Z: reverse coordinates Z image.
      • +
      • +
      • Mode 8 Bits
      +

      The beginning of the operation value automatically adapts to the selected function: 0 if the setting is on black (Black) 255 or 20 if the setting is white (White). +

      +
      • +
      • Wire: build your line (vector) in the form of Wire.
      • +
      • Bspline: build your line (vector) in the form of Bspline.
      • +
      • Cloud build the points vectors in the points cloud.
      • +
      • Point: creates a point at each pixel (vector). (the procedure can be long)
      • +
      • Nuance: If the shade option is checked the color of the point is represented as a picture.
      • +
      • +
      • Mode 32 Bits
      • +
      • Photo: the photo mode is automatically activated when a 32-bit image is detected. (the procedure can be long)
      • +
      • Plan: the plan allows you to import a 32-bit image and ignore the background of the plan. By default the map background is black to ignore colors are adjustable with the Capping command. If White is checked, the bottom has ignore will be white. (the procedure can be long)
      • +
      • +
      • Files
      • +
      • pcd: if is checked one file originalName.bmp.pcd is saved in the same directory of the file (pcd v0.7).
      • +
      • asc: if is checked one file originalName.bmp.asc is saved in the same directory of the file. This file can be used as a cloud point (format: X Y Z).
      • +
      • +
      • Capping (10mm)
      • +
      • Slider: give the height of the form the height is displayed on title frame.
      • +
      • Raw mode: to adjust the number of colors (depth). The default mode is 0-20 (which constitutes a filter and to obtain more details according to the complexity of the image) once the checked the mode is 0 to 255 (the entire range of colors).
      • +
      • CheckBox: this checkBox enabled the spinbox.
      • +
      • SpinBox: this spinbox give the contour line do not use (ex: 0 for the base).
      • +
      • Capping: the capping function can be made on the choice of colours, white (default) or black. The degrees of capping rule 20 to 0 (or 255 to 0) if the checkbox is set on W (unchecked) or 0 to 20 (or 0 to 255) if the checkbox is set on B (checked).
      • +
      • SpinBox: this spinbox give the degrees of capping.
      +
      • +
      • File and lauch: opens the image file and launches the conversion.
      • +
      • Quit: exits the function.
      +

      Script

      +

      The icons .png FCTexture.png and .svgFCTexture.svg +


      +Macro_Texture.FCMacro +

      Download the macro to Gist Macro FCTexture.FCMacro +

      +

      Example

      +

      The images were inclined to enhance the 3D effect. +

      +
      + +
      +
      + +
      +
      + +
      +


      +

      +
      + +
      +


      +

      +
      + +
      +


      +

      +
      + +
      +


      +

      +
      + +
      +


      +

      +
      + +
      +


      +

      +
      + +
      +


      +

      +
      + +
      +


      +

      +

      Links

      +

      The discussion on the forum to give your impressions or contact me. +

      The macro Macro Loft for automate the multi loft +

      apply hair cell texture +

      How to handle pdf import properly and feasibly? +

      +

      Revision

      +
      • ver 0.10 : 28/12/2016 add save point in .pcd, .asc display a points cloud, height form, contour
      • +
      • ver 0.9 : 12/12/2016 adding save file .asc for cloud point
      • +
      • ver 0.8 : 16/03/2016 adding progressBar
      • +
      • ver 0.7 : 03/09/2014 Delete "translate" forgotten and bug fix discovered by the passage of PyQt to Pyside !
      • +
      • ver 0.6 : 26/08/2014 Delete all "_translate"
      • +
      • ver 0.5 : 25/08/2014 Delete "_translate (" MainWindow "," Stretching X ", None)" that prevented the display of tooltip with PySide (Windows Vista)
      +
      • ver 0.4 : 08/08/2014 PyQt4 PySide
      +
      • ver 0.3 : 28/03/2014 :comment out the line "# self.checkBox_5.setAccessibleName(_fromUtf8(""))"
      +

      that causes an error with the version FreeCAD : Version: 0.14.3343 (Git), Python version: 2.7.6, Qt version: 4.8.5 +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Macro_FCTreeView.html b/localwiki/Macro_FCTreeView.html new file mode 100644 index 0000000..94d84b4 --- /dev/null +++ b/localwiki/Macro_FCTreeView.html @@ -0,0 +1,258 @@ +Macro FCTreeView

      Macro FCTreeView

      + +
      + + + + + + + + + + + + + + + + + + + + + + + + + + +
      +

      Macro FCTreeView.png Macro FCTreeView

      +
      Description +
      This macro display all object of the project in one list with options sort search by name label... +
      Author +
      Mario52 +
      Links +
      Macros recipes
      How to install macros
      How to customize toolbars +
      Version +
      00.07 +
      Date last modification +
      2018-05-06 +
      +

      + +
      +


      +

      +

      Description

      +

      Macro for list all objects in the project in one list without hierarchy, options sort by name, label, visibility, group, by length option search by name, label .... without case sensitive or with case sensitive and select all objects displayed in the macro window. +

      +

      How To Use

      +

      Macro FCTreeView +

      +
      +


      +

      +

      Section Window

      +

      The title display the option, number and type object(s) displayed +

      +
      • O = Objects
      • +
      • N = Name
      • +
      • L = Label
      • +
      • T = Total
      • +
      • G = Group
      • +
      • S = Single
      • +
      • V = Visible
      • +
      • H = Hidden
      +

      If one object are selected : the Placement Base, Rotation and Center of mass is displayed (if available !) +Icon used for the Name of object Icon used for the Name of object (the scrollbar is colored blue) +

      Icon used for the Label of object Icon used for the Label of object (the scrollbar is colored blue clear) +

      Icon used for visualise if the object is status Visible (mouse click for Hidden) Icon used for visualise if the object is status Visible (mouse click for Hidden) (the scrollbar is colored green) +

      Icon used for visualise if the object is status Hidden (mouse click for Visible) Icon used for visualise if the object is status Hidden (mouse click for Visible) (the scrollbar is colored red) +

      Icon used for the Name contains objects (or folder Group) Icon used for the Name contains objects (or folder Group) +

      Icon used for inform the object in a group the number objects is displayed in top group Icon used for inform the object in a group the number objects is displayed in top group (the scrollbar is colored red clear) +

      Icon used for displayed the single object (not group) Icon used for displayed the single object (not group) +

      +

      Section Sort by :

      +

      Macro FCTreeView 10.png Name Icon used for flip/flop normal/reverse the data listing sort by Name +

      Macro FCTreeView 11.png Label Icon used for flip/flop normal/reverse the data listing sort by Label +

      Macro FCTreeView 12.png Visible Icon used for flip/flop normal/reverse the data listing sort by Visibile/Hidden +

      Macro FCTreeView 13.png Group Icon used for flip/flop normal/reverse the data listing sort by Group/Single object +

      Macro FCTreeView 19.png Length If this check Box is checked the sort is created by length with the button clicked (Name, Label ...) +

      +

      Section Global

      +

      Macro FCTreeView 21.png Split flip/flop Split the Name list +

      Macro FCTreeView 22.png Split flip/flop Split the Name and Label list +

      Macro FCTreeView 14.png Expend flip/flop the data listing Fold/Expend +

      Macro FCTreeView 15.png Expend flip/flop the data listing Expend/Fold +

      Macro FCTreeView 06.png Visibility flip/flop normal/Visibility +

      Macro FCTreeView 07.png Group flip/flop normal/Group +

      Macro FCTreeView 16.png Reload reload the data in the project +

      Macro FCTreeView 18.png Original return in original organisation after operation visibility/Hidden +

      Macro FCTreeView 01.png All Visible visualise if the object is status Visible +

      Macro FCTreeView 02.png All Hidden visualise if the object is status Hidden +

      +

      Section Search

      +

      Macro FCTreeView 20.png Clear Clear the search line edit +

      +

      The radioButton options Search:

      +
      • ("NLwc") : Search by Name and Label Without respecting the sensitive Case
      +
      • ("Nsc") : Search by Name and respecting the Sensitive Case
      +
      • ("Lwc") : Search by Label Without respecting the sensitive Case
      +
      • ("NLsc") : Search by Name and Label and respecting the Sensitive Case
      +
      • ("NLwsc") : Search by Name and Label in Word and respecting the Sensitive Case (same panel selection of FreeCAD)
      +
      • (Nu)  : Search by numeric value (radius, length, angle .....) see version section
      +

      Macro FCTreeView 23.png Select flip/flop for Selected all object(s) displayed in the window +

      Macro FCTreeView 24.png Unselected flip/flop Unselected all object(s) +

      Macro FCTreeView 25.png S Sheet access in Spreadsheet options +

      +

      The SpreadSheet options:

      +

      Macro FCTreeView +

      +
      +


      +Macro FCTreeView 001.png +

      Macro FCTreeView 002.png +

      +
      • CheckBox options for select the data to save in spreadsheet
      +

      Macro FCTreeView 28.png Select : Select all checkBox option to save +

      Macro FCTreeView 29.png Select : unSelect all checkBox option to save +

      Macro FCTreeView 003.png +

      +
      • Value : alone the value is saved in the cell +
        • Ex : 10.00 Macro FCTreeView 30.png
      • +
      • Val Gr : the value and the unit are saved in unique cell +
        • Ex : 10.00 mm Macro FCTreeView 31.png
      • +
      • Val Gr Ph : the value, the unit and the physic data is saved in unique cell +
        • Ex : 10.00 mm Length Macro FCTreeView 32.png
      • +
      • Split : if the Split checkBox is checked, the data is cut saved in separate cell +
        • Ex : 10.00 | mm | length Macro FCTreeView 33.png
      +

      Macro FCTreeView 004.png +

      +
      • Combobox mm : select the unit length desired. The value is convert in the selected unit. The units length available are: +
        • km, hm, dam, m, dm, cm, mm, um, nm, pm, fm, in, lk, ft, yd, rd, ch, fur, mi, lea, nmi
      • +
      • Combobox gram : select the unit weight desired. The value is convert in the selected unit. The units weight available are: +
        • t, q, kg, hg, dag, g, dg, cg, mg, µg, ng, pg, fg, gr, dr, oz, oz t, lb, t lb, st, qtr, cwt, tonneau fr, ct
      • +
      • Spinbox Densite : give the density by dm3 of the material used (Default : 1.0000)
      • +
      • Spinbox Round : give the round value desired (Default : 3)
      +

      Macro FCTreeView 005.png +

      +
      • Combobox Name spreadSheet : List the spreadsheet in the document
      • +
      • Line edit Name spreadSheet : Display the actual spreadsheet or give the name for the new spreadsheet
      +

      Macro FCTreeView 006.png +

      Macro FCTreeView 28.png Select select all checkbox options +

      Macro FCTreeView 29.png Unselect unselected all checkbox options +

      Macro FCTreeView 27.png Save save the data in Spreadsheet displayed. if no spreadsheet is active the spreadsheet named FCSpreadSheet is created +

      Macro FCTreeView 26.png Quit quit the Spreadsheet options +

      +

      Icons

      +

      The icon must be copied into the same directory as the macro +

      Icon used for the Name of object Icon used for visualise if the object is status Visible (mouse click for Hidden) +Icon used for visualise if the object is status Hidden (mouse click for Visible) +Icon used for inform the object in a group the number objects is displayed in top group +Icon used for displayed the single object (not group) +Icon used for the Label of object +Icon used for flip/flop normal/Visibility +Icon used for flip/flop normal/Group +Icon used for Reverse the data listing (momentarily not used) +Icon used for quit Macro FCTreeView (momentarily not used) +Icon used for flip/flop normal/reverse the data listing sort by Name +Icon used for flip/flop normal/reverse the data listing sort by Label +Icon used for flip/flop normal/reverse the data listing sort by Visibility/Hidden +Icon used for flip/flop normal/reverse the data listing sort by Grout/Single object +Icon used for flip/flop the data listing Fold/Expend +Icon used for flip/flop the data listing Expend/Fold +Icon used for reload the data in the project +Icon used for the Name contains objects (or folder Group) +Icon used for return in original organisation after operation visibility/Hidden +If this check Box is checked the sort is created by length with the button clicked (Name, Label ...) +Icon used for Clear the search line edit +Icon used for flip/flop Split the Name list +Icon used for flip/flop Split the Name and Label list +Icon used for Selected all object(s) displayed in the window +Icon used for Unselected all object(s) +Icon used for access in Spreadsheet options +Icon used for quit the Spreadsheet options +Icon used for save the data in Spreadsheet +Icon used for select all checkbox options +Icon used for unselected all checkbox options +Icon used for save the value data in Spreadsheet +Icon used for save the value and Unit data in Spreadsheet +Icon used for save the value, Unit and type data in Spreadsheet +Icon used for split the value, Unit and type in cell separate in Spreadsheet +

      +

      Script

      +

      For prevent many instance the clic on ToolBar button are effect flip/flop (hide/visible) +

      The macro is located in right dock for change it modify the value line number 133 testing = 0 (or change it with the mouse as a widget normal) +

      The icon ToolBar Macro FCTreeView +

      Macro FCTreeView.FCMacro +

      + +


      +

      +

      To do

      +

      Docked the macro +

      +

      Version

      +

      ver 00.07 (06/05/2018) : modify procedure for search the last cell used +

      ver 00.06 (13/12/2017) : correct little bug line del line num 1881 "del listeSortedBis[doublon][4:] # supprime le fond inutile" thanks renatorivo +

      ver 00.05 (27/11/2017) : add creation spreadsheet and many option for him +

      ver 00.04 (29-09-2017) : add search by numeric value (length, radius....) +

      values researched : +

      +
      global impost                 ; impost = ["Angle","Angle0","Angle1","Angle2","Angle3","ChamferSize","Circumradius","Columns","Degree",
      +                                          "FilletRadius","FirstAngle","Growth","Height","LastAngle","Length","Length2","MajorRadius",
      +                                          "MinorRadius","Pitch","Polygon","Radius","Radius1","Radius2","Radius3","Rows","Size","Width",
      +                                          "X","X1","X2","Xmax","Xmin","X2max","X2min",
      +                                          "Y","Y1","Y2","Ymax","Ymin","Y2max","Y2min",
      +                                          "Z","Z1","Z2","Zmax","Zmin","Z2max","Z2min"] 
      +

      ver 00.03 (23/09/2017) : add search by type object +

      ver 00.02 (11/09/2017) : modify for docked and prevent many instance the clic on button are effect flip/flop (macro hide/visible) +

      ver 00.01 (08/09/2017)  : +

      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Macro_FCTreeView.png b/localwiki/Macro_FCTreeView.png new file mode 100644 index 0000000..8240f25 Binary files /dev/null and b/localwiki/Macro_FCTreeView.png differ diff --git a/localwiki/Macro_FCTreeView_00.png b/localwiki/Macro_FCTreeView_00.png new file mode 100644 index 0000000..000cfd1 Binary files /dev/null and b/localwiki/Macro_FCTreeView_00.png differ diff --git a/localwiki/Macro_FCTreeView_001.png b/localwiki/Macro_FCTreeView_001.png new file mode 100644 index 0000000..110ea94 Binary files /dev/null and b/localwiki/Macro_FCTreeView_001.png differ diff --git a/localwiki/Macro_FCTreeView_002.png b/localwiki/Macro_FCTreeView_002.png new file mode 100644 index 0000000..1759833 Binary files /dev/null and b/localwiki/Macro_FCTreeView_002.png differ diff --git a/localwiki/Macro_FCTreeView_003.png b/localwiki/Macro_FCTreeView_003.png new file mode 100644 index 0000000..c77367a Binary files /dev/null and b/localwiki/Macro_FCTreeView_003.png differ diff --git a/localwiki/Macro_FCTreeView_004.png b/localwiki/Macro_FCTreeView_004.png new file mode 100644 index 0000000..778de9c Binary files /dev/null and b/localwiki/Macro_FCTreeView_004.png differ diff --git a/localwiki/Macro_FCTreeView_005.png b/localwiki/Macro_FCTreeView_005.png new file mode 100644 index 0000000..b8710b9 Binary files /dev/null and b/localwiki/Macro_FCTreeView_005.png differ diff --git a/localwiki/Macro_FCTreeView_006.png b/localwiki/Macro_FCTreeView_006.png new file mode 100644 index 0000000..8a5062d Binary files /dev/null and b/localwiki/Macro_FCTreeView_006.png differ diff --git a/localwiki/Macro_FCTreeView_01.png b/localwiki/Macro_FCTreeView_01.png new file mode 100644 index 0000000..a433028 Binary files /dev/null and b/localwiki/Macro_FCTreeView_01.png differ diff --git a/localwiki/Macro_FCTreeView_02.png b/localwiki/Macro_FCTreeView_02.png new file mode 100644 index 0000000..9b6d925 Binary files /dev/null and b/localwiki/Macro_FCTreeView_02.png differ diff --git a/localwiki/Macro_FCTreeView_03.png b/localwiki/Macro_FCTreeView_03.png new file mode 100644 index 0000000..16dddc8 Binary files /dev/null and b/localwiki/Macro_FCTreeView_03.png differ diff --git a/localwiki/Macro_FCTreeView_04.png b/localwiki/Macro_FCTreeView_04.png new file mode 100644 index 0000000..6e258f9 Binary files /dev/null and b/localwiki/Macro_FCTreeView_04.png differ diff --git a/localwiki/Macro_FCTreeView_05.png b/localwiki/Macro_FCTreeView_05.png new file mode 100644 index 0000000..a1e3f31 Binary files /dev/null and b/localwiki/Macro_FCTreeView_05.png differ diff --git a/localwiki/Macro_FCTreeView_06.png b/localwiki/Macro_FCTreeView_06.png new file mode 100644 index 0000000..50c77ef Binary files /dev/null and b/localwiki/Macro_FCTreeView_06.png differ diff --git a/localwiki/Macro_FCTreeView_07.png b/localwiki/Macro_FCTreeView_07.png new file mode 100644 index 0000000..ddb60f5 Binary files /dev/null and b/localwiki/Macro_FCTreeView_07.png differ diff --git a/localwiki/Macro_FCTreeView_08.png b/localwiki/Macro_FCTreeView_08.png new file mode 100644 index 0000000..c5bc90d Binary files /dev/null and b/localwiki/Macro_FCTreeView_08.png differ diff --git a/localwiki/Macro_FCTreeView_09.png b/localwiki/Macro_FCTreeView_09.png new file mode 100644 index 0000000..d88266c Binary files /dev/null and b/localwiki/Macro_FCTreeView_09.png differ diff --git a/localwiki/Macro_FCTreeView_10.png b/localwiki/Macro_FCTreeView_10.png new file mode 100644 index 0000000..ff39e88 Binary files /dev/null and b/localwiki/Macro_FCTreeView_10.png differ diff --git a/localwiki/Macro_FCTreeView_11.png b/localwiki/Macro_FCTreeView_11.png new file mode 100644 index 0000000..4bb0948 Binary files /dev/null and b/localwiki/Macro_FCTreeView_11.png differ diff --git a/localwiki/Macro_FCTreeView_12.png b/localwiki/Macro_FCTreeView_12.png new file mode 100644 index 0000000..5ae4b8f Binary files /dev/null and b/localwiki/Macro_FCTreeView_12.png differ diff --git a/localwiki/Macro_FCTreeView_13.png b/localwiki/Macro_FCTreeView_13.png new file mode 100644 index 0000000..07e4285 Binary files /dev/null and b/localwiki/Macro_FCTreeView_13.png differ diff --git a/localwiki/Macro_FCTreeView_14.png b/localwiki/Macro_FCTreeView_14.png new file mode 100644 index 0000000..374e803 Binary files /dev/null and b/localwiki/Macro_FCTreeView_14.png differ diff --git a/localwiki/Macro_FCTreeView_15.png b/localwiki/Macro_FCTreeView_15.png new file mode 100644 index 0000000..99d3ef2 Binary files /dev/null and b/localwiki/Macro_FCTreeView_15.png differ diff --git a/localwiki/Macro_FCTreeView_16.png b/localwiki/Macro_FCTreeView_16.png new file mode 100644 index 0000000..7a24bfd Binary files /dev/null and b/localwiki/Macro_FCTreeView_16.png differ diff --git a/localwiki/Macro_FCTreeView_17.png b/localwiki/Macro_FCTreeView_17.png new file mode 100644 index 0000000..c9af40f Binary files /dev/null and b/localwiki/Macro_FCTreeView_17.png differ diff --git a/localwiki/Macro_FCTreeView_18.png b/localwiki/Macro_FCTreeView_18.png new file mode 100644 index 0000000..8240f25 Binary files /dev/null and b/localwiki/Macro_FCTreeView_18.png differ diff --git a/localwiki/Macro_FCTreeView_19.png b/localwiki/Macro_FCTreeView_19.png new file mode 100644 index 0000000..e266cea Binary files /dev/null and b/localwiki/Macro_FCTreeView_19.png differ diff --git a/localwiki/Macro_FCTreeView_20.png b/localwiki/Macro_FCTreeView_20.png new file mode 100644 index 0000000..ee971b4 Binary files /dev/null and b/localwiki/Macro_FCTreeView_20.png differ diff --git a/localwiki/Macro_FCTreeView_21.png b/localwiki/Macro_FCTreeView_21.png new file mode 100644 index 0000000..f6f5a0f Binary files /dev/null and b/localwiki/Macro_FCTreeView_21.png differ diff --git a/localwiki/Macro_FCTreeView_22.png b/localwiki/Macro_FCTreeView_22.png new file mode 100644 index 0000000..77d51a0 Binary files /dev/null and b/localwiki/Macro_FCTreeView_22.png differ diff --git a/localwiki/Macro_FCTreeView_23.png b/localwiki/Macro_FCTreeView_23.png new file mode 100644 index 0000000..29c939d Binary files /dev/null and b/localwiki/Macro_FCTreeView_23.png differ diff --git a/localwiki/Macro_FCTreeView_24.png b/localwiki/Macro_FCTreeView_24.png new file mode 100644 index 0000000..77cd248 Binary files /dev/null and b/localwiki/Macro_FCTreeView_24.png differ diff --git a/localwiki/Macro_FCTreeView_25.png b/localwiki/Macro_FCTreeView_25.png new file mode 100644 index 0000000..b965272 Binary files /dev/null and b/localwiki/Macro_FCTreeView_25.png differ diff --git a/localwiki/Macro_FCTreeView_26.png b/localwiki/Macro_FCTreeView_26.png new file mode 100644 index 0000000..dfbb071 Binary files /dev/null and b/localwiki/Macro_FCTreeView_26.png differ diff --git a/localwiki/Macro_FCTreeView_27.png b/localwiki/Macro_FCTreeView_27.png new file mode 100644 index 0000000..e55d125 Binary files /dev/null and b/localwiki/Macro_FCTreeView_27.png differ diff --git a/localwiki/Macro_FCTreeView_28.png b/localwiki/Macro_FCTreeView_28.png new file mode 100644 index 0000000..dc6243d Binary files /dev/null and b/localwiki/Macro_FCTreeView_28.png differ diff --git a/localwiki/Macro_FCTreeView_29.png b/localwiki/Macro_FCTreeView_29.png new file mode 100644 index 0000000..46f3831 Binary files /dev/null and b/localwiki/Macro_FCTreeView_29.png differ diff --git a/localwiki/Macro_FCTreeView_30.png b/localwiki/Macro_FCTreeView_30.png new file mode 100644 index 0000000..ab98c5f Binary files /dev/null and b/localwiki/Macro_FCTreeView_30.png differ diff --git a/localwiki/Macro_FCTreeView_31.png b/localwiki/Macro_FCTreeView_31.png new file mode 100644 index 0000000..2b7f405 Binary files /dev/null and b/localwiki/Macro_FCTreeView_31.png differ diff --git a/localwiki/Macro_FCTreeView_32.png b/localwiki/Macro_FCTreeView_32.png new file mode 100644 index 0000000..097bc00 Binary files /dev/null and b/localwiki/Macro_FCTreeView_32.png differ diff --git a/localwiki/Macro_FCTreeView_33.png b/localwiki/Macro_FCTreeView_33.png new file mode 100644 index 0000000..f248ed6 Binary files /dev/null and b/localwiki/Macro_FCTreeView_33.png differ diff --git a/localwiki/Macro_FCWire_To_Volume.html b/localwiki/Macro_FCWire_To_Volume.html new file mode 100644 index 0000000..2b71836 --- /dev/null +++ b/localwiki/Macro_FCWire_To_Volume.html @@ -0,0 +1,456 @@ +Macro FCWire To Volume

      Macro FCWire To Volume

      + +
      + + + + + + + + + + + + + + + + + + + + + + + + + + +
      +

      Macro FCWire To Volume.png Macro FCWire To Volume

      +
      Description +
      Create the boolean operation with the selected wires +
      Author +
      Mario52 +
      Links +
      Macros recipes
      How to install macros
      How to customize toolbars +
      Version +
      1.0 +
      Date last modification +
      2016-10-10 +
      +

      + +
      Macro FCWire To Volume 01.png +
      +

      Description

      +

      This macro create on object boolean with the object Draft selected. +

      +

      Uses

      +

      Select the wires objects, enter the thickness choice the operation desired and click the button Create +

      +
      Macro FCWire To Volume 00.png
      +
      +
      • SpinBox : Give the thickness
      • +
      • Single : If the checkBox is checked the object is on single object, if not the object created conserve the hierarchy of the construction the object (Default). The originals objects hare not modified.
      • +
      • Common , Substract , Union , Difference : Boolean's operations
      • +
      • X , Y , Z : Extrude Axis (Z by Default)
      • +
      • Quit : Quit themacro
      • +
      • Create : Create the Boolean object
      +

      Script

      +

      Copy the macro in your macro folder. +

      The icon for the tool bar Macro FCWire To Volume.png +

      Macro_FCWire_To_Volume.FCMacro +

      +
      # -*- coding: utf-8 -*-
      +from __future__ import unicode_literals
      +#
      +"""
      +***************************************************************************
      +*   Copyright (c) 2016 <mario52>                                          *
      +*                                                                         *
      +*   This file is a supplement to the FreeCAD CAx development system.      *
      +*                                                                         *
      +*   This program is free software; you can redistribute it and/or modify  *
      +*   it under the terms of the GNU Lesser General Public License (LGPL)    *
      +*   as published by the Free Software Foundation; either version 2 of     *
      +*   the License, or (at your option) any later version.                   *
      +*   for detail see the LICENCE text file.                                 *
      +*                                                                         *
      +*   This software is distributed in the hope that it will be useful,      *
      +*   but WITHOUT ANY WARRANTY; without even the implied warranty of        *
      +*   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the         *
      +*   GNU Library General Public License for more details.                  *
      +*                                                                         *
      +*   You should have received a copy of the GNU Library General Public     *
      +*   License along with this macro; if not, write to the Free Software     *
      +*   Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  *
      +*   USA                                                                   *
      +***************************************************************************
      +*           WARNING! All changes in this file will be lost and            *  
      +*                  may cause malfunction of the program                   *
      +***************************************************************************
      +"""
      +#Macro_FCWire_To_Volume 10/10/2016_01
      +#
      +#OS: Windows 10
      +#Word size of OS: 64-bit
      +#Word size of FreeCAD: 64-bit
      +#Version: 0.16.6706 (Git)
      +#Build type: Release
      +#Branch: releases/FreeCAD-0-16
      +#Hash: f86a4e411ff7848dea98d7242f43b7774bee8fa0
      +#Python version: 2.7.8
      +#Qt version: 4.8.7
      +#Coin version: 4.0.0a
      +#OCC version: 6.8.0.oce-0.17
      +#
      +__title__   = "Macro_FCWire_To_Volume"
      +__author__  = "Mario52"
      +__url__     = "http://www.freecadweb.org/index-fr.html"
      +__version__ = "00.01"
      +__date__    = "10/10/2016"
      +
      +try:
      +    import PyQt4
      +    from PyQt4 import QtGui ,QtCore
      +    from PyQt4.QtGui import *
      +    from PyQt4.QtCore import *
      +except Exception:
      +    import PySide
      +    from PySide import QtGui ,QtCore
      +    from PySide.QtGui import *
      +    from PySide.QtCore import *
      + 
      +import Draft, Part, PartGui, FreeCADGui, FreeCAD
      +from FreeCAD import Base
      +import math
      +from math import sqrt, pi, sin, cos, asin
      +
      +Gui = FreeCADGui
      +App = FreeCAD
      +
      +try:
      +    _fromUtf8 = QtCore.QString.fromUtf8
      +except AttributeError:
      +    def _fromUtf8(s):
      +        return s
      +
      +try:
      +    _encoding = QtGui.QApplication.UnicodeUTF8
      +    def _translate(context, text, disambig):
      +        return QtGui.QApplication.translate(context, text, disambig, _encoding)
      +except AttributeError:
      +    def _translate(context, text, disambig):
      +        return QtGui.QApplication.translate(context, text, disambig)
      +
      +def errorDialog(msg):
      +    diag = QtGui.QMessageBox(QtGui.QMessageBox.Critical,u"Error Message",msg )
      +#    diag.setWindowModality(QtCore.Qt.ApplicationModal)            # la fonction a ete desactivee pour favoriser "WindowStaysOnTopHint"
      +    try:
      +        diag.setWindowFlags(PyQt4.QtCore.Qt.WindowStaysOnTopHint)  # PyQt4  # cette fonction met la fenetre en avant
      +    except Exception:    
      +        diag.setWindowFlags(PySide.QtCore.Qt.WindowStaysOnTopHint) # PySide # cette fonction met la fenetre en avant
      +    diag.exec_()
      +        
      +class Ui_MainWindow(object):
      +
      +    def __init__(self ):
      +        self.window = MainWindow
      +        #self.path   = FreeCAD.ConfigGet("AppHomePath")
      +        self.path   = FreeCAD.ConfigGet("UserAppData")
      +        self.path   = self.path.replace("\\","/")
      +
      +        self.thicknessValue  = 0.0
      +        self.thicknessX      = 0.0     # extrusion
      +        self.thicknessY      = 0.0     # extrusion
      +        self.thicknessZ      = 0.0     # extrusion
      +
      +    def setupUi(self, MainWindow):
      +        self.window = MainWindow
      +        MainWindow.setObjectName(_fromUtf8("MainWindow"))
      +        MainWindow.resize(171, 180)
      +        MainWindow.setMinimumSize(QtCore.QSize(171, 180))
      +        MainWindow.setMaximumSize(QtCore.QSize(171, 180))
      +        self.centralwidget = QtGui.QWidget(MainWindow)
      +        self.centralwidget.setObjectName(_fromUtf8("centralwidget"))
      +
      +        self.fontGlobal_08 = QtGui.QFont()            # pour compatibilite Windows Linux pour tous les textes
      +        self.fontGlobal_08.setFamily("Arial")         # pour compatibilite Windows Linux pour tous les textes
      +        self.fontGlobal_08.setPointSize(8.0)          # pour compatibilite Windows Linux pour tous les textes
      +
      +        self.label_01 = QtGui.QLabel(self.centralwidget)
      +        self.label_01.setGeometry(QtCore.QRect(10, 0, 151, 16))
      +        self.label_01.setFont(self.fontGlobal_08)                       # pour compatibilite W L
      +        self.label_01.setObjectName(_fromUtf8("label_01"))
      +
      +        self.doubleSpinBox = QtGui.QDoubleSpinBox(self.centralwidget)
      +        self.doubleSpinBox.setGeometry(QtCore.QRect(10, 20, 81, 22))
      +        self.doubleSpinBox.setFont(self.fontGlobal_08)                  # pour compatibilite W L
      +        self.doubleSpinBox.setObjectName(_fromUtf8("doubleSpinBox"))
      +        self.doubleSpinBox.setMinimum(0)
      +        self.doubleSpinBox.setMaximum(999999.999999)
      +        self.doubleSpinBox.setDecimals(3)
      +        self.doubleSpinBox.setValue(0.0)
      +        self.doubleSpinBox.valueChanged.connect(self.on_doubleSpinBox) ###
      +
      +        self.checkBox_01 = QtGui.QCheckBox(self.centralwidget)
      +        self.checkBox_01.setGeometry(QtCore.QRect(100, 23, 70, 17))
      +        self.checkBox_01.setFont(self.fontGlobal_08)                    # pour compatibilite W L
      +        self.checkBox_01.setObjectName(_fromUtf8("checkBox_01"))
      +        self.checkBox_01.setChecked(False)    # True
      +        self.checkBox_01.setToolTip(_fromUtf8("Check this checkBox"+"\n"+
      +                                              "for create single object"))
      +
      +        self.FrameOp = QtGui.QFrame(self.centralwidget)
      +        self.FrameOp.setGeometry(QtCore.QRect(10, 50, 81, 80))
      +        self.FrameOp.setFrameShape(QtGui.QFrame.StyledPanel)
      +        self.FrameOp.setFrameShadow(QtGui.QFrame.Raised)
      +        self.FrameOp.setObjectName(_fromUtf8("FrameOp"))
      +
      +        self.RB_Common = QtGui.QRadioButton(self.FrameOp)
      +        self.RB_Common.setGeometry(QtCore.QRect(10, 0, 82, 17))
      +        self.RB_Common.setFont(self.fontGlobal_08)                      # pour compatibilite W L
      +        self.RB_Common.setChecked(True)
      +        self.RB_Common.setObjectName(_fromUtf8("RB_Common"))
      +
      +        self.RB_Substract = QtGui.QRadioButton(self.FrameOp)
      +        self.RB_Substract.setGeometry(QtCore.QRect(10, 20, 82, 17))
      +        self.RB_Substract.setFont(self.fontGlobal_08)                   # pour compatibilite W L
      +        self.RB_Substract.setObjectName(_fromUtf8("RB_Substract"))
      +
      +        self.RB_Union = QtGui.QRadioButton(self.FrameOp)
      +        self.RB_Union.setGeometry(QtCore.QRect(10, 40, 82, 17))
      +        self.RB_Union.setFont(self.fontGlobal_08)                       # pour compatibilite W L
      +        self.RB_Union.setObjectName(_fromUtf8("RB_Union"))
      +
      +        self.RB_Difference = QtGui.QRadioButton(self.FrameOp)
      +        self.RB_Difference.setGeometry(QtCore.QRect(10, 60, 82, 17))
      +        self.RB_Difference.setFont(self.fontGlobal_08)                  # pour compatibilite W L
      +        self.RB_Difference.setObjectName(_fromUtf8("RB_Difference"))
      +
      +        self.FrameAxis = QtGui.QFrame(self.centralwidget)
      +        self.FrameAxis.setGeometry(QtCore.QRect(90, 50, 71, 80))
      +        self.FrameAxis.setFrameShape(QtGui.QFrame.StyledPanel)
      +        self.FrameAxis.setFrameShadow(QtGui.QFrame.Raised)
      +        self.FrameAxis.setObjectName(_fromUtf8("FrameAxis"))
      +
      +        self.RB_Axis_X = QtGui.QRadioButton(self.FrameAxis)
      +        self.RB_Axis_X.setGeometry(QtCore.QRect(10, 0, 71, 17))
      +        self.RB_Axis_X.setFont(self.fontGlobal_08)                      # pour compatibilite W L
      +        self.RB_Axis_X.setObjectName(_fromUtf8("RB_Axis_X"))
      +        self.RB_Axis_X.setToolTip(_fromUtf8("Plane YZ extrude direction X"))
      +
      +        self.RB_Axis_Y = QtGui.QRadioButton(self.FrameAxis)
      +        self.RB_Axis_Y.setGeometry(QtCore.QRect(10, 30, 71, 17))
      +        self.RB_Axis_Y.setFont(self.fontGlobal_08)                      # pour compatibilite W L
      +        self.RB_Axis_Y.setObjectName(_fromUtf8("RB_Axis_Y"))
      +        self.RB_Axis_Y.setToolTip(_fromUtf8("Plane XZ extrude direction Y"))
      +
      +        self.RB_Axis_Z = QtGui.QRadioButton(self.FrameAxis)
      +        self.RB_Axis_Z.setGeometry(QtCore.QRect(10, 60, 71, 17))
      +        self.RB_Axis_Z.setFont(self.fontGlobal_08)                      # pour compatibilite W L
      +        self.RB_Axis_Z.setObjectName(_fromUtf8("RB_Axis_Z"))
      +        self.RB_Axis_Z.setChecked(True)
      +        self.RB_Axis_Z.setToolTip(_fromUtf8("Plane XY extrude direction Z"))
      +
      +        self.PB_Quit = QtGui.QPushButton(self.centralwidget)
      +        self.PB_Quit.setGeometry(QtCore.QRect(10, 140, 73, 23))
      +        self.PB_Quit.setFont(self.fontGlobal_08)                       # pour compatibilite W L
      +        self.PB_Quit.setObjectName(_fromUtf8("PB_Quit"))
      +        self.PB_Quit.clicked.connect(self.on_PB_Quit) ###
      +
      +        self.PB_Create = QtGui.QPushButton(self.centralwidget)
      +        self.PB_Create.setGeometry(QtCore.QRect(90, 140, 73, 23))
      +        self.PB_Create.setFont(self.fontGlobal_08)                      # pour compatibilite W L
      +        self.PB_Create.setObjectName(_fromUtf8("PB_Create"))
      +        self.PB_Create.clicked.connect(self.on_PB_Create) ###
      +
      +        MainWindow.setCentralWidget(self.centralwidget)
      +        self.retranslateUi(MainWindow)
      +        QtCore.QMetaObject.connectSlotsByName(MainWindow)
      +
      +    def retranslateUi(self, MainWindow):
      +        MainWindow.setWindowTitle("FCWire To Volume")
      +        self.label_01.setText("FCWire To Volume")
      +        self.checkBox_01.setText("Single")
      +        self.RB_Common.setText("Common")
      +        self.RB_Substract.setText("Substract")
      +        self.RB_Union.setText("Union")
      +        self.RB_Difference.setText("Difference")
      +        self.RB_Axis_X.setText( "X Axis")
      +        self.RB_Axis_Y.setText("Y Axis")
      +        self.RB_Axis_Z.setText("Z Axis")
      +        self.PB_Quit.setText("Quit")
      +        self.PB_Create.setText("Create")
      +
      +        try:
      +            MainWindow.setWindowFlags(PyQt4.QtCore.Qt.WindowStaysOnTopHint)         # PyQt4 cette fonction met la fenetre en avant
      +        except Exception:
      +            MainWindow.setWindowFlags(PySide.QtCore.Qt.WindowStaysOnTopHint)        # PySide cette fonction met la fenetre en avant
      +
      +    def on_doubleSpinBox(self,value):
      +        self.thicknessValue = value
      +
      +    def on_PB_Quit(self):                        # Quit
      +        App.Console.PrintMessage(str("Fin FCWire To Volume ")+"\n")
      +        self.window.hide()
      +
      +    def on_PB_Create(self):
      +        selectionObjects = FreeCADGui.Selection.getSelection()
      +        noface = 0
      +        try:
      +            selectedEdge = FreeCADGui.Selection.getSelectionEx()[0].SubObjects[0] # select one element SubObjects
      +            if str(selectedEdge)[1:5] == "Face":
      +                noface = 1
      +        except Exception:
      +            None
      +
      +        selectionDuplicate  = []
      +        del selectionDuplicate[:]
      +        p  = []
      +        del p[:]
      +        
      +        try:
      +            ###########
      +            self.thicknessX = 0.0
      +            self.thicknessY = 0.0
      +            self.thicknessZ = 0.0
      +    
      +            if self.RB_Axis_X.isChecked():
      +                self.thicknessX = self.thicknessValue
      +            if self.RB_Axis_Y.isChecked():
      +                self.thicknessY = self.thicknessValue
      +            if self.RB_Axis_Z.isChecked():
      +                self.thicknessZ = self.thicknessValue
      +            ###########
      +    
      +            if (len(selectionObjects) >= 2) and (noface == 0) and (self.thicknessX + self.thicknessY + self.thicknessZ != 0.0):
      +                for i in selectionObjects:            # duplicate object
      +                    Part.show(i.Shape.copy())
      +                    sD = doc.ActiveObject
      +                    sD.Label = i.Name
      +                    selectionDuplicate.append(sD)
      +            
      +                for i in (selectionDuplicate):        # extrude object
      +                    a = Draft.extrude(i,Base.Vector(self.thicknessX,self.thicknessY,self.thicknessZ))    # axis extrude X Y Z
      +                    a.Solid = True
      +                    p.append(a)
      +            
      +                if self.RB_Common.isChecked():
      +                    name = "Common_" + selectionDuplicate[0].Label         ## create Common_
      +                    tx = doc.addObject("Part::MultiCommon",name)
      +                    tx.Shapes = p
      +                    doc.recompute()
      +                    if self.checkBox_01.isChecked():
      +                        Part.show(tx.Shape)
      +                        singleO = App.ActiveDocument.ActiveObject
      +                        singleO.Label = name
      +                        doc.removeObject(tx.Name)
      +                        for i in range(len(selectionDuplicate)):
      +                            doc.removeObject(selectionDuplicate[i].Name)
      +                            doc.removeObject(p[i].Name)
      +                    App.Console.PrintMessage("RB_Common ")
      +
      +                elif self.RB_Substract.isChecked():
      +                    name = str("Cut_" + selectionDuplicate[0].Label)       ## create Cut_
      +                    tx = doc.addObject("Part::Cut",name)
      +                    tx.Base = p[0]
      +                    tx.Tool = p[1]
      +                    doc.recompute()
      +                    if self.checkBox_01.isChecked():
      +                        Part.show(tx.Shape)
      +                        singleO = App.ActiveDocument.ActiveObject
      +                        singleO.Label = name
      +                        doc.removeObject(tx.Name)
      +                        for i in range(len(selectionDuplicate)):
      +                            doc.removeObject(selectionDuplicate[i].Name)
      +                            doc.removeObject(p[i].Name)
      +                    App.Console.PrintMessage("RB_Substract ")
      +            
      +                elif self.RB_Union.isChecked():
      +                    name = str("Fusion_" + selectionDuplicate[0].Label)    ## create Fusion_
      +                    tx = doc.addObject("Part::MultiFuse",name)
      +                    tx.Shapes = p
      +                    doc.recompute()
      +                    if self.checkBox_01.isChecked():
      +                        Part.show(tx.Shape)
      +                        singleO = App.ActiveDocument.ActiveObject
      +                        singleO.Label = name
      +                        doc.removeObject(tx.Name)
      +                        for i in range(len(selectionDuplicate)):
      +                            doc.removeObject(selectionDuplicate[i].Name)
      +                            doc.removeObject(p[i].Name)
      +                    App.Console.PrintMessage("RB_Union")
      +            
      +                elif self.RB_Difference.isChecked():
      +                    name = "CommonD_" + selectionDuplicate[0].Label        ##
      +                    commun = doc.addObject("Part::MultiCommon",name)
      +                    commun.Shapes = p
      +                    name = str("FusionD_" + selectionDuplicate[0].Label)   ##
      +                    fusion = doc.addObject("Part::MultiFuse",name)
      +                    fusion.Shapes = p
      +                    name = str("Difference_" + selectionDuplicate[0].Label)## create Difference_
      +                    difference = doc.addObject("Part::Cut",name)
      +                    difference.Base = fusion
      +                    difference.Tool = commun
      +                    doc.recompute()
      +                    if self.checkBox_01.isChecked():
      +                        Part.show(difference.Shape)
      +                        singleO = App.ActiveDocument.ActiveObject
      +                        singleO.Label = name
      +                        doc.removeObject(commun.Name)
      +                        doc.removeObject(fusion.Name)
      +                        doc.removeObject(difference.Name)
      +                        for i in range(len(selectionDuplicate)):
      +                            doc.removeObject(selectionDuplicate[i].Name)
      +                            doc.removeObject(p[i].Name)
      +                    App.Console.PrintMessage("RB_Difference ")
      +            
      +                doc.recompute()
      +                App.Console.PrintMessage(str(self.thicknessX)+" "+str(self.thicknessY)+" "+str(self.thicknessZ) + "\n")
      +            else:
      +                if (self.thicknessX + self.thicknessY + self.thicknessZ == 0.0):
      +                    App.Console.PrintError("Thickness = 0" + "\n")
      +                else:
      +                    App.Console.PrintError("Not for Face" + "\n")
      +        except Exception:
      +            print "Wrong selection or operation"
      +
      +#______________________________________________________________________________________
      +
      +doc = FreeCAD.ActiveDocument
      +if doc == None:
      +    doc = FreeCAD.newDocument()
      +
      +MainWindow = QtGui.QMainWindow()
      +ui = Ui_MainWindow()
      +ui.setupUi(MainWindow)
      +MainWindow.show() 
      +

      Link

      +

      The tread in the forum Bunch of issues/questions +

      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Macro_FCWire_To_Volume_00.png b/localwiki/Macro_FCWire_To_Volume_00.png new file mode 100644 index 0000000..a8f1cbc Binary files /dev/null and b/localwiki/Macro_FCWire_To_Volume_00.png differ diff --git a/localwiki/Macro_FC_Convert_Lines.html b/localwiki/Macro_FC_Convert_Lines.html new file mode 100644 index 0000000..018353b --- /dev/null +++ b/localwiki/Macro_FC_Convert_Lines.html @@ -0,0 +1,264 @@ +Macro FC Convert Lines

      Macro FC Convert Lines

      + +
      + + + + + + + + + + + + + + + + + + + + + + + + + + +
      +

      Macro FCConvertLines.png Macro FC Convert Lines

      +
      Description +
      This macro convert the object line, wire in line Dash, DashDot or DashDotDot with the dimensions given. +

      . +

      +
      Author +
      mario52 +
      Links +
      Macros recipes
      How to install macros
      How to customize toolbars +
      Version +
      00.07 +
      Date last modification +
      2017-05-13 +
      +

      + +
      +


      +

      +

      Description

      +

      This macro convert the object line, wire in line Dash, DashDot, DashDotDot, ZigZag, Hand with the dimensions given. +

      +
      ConvertLines Dash, Dash dot, Dash dot dot
      +
      +

      Use

      +

      Copy the macro in your macros folder and launch +FCConvertLines Gui +

      +
      FCConvertLines Gui
      +
      +

      First section : +

      Cut line (Checked by default) +

      +
      FCConvertLines
      +
      • Select one or more lines in the 3D View
      • +
      • SpinBox : for enter number Cuts or cut to length ... (Default number cut suffix displayed "x Cut")
      • +
      • Create L. : if this checkbox is checked the line is created
      • +
      • Dimension : if this checkbox is checked the number tipped is on length the definition change by tree decimal and the suffix displayed is "x.000 Dim"
      • +
      • Bicolor : if this checkbox is checked the lines created are colored alternately Red White if is not checked the color is the color defined with the button Color
      • +
      • Points : if this checkbox is checked one point is created and the color is the color defined Bicolor or * The options Options lines are available
      +

      Color +

      +
      +


      +Second section : +

      Type line : Dash +

      +
      FCConvertLines
      +
      • The screen at the bottom of the macro change in line Dash
      • +
      • Select one or more lines in the 3D View
      • +
      • Line A : dimension of the dash (see A in the screen)
      • +
      • Space B : dimension of the space (see B in the screen)
      • +
      • The lines have created the configuration specifications set in options lines
      +
      +

      Third section : +

      Type line : DashDot +

      +
      FCConvertLines
      +
      • The screen at the bottom of the macro change in line DashDot
      • +
      • Select one or more lines in the 3D View
      • +
      • Line A : dimension of the dash (see A in the screen)
      • +
      • Space B : dimension of the space (see B in the screen) (May be different D)
      • +
      • Line 2 C : dimension of the dash (see C in the screen)
      • +
      • Space 2 D : dimension of the space (see D in the screen) (May be different B)
      +
      +

      Fourth section : +

      Type line : DashDotDot +

      +
      FCConvertLines
      +
      • The screen at the bottom of the macro change in line DashDotDot
      • +
      • Select one or more lines in the 3D View
      • +
      • Line A : dimension of the dash (see A in the screen)
      • +
      • Space B : dimension of the space (see B in the screen)
      • +
      • Line 2 C : dimension of the dash (see C in the screen)
      • +
      • Space 2 D : dimension of the space (see D in the screen)
      +
      +

      Fifth section : +

      Type line : ZigZag +

      +
      FCConvertLines
      +
      • The screen at the bottom of the macro change in line ZigZag
      • +
      • This line are created
      • +
      • Number heads : number of heads for the total line
      • +
      • _____140.0_____ : The length total of the line are calculate in real time and displayed in this window
      • +
      • Begin A : dimension of begin line until first head, this section line hare same in the end line (see A in the screen)
      • +
      • Dimension B : dimension between the end and begin head (see B in the screen)
      • +
      • Gap C : dimension of the head (see C in the screen)
      • +
      • Height D : height dimension of the the head (see D in the screen)
      • +
      • Number E : number of heads contiguous (see E in the screen)
      • +
      • The options Plane and Options lines are available
      +
      +

      Sixth section : +

      Type line : Hand +

      +
      FCConvertLines
      +
      • This line are created
      • +
      • Length A : The length total of the line (see A in the screen)
      • +
      • Height B : Height of the line (see B in the screen)
      • +
      • Wave : compression or uncompress of the wave (see Wave in the screen)
      • +
      • The options Plane and Options lines are available
      +
      +

      Seventh section : +

      Options line : +

      +
      FCConvertLines
      +

      This options are available for all menu +

      +
      • __2,00 Width__ : dimension of the width of the line(s)
      • +
      • __2,00 Point S__ : dimension of the points of the line(s)
      • +
      • Color : color of the line(s) this button are colored with the color selected (if the checkbox "Bicolor" in the menu "Cut line" is checked this option are not used for this menu)
      +
      +

      Eighth section : +

      Option Plane +

      This option are available only for "ZigZag" and "Hand" +

      +
      FCConvertLines
      +
      • XY : Plane XY
      • +
      • YZ : Plane YZ
      • +
      • XZ : Plane XZ
      +
      +

      Ninth section : +

      Button +

      +
      FCConvertLines
      +
      +
      • Save type : the line configured is saved in one file (one file for one type line). While saving a file header is predetermined depending on the chosen menu (example : Dash is saved, in the save window is displayed "Dash_.FCConvertL" you can modify to "Dash_my_config_10.FCConvertL" or the name you want... this method allow sharpens clear)
      • +
      • Load type : load one file configured
      • +
      • Name type line________________ : name of the type configured this name is saved in the file
      • +
      • Reset : reset the data's in the original configuration
      • +
      • Create Comp : this button create on compound with the lines created (ten lines selected = one compound)
      • +
      • Create : create the lines separately (ten lines selected = ten lines created)
      • +
      • Quit : quit the macro
      +
      +


      +

      +

      The files to copy in your directory with the macro (10 files images)

      +

      The icon for the toolBar +

      +
      Macro_FCConvertLines
      +
      +

      Title +

      +
      ConvertLines_Title
      +
      +

      Line Dash : +

      +
      ConvertLines_Dash
      +
      +

      Line DashDot : +

      +
      ConvertLines Dash dot
      +
      +

      Line DashDotDot : +

      +
      ConvertLines Dash dot dot
      +
      +

      Line Zigzag : +

      +
      ConvertLines_Zigzag
      +
      +

      Line Hand : +

      +
      ConvertLines_Hand
      +
      +

      View : +

      +
      +

      ConvrtLines_View-front ConvrtLines_View-right ConvrtLines_View-right +

      +
      +

      Script

      +

      Copy the macro Macro_FCConvertLines.FCMacro in your macros folder +

      the script on Gist Macro_FCConvertLines.FCMacro +

      +

      Examples

      +

      Example dot, dash dot, dash dot, dash dot dot +

      +
      Macro FCConvertLines 11b.png
      +
      +

      Example hand, zigzag +

      +
      Macro FCConvertLines 11.png
      +
      +

      Example hand +

      +
      Macro FCConvertLines 012.png
      +

      All lines created the configuration specifications set in this Option lines +

      +
      +

      Example hand can make beautiful sine wave or totally anarchic +

      +
      Macro FCConvertLines 013.png
      +
      +


      +Example convert ShapeString to sketch (the curves hare not authorized for convert Shape to Sketch) +

      +
      ShapeString To Sketch.gif
      +
      +


      +

      +

      Version

      +

      ver 00.07 13/05/2017 correct bug after create "Alternate ...." the dimension of lines stay with the dimension alternative and not restitution the desired dimensions +

      ver 00.06 20/02/2017 correction of precision cut (replace "numberOfPoints = longueur" to "numberOfPoints = (longueur + 1)") +

      ver 00.05 11/01/2017 replace de search method macro path +

      ver 00.04 05/09/2016 setPointSize(8.0) +

      ver 00.02 18/02/2016 +

      ver 00.01 19/01/2016 +

      ver 00.00 19/01/2016 +

      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Macro_FaceToSketch.html b/localwiki/Macro_FaceToSketch.html new file mode 100644 index 0000000..99169b7 --- /dev/null +++ b/localwiki/Macro_FaceToSketch.html @@ -0,0 +1,79 @@ +Macro FaceToSketch

      Macro FaceToSketch

      + +
      + + + + + + + + + + + + + + + + + + + + + + + + + + +
      +

      Text-x-python.png FaceToSketch

      +
      Description +
      Converts a face into a sketch without constraints. +
      Author +
      Jreinhardt +
      Links +
      Macros recipes
      How to install macros
      How to customize toolbars +
      Version +
      1.0 +
      Date last modification +
      2013-12-23 +
      +

      Contents

      + +
      + +
      +


      +

      This macro breaks down your form with function Draft Downgrade.png Draft Downgrade and transforms the face selected in a sketch without constraints, and ready to be modified. +


      +

      +
      import Draft
      +  
      +wires,_faces = Draft.downgrade(FreeCADGui.Selection.getSelection(),delete=True)
      +  
      +sketch = Draft.makeSketch(wires[0:1])
      +for wire in wires[1:]:
      +    Draft.makeSketch([wire],addTo=sketch)
      +  
      +for wire in wires:
      +    FreeCAD.ActiveDocument.removeObject(wire.Name) 
      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Macro_FlattenWire.html b/localwiki/Macro_FlattenWire.html new file mode 100644 index 0000000..22671cc --- /dev/null +++ b/localwiki/Macro_FlattenWire.html @@ -0,0 +1,76 @@ +Macro FlattenWire

      Macro FlattenWire

      + +
      + + + + + + + + + + + + + + + + + + + + + + + + + + +
      +

      Text-x-python.png FlattenWire

      +
      Description +
      This macro flattens draft wires that are not plane to their median Z coordinate +
      Author +
      Yorik +
      Links +
      Macros recipes
      How to install macros
      How to customize toolbars +
      Version +
      1.0 +
      Date last modification +
      2011-08-01 +
      +

      Contents

      + +
      + +
      +


      +

      This macro flattens draft wires that are not plane to their median Z coordinate +

      +
      import FreeCAD
      +obj = FreeCAD.ActiveDocument.ActiveObject
      +z = 0
      +for p in obj.Points: z += p.z
      +z = z/len(obj.Points)
      +newpoints = []
      +for p in obj.Points: newppoints.append(FreeCAD.Vector(p.x,p.y,z))
      +obj.Points = newppoints 
      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Macro_FlattenWire3Points.html b/localwiki/Macro_FlattenWire3Points.html new file mode 100644 index 0000000..0c99795 --- /dev/null +++ b/localwiki/Macro_FlattenWire3Points.html @@ -0,0 +1,99 @@ +Macro FlattenWire3Points

      Macro FlattenWire3Points

      + +
      + + + + + + + + + + + + + + + + + + + + + + + + + + +
      +

      Text-x-python.png FlattenWire3Points

      +
      Description +
      This macro flattens draft wires that are not planar on a plane defined by 3 points +
      Author +
      Yorik +
      Links +
      Macros recipes
      How to install macros
      How to customize toolbars +
      Version +
      1.0 +
      Date last modification +
      2016-02-06 +
      +

      Contents

      + +
      + +
      +


      +

      This macro flattens draft wires that are not planar on a plane defined by 3 points. To use this macro, select first 3 vertices from a single Draft Wire. +

      +
      import FreeCAD,FreeCADGui,Draft
      + 
      + # check selection
      + sel = FreeCADGui.Selection.getSelectionEx()
      + ok = True
      + if len(sel) != 1:
      +    FreeCAD.Console.PrintError("Please select 3 vertices from one Draft wire\n")
      +    ok = False
      + sel = sel[0]
      + if Draft.getType(sel.Object) not in ["Wire","BSpline"]:
      +    FreeCAD.Console.PrintError("Please select 3 vertices from one Draft wire\n")
      +    ok = False
      + if len(sel.SubElementNames) != 3:
      +    FreeCAD.Console.PrintError("Please select 3 vertices from one Draft wire\n")
      +    ok = False
      + for e in sel.SubElementNames:
      +    if not "Vertex" in e:
      +        FreeCAD.Console.PrintError("Please select 3 vertices from one Draft wire\n")
      +        ok = False
      + 
      + if ok:
      +    # define a plane
      +    p1 = getattr(sel.Object.Shape,sel.SubElementNames[0]).Point
      +    p2 = getattr(sel.Object.Shape,sel.SubElementNames[1]).Point
      +    p3 = getattr(sel.Object.Shape,sel.SubElementNames[2]).Point
      +    p4 = p2.sub(p1).cross(p3.sub(p1))
      +    
      +    # project wire points
      +    points = []
      +    for p in sel.Object.Points:
      +        points.append(p.projectToPlane(p1,p4))
      +    sel.Object.Points = points 
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Macro_ForceRecompute.html b/localwiki/Macro_ForceRecompute.html new file mode 100644 index 0000000..759b756 --- /dev/null +++ b/localwiki/Macro_ForceRecompute.html @@ -0,0 +1,88 @@ +Macro ForceRecompute

      Macro ForceRecompute

      + +
      + + + + + + + + + + + + + + + + + + + + + + + + + + +
      +

      Force Recompute.png Macro Force Recompute

      +
      Description +
      Forces manual recompute of model +
      Author +
      shoogen +
      Links +
      Macros recipes
      How to install macros
      How to customize toolbars +
      Version +
      1.0 +
      Date last modification +
      2014-09-01 +
      +

      + +
      +


      +

      Sometimes the user applies changes to the model in FreeCAD. +But FreeCAD does not seem to recognize them. +So the blue "Recompute" icon View-refresh.svg stayes greyed out. +This small macro forces a manual recompute of the model. +

      Since FreeCAD v0.17, the effect of this macro can be achieved through GUI. Right-click project in model tree view, and pick "Mark to recompute" from context menu. After that, press Recompute button. +

      +

      Use

      +

      Just run the macro when needed. +

      +

      Script

      +

      Macro Force_Recompute.py +

      +
      # -*- coding: utf-8 -*-
      +# Force Recompute
      +# macro provided by shoogen
      +
      +import FreeCAD
      +for obj in FreeCAD.ActiveDocument.Objects:
      + obj.touch()
      +FreeCAD.ActiveDocument.recompute() 
      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Macro_FreeCAD_to_Kerkythea.html b/localwiki/Macro_FreeCAD_to_Kerkythea.html new file mode 100644 index 0000000..b934018 --- /dev/null +++ b/localwiki/Macro_FreeCAD_to_Kerkythea.html @@ -0,0 +1,647 @@ +Macro FreeCAD to Kerkythea

      Macro FreeCAD to Kerkythea

      + +
      + + + + + + + + + + + + + + + + + + + + + + + + + + +
      +

      Text-x-python.png FC to Kerkythea

      +
      Description +
      Export FreeCAD-Model to Kerkythea +
      Author +
      marmni +
      Links +
      Macros recipes
      How to install macros
      How to customize toolbars +
      Version +
      1.0 +
      Date last modification +
      2015-05-30 +
      +

      + +
      +


      +

      Macro to export your model to the raytracing program Kerkythea. +

      +

      Use

      +

      The macro you can find in the following github repository: FreeCAD to Kerkythea-Exporter +

      It is pretty self-explanatory. +At the moment there are problems with exporting lights and the camera position. +

      +

      Link

      +

      The page discussion Kerkythea Rendering System +


      +

      +

      Script

      +

      Macro ExportToKerkythea.py +

      +
      # -*- coding: utf8 -*-
      +#**************************************************************************************
      +#*         *
      +#*   Kerkythea exporter         *
      +#*   Copyright (c) 2014,2015 *
      +#*   marmni <marmni@onet.eu> *
      +#* *
      +#* *
      +#*   This program is free software; you can redistribute it and/or modify        *
      +#*   it under the terms of the GNU Lesser General Public License (LGPL) *
      +#*   as published by the Free Software Foundation; either version 2 of        *
      +#*   the License, or (at your option) any later version.*
      +#*   for detail see the LICENCE text file.*
      +#*                          *
      +#*   This program is distributed in the hope that it will be useful,                                  *
      +#*   but WITHOUT ANY WARRANTY; without even the implied warranty of                  *
      +#*   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the  *
      +#*   GNU Library General Public License for more details.                          *
      +#*           *
      +#*   You should have received a copy of the GNU Library General Public                          *
      +#*   License along with this program; if not, write to the Free Software                                  *
      +#*   Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307                          *
      +#*   USA               *
      +#*          *
      +#****************************************************************************
      +
      +#****************************************************************************
      +#*  *
      +#* BASED ON*
      +#*  *
      +#* IOANNIS PANTAZOPOULOS*
      +#*  *
      +#* Sample code exporting basic Kerkythea XML file.*
      +#*  *
      +#* Version v1.0*
      +#*  *
      +#****************************************************************************
      +
      +__title__="Kerkythea exporter"
      +__author__ = "marmni <marmni@onet.eu>"
      +__url__ = ["http://www.freecadweb.org"]
      +
      +
      +import FreeCAD, FreeCADGui
      +import re
      +import random
      +import __builtin__
      +import Mesh
      +from PySide import QtCore, QtGui
      +import sys
      +import os
      +
      +
      +##############################################
      +#
      +##############################################
      +class point3D:
      +def __init__(self, point):
      +self.x = "%.4f" % (point[0] * 0.001)
      +self.y = "%.4f" % (point[1] * 0.001)
      +self.z = "%.4f" % (point[2] * 0.001)
      +
      +def __str__(self):
      +return '<P xyz="{0} {1} {2}"/>'.format(self.x, self.y, self.z)
      +
      +#def __eq__(self, other):
      +#if self.x == other.x and self.y == other.y and self.z == other.z:
      +#return True
      +#else:
      +#return False 
      +
      +
      +##############################################
      +#
      +##############################################
      +class indexListPoint3D:
      +def __init__(self, point):
      +self.i = point[0]
      +self.j = point[1]
      +self.k = point[2]
      +
      +def __str__(self):
      +return '<F ijk="{0} {1} {2}"/>'.format(self.i, self.j, self.k)
      +
      +
      +##############################################
      +#
      +##############################################
      +class Material:
      +def __init__(self):
      +self.diffuse = None  # Texture()
      +self.shininess = 1000.0
      +self.ior = 2.0
      +
      +def write(self, file):
      +file.write('''<Object Identifier="Whitted Material" Label="Whitted Material" Name="" Type="Material">\n''')
      +
      +self.diffuse.write(file, "Diffuse")
      +self.diffuse.write(file, "Translucent")
      +self.diffuse.write(file, "Specular")
      +self.diffuse.write(file, "Transmitted")
      +
      +file.write('''<Parameter Name="Shininess" Type="Real" Value="{shininess}"/>
      +<Parameter Name="Transmitted Shininess" Type="Real" Value="{shininess}"/>
      +<Parameter Name="Index of Refraction" Type="Real" Value="{ior}"/>
      +</Object>\n'''.format(shininess=self.shininess, ior=self.ior))
      +
      +
      +##############################################
      +#
      +##############################################
      +class Texture:
      +def __init__(self, color):
      +self.color = color
      +
      +def getColorSTR(self):
      +return '{0} {1} {2}'.format(self.color[0], self.color[1], self.color[2])
      +
      +def toGrayscale(self):
      +RGB = 0.299 * self.color[0] + 0.587 * self.color[1] + 0.114 * self.color[2]
      +self.color = [RGB, RGB, RGB]
      +
      +def write(self, file, identifier):
      +file.write('''<Object Identifier="./{identifier}/Constant Texture" Label="Constant Texture" Name="" Type="Texture">
      +<Parameter Name="Color" Type="RGB" Value="{color}"/>
      +</Object>\n'''.format(identifier=identifier, color=self.getColorSTR()))
      +
      +
      +##############################################
      +#
      +##############################################
      +class Model:
      +def __init__(self):
      +self.vertexList = []
      +self.normalList = []
      +self.indexList = []
      +
      +self.name = self.wygenerujID(5, 5)
      +self.material = Material()
      +
      +def addFace(self, face):
      +mesh = self.meshFace(face)
      +for pp in mesh.Facets:
      +num = len(self.vertexList)
      +for kk in pp.Points:
      +self.vertexList.append(point3D(kk))
      +self.indexList.append(indexListPoint3D([num, num + 1, num + 2]))
      +
      +def meshFace(self, shape):
      +faces = []
      +triangles = shape.tessellate(1) # the number represents the precision of the tessellation
      +for tri in triangles[1]:
      +face = []
      +for i in range(3):
      +vindex = tri[i]
      +face.append(triangles[0][vindex])
      +faces.append(face)
      +m = Mesh.Mesh(faces)
      +#Mesh.show(m)
      +return m
      +
      +def wygenerujID(self, ll, lc):
      +''' generate random model name '''
      +numerID = ""
      +
      +for i in range(ll):
      +numerID += random.choice('abcdefghij')
      +numerID += "_"
      +for i in range(lc):
      +numerID += str(random.randrange(0, 99, 1))
      +
      +return numerID
      +
      +def write(self, file):
      +file.write('''
      +<Object Identifier="./Models/{name}" Label="Default Model" Name="{name}" Type="Model"> 
      +<Object Identifier="Triangular Mesh" Label="Triangular Mesh" Name="" Type="Surface">
      +<Parameter Name="Vertex List" Type="Point3D List" Value="{pointListSize}">\n'''.format(name=self.name, pointListSize=len(self.vertexList)))
      +
      +for i in self.vertexList:
      +file.write('{0}\n'.format(i))
      +
      +file.write('''</Parameter>
      +<Parameter Name="Normal List" Type="Point3D List" Value="{pointListSize}">\n'''.format(pointListSize=len(self.vertexList)))
      +file.write('<P xyz="0 0 -1"/>\n' * len(self.vertexList))
      +file.write('''</Parameter>
      +<Parameter Name="Index List" Type="Triangle Index List" Value="{indexListSize}">\n'''.format(indexListSize=len(self.indexList)))
      +
      +for i in self.indexList:
      +file.write('{0}\n'.format(i))
      +
      +file.write('''</Parameter>\n</Object>\n''')
      +
      +self.material.write(file)
      +
      +file.write('</Object>\n')
      +
      +
      +##############################################
      +#
      +##############################################
      +class Camera:
      +def __init__(self):
      +self.name = "Camera_1"
      +self.f_number = "Pinhole"
      +self.resolution = "1024x768"
      +self.focusDistance = "1"
      +self.lensSamples = "3"
      +self.blades = "3"
      +self.diaphragm = "Circular"
      +self.projection = "Planar"
      +
      +def addParameter(self, name, pType, value):
      +return '<Parameter Name="{0}" Type="{1}" Value="{2}"/>\n'.format(name, pType, value)
      +
      +def write(self, file):
      +cam = FreeCADGui.ActiveDocument.ActiveView.getCameraNode()
      +camValues = cam.position.getValue()
      +
      +x = "%.4f" % (30 * .0254)
      +y = "%.4f" % (30 * .0254)
      +z = "%.4f" % (30 * .0254)
      +
      +file.write('<Object Identifier="./Cameras/{0}" Label="Pinhole Camera" Name="{0}" Type="Camera">\n'.format(self.name))
      +file.write(self.addParameter("Resolution", "String", self.resolution))
      +file.write(self.addParameter("Frame", "Transform", "-0.609474 0.471636 -0.63726 {0} 0.792806 0.362576 -0.489895 {1} 2.70762e-06 -0.803802 -0.594897 {2}".format(x, y, z)))
      +file.write(self.addParameter("Focus Distance", "Real", self.focusDistance))
      +file.write(self.addParameter("f-number", "String", self.f_number))
      +file.write(self.addParameter("Lens Samples", "Integer",self.lensSamples ))
      +file.write(self.addParameter("Blades", "Integer", self.blades))
      +file.write(self.addParameter("Diaphragm", "String", self.diaphragm))
      +file.write(self.addParameter("Projection", "String", self.projection))
      +file.write('</Object>\n')
      +
      +
      +##############################################
      +#
      +##############################################
      +class exportTokerkythea:
      +def __init__(self):
      +self.models = []
      +self.cameras = []
      +modelsMultiColors = False
      +
      +def write(self, file, name):
      +file = __builtin__.open(file, "w")
      +#
      +self.writeHeader(file, name)
      +
      +if self.modelsMultiColors:
      +for i, j in self.models.items():
      +file.write('<Object Identifier="./Models/{0}" Label="Default Model" Name="{0}" Type="Model">\n'.format(i))
      +for k in j:
      +k.write(file)
      +file.write('</Object>\n')
      +else:
      +for i in self.models.values():
      +i.write(file)
      +# CAMERA
      +activeCamera = self.cameras[0][0].name
      +for i in self.cameras:
      +i[0].write(file)
      +if i[1]:
      +activeCamera = i[0].name
      +#
      +file.write('<Parameter Name="./Cameras/Active" Type="String" Value="{0}"/>\n'.format(activeCamera))
      +
      +self.writeFooter(file, name)
      +
      +def writeHeader(self, file, name):
      +file.write('''<Root Label="Kernel" Name="" Type="Kernel">
      +<Object Identifier="./Ray Tracers/Metropolis Light Transport" Label="Metropolis Light Transport" Name="Metropolis Light Transport" Type="Ray Tracer">
      +</Object>
      +<Object Identifier="./Environments/Octree Environment" Label="Octree Environment" Name="Octree Environment" Type="Environment">
      +</Object>
      +<Object Identifier="./Filters/Simple Tone Mapping" Label="Simple Tone Mapping" Name="" Type="Filter">
      +</Object>
      +<Object Identifier="./Scenes/{0}" Label="Default Scene" Name="{0}" Type="Scene">\n
      +'''.format(name))
      +
      +def writeFooter(self, file, name):
      +file.write('''</Object>
      +<Parameter Name="Mip Mapping" Type="Boolean" Value="1"/>
      +<Parameter Name="./Interfaces/Active" Type="String" Value="Null Interface"/>
      +<Parameter Name="./Modellers/Active" Type="String" Value="XML Modeller"/>
      +<Parameter Name="./Image Handlers/Active" Type="String" Value="Free Image Support"/>
      +<Parameter Name="./Ray Tracers/Active" Type="String" Value="Metropolis Light Transport"/>
      +<Parameter Name="./Irradiance Estimators/Active" Type="String" Value="Null Irradiance Estimator"/>
      +<Parameter Name="./Direct Light Estimators/Active" Type="String" Value="Null Direct Light Estimator"/>
      +<Parameter Name="./Environments/Active" Type="String" Value="Octree Environment"/>
      +<Parameter Name="./Filters/Active" Type="String" Value="Simple Tone Mapping"/>
      +<Parameter Name="./Scenes/Active" Type="String" Value="{0}"/>
      +<Parameter Name="./Libraries/Active" Type="String" Value="Material Librarian"/>
      +</Root>'''.format(name))
      +
      +
      +##############################################
      +#
      +##############################################
      +
      +class exportKerkytheaDialog(QtGui.QDialog):
      +def __init__(self, parent=None):
      +QtGui.QDialog.__init__(self, parent)
      +
      +self.setWindowTitle(u'Export to Kerkythea v1.1')
      +self.setFixedSize(500, 550)
      +
      +#
      +self.buttonAccept = QtGui.QPushButton('Accept')
      +#
      +tab = QtGui.QTabWidget()
      +tab.addTab(self.addGeneralPage(), u'General')
      +tab.addTab(self.addLightsPage(), u'Light')
      +tab.addTab(self.addCmerasPage(), u'Camera')
      +#
      +lay = QtGui.QVBoxLayout(self)
      +lay.addWidget(tab)
      +lay.addWidget(self.buttonAccept)
      +
      +def changePathF(self):
      +path = QtGui.QFileDialog().getSaveFileName(self, u"Save as", os.path.expanduser("~"), "*.xml")
      +
      +fileName = path[0]
      +if not fileName == "":
      +if not fileName.endswith('xml'):
      +fileName = fileName + '.xml'
      +self.filePath.setText(fileName)
      +
      +def addGeneralPage(self):
      +self.filePath = QtGui.QLineEdit(os.path.join(os.path.expanduser("~"), 'Unnamed.xml'))
      +self.filePath.setReadOnly(True)
      +
      +changePath = QtGui.QPushButton('...')
      +changePath.setFixedWidth(30)
      +self.connect(changePath, QtCore.SIGNAL("clicked ()"), self.changePathF)
      +
      +generalBox = QtGui.QGroupBox(u'General')
      +generalBoxLay = QtGui.QGridLayout(generalBox)
      +generalBoxLay.addWidget(QtGui.QLabel(u'Path           '), 0, 0, 1, 1)
      +generalBoxLay.addWidget(self.filePath, 0, 1, 1, 2)
      +generalBoxLay.addWidget(changePath, 0, 3, 1, 1)
      +
      +generalBoxLay.setColumnStretch(1, 10)
      +#
      +self.exportObjects_All = QtGui.QRadioButton(u'All visible objects')
      +self.exportObjects_All.setChecked(True)
      +self.exportObjects_Selected = QtGui.QRadioButton(u'All selected objects')
      +self.exportObjects_SelectedFaces = QtGui.QRadioButton(u'All selected faces')
      +self.exportObjects_SelectedFaces.setDisabled(True)
      +
      +exportObjectsBox = QtGui.QGroupBox(u'Export objects')
      +exportObjectsBoxLay = QtGui.QVBoxLayout(exportObjectsBox)
      +exportObjectsBoxLay.addWidget(self.exportObjects_All)
      +exportObjectsBoxLay.addWidget(self.exportObjects_Selected)
      +exportObjectsBoxLay.addWidget(self.exportObjects_SelectedFaces)
      +#
      +self.exportObjectsAs_YES = QtGui.QRadioButton(u'Yes')
      +self.exportObjectsAs_YES.setChecked(True)
      +self.exportObjectsAs_NO = QtGui.QRadioButton(u'No')
      +
      +exportObjectsAsBox = QtGui.QGroupBox(u'Group models by color')
      +exportObjectsAsBoxLay = QtGui.QVBoxLayout(exportObjectsAsBox)
      +exportObjectsAsBoxLay.addWidget(self.exportObjectsAs_YES)
      +exportObjectsAsBoxLay.addWidget(self.exportObjectsAs_NO)
      +#
      +self.exportObjectColor_MulCol = QtGui.QRadioButton(u'Multi colors')
      +self.exportObjectColor_Gray = QtGui.QRadioButton(u'Grayscale')
      +self.exportObjectColor_SinCol = QtGui.QRadioButton(u'Single color (random)')
      +self.exportObjectColor_SinCol.setChecked(True)
      +
      +self.exportObjectColorBox = QtGui.QGroupBox(u'Colors')
      +self.exportObjectColorBox.setDisabled(True)
      +exportObjectColorBoxLay = QtGui.QVBoxLayout(self.exportObjectColorBox)
      +exportObjectColorBoxLay.addWidget(self.exportObjectColor_MulCol)
      +exportObjectColorBoxLay.addWidget(self.exportObjectColor_Gray)
      +exportObjectColorBoxLay.addWidget(self.exportObjectColor_SinCol)
      +#####
      +widget = QtGui.QWidget()
      +
      +lay = QtGui.QGridLayout(widget)
      +lay.addWidget(generalBox, 0, 0, 1, 4)
      +lay.addWidget(exportObjectsBox, 1, 0, 1, 4)
      +lay.addWidget(exportObjectsAsBox, 2, 0, 1, 2)
      +lay.addWidget(self.exportObjectColorBox, 2, 2, 1, 2)
      +
      +lay.setRowStretch(10, 10)
      +#lay.setColumnStretch(10, 10)
      +return widget
      +
      +def addLightsPage(self):
      +widget = QtGui.QWidget()
      +
      +return widget
      +
      +def addCmerasPage(self):
      +self.resolution = QtGui.QComboBox()
      +self.resolution.addItems(['200x200', '320x200', '320x240', '500x500', '512x384', '640x480', '768x576', '800x600', '1024x768', '1280x1024', '1600x1200', '2048x1536', '2816x2112'])
      +self.resolution.setCurrentIndex(self.resolution.findText('1024x768'))
      +
      +self.cameraName = QtGui.QLineEdit(u'Camera 1')
      +
      +filmBox = QtGui.QGroupBox(u'General')
      +filmBoxLay = QtGui.QGridLayout(filmBox)
      +filmBoxLay.addWidget(QtGui.QLabel(u'Camera name'), 0, 0, 1, 1)
      +filmBoxLay.addWidget(self.cameraName, 0, 1, 1, 1)
      +filmBoxLay.addWidget(QtGui.QLabel(u'Resolution'), 1, 0, 1, 1)
      +filmBoxLay.addWidget(self.resolution, 1, 1, 1, 1)
      +
      +filmBoxLay.setHorizontalSpacing(50)
      +#
      +self.fNumber = QtGui.QComboBox()
      +self.fNumber.addItems(['1', '1.4', '2', '2.8', '4', '5.6', '8', '16', '22', 'Pinhole'])
      +self.fNumber.setCurrentIndex(self.fNumber.findText('Pinhole'))
      +
      +self.focusDistance = QtGui.QDoubleSpinBox()
      +self.focusDistance.setValue(1.0)
      +self.focusDistance.setRange(0.0, 1000.0)
      +
      +self.lensSamples = QtGui.QSpinBox()
      +self.lensSamples.setValue(3)
      +self.lensSamples.setRange(0, 1000)
      +
      +lensBox = QtGui.QGroupBox(u'Lens')
      +lensBoxLay = QtGui.QGridLayout(lensBox)
      +lensBoxLay.addWidget(QtGui.QLabel(u'f-number'), 0, 0, 1, 1, QtCore.Qt.AlignHCenter)
      +lensBoxLay.addWidget(self.fNumber, 1, 0, 1, 1)
      +lensBoxLay.addWidget(QtGui.QLabel(u'Focus Distance'), 0, 1, 1, 1, QtCore.Qt.AlignHCenter)
      +lensBoxLay.addWidget(self.focusDistance, 1, 1, 1, 1)
      +lensBoxLay.addWidget(QtGui.QLabel(u'Lens Samples'), 0, 2, 1, 1, QtCore.Qt.AlignHCenter)
      +lensBoxLay.addWidget(self.lensSamples, 1, 2, 1, 1)
      +
      +lensBoxLay.setHorizontalSpacing(50)
      +#
      +self.projection = QtGui.QComboBox()
      +self.projection.addItems(['Planar', 'Cylindrical', 'Spherical', 'Parallel'])
      +self.projection.setCurrentIndex(self.projection.findText('Planar'))
      +
      +self.diaphragm = QtGui.QComboBox()
      +self.diaphragm.addItems(['Circular', 'Polygonal'])
      +self.diaphragm.setCurrentIndex(self.diaphragm.findText('Circular'))
      +
      +self.blades = QtGui.QSpinBox()
      +self.blades.setValue(3)
      +self.blades.setRange(3, 1000)
      +
      +geometryBox = QtGui.QGroupBox(u'Geometry')
      +geometryBoxLay = QtGui.QGridLayout(geometryBox)
      +geometryBoxLay.addWidget(QtGui.QLabel(u'Projection'), 0, 0, 1, 1, QtCore.Qt.AlignHCenter)
      +geometryBoxLay.addWidget(self.projection, 1, 0, 1, 1)
      +geometryBoxLay.addWidget(QtGui.QLabel(u'Diaphragm'), 0, 1, 1, 1, QtCore.Qt.AlignHCenter)
      +geometryBoxLay.addWidget(self.diaphragm, 1, 1, 1, 1)
      +geometryBoxLay.addWidget(QtGui.QLabel(u'Blades'), 0, 2, 1, 1, QtCore.Qt.AlignHCenter)
      +geometryBoxLay.addWidget(self.blades, 1, 2, 1, 1)
      +
      +geometryBoxLay.setHorizontalSpacing(50)
      +#
      +#####
      +widget = QtGui.QWidget()
      +lay = QtGui.QVBoxLayout(widget)
      +lay.addWidget(filmBox)
      +lay.addWidget(lensBox)
      +lay.addWidget(geometryBox)
      +lay.addStretch(10)
      +
      +return widget
      +
      +
      +
      +class exportKerkythea(exportKerkytheaDialog):
      +def __init__(self, parent=None):
      +exportKerkytheaDialog.__init__(self, parent)
      +
      +self.connect(self.buttonAccept, QtCore.SIGNAL("clicked ()"), self.acceptw)
      +self.connect(self.exportObjectsAs_YES, QtCore.SIGNAL("clicked ()"), self.setColors)
      +self.connect(self.exportObjectsAs_NO, QtCore.SIGNAL("clicked ()"), self.setColors)
      +
      +def setColors(self):
      +if self.exportObjectsAs_YES.isChecked():
      +self.exportObjectColor_SinCol.setChecked(True)
      +self.exportObjectColorBox.setDisabled(True)
      +else:
      +self.exportObjectColorBox.setDisabled(False)
      +
      +def acceptw(self):
      +if self.exportObjects_All.isChecked():
      +projectObjects = [i for i in FreeCAD.ActiveDocument.Objects if i.ViewObject.Visibility]
      +elif self.exportObjects_Selected.isChecked():
      +projectObjects = []
      +for i in FreeCADGui.Selection.getSelection():
      +if i.ViewObject.Visibility and i not in projectObjects:
      +projectObjects.append(i)
      +#
      +
      +projectModels = {}
      +for i in projectObjects:  # objects in document
      +try:
      +objectColors = i.ViewObject.DiffuseColor
      +shape = i.Shape.Faces
      +except:
      +continue
      +
      +for j in range(len(i.Shape.Faces)):  # object faces
      +# get face color
      +if len(objectColors) == len(i.Shape.Faces):
      +modelType = objectColors[j]
      +else:
      +modelType = objectColors[0]
      +#
      +if self.exportObjectsAs_YES.isChecked():
      +modelID = str(modelType)
      +else:
      +modelID = i.Label
      +#
      +if self.exportObjectColor_SinCol.isChecked():
      +modelsMultiColors = False
      +
      +if not modelID in projectModels:
      +model = Model()
      +if self.exportObjectsAs_NO.isChecked():
      +model.name = modelID
      +model.material.diffuse = Texture(modelType)
      +projectModels[modelID] = model
      +else:
      +model = projectModels[modelID]
      +else:
      +modelsMultiColors = True
      +
      +if not modelID in projectModels:
      +projectModels[modelID] = []
      +
      +model = Model()
      +model.name = 'Face {0}'.format(j)
      +model.material.diffuse = Texture(modelType)
      +if self.exportObjectColor_Gray.isChecked():
      +model.material.diffuse.toGrayscale()
      +projectModels[modelID].append(model)
      +   
      +#model = Model()
      +#model.material.diffuse = Texture(modelType)
      +#projectModels[i.Label].append(model)
      +#
      +model.addFace(i.Shape.Faces[j])
      +
      +exporter = exportTokerkythea()
      +   exporter.modelsMultiColors = modelsMultiColors
      +exporter.models = projectModels
      +# CAMERA
      +camera = Camera()
      +camera.name = self.cameraName.text()
      +camera.f_number = self.fNumber.currentText()
      +camera.resolution = self.resolution.currentText()
      +camera.focusDistance = self.focusDistance.value()
      +camera.lensSamples = self.lensSamples.value()
      +camera.blades = self.blades.value()
      +camera.diaphragm = self.diaphragm.currentText()
      +camera.projection = self.projection.currentText()
      +
      +exporter.cameras.append([camera, True])
      +#
      +exporter.write(self.filePath.text(), FreeCAD.ActiveDocument.Label)
      +
      +self.close()
      +
      +exportKerkythea().exec_() 
      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Macro_GMSH.html b/localwiki/Macro_GMSH.html new file mode 100644 index 0000000..2e435fb --- /dev/null +++ b/localwiki/Macro_GMSH.html @@ -0,0 +1,82 @@ +Macro GMSH

      Macro GMSH

      + +
      + + + + + + + + + + + + + + + + + + + + + + + + + + +
      +

      Text-x-python.png GMSHMacro

      +
      Description +
      Create FEM Meshes by GMSH Mesh Generator +
      Author +
      psicofil +
      Links +
      Macros recipes
      How to install macros
      How to customize toolbars +
      Version +
      1.0 +
      Date last modification +
      2015-08-24 +
      +

      + +
      +


      +

      Simple macro to create FEM Meshes by the Mesh Generator GMSH. It is possible to create linear or bilinear (quadratic) Beam-, Shell- and Volumeelements in +

      GMSH +

      +

      Use

      +

      The macro you can find in the following github repository: GMSH Macro +

      +

      Additional Installations

      +

      GMSH has to be installed. See [1]. The macro is intended to run on Linux, OSX and Windows operating system. The binary path of GMSH has to be adapted in the macro. +

      +

      Link

      +

      The page discussion GMSH macro +

      See the how to use the macro on YouTube. +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Macro_Geneva_Wheel.html b/localwiki/Macro_Geneva_Wheel.html new file mode 100644 index 0000000..bc97db5 --- /dev/null +++ b/localwiki/Macro_Geneva_Wheel.html @@ -0,0 +1,200 @@ +Macro Geneva Wheel

      Macro Geneva Wheel

      + +
      + + + + + + + + + + + + + + + + + + + + + + + + + + +
      +

      Text-x-python.png Geneva Wheel

      +
      Description +
      Allows the user to create a Geneva wheel mechanism from scratch. Must edit values within the Macro to alter the size of the object. +
      Author +
      Drei +
      Links +
      Macros recipes
      How to install macros
      How to customize toolbars +
      Version +
      1.0 +
      Date last modification +
      2014-09-21 +
      +

      + +
      Geneva.png +

      How To Use

      +

      This Macro creates the main parts of a Geneva Wheel Mechanism. It depends on six values that must be altered in the code, read the comments in the code. The variables are: +

      + + + + + + +
      Input +Output +
      +
      • a = Drive Crank Radius
      • +
      • b = Geneva Wheel Radius
      • +
      • n = Driven Slot Quantity
      • +
      • p = Drive Pin Diameter
      • +
      • t = Tolerance
      • +
      • h = Height
      +
      +
      • c = Distance Between Centers
      • +
      • s = Slot Center Width
      • +
      • w = Slot Width
      • +
      • y = Stop Arc Radius
      • +
      • z = Stop Disc Radius
      • +
      • v = Clearance Arc
      +
      +

      Link

      +

      Macro Geneva Wheel GUI: A GUI front end based on this macro that allows the user to create a Geneva wheel mechanism from scratch. +

      +

      Macro

      +
      #Creation of a Geneva Wheel with Parametric values  By: Isaac Ayala (drei)
      +#This Macro creates the main parts of a Geneva Wheel Mechanism 
      +
      +#It depends on six values that must be altered in the following code
      +#The variables are a, b, n, p, t and h. 
      +
      +#Definition for each variable
      +#    Input
      +#a = Drive Crank Radius
      +#b = Geneva Wheel Radius
      +#n = Driven Slot Quantity
      +#p = Drive Pin Diameter
      +#t = Tolerance
      +#h = Height
      +#    Output
      +#c = Distance Between Centers
      +#s = Slot Center Width
      +#w = Slot Width
      +#y = Stop Arc Radius
      +#z = Stop Disc Radius
      +#v = Clearance Arc
      +
      +#Please note that you can alter the code so it depends on five values exclusively
      +#Just replace c, and either a or b with the following
      +#    Keep value for a
      +#c = a/math.sin(math.pi/n)
      +#b = math.sqrt((math.pow(c,2))-(math.pow(a,2)))
      +#    Keep value for b
      +#c = b/math.cos(math.pi/n)
      +#a = math.sqrt((math.pow(c,2))-(math.pow(b,2)))
      +
      +from __future__ import division
      +import time
      +import math
      +from PySide import QtCore, QtGui
      +from FreeCAD import Base
      +import Part
      +
      +#Inputs
      +a = 25.0
      +b = 60.0
      +n = 6
      +p = 4
      +t = 0.01
      +h = 5
      +T = 60
      +
      +#Outputs
      +c = math.sqrt(pow(a,2) + pow(b,2))
      +s = a + b - c
      +w = p + t
      +y = a - (1.5 * p)
      +z = y - t
      +v = (b * z)/a 
      +
      +#    Create the Drive Crank (Will be placed on the origin)
      +driveCrank = Part.makeCylinder(z, h)
      +driveCrank.translate(Base.Vector(0,0,0))
      +
      +genevaWheelClearanceCut = Part.makeCylinder(b, h)
      +genevaWheelClearanceCut.translate(Base.Vector(-c,0,0))
      +
      +driveCrank = driveCrank.cut(genevaWheelClearanceCut)
      +
      +driveCrankBase = Part.makeCylinder((1.5*a), h)
      +driveCrankBase.translate(Base.Vector(0,0,-h))
      +
      +driveCrank = driveCrank.fuse(driveCrankBase)
      +
      +drivePin = Part.makeCylinder(p,h)
      +drivePin.translate(Base.Vector(-a,0,0))
      +
      +driveCrank = driveCrank.fuse(drivePin)
      +
      +#    Create the Geneva  Wheel (Will be placed on the x-axis on the left side)
      +genevaWheel = Part.makeCylinder(b,h)
      +genevaWheel.translate(Base.Vector(-c,0,0))
      +
      +stopArc = Part.makeCylinder(y, h)
      +stopArc.translate(Base.Vector(((y-(b/2)),0,0)))
      +stopArc.rotate(Base.Vector(-c,0,0),Base.Vector(0,0,1),30)
      +
      +for i in range(6):
      +    stopArc.rotate(Base.Vector(-c,0,0),Base.Vector(0,0,1),60)
      +    genevaWheel = genevaWheel.cut(stopArc)
      +
      +slotLength = Part.makeBox(s,(2*w),h)
      +slotLength.translate(Base.Vector(-a,-w,0))
      +
      +slotRadius = Part.makeCylinder(w,h)
      +slotRadius.translate(Base.Vector(-a,0,0))
      +
      +slot=slotLength.fuse(slotRadius)
      +
      +for i in range(6):
      +    slot.rotate(Base.Vector(-c,0,0),Base.Vector(0,0,1),60)
      +    genevaWheel = genevaWheel.cut(slot)
      +
      +#    Display Result
      +
      +Part.show(driveCrank)
      +Part.show(genevaWheel) 
      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Macro_Geneva_Wheel_GUI.html b/localwiki/Macro_Geneva_Wheel_GUI.html new file mode 100644 index 0000000..5ff5ed1 --- /dev/null +++ b/localwiki/Macro_Geneva_Wheel_GUI.html @@ -0,0 +1,269 @@ +Macro Geneva Wheel GUI

      Macro Geneva Wheel GUI

      + +
      + + + + + + + + + + + + + + + + + + + + + + + + + + +
      +

      GW Dim.png Geneva Wheel GUI

      +
      Description +
      A GUI front end that allows the user to create a Geneva wheel mechanism from scratch. Based on drei's Macro Geneva Wheel +
      Author +
      quick61 +
      Links +
      Macros recipes
      How to install macros
      How to customize toolbars +
      Version +
      1.0 +
      Date last modification +
      2014-09-21 +
      +

      + +
      +


      +

      +

      How To Use

      +

      To use this Macro, copy it to your FreeCAD Macro directory and include the graphic image GW_Dim.png below in the same directory as the Macro. +


      +

      +
      Copy and include this graphic with the macro.
      +

      Screenshot

      +

      Screenshot of Macro and result. +

      +

      Macro

      +
      #Creation of a Geneva Wheel with Parametric values  By: Isaac Ayala (drei) & Mark Stephen (quick61)
      +#This Macro creates the main parts of a Geneva Wheel Mechanism 
      +
      +#It depends on six values that must be altered in the following code
      +#The variables are a, b, n, p, t and h.
      +
      +#Definition for each variable
      +#    Input
      +#a = Drive Crank Radius
      +#b = Geneva Wheel Radius
      +#p = Drive Pin Radius
      +#t = Geneva Wheel Tolerance
      +#h = Geneva Wheel Height 
      +#n = Driven Slot Quantity
      +#    Output
      +#c = Distance Between Centers
      +#s = Slot Center Width
      +#w = Slot Width
      +#y = Stop Arc Radius
      +#z = Stop Disc Radius
      +#v = Clearance Arc
      +
      +#Please note that you can alter the code so it depends on five values exclusively
      +#Just replace c, and either a or b with the following
      +#    Keep value for a
      +#c = a/math.sin(math.pi/n)
      +#b = math.sqrt((math.pow(c,2))-(math.pow(a,2)))
      +#    Keep value for b
      +#c = b/math.cos(math.pi/n)
      +#a = math.sqrt((math.pow(c,2))-(math.pow(b,2)))
      +
      +from __future__ import division
      +import math
      +from FreeCAD import Base
      +from PySide import QtGui, QtCore
      +from PySide.QtGui import QApplication, QDialog, QMainWindow
      +import Part
      +import Draft
      +class p():
      +
      +
      +   def Ggear(self):
      +
      +      try:
      +         #Inputs
      +         a = float(self.dCr.text())
      +         #b = float(self.gWr.text())
      +         p = float(self.dPd.text())
      +         t = float(self.gWt.text())
      +         h = float(self.gWh.text())
      +         n = float(self.gWn.text())
      +
      +         #Outputs
      +         #c = math.sqrt(pow(a,2) + pow(b,2))
      +         c = a/math.sin(math.pi/n)
      +         b = math.sqrt((math.pow(c,2))-(math.pow(a,2)))
      +         s = a + b - c
      +         w = p + t
      +         y = a - (3 * p)
      +         z = y - t
      +         v = (b * z)/a
      +         m = math.sqrt((v**2)+(z**2)) # Solves for location of clearance cut axis
      +
      +         #    Create the Drive Crank (Will be placed on the origin)
      +         driveCrank = Part.makeCylinder(z, h)
      +         #driveCrank.translate(Base.Vector(0,0,0))
      +
      +         #genevaWheelClearanceCut = Part.makeCylinder(b, h)
      +         #genevaWheelClearanceCut.translate(Base.Vector(-c,0,0))
      +
      +         genevaWheelClearanceCut = Part.makeCylinder(v, h)
      +         genevaWheelClearanceCut.translate(Base.Vector(-m,0,0))
      +
      +         driveCrank = driveCrank.cut(genevaWheelClearanceCut)
      +
      +         driveCrankBase = Part.makeCylinder((a+(2*p)), h)
      +         driveCrankBase.translate(Base.Vector(0,0,-h))
      +
      +         driveCrank = driveCrank.fuse(driveCrankBase)
      +
      +         drivePin = Part.makeCylinder(p,h)
      +         drivePin.translate(Base.Vector(-a,0,0))
      +
      +         driveCrank = driveCrank.fuse(drivePin)
      +
      +         #    Create the Geneva  Wheel (Will be placed on the x-axis on the left side)
      +         genevaWheel = Part.makeCylinder(b,h)
      +         genevaWheel.translate(Base.Vector(-c,0,0))
      +
      +         stopArc = Part.makeCylinder(y, h)
      +         stopArc.rotate(Base.Vector(-c,0,0),Base.Vector(0,0,1),(180/n))
      +
      +         for i in range(int(n)):
      +            stopArc.rotate(Base.Vector(-c,0,0),Base.Vector(0,0,1),(360/n))
      +            genevaWheel = genevaWheel.cut(stopArc)
      +
      +         slotLength = Part.makeBox(s,(2*w),h)
      +         slotLength.translate(Base.Vector(-a,-w,0))
      +
      +         slotRadius = Part.makeCylinder(w,h)
      +         slotRadius.translate(Base.Vector(-a,0,0))
      +
      +         slot=slotLength.fuse(slotRadius)
      +
      +         for i in range(int(n)):
      +            slot.rotate(Base.Vector(-c,0,0),Base.Vector(0,0,1),(360/n))
      +            genevaWheel = genevaWheel.cut(slot)
      +
      +         #    Display Result
      +
      +         Part.show(driveCrank)
      +         Part.show(genevaWheel)
      +
      +      except:
      +         FreeCAD.Console.PrintError("Unable to complete task. Please recheck your data entries.")
      +
      +      self.close()
      +
      +   def close(self):
      +      self.dialog.hide()
      +
      +   def __init__(self):
      +      self.dialog = None
      +
      +      self.dialog = QtGui.QDialog()
      +      self.dialog.resize(240,100)
      +
      +      self.dialog.setWindowTitle("Geneva Wheel Macro")
      +      la = QtGui.QVBoxLayout(self.dialog)
      +
      +      DCR = QtGui.QLabel("Drive Crank Radius ( A )")
      +      la.addWidget(DCR)
      +      self.dCr = QtGui.QLineEdit()
      +      la.addWidget(self.dCr)
      +
      +      #GWR = QtGui.QLabel("Geneva Wheel Radius ( B )")
      +      #la.addWidget(GWR)
      +      #self.gWr = QtGui.QLineEdit()
      +      #la.addWidget(self.gWr)
      +
      +      DPD = QtGui.QLabel("Drive Pin Radius ( C )")
      +      la.addWidget(DPD)
      +      self.dPd = QtGui.QLineEdit()
      +      la.addWidget(self.dPd)
      +
      +      GWT = QtGui.QLabel("Geneva Wheel Tolerance ( D )")
      +      la.addWidget(GWT)
      +      self.gWt = QtGui.QLineEdit()
      +      la.addWidget(self.gWt)
      +
      +      GWH = QtGui.QLabel("Geneva Wheel Height")
      +      la.addWidget(GWH)
      +      self.gWh = QtGui.QLineEdit()
      +      la.addWidget(self.gWh)
      +
      +      GWN = QtGui.QLabel("Driven Slot Quantity")
      +      la.addWidget(GWN)
      +      self.gWn = QtGui.QLineEdit()
      +      la.addWidget(self.gWn)
      +
      +      #
      +      # - Include graphic image in dialog window - 
      +      #
      +      # Insure that image is in the same directory as this Macro.
      +      # Image should be available from same source as Macro.
      +      #
      +  
      +      import os
      +      macro_dir = os.path.dirname(__file__)
      +      self.PiX = QtGui.QLabel()
      +      self.PiX.setPixmap(os.path.join(macro_dir, "GW_Dim.png"))
      +
      +      hbox = QtGui.QHBoxLayout()
      +      hbox.addStretch()
      +      hbox.addWidget(self.PiX)
      +      hbox.addStretch()
      +      
      +      la.addSpacing(15)
      +      la.addLayout(hbox)
      +      la.addSpacing(15)
      +
      +      # - End Image layout -
      +
      +      okbox = QtGui.QDialogButtonBox(self.dialog)
      +      okbox.setOrientation(QtCore.Qt.Horizontal)
      +      okbox.setStandardButtons(QtGui.QDialogButtonBox.Cancel 
      +

      Links

      +

      This Macro is based on Macro Geneva Wheel +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Macro_Geodesic_Dome.html b/localwiki/Macro_Geodesic_Dome.html new file mode 100644 index 0000000..5c03a23 --- /dev/null +++ b/localwiki/Macro_Geodesic_Dome.html @@ -0,0 +1,358 @@ +Macro Geodesic Dome

      Macro Geodesic Dome

      + +
      + + + + + + + + + + + + + + + + + + + + + + + + + + +
      +

      Text-x-python.png Macro Geodesic Dome

      +
      Description +
      This macro creates a geodesic dome +
      Author +
      Ulrich Brammer +
      Links +
      Macros recipes
      How to install macros
      How to customize toolbars +
      Version +
      01.00 +
      Date last modification +
      2015-01-04 +
      +

      Contents

      + +
      + +
      +


      +

      This macro creates a geodesic dome shell. The dome radius and the frequency parameter will be set at creation time. +


      +Geodesic macro.png +

      +
      +


      +

      +
      # -*- coding: utf-8 -*-
      +
      +# Form implementation generated from reading ui file 'geodesic_dialog.ui'
      +# And changed manually to use FreeCAD "Gui::InputField"
      +# Created: Sun Jan  4 22:20:58 2015
      +#      by: pyside-uic 0.2.15 running on PySide 1.2.2
      +#
      +# 
      +'''
      +************************************************************************
      +* Copyright (c)2015 Ulrich Brammer <ulrich1a[at]users.sourceforge.net> *
      +*                                                                      *
      +* This file is a supplement to the FreeCAD CAx development system.     *
      +*                                                                      *
      +* This program is free software; you can redistribute it and/or modify *
      +* it under the terms of the GNU Lesser General Public License (LGPL)   *
      +* as published by the Free Software Foundation; either version 2 of    *
      +* the License, or (at your option) any later version.                  *
      +* for detail see the LICENCE text file.                                *
      +*                                                                      *
      +* This software is distributed in the hope that it will be useful,     *
      +* but WITHOUT ANY WARRANTY; without even the implied warranty of       *
      +* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the        *
      +* GNU Library General Public License for more details.                 *
      +*                                                                      *
      +* You should have received a copy of the GNU Library General Public    *
      +* License along with this macro; if not, write to the Free Software    *
      +* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307 *
      +* USA                                                                  *
      +*                                                                      *
      +************************************************************************
      +'''
      +
      +
      +from PySide import QtCore, QtGui
      +import FreeCAD, FreeCADGui, math, Part
      +from FreeCAD import Base
      +
      +class Ui_Dialog(object):
      +  def setupUi(self, Dialog):
      +    Dialog.setObjectName("Dialog")
      +    Dialog.resize(477, 188)
      +    self.dia = Dialog
      +    self.gridLayoutWidget = QtGui.QWidget(Dialog)
      +    self.gridLayoutWidget.setGeometry(QtCore.QRect(19, 19, 440, 141))
      +    self.gridLayoutWidget.setObjectName("gridLayoutWidget")
      +    self.gridLayout = QtGui.QGridLayout(self.gridLayoutWidget)
      +    self.gridLayout.setContentsMargins(0, 0, 0, 0)
      +    self.gridLayout.setObjectName("gridLayout")
      +    self.label = QtGui.QLabel(self.gridLayoutWidget)
      +    self.label.setObjectName("label")
      +    self.gridLayout.addWidget(self.label, 0, 0, 1, 1)
      +    #self.lineEdit = QtGui.QLineEdit(self.gridLayoutWidget)
      +    fui = FreeCADGui.UiLoader()
      +    self.lineEdit = fui.createWidget("Gui::InputField")
      +    
      +    self.lineEdit.setObjectName("lineEdit")
      +    self.gridLayout.addWidget(self.lineEdit, 0, 1, 1, 1)
      +    self.label_2 = QtGui.QLabel(self.gridLayoutWidget)
      +    self.label_2.setObjectName("label_2")
      +    self.gridLayout.addWidget(self.label_2, 1, 0, 1, 1)
      +    self.lineEdit_2 = QtGui.QLineEdit(self.gridLayoutWidget)
      +    self.lineEdit_2.setObjectName("lineEdit_2")
      +    self.gridLayout.addWidget(self.lineEdit_2, 1, 1, 1, 1)
      +    self.label_3 = QtGui.QLabel(self.gridLayoutWidget)
      +    self.label_3.setObjectName("label_3")
      +    self.gridLayout.addWidget(self.label_3, 2, 0, 1, 1)
      +    self.buttonBox = QtGui.QDialogButtonBox(self.gridLayoutWidget)
      +    self.buttonBox.setOrientation(QtCore.Qt.Horizontal)
      +    self.buttonBox.setStandardButtons \
      +      (QtGui.QDialogButtonBox.Cancel|QtGui.QDialogButtonBox.Ok)
      +    self.buttonBox.setObjectName("buttonBox")
      +    self.gridLayout.addWidget(self.buttonBox, 2, 1, 1, 1)
      +
      +    self.retranslateUi(Dialog)
      +    QtCore.QObject.connect(self.buttonBox, \
      +      QtCore.SIGNAL("accepted()"), self.makeSomething)
      +    QtCore.QObject.connect(self.buttonBox, \
      +      QtCore.SIGNAL("rejected()"), self.makeNothing)
      +    QtCore.QMetaObject.connectSlotsByName(Dialog)
      +
      +  def retranslateUi(self, Dialog):
      +    Dialog.setWindowTitle(QtGui.QApplication.translate \
      +      ("Dialog", "Geodesic Dome Creator",  \
      +      None, QtGui.QApplication.UnicodeUTF8))
      +    self.label.setText(QtGui.QApplication.translate \
      +      ("Dialog", "Dome Radius", None, QtGui.QApplication.UnicodeUTF8))
      +    self.label_2.setText(QtGui.QApplication.translate \
      +      ("Dialog", "Frequency Parameter\n(Integer between 1 to 10)", \
      +      None,QtGui.QApplication.UnicodeUTF8))
      +    self.label_3.setText(QtGui.QApplication.translate \
      +      ("Dialog", "This Macro creates \na full geodesic dome shell.\nX-Y-symmetry plane \nfor even frequencies", \
      +      None, QtGui.QApplication.UnicodeUTF8))
      +
      +  def makeSomething(self):
      +    print "accepted! Dome radius: ", self.lineEdit.property("text"), \
      +      " with Frequency: ", int(self.lineEdit_2.text())
      +
      +    doc=App.activeDocument()
      +    label = "GeodesicDome"
      +
      +    theDome = doc.addObject("Part::Feature",label)
      +    radius = self.lineEdit.property("text")
      +    frequency = int(self.lineEdit_2.text())
      +      
      +    self.dia.close()
      +    self.makeDome(theDome, radius, frequency)
      +    doc.recompute()
      +    
      +    
      +  def makeNothing(self):
      +    print "rejected!!"
      +    self.dia.close()
      +    
      +
      +
      +  def makeDome(self, obj, domeRad_str, ny):
      +    
      +    def makeFreqFaces(fPt, sPt, thPt, ny = 1):
      +      # makes the geodesic dome faces out of the points of an
      +      # icosahedron triangle
      +      b = self.a/ny # length of frequent triangles
      +      # definition of direction vectors
      +      growVec = (sPt - fPt)
      +      # growVec = (fPt - sPt)
      +      growVec.multiply(1.0/ny)
      +      crossVec = (thPt - sPt)
      +      # crossVec = (sPt - thPt)
      +      crossVec.multiply(1.0/ny)
      +      
      +      for k in range(ny):
      +        kThirdPt = fPt + growVec * (k+0.0)
      +        dThirdPt = Base.Vector(kThirdPt.x, kThirdPt.y, kThirdPt.z)
      +        dThirdPt = dThirdPt.normalize().multiply(domeRad.Value)
      +        kSecPt = fPt + growVec * (k+1.0)
      +        dSecPt = Base.Vector(kSecPt.x, kSecPt.y, kSecPt.z)
      +        dSecPt = dSecPt.normalize().multiply(domeRad.Value)
      +        # thirdEdge = Part.makeLine(kSecPt, kThirdPt)
      +        # thirdEdge = Part.makeLine(dSecPt, dThirdPt)
      +        for l in range(k+1):
      +          firstPt = kSecPt + crossVec *(l+1.0)
      +          dFirstPt = firstPt.normalize().multiply(domeRad.Value)
      +          secPt = kSecPt + crossVec *(l+0.0)
      +          dSecPt =secPt.normalize().multiply(domeRad.Value)
      +          thirdPt = kThirdPt + crossVec *(l+0.0)
      +          dThirdPt = thirdPt.normalize().multiply(domeRad.Value)
      +          #thirdEdge = Part.makeLine(secPt, thirdPt)
      +          thirdEdge = Part.makeLine(dSecPt, dThirdPt)
      +          # Part.show(thirdEdge)
      +          if l > 0:
      +            print "in l: ", l, " mod 2: ", l%2
      +            # What to do here?
      +            #secEdge = Part.makeLine(oThirdPt,thirdPt)
      +            secEdge = Part.makeLine(doThirdPt,dThirdPt)
      +            # Part.show(secEdge)
      +            #thirdEdge = Part.makeLine(secPt, thirdPt)
      +            #thirdEdge = Part.makeLine(dSecPt, dThirdPt)
      +            # Part.show(thirdEdge)
      +            triWire = Part.Wire([firstEdge, secEdge, thirdEdge])
      +            # Part.show(triWire)
      +            triFace = Part.Face(triWire)
      +            self.domeFaces.append(triFace)
      +            #Part.show(triFace)
      +          
      +          oThirdPt = thirdPt
      +          doThirdPt = oThirdPt.normalize().multiply(domeRad.Value)
      +          # oFirstPt = firstPt
      +          #firstEdge = Part.makeLine(thirdPt,firstPt)
      +          firstEdge = Part.makeLine(dThirdPt,dFirstPt)
      +          oFirstEdge = firstEdge
      +          #secEdge = Part.makeLine(firstPt,secPt)
      +          secEdge = Part.makeLine(dFirstPt,dSecPt)
      +          #Part.show(firstEdge)
      +          #Part.show(secEdge)
      +          #Part.show(thirdEdge)
      +          triWire = Part.Wire([firstEdge, secEdge, thirdEdge])
      +          triFace = Part.Face(triWire)
      +          self.domeFaces.append(triFace)
      +          #Part.show(triFace)
      +    
      +    
      +    domeRad = FreeCAD.Units.Quantity(domeRad_str)
      +  
      +    # self.a = Strutlength of underlying icosahedron:
      +    self.a=(4.0*domeRad.Value)/math.sqrt(2.0*math.sqrt(5.0)+10.0) 
      +    
      +    # icoAngle: angle of vertices of icosahedron points 
      +    # not a north or south pole
      +    self.icoAngle = math.atan(0.5)
      +    
      +    self.icoLat = domeRad.Value * math.sin(self.icoAngle)
      +    self.latRad = domeRad.Value * math.cos(self.icoAngle)
      +    self.ang36 = math.radians(36.0)
      +    
      +    # Calculation all points of the icosahedron
      +    self.icoPts = []
      +    self.icoPts.append(Base.Vector(0.0, 0.0, domeRad.Value))
      +    
      +    for i in range(10):
      +      self.icoCos = self.latRad * math.cos(i*self.ang36)
      +      self.icoSin = self.latRad * math.sin(i*self.ang36)
      +      if i%2 == 0:
      +        self.icoPts.append(Base.Vector(self.icoSin, self.icoCos, self.icoLat))
      +      else:
      +        self.icoPts.append(Base.Vector(self.icoSin, self.icoCos, -self.icoLat))
      +    
      +    self.icoPts.append(Base.Vector(0.0, 0.0, -domeRad.Value))
      +    
      +    # making the faces of the icosahedron
      +    
      +    self.icoFaces = [] # collects faces of the underlying icosahedron
      +    self.domeFaces = [] # collects the faces of the geodesic dome
      +    
      +    thirdPt = self.icoPts[9]
      +    thirdEdge = Part.makeLine(self.icoPts[0],thirdPt)
      +    for i in range(5):
      +      j = i*2+1
      +      firstEdge = Part.makeLine(thirdPt,self.icoPts[j])
      +      secEdge = Part.makeLine(self.icoPts[j],self.icoPts[0])
      +      triWire = Part.Wire([firstEdge, secEdge, thirdEdge])
      +      triFace = Part.Face(triWire)
      +      self.icoFaces.append(triFace)
      +      # Part.show(triFace)
      +      makeFreqFaces(self.icoPts[j], self.icoPts[0], thirdPt, ny)
      +      
      +      thirdEdge = Part.makeLine(self.icoPts[0],self.icoPts[j])
      +      thirdPt = self.icoPts[j]
      +      
      +    thirdPt = self.icoPts[9]
      +    secPt = self.icoPts[10]
      +    thirdEdge = Part.makeLine(secPt,thirdPt)
      +    
      +    for i in range(10):
      +      j = i+1
      +      firstEdge = Part.makeLine(thirdPt,self.icoPts[j])
      +      secEdge = Part.makeLine(self.icoPts[j],secPt)
      +      triWire = Part.Wire([firstEdge, secEdge, thirdEdge])
      +      triFace = Part.Face(triWire)
      +      self.icoFaces.append(triFace)
      +      #Part.show(triFace)
      +      makeFreqFaces(self.icoPts[j], secPt, thirdPt, ny)
      +    
      +      thirdPt = secPt  
      +      secPt = self.icoPts[j]  
      +      thirdEdge = Part.makeLine(secPt,thirdPt)
      +    
      +    
      +    thirdPt = self.icoPts[10]
      +    thirdEdge = Part.makeLine(self.icoPts[11],thirdPt)
      +    for i in range(5):
      +      j = i*2+2
      +      firstEdge = Part.makeLine(thirdPt,self.icoPts[j])
      +      secEdge = Part.makeLine(self.icoPts[j],self.icoPts[11])
      +      triWire = Part.Wire([firstEdge, secEdge, thirdEdge])
      +      triFace = Part.Face(triWire)
      +      self.icoFaces.append(triFace)
      +      #Part.show(triFace)
      +      makeFreqFaces(self.icoPts[j], self.icoPts[11], thirdPt, ny)
      +      
      +      thirdEdge = Part.makeLine(self.icoPts[11],self.icoPts[j])
      +      thirdPt = self.icoPts[j]
      +    
      +    # Shell of a corresponding icosahedron  
      +    newShell = Part.Shell(self.icoFaces)
      +    #Part.show(newShell)
      +    
      +    # Shell of the geodesic dome
      +    #self.domeShell = Part.Shell(self.domeFaces)
      +    #Part.show(self.domeShell)
      +    obj.Shape = Part.Shell(self.domeFaces)
      +    
      +    # Shere with radius of geodesic dome for debugging purposes
      +    testSphere = Part.makeSphere(domeRad.Value)
      +    #Part.show(testSphere)
      +  
      +
      +d = QtGui.QWidget()
      +d.ui = Ui_Dialog()
      +d.ui.setupUi(d)
      +d.ui.lineEdit_2.setText("2")
      +d.ui.lineEdit.setProperty("text", "2 m")
      +
      +d.show() 
      +

      Get the code from Github here! +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Macro_Global_Variable_Watcher.html b/localwiki/Macro_Global_Variable_Watcher.html new file mode 100644 index 0000000..b919782 --- /dev/null +++ b/localwiki/Macro_Global_Variable_Watcher.html @@ -0,0 +1,386 @@ +Macro Global Variable Watcher

      Macro Global Variable Watcher

      + +
      + + + + + + + + + + + + + + + + + + + + + + + + + + +
      +

      Macro Global Variable Watcher.png Macro Global Variable Watcher

      +
      Description +
      This macro displays the global variables within the FreeCAD system, (e.g. FreeCAD.myVariable). +
      Author +
      Piffpoof +
      Links +
      Macros recipes
      How to install macros
      How to customize toolbars +
      Version +
      1.0 +
      Date last modification +
      2015-02-09 +
      +

      + +
      +


      +

      +

      Description

      +

      This macro displays the Python variables of the form "FreeCAD.variable1" which have the Python code has created in the FreeCAD system. The user may add and remove variables from the display, which may also be updated on a timed basis. +

      +

      Installation

      +

      All the code for variableWatcher.FCMacro is in one macro. So installation is comprised of copying the code to the appropriate Macro directory and invoking the Global Variable Watcher from the Macro menu, the Python console or a toolbar button (the preferred method). +

      + +

      Usage

      +

      Select global variables to be watched by using the rightmost pop-up menu. Click the "Display Now" button to immediately display the variable and its value, or click on the "Timer On" button to start an automatic timer. The interval for the timer is set in the far left pop-up menu. The topmost option on the rightmost pop-up menu is to update the list of global variables as they may have been created or deleted under program control. +

      A variable may be removed from the watch list by right-clicking over it or it's value, and selecting "remove variable" +

      +

      User Interface

      +

      MacroVariableWatcherGui1.jpg +

      +

      Options

      +

      There are no options. +

      +

      Remarks

      +

      This is a pre-release version and not all aspects are finalised - especially the listing the global variable and their values +

      +

      Script

      +
      # -*- coding: utf-8 -*-
      +#
      +#Variable Watcher
      +#displays variables of the form FreeCAD.*,
      +#either manually or on a timed basis
      +#
      +################################
      +# routine to <description goes here>
      +"""
      +script does <long winded description goes here>
      +"""
      +################################
      +
      +# import statements
      +import FreeCAD
      +import math, collections, time
      +from datetime import datetime
      +from threading import Timer
      +from PySide import QtGui, QtCore
      +
      +# UI Class definitions
      +
      +class VariableWatcher(QtGui.QDialog):
      +""""""
      +def __init__(self):
      +super(VariableWatcher, self).__init__()
      +self.initUI()
      +def initUI(self):
      +column1LH= 10
      +column2LH= 350
      +headerY= 20
      +row1= 50
      +row2= 75
      +row3= 100
      +row4= 125
      +row5= 150
      +# define windowxLoc,yLoc,xDim,yDim
      +self.setGeometry(250, 250, 750, 200)
      +self.setWindowTitle("Variable Watcher")
      +self.setWindowFlags(QtCore.Qt.WindowStaysOnTopHint)
      +self.intervalDefault = str(2)
      +# labels
      +self.name1 = QtGui.QLabel(varLabelSpaces, self)
      +self.name1.move(column1LH, row1)
      +self.value1 = QtGui.QLabel(varValueSpaces, self)
      +self.value1.move(column2LH, row1)
      +self.name2 = QtGui.QLabel(varLabelSpaces, self)
      +self.name2.move(column1LH, row2)
      +self.value2 = QtGui.QLabel(varValueSpaces, self)
      +self.value2.move(column2LH, row2)
      +self.name3 = QtGui.QLabel(varLabelSpaces, self)
      +self.name3.move(column1LH, row3)
      +self.value3 = QtGui.QLabel(varValueSpaces, self)
      +self.value3.move(column2LH, row3)
      +self.name4 = QtGui.QLabel(varLabelSpaces, self)
      +self.name4.move(column1LH, row4)
      +self.value4 = QtGui.QLabel(varValueSpaces, self)
      +self.value4.move(column2LH, row4)
      +self.name5 = QtGui.QLabel(varLabelSpaces, self)
      +self.name5.move(column1LH, row5)
      +self.value5 = QtGui.QLabel(varValueSpaces, self)
      +self.value5.move(column2LH, row5)
      +self.intervalLbl = QtGui.QLabel("interval", self)
      +self.intervalLbl.move(90, headerY)
      +self.timestampLbl = QtGui.QLabel("                 ", self)
      +self.timestampLbl.move(300, 180)
      +# radio buttons
      +self.timerOnRB  = QtGui.QRadioButton("Timer On",self)
      +self.timerOnRB.setEnabled(True)
      +self.timerOnRB.clicked.connect(self.onTimerOnRB)
      +self.timerOnRB.move(150,headerY-10)
      +self.timerOffRB = QtGui.QRadioButton("Timer Off",self)
      +self.timerOffRB.setEnabled(True)
      +self.timerOffRB.setChecked(True)
      +self.timerOffRB.clicked.connect(self.onTimerOffRB)
      +self.timerOffRB.move(150,headerY+10)
      +#
      +nowButton = QtGui.QPushButton('Display Now', self)
      +nowButton.clicked.connect(self.onDisplayNow)
      +nowButton.move(250, headerY-7)
      +# set up lists for pop-ups
      +self.intervalPopupItems = ("0.5","1","2","3","4","5","6","7","8","9","10")
      +# set up pop-up menu for timer interval
      +self.intervalPop = QtGui.QComboBox(self)
      +self.intervalPop.addItems(self.intervalPopupItems)
      +self.intervalPop.setCurrentIndex(self.intervalPopupItems.index(self.intervalDefault))
      +self.interval = self.intervalDefault
      +self.intervalPop.move(10,headerY-5)
      +self.intervalPop.activated[str].connect(self.onIntervalActivated)
      +# set up pop-up menu FreeCAD global variables to watch
      +self.globVar = QtGui.QComboBox(self)
      +self.globVar.addItems(fcGlobalVars())
      +self.globVar.setCurrentIndex(0)
      +self.globVar.setGeometry(0,0,250,30)
      +self.globVar.move(375,headerY-7)
      +self.globVar.activated[str].connect(self.onMenuChoice)
      +#
      +cancelButton = QtGui.QPushButton('Cancel', self)
      +cancelButton.clicked.connect(self.onCancel)
      +cancelButton.move(650, headerY-7)
      +# contextual menu for removing variable from watch list
      +mnuRemove = QtGui.QAction(self)
      +mnuRemove.setText("remove variable")
      +mnuRemove.triggered.connect(self.onRemoveVariable)
      +# define menu and add option
      +self.name1.setContextMenuPolicy(QtCore.Qt.ActionsContextMenu)
      +self.name1.addAction(mnuRemove)
      +self.name2.setContextMenuPolicy(QtCore.Qt.ActionsContextMenu)
      +self.name2.addAction(mnuRemove)
      +self.name3.setContextMenuPolicy(QtCore.Qt.ActionsContextMenu)
      +self.name3.addAction(mnuRemove)
      +self.name4.setContextMenuPolicy(QtCore.Qt.ActionsContextMenu)
      +self.name4.addAction(mnuRemove)
      +self.name5.setContextMenuPolicy(QtCore.Qt.ActionsContextMenu)
      +self.name5.addAction(mnuRemove)
      +self.value1.setContextMenuPolicy(QtCore.Qt.ActionsContextMenu)
      +self.value1.addAction(mnuRemove)
      +self.value2.setContextMenuPolicy(QtCore.Qt.ActionsContextMenu)
      +self.value2.addAction(mnuRemove)
      +self.value3.setContextMenuPolicy(QtCore.Qt.ActionsContextMenu)
      +self.value3.addAction(mnuRemove)
      +self.value4.setContextMenuPolicy(QtCore.Qt.ActionsContextMenu)
      +self.value4.addAction(mnuRemove)
      +self.value5.setContextMenuPolicy(QtCore.Qt.ActionsContextMenu)
      +self.value5.addAction(mnuRemove)
      +
      +self.show()
      +#
      +def onIntervalActivated(self, text):
      +self.interval = text
      +
      +def onTimerOffRB(self):
      +# don't do much, this button serves as a semaphore for the timer routine
      +pass
      +
      +def onTimerOnRB(self):
      +# launch timer routine which is based on the Off radio button
      +self.timerRoutine()
      +
      +def timerRoutine(self):
      +if self.timerOnRB.isChecked():
      +# if the On button is still checked then launch another timer event
      +#print self.interval
      +Timer(float(self.interval), self.timerRoutine, ()).start()
      +#Timer(2, self.timerRoutine, ()).start()
      +else:
      +FreeCAD.Console.PrintMessage("Timer ceasing\n")
      +# now do what should be done
      +self.timerRoutineActions()
      +
      +def timerRoutineActions(self):
      +global watchedVariables
      +if len(watchedVariables)>0:
      +self.displayVariables()
      +else:
      +FreeCAD.Console.PrintMessage("Timer found no variables\n")
      +self.timestamp()
      +
      +def timestamp(self):
      +self.timestampLbl.setText(datetime.now().strftime('%H:%M:%S'))
      +
      +def onDisplayNow(self):
      +self.timestamp()
      +if len(watchedVariables)>0:
      +self.displayVariables()
      +else:
      +FreeCAD.Console.PrintMessage("Found no variables\n")
      +
      +def onMenuChoice(self,aChoice):
      +# handle the user choice from the list of FreeCAD global variables
      +if aChoice==topOfMenuChoices:
      +# wants to update list of Global variable in FreeCAD
      +self.globVarPopupItems  = fcGlobalVars()
      +self.globVar.clear()
      +self.globVar.addItems(self.globVarPopupItems)
      +else:
      +if hasattr(FreeCAD,aChoice):
      +varStr = "FreeCAD."+aChoice
      +exec "varVal = "+varStr
      +exec "dataTypeStr = str(type(" + varStr + "))"
      +self.addVariable(varStr,varVal.__repr__())
      +
      +def addVariable(self, aNameStr, aValueStr):
      +global watchedVariables
      +if len(watchedVariables)<watchVariableLimit:
      +# screen limited in size for now
      +if aNameStr not in watchedVariables.keys():
      +# prevent adding same variable twice
      +watchedVariables[aNameStr] = aValueStr
      +self.displayVariables()
      +
      +def onRemoveVariable(self):
      +global watchedVariables
      +if self.name1.underMouse() or self.value1.underMouse():
      +variableToRemove = self.name1.text()
      +if self.name2.underMouse() or self.value2.underMouse():
      +variableToRemove = self.name2.text()
      +if self.name3.underMouse() or self.value3.underMouse():
      +variableToRemove = self.name3.text()
      +#print variableToRemove
      +watchedVariables.pop(variableToRemove)
      +self.displayVariables()
      +
      +def displayVariables(self):
      +global watchedVariables
      +
      +sortedKeys = watchedVariables.keys()
      +sortedKeysCount = len(sortedKeys)
      +# clear display variables
      +self.name1.setText("")
      +self.value1.setText("")
      +self.name2.setText("")
      +self.value2.setText("")
      +self.name3.setText("")
      +self.value3.setText("")
      +self.name4.setText("")
      +self.value4.setText("")
      +self.name5.setText("")
      +self.value5.setText("")
      +# now display variable names and values
      +# use 'if hasattr(FreeCAD,"ABC"):' to ensure that variable still exists
      +for i in range(0,min(len(watchedVariables),5)):
      +aNameStr = sortedKeys[i]
      +exec "aValueStr = "+aNameStr+".__repr__()"
      +#print aNameStr, " ", aValueStr
      +if i==0:
      +self.name1.setText(aNameStr)
      +self.value1.setText(aValueStr)
      +elif i==1:
      +self.name2.setText(aNameStr)
      +self.value2.setText(aValueStr)
      +elif i==2:
      +self.name3.setText(aNameStr)
      +self.value3.setText(aValueStr)
      +elif i==3:
      +self.name4.setText(aNameStr)
      +self.value4.setText(aValueStr)
      +elif i==4:
      +self.name5.setText(aNameStr)
      +self.value5.setText(aValueStr)
      +
      +def onCancel(self):
      +# need to shut down timer if running
      +self.close()
      +
      +# Class definitions
      +
      +# Functions definitions
      +
      +def fcGlobalVars():
      +varDict = list()
      +varDict.append(topOfMenuChoices)
      +for i in FreeCAD.__dict__.keys():
      +typeStr = type(FreeCAD.__dict__[i])
      +# disregard functions or methods, module
      +if str(typeStr) in ("<type 'type'>","<type 'builtin_function_or_method'>","<type 'module'>"):
      +pass
      +else:
      +# ignore reserved variable names
      +if str(i) in ("PythonAssistantWindowStatus","GuiUp","ActiveDocument", "__path__", "__package__", "__doc__", "__name__"):
      +pass
      +else:
      +varDict.append(i)
      +return varDict
      +
      +# Constant definitions
      +topOfMenuChoices = ">Update list of global variables<"
      +varLabelSpaces = ">                                                                    <"
      +varValueSpaces = ">                                                                                      <"
      +
      +# code ***********************************************************************************
      +global watchVariables, watchVariableLimit
      +watchedVariables = {}
      +watchVariableLimit = 5 # number of lines on screen
      +
      +form = VariableWatcher()
      +form.exec_()
      +#
      +#OS: Mac OS X
      +#Word size: 64-bit
      +#Version: 0.14.3703 (Git)
      +#Branch: releases/FreeCAD-0-14
      +#Hash: c6edd47334a3e6f209e493773093db2b9b4f0e40
      +#Python version: 2.7.5
      +#Qt version: 4.8.6
      +#Coin version: 3.1.3
      +#SoQt version: 1.5.0
      +#OCC version: 6.7.0
      +#
      +#thus ends the macro... 
      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Macro_Guitar_fretboard.html b/localwiki/Macro_Guitar_fretboard.html new file mode 100644 index 0000000..0127f5c --- /dev/null +++ b/localwiki/Macro_Guitar_fretboard.html @@ -0,0 +1,584 @@ +Macro Guitar fretboard

      Macro Guitar fretboard

      + +
      + + + + + + + + + + + + + + + + + + + + + + + + + + +
      +

      Text-x-python.png Macro Guitar fretboard

      +
      Description +
      Create Guitar fretboard. +
      Author +
      ryback08 +
      Links +
      Macros recipes
      How to install macros
      How to customize toolbars +
      Version +
      0.2 +
      Date last modification +
      2018-01-25 +
      +

      + +
      Fretboard freecad2.png +

      Description

      +

      Guitar Fretboard Maker (Macro), Python scrpit is unbelievable to make complexe form.... +

      This macro creates a conical compound (or not) fretboard with nut and fret slot to export in CAM software +

      +

      Code

      +

      Macro Guitar fretboard.FCMacro +

      +
      # -*- coding: utf-8 -*-
      +
      +# Form implementation generated from reading ui file 'dialog.ui'
      +#
      +# Created: Sat Jan 14 00:33:37 2012
      +#      by: PyQt4 UI code generator 4.9
      +#      
      +# WARNING! All changes made in this file will be lost!
      +#
      +#
      +###################################### FREECAD Macro - Draw fretboard guitar #############################################
      +# ressource :                                                                                                            #
      +# Freecad dialog creation : http://sourceforge.net/apps/mediawiki/free-cad/index.php?title=Dialog_creation               #
      +# Topological data scripting : http://sourceforge.net/apps/mediawiki/free-cad/index.php?title=Topological_data_scripting #
      +# Fret slot theory : http://www.jpbourgeois.org/guitar/frets.htm                                                         #
      +#                                                                                                                        #
      +# For personal use only and / or non-profit use                                                                          #
      +# (C)2012 By LEPINE Florent                                                                                              #
      +# V0.1  -  2012/03/18                                                                                                    #
      +# V0.2  -  2018/01/25 : PySide                                                                                           #
      +# Special thanks to FreeCAD team                                                                                         #
      +#                                                                                                                        #
      +##########################################################################################################################
      +#                                                                                                                        #
      +#  ### English ###                                                                                                       #
      +#  This macro creates a conical compound (or not) fretboard with nut and fret slot to export in CAM software             #                       
      +#                                                                                                                        #
      +#  ### Francais ###                                                                                                      #
      +#  Cette macro creer une touche a radius progressif (ou pas) avec les défonces du sillet et l'emplacement des frettes    #
      +#  afin d'etre exporter dans un module de parcourt d'outil CAM                                                           #          
      +#                                                                                                                        #
      +##########################################################################################################################
      +
      +
      +
      +from PySide import QtCore, QtGui
      +import FreeCAD, Part
      +from FreeCAD import Base
      +
      +try:
      +    _fromUtf8 = QtCore.QString.fromUtf8
      +except AttributeError:
      +    _fromUtf8 = lambda s: s
      +
      +
      +   ################################################################################################
      +   ######### begin of dialog box definition / debut de la definition de la boite de dialogue ######
      +   ################################################################################################
      +
      +
      +class Ui_Dialog(object):
      +    def setupUi(self, Dialog):
      +        Dialog.setObjectName(_fromUtf8("Dialog"))
      +        Dialog.resize(380, 491)
      +        self.label_scalelength = QtGui.QLabel(Dialog)
      +        self.label_scalelength.setGeometry(QtCore.QRect(10, 30, 271, 21))
      +        self.label_scalelength.setToolTip(_fromUtf8(""))
      +        self.label_scalelength.setWhatsThis(_fromUtf8(""))
      +        self.label_scalelength.setObjectName(_fromUtf8("label_scalelength"))
      +        self.lineEdit_scalelength = QtGui.QLineEdit(Dialog)
      +        self.lineEdit_scalelength.setGeometry(QtCore.QRect(280, 30, 51, 20))
      +        self.lineEdit_scalelength.setWhatsThis(_fromUtf8(""))
      +        self.lineEdit_scalelength.setObjectName(_fromUtf8("lineEdit_scalelength"))
      +        self.lineEdit_nutwidth = QtGui.QLineEdit(Dialog)
      +        self.lineEdit_nutwidth.setGeometry(QtCore.QRect(280, 90, 51, 20))
      +        self.lineEdit_nutwidth.setObjectName(_fromUtf8("lineEdit_nutwidth"))
      +        self.label_nutwidth = QtGui.QLabel(Dialog)
      +        self.label_nutwidth.setGeometry(QtCore.QRect(10, 90, 271, 21))
      +        self.label_nutwidth.setToolTip(_fromUtf8(""))
      +        self.label_nutwidth.setObjectName(_fromUtf8("label_nutwidth"))
      +        self.lineEdit_nutradius = QtGui.QLineEdit(Dialog)
      +        self.lineEdit_nutradius.setGeometry(QtCore.QRect(280, 110, 51, 20))
      +        self.lineEdit_nutradius.setObjectName(_fromUtf8("lineEdit_nutradius"))
      +        self.label_nutradius = QtGui.QLabel(Dialog)
      +        self.label_nutradius.setGeometry(QtCore.QRect(10, 110, 271, 21))
      +        self.label_nutradius.setToolTip(_fromUtf8(""))
      +        self.label_nutradius.setObjectName(_fromUtf8("label_nutradius"))
      +        self.lineEdit_bodywidth = QtGui.QLineEdit(Dialog)
      +        self.lineEdit_bodywidth.setGeometry(QtCore.QRect(280, 150, 51, 20))
      +        self.lineEdit_bodywidth.setObjectName(_fromUtf8("lineEdit_bodywidth"))
      +        self.label_bodywidth = QtGui.QLabel(Dialog)
      +        self.label_bodywidth.setGeometry(QtCore.QRect(10, 150, 271, 21))
      +        self.label_bodywidth.setToolTip(_fromUtf8(""))
      +        self.label_bodywidth.setObjectName(_fromUtf8("label_bodywidth"))
      +        self.lineEdit_bodyradius = QtGui.QLineEdit(Dialog)
      +        self.lineEdit_bodyradius.setGeometry(QtCore.QRect(280, 190, 51, 20))
      +        self.lineEdit_bodyradius.setObjectName(_fromUtf8("lineEdit_bodyradius"))
      +        self.label_bodyradius = QtGui.QLabel(Dialog)
      +        self.label_bodyradius.setGeometry(QtCore.QRect(10, 190, 271, 21))
      +        self.label_bodyradius.setToolTip(_fromUtf8(""))
      +        self.label_bodyradius.setObjectName(_fromUtf8("label_bodyradius"))
      +        self.label_thicknessboard = QtGui.QLabel(Dialog)
      +        self.label_thicknessboard.setGeometry(QtCore.QRect(10, 230, 271, 21))
      +        self.label_thicknessboard.setToolTip(_fromUtf8(""))
      +        self.label_thicknessboard.setObjectName(_fromUtf8("label_thicknessboard"))
      +        self.lineEdit_thicknessboard = QtGui.QLineEdit(Dialog)
      +        self.lineEdit_thicknessboard.setGeometry(QtCore.QRect(280, 230, 51, 20))
      +        self.lineEdit_thicknessboard.setObjectName(_fromUtf8("lineEdit_thicknessboard"))
      +        self.label_nfret = QtGui.QLabel(Dialog)
      +        self.label_nfret.setGeometry(QtCore.QRect(10, 50, 271, 21))
      +        self.label_nfret.setToolTip(_fromUtf8(""))
      +        self.label_nfret.setObjectName(_fromUtf8("label_nfret"))
      +        self.lineEdit_nfret = QtGui.QLineEdit(Dialog)
      +        self.lineEdit_nfret.setGeometry(QtCore.QRect(280, 50, 51, 20))
      +        self.lineEdit_nfret.setObjectName(_fromUtf8("lineEdit_nfret"))
      +        self.label_fretslotdepth = QtGui.QLabel(Dialog)
      +        self.label_fretslotdepth.setGeometry(QtCore.QRect(10, 270, 271, 21))
      +        self.label_fretslotdepth.setToolTip(_fromUtf8(""))
      +        self.label_fretslotdepth.setObjectName(_fromUtf8("label_fretslotdepth"))
      +        self.lineEdit_fretslotdepth = QtGui.QLineEdit(Dialog)
      +        self.lineEdit_fretslotdepth.setGeometry(QtCore.QRect(280, 270, 51, 20))
      +        self.lineEdit_fretslotdepth.setObjectName(_fromUtf8("lineEdit_fretslotdepth"))
      +        self.lineEdit_fretslotwidth = QtGui.QLineEdit(Dialog)
      +        self.lineEdit_fretslotwidth.setGeometry(QtCore.QRect(280, 290, 51, 20))
      +        self.lineEdit_fretslotwidth.setObjectName(_fromUtf8("lineEdit_fretslotwidth"))
      +        self.label_fretslotwidth = QtGui.QLabel(Dialog)
      +        self.label_fretslotwidth.setGeometry(QtCore.QRect(10, 290, 271, 21))
      +        self.label_fretslotwidth.setToolTip(_fromUtf8(""))
      +        self.label_fretslotwidth.setObjectName(_fromUtf8("label_fretslotwidth"))
      +        self.label_fretslotmarging = QtGui.QLabel(Dialog)
      +        self.label_fretslotmarging.setGeometry(QtCore.QRect(10, 310, 271, 21))
      +        self.label_fretslotmarging.setToolTip(_fromUtf8(""))
      +        self.label_fretslotmarging.setObjectName(_fromUtf8("label_fretslotmarging"))
      +        self.lineEdit_fretslotmarging = QtGui.QLineEdit(Dialog)
      +        self.lineEdit_fretslotmarging.setGeometry(QtCore.QRect(280, 310, 51, 20))
      +        self.lineEdit_fretslotmarging.setObjectName(_fromUtf8("lineEdit_fretslotmarging"))
      +        self.label_nutslotwidth = QtGui.QLabel(Dialog)
      +        self.label_nutslotwidth.setGeometry(QtCore.QRect(10, 350, 271, 21))
      +        self.label_nutslotwidth.setToolTip(_fromUtf8(""))
      +        self.label_nutslotwidth.setObjectName(_fromUtf8("label_nutslotwidth"))
      +        self.lineEdit_nutslotwidth = QtGui.QLineEdit(Dialog)
      +        self.lineEdit_nutslotwidth.setGeometry(QtCore.QRect(280, 350, 51, 20))
      +        self.lineEdit_nutslotwidth.setObjectName(_fromUtf8("lineEdit_nutslotwidth"))
      +        self.label_nutslotdepth = QtGui.QLabel(Dialog)
      +        self.label_nutslotdepth.setGeometry(QtCore.QRect(10, 370, 271, 21))
      +        self.label_nutslotdepth.setToolTip(_fromUtf8(""))
      +        self.label_nutslotdepth.setObjectName(_fromUtf8("label_nutslotdepth"))
      +        self.lineEdit_nutslotdepth = QtGui.QLineEdit(Dialog)
      +        self.lineEdit_nutslotdepth.setGeometry(QtCore.QRect(280, 370, 51, 20))
      +        self.lineEdit_nutslotdepth.setObjectName(_fromUtf8("lineEdit_nutslotdepth"))
      +        self.OK = QtGui.QPushButton(Dialog)
      +        self.OK.setGeometry(QtCore.QRect(150, 440, 75, 23))
      +        self.OK.setObjectName(_fromUtf8("OK"))
      +        self.lineEdit_lastfretlenght = QtGui.QLineEdit(Dialog)
      +        self.lineEdit_lastfretlenght.setGeometry(QtCore.QRect(280, 170, 51, 20))
      +        self.lineEdit_lastfretlenght.setObjectName(_fromUtf8("lineEdit_lastfretlenght"))
      +        self.label_lastfretlenght = QtGui.QLabel(Dialog)
      +        self.label_lastfretlenght.setGeometry(QtCore.QRect(10, 170, 271, 21))
      +        self.label_lastfretlenght.setToolTip(_fromUtf8(""))
      +        self.label_lastfretlenght.setObjectName(_fromUtf8("label_lastfretlenght"))
      +        self.lineEdit_lengthbeforenut = QtGui.QLineEdit(Dialog)
      +        self.lineEdit_lengthbeforenut.setGeometry(QtCore.QRect(280, 390, 51, 20))
      +        self.lineEdit_lengthbeforenut.setObjectName(_fromUtf8("lineEdit_lengthbeforenut"))
      +        self.label_lengthbeforenut = QtGui.QLabel(Dialog)
      +        self.label_lengthbeforenut.setGeometry(QtCore.QRect(10, 390, 271, 21))
      +        self.label_lengthbeforenut.setToolTip(_fromUtf8(""))
      +        self.label_lengthbeforenut.setObjectName(_fromUtf8("label_lengthbeforenut"))
      +        self.label_mm_01 = QtGui.QLabel(Dialog)
      +        self.label_mm_01.setGeometry(QtCore.QRect(340, 30, 21, 21))
      +        self.label_mm_01.setToolTip(_fromUtf8(""))
      +        self.label_mm_01.setWhatsThis(_fromUtf8(""))
      +        self.label_mm_01.setObjectName(_fromUtf8("label_mm_01"))
      +        self.label_mm_02 = QtGui.QLabel(Dialog)
      +        self.label_mm_02.setGeometry(QtCore.QRect(340, 90, 21, 21))
      +        self.label_mm_02.setToolTip(_fromUtf8(""))
      +        self.label_mm_02.setWhatsThis(_fromUtf8(""))
      +        self.label_mm_02.setObjectName(_fromUtf8("label_mm_02"))
      +        self.label_pouces_2 = QtGui.QLabel(Dialog)
      +        self.label_pouces_2.setGeometry(QtCore.QRect(340, 110, 41, 21))
      +        self.label_pouces_2.setToolTip(_fromUtf8(""))
      +        self.label_pouces_2.setWhatsThis(_fromUtf8(""))
      +        self.label_pouces_2.setObjectName(_fromUtf8("label_pouces_2"))
      +        self.label_pouces_1 = QtGui.QLabel(Dialog)
      +        self.label_pouces_1.setGeometry(QtCore.QRect(340, 190, 41, 21))
      +        self.label_pouces_1.setToolTip(_fromUtf8(""))
      +        self.label_pouces_1.setWhatsThis(_fromUtf8(""))
      +        self.label_pouces_1.setObjectName(_fromUtf8("label_pouces_1"))
      +        self.label_mm_03 = QtGui.QLabel(Dialog)
      +        self.label_mm_03.setGeometry(QtCore.QRect(340, 170, 21, 21))
      +        self.label_mm_03.setToolTip(_fromUtf8(""))
      +        self.label_mm_03.setWhatsThis(_fromUtf8(""))
      +        self.label_mm_03.setObjectName(_fromUtf8("label_mm_03"))
      +        self.label_mm_04 = QtGui.QLabel(Dialog)
      +        self.label_mm_04.setGeometry(QtCore.QRect(340, 230, 21, 21))
      +        self.label_mm_04.setToolTip(_fromUtf8(""))
      +        self.label_mm_04.setWhatsThis(_fromUtf8(""))
      +        self.label_mm_04.setObjectName(_fromUtf8("label_mm_04"))
      +        self.label_mm_05 = QtGui.QLabel(Dialog)
      +        self.label_mm_05.setGeometry(QtCore.QRect(340, 270, 21, 21))
      +        self.label_mm_05.setToolTip(_fromUtf8(""))
      +        self.label_mm_05.setWhatsThis(_fromUtf8(""))
      +        self.label_mm_05.setObjectName(_fromUtf8("label_mm_05"))
      +        self.label_mm_06 = QtGui.QLabel(Dialog)
      +        self.label_mm_06.setGeometry(QtCore.QRect(340, 290, 21, 21))
      +        self.label_mm_06.setToolTip(_fromUtf8(""))
      +        self.label_mm_06.setWhatsThis(_fromUtf8(""))
      +        self.label_mm_06.setObjectName(_fromUtf8("label_mm_06"))
      +        self.label_mm_07 = QtGui.QLabel(Dialog)
      +        self.label_mm_07.setGeometry(QtCore.QRect(340, 310, 21, 21))
      +        self.label_mm_07.setToolTip(_fromUtf8(""))
      +        self.label_mm_07.setWhatsThis(_fromUtf8(""))
      +        self.label_mm_07.setObjectName(_fromUtf8("label_mm_07"))
      +        self.label_mm_08 = QtGui.QLabel(Dialog)
      +        self.label_mm_08.setGeometry(QtCore.QRect(340, 350, 21, 21))
      +        self.label_mm_08.setToolTip(_fromUtf8(""))
      +        self.label_mm_08.setWhatsThis(_fromUtf8(""))
      +        self.label_mm_08.setObjectName(_fromUtf8("label_mm_08"))
      +        self.label_mm_09 = QtGui.QLabel(Dialog)
      +        self.label_mm_09.setGeometry(QtCore.QRect(340, 370, 21, 21))
      +        self.label_mm_09.setToolTip(_fromUtf8(""))
      +        self.label_mm_09.setWhatsThis(_fromUtf8(""))
      +        self.label_mm_09.setObjectName(_fromUtf8("label_mm_09"))
      +        self.label_mm_10 = QtGui.QLabel(Dialog)
      +        self.label_mm_10.setGeometry(QtCore.QRect(340, 390, 21, 21))
      +        self.label_mm_10.setToolTip(_fromUtf8(""))
      +        self.label_mm_10.setWhatsThis(_fromUtf8(""))
      +        self.label_mm_10.setObjectName(_fromUtf8("label_mm_10"))
      +        self.label_mm_11 = QtGui.QLabel(Dialog)
      +        self.label_mm_11.setGeometry(QtCore.QRect(340, 150, 21, 21))
      +        self.label_mm_11.setToolTip(_fromUtf8(""))
      +        self.label_mm_11.setWhatsThis(_fromUtf8(""))
      +        self.label_mm_11.setObjectName(_fromUtf8("label_mm_11"))
      +
      +        self.dialog = Dialog  ### Add to close windows at end of macro
      +
      +
      +
      +        self.retranslateUi(Dialog)
      +        QtCore.QObject.connect(self.OK,QtCore.SIGNAL("pressed()"),self.createFretboard)    ###### See Freecad doc - connect pushbuton #####
      +        QtCore.QMetaObject.connectSlotsByName(Dialog)
      +        Dialog.setTabOrder(self.lineEdit_scalelength, self.lineEdit_nfret)
      +        Dialog.setTabOrder(self.lineEdit_nfret, self.lineEdit_nutwidth)
      +        Dialog.setTabOrder(self.lineEdit_nutwidth, self.lineEdit_nutradius)
      +        Dialog.setTabOrder(self.lineEdit_nutradius, self.lineEdit_bodywidth)
      +        Dialog.setTabOrder(self.lineEdit_bodywidth, self.lineEdit_lastfretlenght)
      +        Dialog.setTabOrder(self.lineEdit_lastfretlenght, self.lineEdit_bodyradius)
      +        Dialog.setTabOrder(self.lineEdit_bodyradius, self.lineEdit_thicknessboard)
      +        Dialog.setTabOrder(self.lineEdit_thicknessboard, self.lineEdit_fretslotdepth)
      +        Dialog.setTabOrder(self.lineEdit_fretslotdepth, self.lineEdit_fretslotwidth)
      +        Dialog.setTabOrder(self.lineEdit_fretslotwidth, self.lineEdit_fretslotmarging)
      +        Dialog.setTabOrder(self.lineEdit_fretslotmarging, self.lineEdit_nutslotwidth)
      +        Dialog.setTabOrder(self.lineEdit_nutslotwidth, self.lineEdit_nutslotdepth)
      +        Dialog.setTabOrder(self.lineEdit_nutslotdepth, self.lineEdit_lengthbeforenut)
      +        Dialog.setTabOrder(self.lineEdit_lengthbeforenut, self.OK)
      +
      +
      +
      +
      +    def retranslateUi(self, Dialog):
      +        Dialog.setWindowTitle(QtGui.QApplication.translate("Dialog", "Fretboard Maker", None, QtGui.QApplication.UnicodeUTF8))
      +        self.label_scalelength.setText(QtGui.QApplication.translate("Dialog", "Scale Length - Diapason", None, QtGui.QApplication.UnicodeUTF8))
      +        self.lineEdit_scalelength.setText(QtGui.QApplication.translate("Dialog", "648", None, QtGui.QApplication.UnicodeUTF8))
      +        self.lineEdit_nutwidth.setText(QtGui.QApplication.translate("Dialog", "43", None, QtGui.QApplication.UnicodeUTF8))
      +        self.label_nutwidth.setText(QtGui.QApplication.translate("Dialog", "Width at nut - Largeur au sillet", None, QtGui.QApplication.UnicodeUTF8))
      +        self.lineEdit_nutradius.setText(QtGui.QApplication.translate("Dialog", "10", None, QtGui.QApplication.UnicodeUTF8))
      +        self.label_nutradius.setText(QtGui.QApplication.translate("Dialog", "Radius at nut - Rayon au sillet", None, QtGui.QApplication.UnicodeUTF8))
      +        self.lineEdit_bodywidth.setText(QtGui.QApplication.translate("Dialog", "52", None, QtGui.QApplication.UnicodeUTF8))
      +        self.label_bodywidth.setText(QtGui.QApplication.translate("Dialog", "Width at body - Largeur au Corps", None, QtGui.QApplication.UnicodeUTF8))
      +        self.lineEdit_bodyradius.setText(QtGui.QApplication.translate("Dialog", "16", None, QtGui.QApplication.UnicodeUTF8))
      +        self.label_bodyradius.setText(QtGui.QApplication.translate("Dialog", "Radius at body - Rayon au Corps", None, QtGui.QApplication.UnicodeUTF8))
      +        self.label_thicknessboard.setText(QtGui.QApplication.translate("Dialog", "Board thickness - Epaisseur de touche", None, QtGui.QApplication.UnicodeUTF8))
      +        self.lineEdit_thicknessboard.setText(QtGui.QApplication.translate("Dialog", "7", None, QtGui.QApplication.UnicodeUTF8))
      +        self.label_nfret.setText(QtGui.QApplication.translate("Dialog", "No. of frets - No. de frettes", None, QtGui.QApplication.UnicodeUTF8))
      +        self.lineEdit_nfret.setText(QtGui.QApplication.translate("Dialog", "24", None, QtGui.QApplication.UnicodeUTF8))
      +        self.label_fretslotdepth.setText(QtGui.QApplication.translate("Dialog", "Depth of fret slot - Pronfondeur rainure de frette", None, QtGui.QApplication.UnicodeUTF8))
      +        self.lineEdit_fretslotdepth.setText(QtGui.QApplication.translate("Dialog", "3", None, QtGui.QApplication.UnicodeUTF8))
      +        self.lineEdit_fretslotwidth.setText(QtGui.QApplication.translate("Dialog", "0.6", None, QtGui.QApplication.UnicodeUTF8))
      +        self.label_fretslotwidth.setText(QtGui.QApplication.translate("Dialog", "Width of fret slot - Largeur rainure de frette", None, QtGui.QApplication.UnicodeUTF8))
      +        self.label_fretslotmarging.setText(QtGui.QApplication.translate("Dialog", "Marge  - Marge par rapport au bord", None, QtGui.QApplication.UnicodeUTF8))
      +        self.lineEdit_fretslotmarging.setText(QtGui.QApplication.translate("Dialog", "2.5", None, QtGui.QApplication.UnicodeUTF8))
      +        self.label_nutslotwidth.setText(QtGui.QApplication.translate("Dialog", "Width of nut slot - largeur du sillet", None, QtGui.QApplication.UnicodeUTF8))
      +        self.lineEdit_nutslotwidth.setText(QtGui.QApplication.translate("Dialog", "15.5", None, QtGui.QApplication.UnicodeUTF8))
      +        self.label_nutslotdepth.setText(QtGui.QApplication.translate("Dialog", "depth of nut slot - profondeur du sillet", None, QtGui.QApplication.UnicodeUTF8))
      +        self.lineEdit_nutslotdepth.setText(QtGui.QApplication.translate("Dialog", "4", None, QtGui.QApplication.UnicodeUTF8))
      +        self.OK.setText(QtGui.QApplication.translate("Dialog", "Create !", None, QtGui.QApplication.UnicodeUTF8))
      +        self.lineEdit_lastfretlenght.setText(QtGui.QApplication.translate("Dialog", "8", None, QtGui.QApplication.UnicodeUTF8))
      +        self.label_lastfretlenght.setText(QtGui.QApplication.translate("Dialog", "length after last fret - Deport apres la dernière frette", None, QtGui.QApplication.UnicodeUTF8))
      +        self.lineEdit_lengthbeforenut.setText(QtGui.QApplication.translate("Dialog", "4", None, QtGui.QApplication.UnicodeUTF8))
      +        self.label_lengthbeforenut.setText(QtGui.QApplication.translate("Dialog", "length before nut slot - Deport avant le sillet", None, QtGui.QApplication.UnicodeUTF8))
      +        self.label_mm_01.setText(QtGui.QApplication.translate("Dialog", "mm", None, QtGui.QApplication.UnicodeUTF8))
      +        self.label_mm_02.setText(QtGui.QApplication.translate("Dialog", "mm", None, QtGui.QApplication.UnicodeUTF8))
      +        self.label_pouces_2.setText(QtGui.QApplication.translate("Dialog", "pouces", None, QtGui.QApplication.UnicodeUTF8))
      +        self.label_pouces_1.setText(QtGui.QApplication.translate("Dialog", "pouces", None, QtGui.QApplication.UnicodeUTF8))
      +        self.label_mm_03.setText(QtGui.QApplication.translate("Dialog", "mm", None, QtGui.QApplication.UnicodeUTF8))
      +        self.label_mm_04.setText(QtGui.QApplication.translate("Dialog", "mm", None, QtGui.QApplication.UnicodeUTF8))
      +        self.label_mm_05.setText(QtGui.QApplication.translate("Dialog", "mm", None, QtGui.QApplication.UnicodeUTF8))
      +        self.label_mm_06.setText(QtGui.QApplication.translate("Dialog", "mm", None, QtGui.QApplication.UnicodeUTF8))
      +        self.label_mm_07.setText(QtGui.QApplication.translate("Dialog", "mm", None, QtGui.QApplication.UnicodeUTF8))
      +        self.label_mm_08.setText(QtGui.QApplication.translate("Dialog", "mm", None, QtGui.QApplication.UnicodeUTF8))
      +        self.label_mm_09.setText(QtGui.QApplication.translate("Dialog", "mm", None, QtGui.QApplication.UnicodeUTF8))
      +        self.label_mm_10.setText(QtGui.QApplication.translate("Dialog", "mm", None, QtGui.QApplication.UnicodeUTF8))
      +        self.label_mm_11.setText(QtGui.QApplication.translate("Dialog", "mm", None, QtGui.QApplication.UnicodeUTF8))
      +
      +
      +   ############################################################################################
      +   ######### end of dialog box definition / fin de la definition de la boite de dialogue ######
      +   ############################################################################################
      +
      +
      +    def createFretboard(self):
      +       try:
      +           #################################################################
      +           ####### first we check if valid numbers have been entered #######
      +           #################################################################
      +           scalelength = float(self.lineEdit_scalelength.text())# diapason
      +           nutwidth = float(self.lineEdit_nutwidth.text())# largeur de la touche au sillet
      +           nutradius = float(self.lineEdit_nutradius.text())# radius de la touche au sillet
      +           bodywidth = float(self.lineEdit_bodywidth.text())# largeur de la touche à la dernière frette
      +           bodyradius = float(self.lineEdit_bodyradius.text())# radius de la touche à la dernière frette
      +           thicknessboard = float(self.lineEdit_thicknessboard.text())# epaisseur de la touche
      +           nfret = int(self.lineEdit_nfret.text())                          # nombre de frettes
      +           fretslotdepth = float(self.lineEdit_fretslotdepth.text())# profondeur du solt des frettes
      +           fretslotwidth = float(self.lineEdit_fretslotwidth.text())        # epaisseur du slot des frettes
      +           marging = float(self.lineEdit_fretslotmarging.text())            # deport du slot des frettes par rapport au bord
      +           nutslotwitdh = float(self.lineEdit_nutslotwidth.text())          # longueur du sillet
      +           nutslotdepth = float(self.lineEdit_nutslotdepth.text())          # profondeur du sillet
      +           lastfretlenght = float(self.lineEdit_lastfretlenght.text())# espace entre la derniere frette et la fin de la touche
      +           lengthbeforenut = float(self.lineEdit_lengthbeforenut.text())# espace restant avant le sillet
      +
      +
      +
      +       except ValueError:
      +           print "Error! values must be valid numbers!"
      +           return None
      +
      +
      +
      +
      +       else:
      +           ##### convert all value in float #####
      +           scalelength = float(scalelength)
      +           nutwidth = float(nutwidth)
      +           nutradius = float(nutradius * 25.4)  # pouces value in mm
      +           bodywidth = float(bodywidth)
      +           bodyradius = float(bodyradius * 25.4)   # pouces value in mm
      +           thicknessboard = float(thicknessboard)
      +           nfret = float(nfret)
      +           fretslotdepth = float(fretslotdepth)
      +           fretslotwidth = float(fretslotwidth)
      +           marging = float(marging)
      +           nutslotwitdh = float(nutslotwitdh)
      +           nutslotdepth = float(nutslotdepth)
      +           lastfretlenght = float(lastfretlenght)
      +           lengthbeforenut = float(lengthbeforenut)
      +           print "ok, All Values are good, Let's go"
      +
      +
      +           ########################################################################
      +           print "1 - Create freatboard bottom"
      +           ########################################################################
      +
      +           endfretboard = scalelength * (1 - (1. / 2) ** (nfret / 12)) + lastfretlenght  # distance at last fret (see formule) + lastfretlengt
      +
      +           ########                   Fretboard Vector                        ######
      +           vnb1 = FreeCAD.Vector(0, (nutwidth / 2), 0)                                   # Vector Nut Bottom 1
      +           vbb1 = FreeCAD.Vector(endfretboard, (bodywidth / 2), 0)                       # Vector Body Bottom 1
      +           vbb2 = FreeCAD.Vector(endfretboard,(-bodywidth / 2), 0)
      +           vnb2 = FreeCAD.Vector(0, (-nutwidth / 2), 0)
      +
      +           ########                      Nut Vector                            ######
      +           vbnb1 = FreeCAD.Vector(-(lengthbeforenut + nutslotwitdh), (nutwidth / 2), 0)  # Vector Before Nut Bottom 1
      +           vbnb2 = FreeCAD.Vector(-(lengthbeforenut + nutslotwitdh), -(nutwidth / 2), 0)
      +
      +           ########                         Draw                               ######
      +           pointslist = [vbnb1,vnb1,vbb1,vbb2,vnb2,vbnb2,vbnb1]
      +           fretboardwire = Part.makePolygon(pointslist)
      +           #Part.show(fretboardwire)
      +           fretboardbottom = Part.Face(fretboardwire)
      +           #Part.show(fretboardbottom)
      +           fbextrude=fretboardbottom.extrude(Base.Vector(0,0,thicknessboard*2))
      +           #Part.show(fbextrude)
      +          
      +
      +
      +           ########################################################################
      +           print "2 - Create freatboard top (radius)"
      +           ########################################################################
      +
      +           ########## radius at begin of fretbaord (fefore nut slot) ##############
      +           cn1 = Part.makeCircle(nutradius, Base.Vector(-(lengthbeforenut + nutslotwitdh),0,-nutradius + thicknessboard), Base.Vector(1,0,0), 70, 110)
      +           #Part.show(cn1)
      +
      +           ############# radius at end of fretboard - radius en fin de touche #####
      +           cn2 = Part.makeCircle(bodyradius, Base.Vector(endfretboard,0,-bodyradius + thicknessboard), Base.Vector(1,0,0), 70, 110)
      +           #Part.show(cn2)
      +
      +           ################## face of 2 radius - assemblage des 2 radius ###########
      +           compradius = Part.makeRuledSurface(cn1,cn2)
      +           #Part.show(compradius)
      +           ftextrude=compradius.extrude(Base.Vector(0,0,-thicknessboard*2))
      +           #Part.show(ftextrude)
      +
      +
      +           ########################################################################
      +           print "3 - regroup fretboard bottom & top"
      +           ########################################################################
      +           cleanfretboard = ftextrude.common(fbextrude)
      +           #Part.show(cleanfretboard)
      +
      +           ########################################################################
      +           print "4 - make nut"
      +           ########################################################################
      +           ########                      Nut Vector                          ######
      +           vnt1 = FreeCAD.Vector(0, (nutwidth / 2), thicknessboard)
      +           vnt2 = FreeCAD.Vector(0, -(nutwidth / 2), thicknessboard)
      +           vnt3 = FreeCAD.Vector(-(nutslotwitdh), (nutwidth / 2), thicknessboard)                
      +           vnt4 = FreeCAD.Vector(-(nutslotwitdh), -(nutwidth / 2), thicknessboard)
      +
      +           ########                     Draw nut                             ######
      +           pointslist = [vnt1,vnt2,vnt4,vnt3,vnt1]
      +           nutwire = Part.makePolygon(pointslist)
      +           nutface = Part.Face(nutwire)
      +           nutextrude=nutface.extrude(Base.Vector(0,0,-nutslotdepth))
      +           #Part.show(nutextrude)
      +
      +           ########################################################################
      +           print "5 - Add nut"
      +           ########################################################################
      +           fretboardnut = cleanfretboard.cut(nutextrude)
      +           #Part.show(fretboardnut)
      +
      +           ########################################################################
      +           print "6 - Add ", int(nfret), " slot fret with ", scalelength, " scale length"
      +           ########################################################################
      +
      +
      +           #####################################################################
      +           ##############   Radius on fretboard - depth fret slot   ############
      +           #####################################################################
      +           fretslotradius=compradius.extrude(Base.Vector(0,0,-fretslotdepth))         # radius (top of fretboard) minus fret slot depth 
      +
      +
      +           #####################################################################
      +           ##############   outline fretboard - margin fret slot    ############
      +           #####################################################################
      +           vnb1fs = FreeCAD.Vector(0, (nutwidth / 2) - marging, 0)                    # Vector Nut Bottom 1 Fret slot
      +           vbb1fs = FreeCAD.Vector(endfretboard, (bodywidth / 2) - marging, 0)        # Vector Body Bottom 1 Fret slot
      +           vbb2fs = FreeCAD.Vector(endfretboard, - ((bodywidth / 2) - marging), 0)
      +           vnb2fs = FreeCAD.Vector(0, - ((nutwidth / 2) - marging), 0)
      +           pointslistfs = [vnb1fs,vbb1fs,vbb2fs,vnb2fs,vnb1fs]
      +           fretboardwirefs = Part.makePolygon(pointslistfs)
      +           #Part.show(fretboardwire)
      +           fretboardbottomfs = Part.Face(fretboardwirefs)
      +           #Part.show(fretboardbottom)
      +           fbextrudefs=fretboardbottomfs.extrude(Base.Vector(0,0,thicknessboard*2))   # fretboardbottom with marging
      +           i=0
      +           incnfret = 0
      +           while (incnfret < nfret ):                                                 # draw all fret
      +                 incnfret = incnfret + 1                 
      +                 nxslot = scalelength * (1 - (1. / 2) ** (float(incnfret) / 12))      # see formule to calcul fret length
      +                 print incnfret, " = ", round(nxslot,2) , " mm"                       
      +   
      +
      +                 #####################################################################
      +                 ##############             Fret slot n° X                ############
      +                 #####################################################################         
      +                 vnfs1 = FreeCAD.Vector (nxslot - (fretslotwidth / 2),   bodywidth, 0)      # Vector Nfret slot
      +                 vnfs2 = FreeCAD.Vector (nxslot + (fretslotwidth / 2),   bodywidth, 0)
      +                 vnfs3 = FreeCAD.Vector (nxslot + (fretslotwidth / 2), - bodywidth, 0)
      +                 vnfs4 = FreeCAD.Vector (nxslot - (fretslotwidth / 2), - bodywidth, 0)                 
      +                 pointslistvnfs = [vnfs1,vnfs2,vnfs3,vnfs4,vnfs1]
      +                 nslotwire = Part.makePolygon(pointslistvnfs)
      +                 nslotextrude = Part.Face(nslotwire)
      +                 
      +                 while (i <= 1 ):
      +                        i = i + 1  
      +                        nslot = nslotextrude.extrude(Base.Vector(0,0,thicknessboard*2))
      +                 else:
      +                        nslot2 = nslotextrude.extrude(Base.Vector(0,0,thicknessboard*2))
      +                        nslot = nslot.fuse(nslot2) 
      +                
      +           else:
      +
      +                  nslot3 = fbextrudefs.common(nslot)                                         # assembling all part (radium, bottom and fret)
      +                  nslot4 = fretslotradius.common(nslot3)
      +                  fretboardfinal = fretboardnut.cut(nslot4)    
      +                  #Part.show(fretboardfinal)
      +                  objet_fretboard = App.ActiveDocument.addObject("Part::Feature","Fretboard")
      +                  objet_fretboard.Shape = fretboardfinal
      +
      +
      +                  print "end of fretboard"
      +                  
      +           ########################################################################
      +           print "6 - Add Scale Length"
      +           ########################################################################
      +           Plane_scale_length = Part.makePlane( thicknessboard * 2 , nutwidth * 2 ,Base.Vector(scalelength,nutwidth,0) , Base.Vector(1,0,0)) #makePlane(length,width,[start_pnt,dir_normal])
      +           #Part.show (Plane_scale_length)
      +           objet_diapason = App.ActiveDocument.addObject("Part::Feature","Diapason")
      +           objet_diapason.Shape = Plane_scale_length
      +
      +           ###### close windows when macro is done #####
      +           self.dialog.hide()
      +
      +
      +
      +class Fretboard():
      +    if App.ActiveDocument is None :   # create new document call 'Fretboard' if no document is open
      +         doc = App.newDocument("Fretboard")
      +    dialog = QtGui.QWidget() 
      +    dialog.ui = Ui_Dialog()
      +    dialog.ui.setupUi(dialog)
      +    dialog.show() 
      +

      Link

      +

      Guitar fretboard macro / guitar body +

      +

      Version

      +
      • Version 0.1 : 2012-03-16
      • +
      • Version 0.2 : 2018-01-25 : convert to PySide
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Macro_Half-Hull_Model.html b/localwiki/Macro_Half-Hull_Model.html new file mode 100644 index 0000000..c909e79 --- /dev/null +++ b/localwiki/Macro_Half-Hull_Model.html @@ -0,0 +1,447 @@ +Macro Half-Hull Model

      Macro Half-Hull Model

      + +
      + + + + + + + + + + + + + + + + + + + + + + + + + + +
      +

      Macro Half Hull Model.png Macro Half-Hull Model

      +
      Description +
      This macro generates both three dimensional half-hull and full-hull models from a series of 2D line drawings. +
      Author +
      Piffpoof +
      Links +
      Macros recipes
      How to install macros
      How to customize toolbars +
      Version +
      1.0 +
      Date last modification +
      2016-01-25 +
      +

      + +
      +


      +

      This macro makes simple models of the hulls of boats and ships. It is intended to aid people modeling or designing hulls by providing the hull surface in a straight forward and timely fashion so they can avoid the time consuming full process. +

      Macro Half-Hull ModelScreenBoatInABottle.jpg +

      +

      Background

      +

      Since antiquity boat builders have had to design boats and then realise them in a three dimensional environment where very few lines are straight, very few surfaces flat and no angles constant over a distance. Hull models were used to make to-scale models which could then be used to review the design or communicate concepts to other persons. The laws of hydrodynamics demand that any vessel passing through a liquid be symmetrical in the cross-section if it is to track (move in a straight line) accurately. Consequently building one side of the hull in the model was all that was necessary - if the half-hull was perfect then its mirror image would also be perfect. In latter years half-hulls became used for symbolic purposes such as plaques, and nautical art. +

      This code came out of a project to build a model in FreeCAD of a 12.5 metre sailing boat. The builders no longer had drawings and the son of the original owner doubted there ever were full drawings. Consequently the hull dimensions had to be measured and then a model constructed within the software, Modern software packages like FreeCAD offer many beneficial features like symmetry constraints but when the final measurement is a model that is "easy on the eye", much "massaging" of models is required. This code was written to help automate that process. +

      The initial purpose of this code was to provide a symmetrical hull which was malleable so it could be fitted to the 3D model being constructed. As the software progressed it was generalised so hopefully it would be of some use to persons: +

      +
      • boat designers producing boat diagrams which can be built from
      • +
      • boat builders who are trying to model what is described on their diagrams
      • +
      • model hull builders.
      +

      Certainly commercial boat designers have all sorts of high end software to assist their work, this isn't supposed to replace that. Rather this is for the hobbyist or home builder to tinker around with. +

      Nautical blueprints have a distinct history with respect to buildings and so are somewhat different in presentation. This is an example of a sailing boat which is more than a century old: +

      Macro Half-Hull ModelImage0.jpg +

      One of the end goals of this software is to use the Draft workbench to generate some of these diagrams using the model to generate the lines. +

      Note on Units in FreeCAD: +

      At present there isn't really any units management system within FreeCAD, but obviously a boat builder or modeller will need an accurate dimensioning system. To use this macro, decide to set the FreeCAD grid size to what ever is appropriate for your work (e.g. mm, cm, inch, foot). FreeCAD is consistent, one FreeCAD unit will constantly equal to one FreeCAD unit. And if you have decided to have a FreeCAD unit equal a specific physical length, then your drawings will remain consistently dimensioned. At present there is work on a units system for FreeCAD so this situation may change soon. +

      +

      Description

      +

      For this macro the hull shapes are defined by a minimum of 3 FreeCAD Sketches: one in the YZ plane, one or more in the XZ plane, one in the XY plane. Here is the minimum hull supported by this macro, it has only 3 Sketches: +

      Macro Half-Hull ModelImage1.jpg +

      Note: in the above diagram we are looking directly at the stern, the bow is pointing away from the viewpoint. +

      From front to back (bow to stern) the 3 Sketches are: +

      + + + + + + + + + + + + + + + + +
      stemline
      +
      YZ plane
      +
      red line in sketch
      +
      cross-section
      +
      XZ plane
      +
      green line in Sketch
      +
      transom
      +
      XY plane
      +
      blue line in Sketch
      +
      +


      +Perhaps it is easier to see with 7 Sketches (one in YZ plane, one in XY plane and 5 in the XZ plane): +

      Macro Half-Hull ModelImage2.jpg +

      With 5 Sketches in the XZ plane it is becoming easier to perceive the shape of the hull. The next 2 pictures show the Sketch lines superimposed on the model FreeCAD constructs, +

      Macro Half-Hull ModelImage3.jpg +

      the second is the same model rotated 90 degrees so the bow is in the foreground: +

      Macro Half-Hull ModelImage3a.jpg +

      Some points to consider: +

      +
      • the Sketches are only for: +
        • the stemline (or bow line) in the YZ plane (red in the above diagram);
        • +
        • the top of the transom in the XY plane (blue in the above diagram);
        • +
        • multiple cross-sections of the hull in the XZ plane (green in the above diagram)
      • +
      • only the starboard side of the hull is drawn in the Sketches, the port side will be generated as a mirror image
      • +
      • each multiple-segment line must be in a separate Sketch
      • +
      • each Sketch must have the same number of line segments (which is 3 in the previous examples)
      • +
      • the more line segments in each Sketch, the closer the FreeCAD generated model will approximate a curved hull
      • +
      • there is no limit to the number of line segment in each Sketch, any number from one up
      • +
      • there is no limit to the number of Sketches in the XZ plane (i.e. cross-sections), any number from one up
      +

      With enough Sketches the model generated may even approach: +

      Macro Half-Hull ModelImage4.jpg +

      The HalfHull macro generates 4 models: +

      +
      • starboard half-hull
      • +
      • port half-hull
      • +
      • complete hull
      • +
      • bulkheads for the complete hull, either with a flush deck or with a coachhouse
      +

      These models are all output in the unified location space of FreeCAD so they can be fitted together - for example the bulkheads can be inserted into the complete hull seamlessly. This is a picture of bulkheads in a boat model during construction: +

      Macro Half-Hull ModelImage5.jpg +

      As well as the bulkheads generated by the macro (note that these bulkheads are for a coachhouse rather than a flush deck): +

      Macro Half-Hull ModelImage6.jpg +

      The composite image below shows the main outputs from this software (the port side half-hull is actually not shown but it is the mirror of the starboard half-hull which is shown). The outputs are in clockwise order from the upper left corner: +

      +
      • starboard half-hull
      • +
      • complete hull
      • +
      • bulkheads (for flush deck, the bulkheads in the previous image were for a coachhouse deck)
      • +
      • the complete hull with the bulkheads inserted
      +

      Macro Half-Hull ModelImage7.jpg +

      As novelty features, the macro will also optionally produce plaques for the half-hulls, and even a bottle for the complete hull: +

      Macro Half-Hull ModelImage8.jpg +

      Macro Half-Hull ModelImage9.jpg +

      +

      Installation

      +

      All the code for halfHullModel.FCMacro is in one macro. So installation is comprised of copying the code to the appropriate Macro directory and invoking the Build Utility from the Macro menu, the Python console or a toolbar button (the preferred method). +

      + +

      Usage

      +

      The FreeCAD operations involved in generating the hull model are rather complex and numerous. Things like the direction a line is drawn can cause the FreeCAD construction of the hull to either abort or turn out like: +

      Macro Half-Hull ModelUsage1.jpg +

      Consequently the steps below need to be followed closely. The macro does allow for certain data inconsistencies but generally if the data (i.e. the Sketches) are incorrect then the output will look like a cheese grater or the macro fill fail with an error. +

      The following instructions refer to the quadrants of the XY graph, this refers to the 4 quarters of the XY graph and they are labelled as follows: +

      Macro Half-Hull ModelUsage2.jpg +

      Create a New Document +

      The very first thing is to create a new document in FreeCAD Document-new.svg. This document will hold all the Sketches that make up your hull definition. +

      +

      Create the Stemline

      +

      The first step is one of creating data for the hull model to be made from. The data is supplied in the form of Sketches within FreeCAD. After the hull model is generated, if changes are to be made then the Sketches are simply edited, and the second step of running the macro repeatedly. +

      +
      1. create a new sketch Sketcher NewSketch.svg, in the YZ-Plane
      2. +
      3. start at origin (0,0) and draw upwards into Quadrant I
        Macro Half-Hull ModelUsage3.jpg
      4. +
      5. the bottom end of the stemline is at the origin (0,0) - this will be the point from where the placement of all the cross-sections and transom will be made
      6. +
      7. the number of line segments in this Sketch determines the number which will be required in each other Sketch
      8. +
      9. save sketch Sketcher LeaveSketch.svg
      10. +
      11. for ease of identification it is probably worth naming the Sketch something like "stemline sketch"
      +

      Create the Cross-section Sketch(es)

      +
      1. create a new sketch Sketcher NewSketch.svg, in the XZ-Plane
      2. +
      3. the following dialog will appear:
        Macro Half-Hull ModelScreenSnapshot1.jpg
        The dialog is asking how far from the origin the Sketch should be placed. This will refer to how far the cross-section is from the bottom of the stemline (which was placed at (0,0)). The cross-sections can be equally spaced but need not be. The forward-most cross-section will be at Y=0 (i.e. the origin where the stemline bottom ends) or at Y<=0. The cross-sections will be at increasingly negative Y values until the transom is at the most negative Y value. In the example above, the cross-section Sketch will be placed 50 FreeCAD units from the origin on the negative Y axis.
      4. +
      5. start on the Y axis and draw upwards into Quadrant I
        - the first (i.e. foremost) cross-section should start at origin (0,0) (or it will look odd as the stemline ends at 0,0) but other cross-sections need only start on the Y axis.
        Macro Half-Hull ModelUsage3.jpg
      6. +
      7. use the same number of line segments as in the Stemline Sketch
      8. +
      9. save sketch Sketcher LeaveSketch.svg
      10. +
      11. repeat as this step necessary, it may be quicker to copy this sketch and then space the copies on the Y-axis, modifications may be made to the individual Sketches as required
      12. +
      13. for naming, it will make things easier to give some sort of sequence to the cross-sections, starting at the bow (i.e. the stemline) and increasing towards the stern (i.e. the transom)
      +

      Create the Transom Sketch in the XY Plane

      +
      1. create a new sketch Sketcher NewSketch.svg, in the XY-Plane
      2. +
      3. start on the Y axis between quadrant III and IV, and draw upwards into Quadrant IV so that the end point is coincident with the rightmost point of the lowest cross-section Sketch in the YZ-plane
        Macro Half-Hull ModelUsage4.jpg
      4. +
      5. use the same number of line segments as in the stemline Sketch
      6. +
      7. save sketch Sketcher LeaveSketch.svg
      8. +
      9. for ease of identification it is probably worth naming the Sketch something like "transom sketch"
      +

      Save the New Document +

      Now save the document Document-save.svg which contains the Sketches that will define the hull shape, giving it some name that is descriptive +

      Once the Sketches have all been created and positioned, the document should look like this from the top view View-top.svg: +

      Macro Half-Hull ModelUsage5.jpg +

      The principal limitations for constructing the model are: +

      +
      • the stemline bottom should end at (0,0)
      • +
      • the bottom centremost end of each cross-section should end at the Y axis - note that it can have any Z value
      +

      This concludes the first step which is one of creating the data which the macro will use to create both half-hulls and complete-hulls. The second step is described in the following section which is titled User Interface +

      +

      User Interface

      +

      In this step the macro will gather some information from the user and then process the input Sketches to generate the desired hull models. This is the only GUI image for the macro and is primarily configuration details for the production of the hull models from the Sketches: +

      Macro Half-Hull ModelScreenSnapshot2.jpg +

      The choices on the GUI window are: +

      +
      • Starboard half-hull
        - checking this will cause the macro to produce a starboard half-hull model +
        • Mounting plaque
          - if checked the macro will mount the half-hull on a plaque +
          • Allow space for keel
            - if checked will cause the half hull to be mounted higher on the plaque than the centre position, this is so a separately generated keel could be placed below the hull
      • +
      • Port half-hull
        - checking this will cause the macro to produce a port half-hull model +
        • Mounting plaque
          - if checked the macro will mount the half-hull on a plaque +
          • Allow space for keel
            - if checked will cause the half hull to be mounted higher on the plaque than the centre position, this is so a separately generated keel could be placed below the hull
      • +
      • Complete hull
        - checking this will cause the macro to produce a complete model +
        • Bottle for complete hull
          - if checked the macro will place the complete hull inside a transparent bottle (complete with cork) +
          • Allow space for keel
            - if checked will cause the half hull to be positioned higher in the bottle than the centre position, this is so a separately generated keel could be placed below the hull
      • +
      • Bulkheads for flush deck
        - checking this will cause the macro to produce bulkheads whose tops are level with the top of the hull, bulkheads will not be generated for the most forward 2 cross-sections or the aft-most 2 cross-sections
      • +
      • Bulkheads for coachhouse
        - checking this will cause the macro to produce bulkheads whose tops are possibly above the top of the hull. +
        • Bulkheads to skip at bow determines how many cross-sections will be left without a bulkhead at the bow
        • +
        • Bulkheads to skip at stern determines how many cross-sections will be left without a bulkhead at the stern
      • +
      • The dimensions of the top of the bulkheads will be configured as per the following diagram:
        Macro Half-Hull ModelUi1.jpg
      • +
      • Cancel button
        - the execution is halted and the window closes
      • +
      • Re-Use Last File button
        - the execution uses the data file AND SETTINGS from the the last run, any changes to settings are ignored
      • +
      • Select File button
        - the standard Open File window is opened where the user can either select a file or Cancel and exit
      +

      When the macro runs it takes configuring data from the user and then reads Sketcher sketches in the selected input file. +

      Note: As the macro works through the Sketches it prints out any exceptions as well as some milestones on the Report View. If you get unexpected results or some parts are missing, that is probably the first place to check. +

      +

      Options

      +

      There are various types of bows and sterns for boats, with sterns having much more variety than bows. Here are examples of transoms and bows from the real world alongside the similar macro output: +

      Sheer Stern +

      Probably the most common stern, typical of all sizes of vessels from commercial ships through to rowing boats. +

      + + + + + +
      Macro Half-Hull ModelOption1.jpgMacro Half-Hull ModelOption2.jpg
      +
      • the XY transom should be as close to the aftmost cross-section as is possible.
      +

      Sugar-Scoop Stern +

      Most likely to be found on a sailing yacht, it is a product of designing to maximise the length of the waterline to benefit from class rules for racing under sail. +

      + + + + + +
      Macro Half-Hull ModelOption3.jpgMacro Half-Hull ModelOption4.jpg
      +
      • place the aftmost 2 cross-sections as close as is feasible, then rotate the aftmost of the two through to an angle of 45 degrees (or whatever is called for) around the X-axis
      +

      Canoe Stern +

      Found on all sizes of water craft, power and sail, pleasure and commercial. +

      + + + + + +
      Macro Half-Hull ModelOption5.jpgMacro Half-Hull ModelOption6.jpg
      +
      • place the aftmost 2 cross-sections as close as is feasible, then rotate the aftmost of the two through to an angle of 45 degrees around the X-axis
      +

      Normal Bow +

      There is a lot less variety in bow shapes than with transoms: +

      + + + + + +
      Macro Half-Hull ModelOption7.jpgMacro Half-Hull ModelOption8.jpg
      +

      Trireme Bow +

      Although not seen very frequently in the last 2 millenia, this was once the definitive bow profile for war-making vessels: +

      + + + + + +
      Macro Half-Hull ModelOption9.jpgMacro Half-Hull ModelOption10.jpg
      +
      • in order for the bow to be correct the poly-line for the stemline needs to be drawn from the bottom to the top which will mean right to left in the Sketcher
      +

      Sample Files

      +

      These files are samples of Sketch data to use with the macro, mainly they are the models for the screen snapshots in the Options section above. The files work with the Macro and so can be downloaded and played with to adapt to your specific requirements. The prefix of 5x3 (for example) means the model has 5 cross-sections and 3 line segments per cross-section (i.e. sketch) +

      To use one of the example files, right-click on the file link and select Save File As... from the menu. The filename will be specified, choose the desired folder/directory to hold the example file. +

      + +

      Remarks

      +
      • almost all the examples on this page are generated with only 3 line segments defining the side of the hull which gives a very faceted appearance, increasing the number of segments in each Sketch would generate a much smoother surface which would increase the realism
      • +
      • doesn't do keels, skegs or rudders, in other words, it doesn't do any of the wet area
      • +
      • doesn't do square bows like push-boats or towed barges
      • +
      • doesn't do submarines (although it will do the lower half of a submarine)
      +

      Known Problems

      +

      The 'Ruled Surface' feature of FreeCAD is used to generate the hull sections from the Sketches. It can sometimes generate the wrong result and display a grater like surface instead of a smooth planar one. This will typically occur when the Sketches are rotated such as when a Sugar Scoop stern is modeled. Also angling a Sheer Transom stern can cause this. If it occurs then typically it will do so in either the half-hull models or the complete hull model - it never seems to occur in all three models for the same hull. Also it usually only happens at the extreme bow or stern. If it happens to section in the middle of the boat then most likely one of the Sketches was drawn in the wrong direction (i.e. either random sequence or top-down where as all lines should be drawn bottom-up) +

      It can usually be removed by using the following steps: +

      +
      • in the Model tab of the Combo View, click on the faulty segment to select it, the faulty segment will show as highlighted on the display
      • +
      • select the Data tab on the bottom half of the Combo View, the lower part of the window will have a Label "Ruled Surface" with a single parameter 'Orientation'
      • +
      • there is a popup menu to the right which has the values 'Automatic', 'Forward', 'Reversed', it will initially be set to 'Automatic'
      • +
      • try one of the other settings (remembering the faulty segment must still be selected in the upper part of the Combo View) which will usually correct the problem
      +

      The following screen snapshot shows the relevant portion of the screen: +

      Macro Half-Hull ModelKnownProblems1.jpg +

      +

      Future Possibilities

      +
      • replace line segments of cross-sections with curved lines
        - this is just at the idea stage but would give a much smoother surface in the vertical dimension, however the horizontal surface would still be faceted as it is now
      • +
      • integrate with Draft workbench to produce drawings from models
        - an initial goal, but the feasibility has not been investigated
      • +
      • handle keels, skegs and rudders
        - one work around for keels with the present system is to model the keel as a half-hull on it's own and then assemble it onto the bottom of the main hull; this would still do nothing for rudders and skegs though
      +

      Glossary

      +

      As with any ancient and practiced trade, a rich and sometimes confusing vocabulary has developed around ships, boats and nautical practices. In describing this macro it is both awkward and inefficient to describe the process without using the correct and accurate terms. The obvious problem is that the average lay person will be unfamiliar with such terminology, hence this vocabulary: +

      + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
      aft + the rear aspect of anything on a boat +

      +

      +
      chinea planar facet of a hull, can be used to + approximate a curved surface or as a finished building technique

      +

      +
      coachhouse + the part of the central deck which is raised above the deck level - usually to accommodate increased headroom in the interior of the boat +

      +

      +
      flush deck + a deck that runs smoothly from the top of one side of the hull to the other, the converse to a coachhouse deck +

      +

      +
      forward + also 'fore'; the front aspect of anything on a boat +

      +

      +
      port + lefthand side looking forward +

      +

      +
      starboard + righthand side looking forward +

      +

      +
      stemline + the sloped vertical edge which is the bow of a hull +

      +

      +
      transom + the curved top edge of the stern face which can be flat or curved +
      +

      Links

      + +

      Script

      +

      This script is running bug free. But due to the large range of possible inputs it may fail for some inputs. If so please report it. +

      The script is too long for the Wiki to display so it must be copied or downloaded from unabbreviated script on pastebin.com +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Macro_Half-Hull_ModelImage0.jpg b/localwiki/Macro_Half-Hull_ModelImage0.jpg new file mode 100644 index 0000000..6a8af51 Binary files /dev/null and b/localwiki/Macro_Half-Hull_ModelImage0.jpg differ diff --git a/localwiki/Macro_Half-Hull_ModelImage1.jpg b/localwiki/Macro_Half-Hull_ModelImage1.jpg new file mode 100644 index 0000000..6e4456f Binary files /dev/null and b/localwiki/Macro_Half-Hull_ModelImage1.jpg differ diff --git a/localwiki/Macro_Half-Hull_ModelImage2.jpg b/localwiki/Macro_Half-Hull_ModelImage2.jpg new file mode 100644 index 0000000..79e3404 Binary files /dev/null and b/localwiki/Macro_Half-Hull_ModelImage2.jpg differ diff --git a/localwiki/Macro_Half-Hull_ModelImage3.jpg b/localwiki/Macro_Half-Hull_ModelImage3.jpg new file mode 100644 index 0000000..2054d0a Binary files /dev/null and b/localwiki/Macro_Half-Hull_ModelImage3.jpg differ diff --git a/localwiki/Macro_Half-Hull_ModelImage3a.jpg b/localwiki/Macro_Half-Hull_ModelImage3a.jpg new file mode 100644 index 0000000..bfb85cf Binary files /dev/null and b/localwiki/Macro_Half-Hull_ModelImage3a.jpg differ diff --git a/localwiki/Macro_Half-Hull_ModelImage4.jpg b/localwiki/Macro_Half-Hull_ModelImage4.jpg new file mode 100644 index 0000000..07af79d Binary files /dev/null and b/localwiki/Macro_Half-Hull_ModelImage4.jpg differ diff --git a/localwiki/Macro_Half-Hull_ModelImage5.jpg b/localwiki/Macro_Half-Hull_ModelImage5.jpg new file mode 100644 index 0000000..af0112a Binary files /dev/null and b/localwiki/Macro_Half-Hull_ModelImage5.jpg differ diff --git a/localwiki/Macro_Half-Hull_ModelImage6.jpg b/localwiki/Macro_Half-Hull_ModelImage6.jpg new file mode 100644 index 0000000..5228db3 Binary files /dev/null and b/localwiki/Macro_Half-Hull_ModelImage6.jpg differ diff --git a/localwiki/Macro_Half-Hull_ModelImage7.jpg b/localwiki/Macro_Half-Hull_ModelImage7.jpg new file mode 100644 index 0000000..9a13b85 Binary files /dev/null and b/localwiki/Macro_Half-Hull_ModelImage7.jpg differ diff --git a/localwiki/Macro_Half-Hull_ModelImage8.jpg b/localwiki/Macro_Half-Hull_ModelImage8.jpg new file mode 100644 index 0000000..e05dcf0 Binary files /dev/null and b/localwiki/Macro_Half-Hull_ModelImage8.jpg differ diff --git a/localwiki/Macro_Half-Hull_ModelImage9.jpg b/localwiki/Macro_Half-Hull_ModelImage9.jpg new file mode 100644 index 0000000..b577c24 Binary files /dev/null and b/localwiki/Macro_Half-Hull_ModelImage9.jpg differ diff --git a/localwiki/Macro_Half-Hull_ModelKnownProblems1.jpg b/localwiki/Macro_Half-Hull_ModelKnownProblems1.jpg new file mode 100644 index 0000000..456cc31 Binary files /dev/null and b/localwiki/Macro_Half-Hull_ModelKnownProblems1.jpg differ diff --git a/localwiki/Macro_Half-Hull_ModelOption1.jpg b/localwiki/Macro_Half-Hull_ModelOption1.jpg new file mode 100644 index 0000000..432c62a Binary files /dev/null and b/localwiki/Macro_Half-Hull_ModelOption1.jpg differ diff --git a/localwiki/Macro_Half-Hull_ModelOption10.jpg b/localwiki/Macro_Half-Hull_ModelOption10.jpg new file mode 100644 index 0000000..d175b04 Binary files /dev/null and b/localwiki/Macro_Half-Hull_ModelOption10.jpg differ diff --git a/localwiki/Macro_Half-Hull_ModelOption2.jpg b/localwiki/Macro_Half-Hull_ModelOption2.jpg new file mode 100644 index 0000000..a463fd7 Binary files /dev/null and b/localwiki/Macro_Half-Hull_ModelOption2.jpg differ diff --git a/localwiki/Macro_Half-Hull_ModelOption3.jpg b/localwiki/Macro_Half-Hull_ModelOption3.jpg new file mode 100644 index 0000000..a71926c Binary files /dev/null and b/localwiki/Macro_Half-Hull_ModelOption3.jpg differ diff --git a/localwiki/Macro_Half-Hull_ModelOption4.jpg b/localwiki/Macro_Half-Hull_ModelOption4.jpg new file mode 100644 index 0000000..20bd1ff Binary files /dev/null and b/localwiki/Macro_Half-Hull_ModelOption4.jpg differ diff --git a/localwiki/Macro_Half-Hull_ModelOption5.jpg b/localwiki/Macro_Half-Hull_ModelOption5.jpg new file mode 100644 index 0000000..caf2d04 Binary files /dev/null and b/localwiki/Macro_Half-Hull_ModelOption5.jpg differ diff --git a/localwiki/Macro_Half-Hull_ModelOption6.jpg b/localwiki/Macro_Half-Hull_ModelOption6.jpg new file mode 100644 index 0000000..0202227 Binary files /dev/null and b/localwiki/Macro_Half-Hull_ModelOption6.jpg differ diff --git a/localwiki/Macro_Half-Hull_ModelOption7.jpg b/localwiki/Macro_Half-Hull_ModelOption7.jpg new file mode 100644 index 0000000..c0debed Binary files /dev/null and b/localwiki/Macro_Half-Hull_ModelOption7.jpg differ diff --git a/localwiki/Macro_Half-Hull_ModelOption8.jpg b/localwiki/Macro_Half-Hull_ModelOption8.jpg new file mode 100644 index 0000000..31be247 Binary files /dev/null and b/localwiki/Macro_Half-Hull_ModelOption8.jpg differ diff --git a/localwiki/Macro_Half-Hull_ModelOption9.jpg b/localwiki/Macro_Half-Hull_ModelOption9.jpg new file mode 100644 index 0000000..96dbd05 Binary files /dev/null and b/localwiki/Macro_Half-Hull_ModelOption9.jpg differ diff --git a/localwiki/Macro_Half-Hull_ModelScreenBoatInABottle.jpg b/localwiki/Macro_Half-Hull_ModelScreenBoatInABottle.jpg new file mode 100644 index 0000000..8b7de24 Binary files /dev/null and b/localwiki/Macro_Half-Hull_ModelScreenBoatInABottle.jpg differ diff --git a/localwiki/Macro_Half-Hull_ModelScreenSnapshot1.jpg b/localwiki/Macro_Half-Hull_ModelScreenSnapshot1.jpg new file mode 100644 index 0000000..b79821f Binary files /dev/null and b/localwiki/Macro_Half-Hull_ModelScreenSnapshot1.jpg differ diff --git a/localwiki/Macro_Half-Hull_ModelScreenSnapshot2.jpg b/localwiki/Macro_Half-Hull_ModelScreenSnapshot2.jpg new file mode 100644 index 0000000..eadc230 Binary files /dev/null and b/localwiki/Macro_Half-Hull_ModelScreenSnapshot2.jpg differ diff --git a/localwiki/Macro_Half-Hull_ModelUi1.jpg b/localwiki/Macro_Half-Hull_ModelUi1.jpg new file mode 100644 index 0000000..6d98caf Binary files /dev/null and b/localwiki/Macro_Half-Hull_ModelUi1.jpg differ diff --git a/localwiki/Macro_Half-Hull_ModelUsage1.jpg b/localwiki/Macro_Half-Hull_ModelUsage1.jpg new file mode 100644 index 0000000..cb4cca9 Binary files /dev/null and b/localwiki/Macro_Half-Hull_ModelUsage1.jpg differ diff --git a/localwiki/Macro_Half-Hull_ModelUsage2.jpg b/localwiki/Macro_Half-Hull_ModelUsage2.jpg new file mode 100644 index 0000000..042a90b Binary files /dev/null and b/localwiki/Macro_Half-Hull_ModelUsage2.jpg differ diff --git a/localwiki/Macro_Half-Hull_ModelUsage3.jpg b/localwiki/Macro_Half-Hull_ModelUsage3.jpg new file mode 100644 index 0000000..9796a00 Binary files /dev/null and b/localwiki/Macro_Half-Hull_ModelUsage3.jpg differ diff --git a/localwiki/Macro_Half-Hull_ModelUsage4.jpg b/localwiki/Macro_Half-Hull_ModelUsage4.jpg new file mode 100644 index 0000000..8559061 Binary files /dev/null and b/localwiki/Macro_Half-Hull_ModelUsage4.jpg differ diff --git a/localwiki/Macro_Half-Hull_ModelUsage5.jpg b/localwiki/Macro_Half-Hull_ModelUsage5.jpg new file mode 100644 index 0000000..056f461 Binary files /dev/null and b/localwiki/Macro_Half-Hull_ModelUsage5.jpg differ diff --git a/localwiki/Macro_Half_turn_stairs.html b/localwiki/Macro_Half_turn_stairs.html new file mode 100644 index 0000000..063761e --- /dev/null +++ b/localwiki/Macro_Half_turn_stairs.html @@ -0,0 +1,339 @@ +Macro Half turn stairs

      Macro Half turn stairs

      + +
      + + + + + + + + + + + + + + + + + + + + + + + + + + +
      +

      Half turn stairs.png Half_turn_stairs

      +
      Description +
      This macro creates a Stair with left or right turn in the defined high. The design of the stairs are defined in stairs.dat file. The step-high of the stair is calculated from the high of the stair. +
      Author +
      Berner +
      Links +
      Macros recipes
      How to install macros
      How to customize toolbars +
      Version +
      1.0 +
      Date last modification +
      2016-10-17 +
      +

      + +
      stairs +
      +


      +

      +

      Description

      +

      This Macro creates a half turning Stair with the design of stairs.dat file left or right turning. +

      +

      Use

      +
      • Launch the macro and change the height of Stair to the hight of your floor. The turning can be left or right.
      +
      +#
      +# Save this Data as file stairs.dat in your macro directory
      +# 
      +# Stufe 0
      +0.0 -240.0 0.0 0.0 0.0 0.0 1000.0 0.0 0.0 1000.0 -240.0 0.0
      +# Stufe 1
      +0.0 0.0 0.0 0.0 240.0 0.0 1000.0 240.0 0.0 1000.0 0.0 0.0
      +# Stufe 2
      +0.0 240.0 0.0 0.0 520.0 0.0 1000.0 520.0 0.0 1000.0 240.0 0.0
      +# Stufe 3
      +0.0 520.0 0.0 0.0 840.0 0.0 1000.0 720.0 0.0 1000.0 520.0 0.0
      +# Stufe 4
      +0.0 840.0 0.0 0.0 1220.0 0.0 1000.0 860.0 0.0 1000.0 720.0 0.0
      +# Stufe 5
      +0.0 1220.0 0.0 0.0 1620.0 0.0 1000.0 1000.0 0.0 1000.0 860.0 0.0
      +# Stufe 6
      +0.0 1620.0 0.0 0.0 2170.0 0.0  140.0 2170.0 0.0 1000.0 1120.0 0.0 1000.0 1000.0 0.0
      +# Stufe 7
      +140.0 2170.0 0.0 680.0 2170.0 0.0 1020.0 1170.0 0.0 1000.0 1170.0 0.0 1000.0 1120.0 0.0 140.0 2170.0 0.0
      +# Stufe 8
      +680.0 2170.0 0.0 1115.0 2170.0 0.0 1115.0 1170.0 0.0 1020.0 1170.0 0.0 
      +# Stufe 9
      +1115.0 2170.0 0.0 1550.0 2170.0 0.0 1210.0 1170.0 0.0 1115.0  1170.0 0.0 1115.0 2170.0 0.0
      +# Stufe 10
      +1550.0 2170.0 0.0 2090.0 2170.0 0.0 1230.0 1120.0 0.0 1230.0 1170.0 0.0 1210.0 1170.0 0.0 1550.0 2170.0 0.0
      +# Stufe 11
      +2090.0 2170.0 0.0 2230.0 2170.0 0.0 2230.0 1620.0 0.0 1230.0 1000.0 0.0 1230.0 1120.0 0.0 2090.0 2170.0 0.0
      +# Stufe 12
      +1230.0 1000.0 0.0 2230.0 1620.0 0.0 2230.0 1230.0 0.0 1230.0 860.0 0.0 1230.0 1000.0 0.0
      +# Stufe 13
      +1230.0 720.0 0.0 1230.0 860.0 0.0 2230.0 1220.0 0.0 2230.0 840.0 0.0 1230.0 720.0 0.0
      +# Stufe 14
      +1230.0 520.0 0.0 1230.0 720.0 0.0 2230.0 840.0 0.0 2230.0 520.0 0.0 1230.0 520.0 0.0
      +# Stufe 15
      +1230.0 240.0 0.0 1230.0 520.0 0.0 2230 520.0 0.0 2230.0 240.0 0.0 1230.0 240.0 0.0
      +# Stufe 16
      +1230.0 0.0 0.0 1230.0 240.0 0.0 2230.0 240.0 0.0 2230.0 0.0 0.0 1230.0 0.0 0.0
      +# Stufe 17
      +1230.0 -240.0 0.0 1230.0 0.0 0.0 2230.0 0.0 0.0 2230.0 -240.0 0.0 1230.0 -240.0 0.0
      +
      +

      Script

      +

      Half_turn_stairs.FCMacro +

      +
      +# -*- coding: utf-8 -*-
      +#
      +# Half_turn_stairs Macro runs with Freecad 0.17
      +#
      +# Author: Berner and Forum
      +#
      +# This macro creates a half turn stair from tupels of x,y,z 
      +# the tupels used to create a dwire for every stair.
      +# The dwire is extruded, so it give with 18 stairs the total rise 
      +#
      +# A sample file with parameters is in stairs.dat
      +#
      +# created a wire with coordinate x y z separated (in the file)
      +#Sample: (delete # on lines without comments)
      +# Stair 0
      +#0.0 -240.0 0.0 0.0 0.0 0.0 1000.0 0.0 0.0 1000.0 -240.0 0.0
      +# Stair 1
      +#0.0 0.0 0.0 0.0 240.0 0.0 1000.0 240.0 0.0 1000.0 0.0 0.0
      +#. . . .
      +
      +from __future__ import unicode_literals
      +from FreeCAD import Base
      +import Draft, Part
      +
      +App.Console.PrintMessage("Half_turn_stairs-Macro\n")
      +# Get location of user macros
      +p=FreeCAD.ParamGet("User parameter:BaseApp/Preferences/Macro")
      +path = p.GetString("MacroPath")
      +dataset = path + "/stairs.dat"                          # path and name of file.txt
      +docname = App.ActiveDocument.Name                       # Name of active document
      + 
      +debug='n' # Debug Values on Console
      +rise = 3100.0 # Geschosshoehe Total Rise
      +
      +left_right="l"  # turn stairs left or left_right
      +# GUI
      +
      +from PySide import QtGui
      +(rise, ok) = QtGui.QInputDialog.getDouble(
      +QtGui.QWidget(), 'Total Rise / Geschosshoehe', 'Total Rise /  Geschosshoehe', 2000, 0, 3100, 4)
      +if ok:
      + left_right = QtGui.QInputDialog.getText(None, "left_right", "Turn Left or Right l/r")[0]
      +if debug == 'y': FreeCAD.Console.PrintMessage("rise="+str(rise) + " " + str(ok) + "\n" )
      +if debug == 'y': FreeCAD.Console.PrintMessage("left_right="+str(left_right) + " " + str(ok) + "\n" )
      +# End Gui
      +step=float(rise/18)  # Treppensteigung / Step_high
      +
      +# functions
      +def objnames():  # List object names
      + doc = FreeCAD.ActiveDocument
      + objs = FreeCAD.ActiveDocument.Objects
      + names=''  #list of objectnames
      + labels='' # list of objectlabels 
      + for obj in objs:
      +    a = obj.Name                                             # list the Name  of the object  (not modifiable)
      +    b = obj.Label                                            # list the Label of the object  (modifiable)
      +    try:
      +        c = obj.LabelText                                    # list the LabeText of the text (modifiable)
      +        names=names+str(a)+" "
      +        labels=labels+str(b)+" "
      +    except:
      +        names=names+str(a)+" "
      +        labels=labels+str(b)+" "
      + return names
      + if debug == 'y': App.Console.PrintMessage("Names="+str(names) +"\n"+"Labels="+ str(labels) + "\n")
      +# end functions
      +
      +file = open(dataset, "r") # open the file read
      +i = 0 #line counter
      +line = file.readline()
      +while(line != ''):    # read number of lines
      +   if line[0:1] != "#" and len(line) >0:
      +    i = i + 1
      +    if debug == "y": App.Console.PrintMessage("Parameter-Line" + str(i) + " " + line + "\n")
      +   line = file.readline() 
      +file.close()
      +numlines=i  # number of parameter-lines
      +if debug == "y": App.Console.PrintMessage("Number of Parameter-Lines =" + str(numlines) + "\n")
      +file = open(dataset, "r")                                  # open the file read
      +wire = []
      +X=Y=Z = 0.0
      +if left_right == "r": 
      + i = 0 #line counter
      +else:
      + i = numlines 
      +line = file.readline()
      +while(line != ''):
      +    num_words = len(line.split())
      +    num_tupel = num_words / 3
      +    if debug == "y": App.Console.PrintMessage(str(num_words) + "\n")
      +    if debug == "y": App.Console.PrintMessage(str(num_tupel) + "\n")
      +    if line[0:1] == "#" or num_words != (num_tupel * 3):
      +     if num_words != (num_tupel * 3):
      +      App.Console.PrintMessage("Error on Inputfile line " + str(i) + "\n")
      +      App.Console.PrintMessage("Only " + str(num_words) + " of multiple of 3 Words\n")
      +    else:
      +     if line[0:1] == "#": 
      +      num_words = 0   #  ignore comment
      +     if debug == "y": App.Console.PrintMessage(line + "\n")
      +     coordinates = line.split()
      +     if debug == "y": App.Console.PrintMessage(str(coordinates) + " " + str(num_words) + " " + str(num_tupel)+ str(type(num_words)) + "\n")
      +     if num_words > 0:
      +      data=""  # generate statement
      +      printline="App.Console.PrintMessage(" # generate variable for PrintMessage (debug)
      +      for x in range(1, num_tupel + 1):
      +       data=data + "X" + str(x) + ",Y" + str(x) + ",Z" + str(x)
      +       printline=printline + "str(X" + str(x) + ") + ' ' + " + "str(Y" + str(x) + ") + ' ' + " + "str(Z" + str(x) + ") + ' '"
      +       if x < num_tupel: 
      +        data=data + ","
      +        printline=printline + " + "
      +      data=data + " = coordinates" 
      +      printline=printline + ")\n"
      +      if debug == "y": App.Console.PrintMessage(data + "\n")
      +      if debug == "y": App.Console.PrintMessage(printline + "\n")
      +      # X1,Y1,Z1,X2,Y2,Z2,X3,Y3,Z3,X4,Y4,Z4 = coordinates
      +      exec(data) # coordinates to variables
      +      if debug == "y": exec(printline) # output input file
      +      #App.Console.PrintMessage(str(X1) + " " + str(Y1) + " " +str(Z1) + "\n")
      +      px=""
      +      pn="" # names of generated variables
      +      for x in range(1, num_tupel +1):
      +       if x < num_tupel:
      +        pn=pn + "p" + str(x) + ","
      +       else:
      +        pn=pn + "p" + str(x)
      +       data = "Z" + str(x) + " = " + str(i * step)  # Korrektur z= 0.0 auf aktuelle step
      +       if debug == "y": App.Console.PrintMessage(data + "\n")
      +       exec(data)
      +       px="p" + str(x) + "= FreeCAD.Vector(float(X" + str(x) + "),float(Y" + str(x) + "),float(Z" + str(x) + "))" 
      +       if debug == "y": App.Console.PrintMessage(px + "\n")
      +       exec(px)
      +      if debug == "y": App.Console.PrintMessage(pn + "\n")
      +      #p1 = FreeCAD.Vector(float(X1),float(Y1),float(Z1))
      +      #p2 = FreeCAD.Vector(float(X2),float(Y2),float(Z2))
      +      #p3 = FreeCAD.Vector(float(X3),float(Y3),float(Z3))
      +      #p4 = FreeCAD.Vector(float(X4),float(Y4),float(Z4))
      +      data="Draft.makeWire([" + pn + "],closed=True)"
      +      if debug == "y": App.Console.PrintMessage(data + "\n")
      +      exec(data)
      +      #Draft.makeWire([p1,p2,p3,p4,p5],closed=True)
      +      if left_right == "r": 
      +       i = i + 1
      +      else:
      +       i = i -1
      +    line = file.readline() 
      +file.close()
      +#
      +# List all objects of the document
      +names = objnames()    # list objectnames
      +App.Console.PrintMessage("names="+str(names) +"\n")
      +#extrude
      +extr="" # suffix for continues Extrude in commands
      +extrnames="Box Cut" #names of source object, because not consitend nameings in freecad
      +j=len(names.split())
      +n=0 #counter
      +if left_right == "r": 
      + l1 = 0
      + l2 = j
      + step = 1
      +else:
      + l1 = j
      + l2 = -1
      + step = -1
      +for x in range(l1, l2, step):
      + w=str(names.split(" ")[x])
      + if w[0:5] == "DWire":
      +  if debug == 'y':  App.Console.PrintMessage("w="+str(w) +"\n")
      +  data = 'f = FreeCAD.getDocument(docname).addObject("Part::Extrusion","Extrude' + str(extr)+ '")'
      +  if debug == "y": App.Console.PrintMessage(data + "\n")
      +  exec(data)
      +  data = 'f = App.getDocument(docname).getObject("Extrude' + str(extr) + '")'
      +  if debug == "y": App.Console.PrintMessage(data + "\n")
      +  exec(data)
      +  data = 'f.Base = App.getDocument(docname).getObject("' + str(w) + '")'
      +  if debug == "y": App.Console.PrintMessage(data + "\n")
      +  exec(data)
      +  data = 'f.DirMode = str("Custom")'
      +  if debug == "y": App.Console.PrintMessage(data + "\n")
      +  exec(data)
      +  data = 'f.Dir = App.Vector(0.000000000000000, 0.000000000000000, 1.000000000000000)'
      +  if debug == "y": App.Console.PrintMessage(data + "\n")
      +  exec(data)
      +  data = 'f.DirLink = None'
      +  if debug == "y": App.Console.PrintMessage(data + "\n")
      +  exec(data)
      +  data = 'f.LengthFwd = 180.000000000000000'
      +  if debug == "y": App.Console.PrintMessage(data + "\n")
      +  exec(data)
      +  data = 'f.LengthRev = 0.000000000000000'
      +  if debug == "y": App.Console.PrintMessage(data + "\n")
      +  exec(data)
      +  data = 'f.Solid = True'
      +  if debug == "y": App.Console.PrintMessage(data + "\n")
      +  exec(data)
      +  data = 'f.Reversed = False'
      +  if debug == "y": App.Console.PrintMessage(data + "\n")
      +  exec(data)
      +  data = 'f.Symmetric = False'
      +  if debug == "y": App.Console.PrintMessage(data + "\n")
      +  exec(data)
      +  data = 'f.TaperAngle = 0.000000000000000'
      +  if debug == "y": App.Console.PrintMessage(data + "\n")
      +  exec(data)
      +  data = 'f.TaperAngleRev = 0.000000000000000'
      +  if debug == "y": App.Console.PrintMessage(data + "\n")
      +  exec(data)
      + # data = 'App.getDocument(docname).Extrude' + str(extr) + '.Placement=App.Placement(App.Vector(0,0,360), #App.Rotation(App.Vector(0,0,1),0), App.Vector(0,0,0))'
      +  #if debug == "y": App.Console.PrintMessage(data + "\n")
      +  #exec(data)
      +  n = n + 1
      +  extr = str("%03d" % n)  # count extrude suffix
      +  extrnames=extrnames + " Extrude" + str("%03d" % x)
      +#
      +FreeCAD.ActiveDocument.recompute()
      +
      +

      Links

      + +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Macro_HealArcs.html b/localwiki/Macro_HealArcs.html new file mode 100644 index 0000000..9e30aa0 --- /dev/null +++ b/localwiki/Macro_HealArcs.html @@ -0,0 +1,90 @@ +Macro HealArcs

      Macro HealArcs

      + +
      + + + + + + + + + + + + + + + + + + + + + + + + + + +
      +

      Text-x-python.png HealArcs

      +
      Description +
      Sometimes arcs are transformed into BSplines, for example when scale operations have been applied to them. This macro recreates valid arcs from them. Useful before exporting to dxf +
      Author +
      Yorik +
      Links +
      Macros recipes
      How to install macros
      How to customize toolbars +
      Version +
      0.1 +
      Date last modification +
      2011-09-24 +
      +

      Contents

      + +
      + +
      +


      +

      Sometimes arcs are transformed into BSplines, for example when scale operations have been applied to them. This macro recreates valid arcs from them. Useful before exporting to dxf +


      +

      +
      try:
      +    import DraftGeomUtils as fcgeo
      +except:
      +    from draftlibs import fcgeo
      +import FreeCAD,FreeCADGui,Part
      +
      +sel = FreeCADGui.Selection.getSelection()
      +if not sel:
      +    FreeCAD.Console.PrintWarning("Select something first!")
      +else:
      +    removeList = []
      +    for obj in sel:
      +        ed = obj.Shape.Edges[0]
      +        arc = fcgeo.arcFromSpline(ed)
      +        if arc:
      +            Part.show(arc)
      +            removeList.append(obj.Name)
      +    FreeCAD.ActiveDocument.recompute()
      +    print "removing ",removeList
      +    for n in removeList:
      +        FreeCAD.ActiveDocument.removeObject(n) 
      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Macro_HighlightCommon.html b/localwiki/Macro_HighlightCommon.html new file mode 100644 index 0000000..d496586 --- /dev/null +++ b/localwiki/Macro_HighlightCommon.html @@ -0,0 +1,83 @@ +Macro HighlightCommon

      Macro HighlightCommon

      + +
      + + + + + + + + + + + + + + + + + + + + + + + + + + +
      +

      Text-x-python.png HightlightCommon

      +
      Description +
      Highlight common parts +
      Author +
      JMG +
      Links +
      Macros recipes
      How to install macros
      How to customize toolbars +
      Version +
      1.0 +
      Date last modification +
      2015-09-24 +
      +

      + +
      +


      +

      +

      Description

      +

      Highlight common parts by showing the common shape in red and setting half-transparency on original parts (the original objects are not modified) +

      Volume common of objects selected +

      +

      Script

      +

      Macro_HighlightCommon.FCMacro +

      The code is visible on Github: Utility/HighlightCommon.FCMacro. +

      +

      Links

      + +


      +

      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Macro_HighlightDifference.html b/localwiki/Macro_HighlightDifference.html new file mode 100644 index 0000000..58b55ac --- /dev/null +++ b/localwiki/Macro_HighlightDifference.html @@ -0,0 +1,111 @@ +Macro HighlightDifference

      Macro HighlightDifference

      + +
      + + + + + + + + + + + + + + + + + + + + + + + + + + +
      +

      HighlightDifference.png HightlightDifference

      +
      Description +
      Compute the difference between two shapes +
      Author +
      Gaël Ecorchard +
      Links +
      Macros recipes
      How to install macros
      How to customize toolbars +
      Version +
      1.0 +
      Date last modification +
      2015-09-24 +
      +

      + +
      +


      +

      +

      Description

      +

      Compute the difference between two shapes. Additions are marked red, removals are marked green. Both original parts will be half transparent. The volume of the additions and removals are printed in the console. +

      Result difference twoo objects created +

      +

      Example

      +
      + +
      +
      +


      +

      +

      Script

      +

      The code is visible on Github: Utility/HighlightDifference.FCMacro. +

      +

      Links

      + +


      +

      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Macro_Image_Scaling.html b/localwiki/Macro_Image_Scaling.html new file mode 100644 index 0000000..0444f05 --- /dev/null +++ b/localwiki/Macro_Image_Scaling.html @@ -0,0 +1,220 @@ +Macro Image Scaling

      Macro Image Scaling

      + +
      + + + + + + + + + + + + + + + + + + + + + + + + + + +
      +

      Text-x-python.png Image Scaling

      +
      Description +
      Scaling of drawings +
      Author +
      JAndersM +
      Links +
      Macros recipes
      How to install macros
      How to customize toolbars +
      Version +
      1.0 +
      Date last modification +
      2016-01-19 +
      +

      + +
      +


      +

      +

      Description

      +

      Macro for easy scaling of drawings, graphics, diagrams, blueprints and similar 2D images in the Image workbench. It works for images imported as planar images in the 3D space. +

      Note: For photos of objects, or images involving objects lying at different distances from the viewpoint, the effect of Parallax (distortion due to "difference in the apparent position of an object viewed along two different lines of sight") must be kept in mind. In the following diagram the 2 blue objects are co-planar with the plane being perpendicular to the user viewpoint and scaling can be used: +

      Perspective.png +

      In the second diagram, the red and green objects are not co-planar with the 2 blue objects and scaling can not be used. Additionally the fact that the red object is co-planar with 1 blue object can not be determined from the single diagram based on the user viewpoint: +

      Parallax.jpg +

      +

      Use

      +
      • run the Macro - a dialogue pops up
      • +
      • click on the two points in the image that you know the true distance between
      • +
      • Select the Image Plane in the tree view
      • +
      • Enter the true distance in mm between the points in the text field of the dialogue and click OK
      • +
      • The image is scaled and the dialogue closes.
      +

      Script

      +
      import FreeCADGui, FreeCAD, Part
      +import math
      +import pivy.coin as pvy
      +from PySide import QtCore, QtGui
      +import DraftTrackers, Draft
      +
      +__title__   = "Macro Image Scaling"
      +__author__  = "JAndersM"
      +__url__     = "http://www.freecadweb.org/index-fr.html"
      +__version__ = "00.01"
      +__date__    = "19/01/2016"
      +
      +try:
      +    _fromUtf8 = QtCore.QString.fromUtf8
      +except AttributeError:
      +    def _fromUtf8(s):
      +        return s
      +
      +try:
      +    _encoding = QtGui.QApplication.UnicodeUTF8
      +    def _translate(context, text, disambig):
      +        return QtGui.QApplication.translate(context, text, disambig, _encoding)
      +except AttributeError:
      +    def _translate(context, text, disambig):
      +        return QtGui.QApplication.translate(context, text, disambig)
      +
      +def distance(p1,p2):
      +    dx=p2[0]-p1[0]
      +    dy=p2[1]-p1[1]
      +    dz=p2[2]-p1[2]
      +    return math.sqrt(dx*dx+dy*dy+dz*dz)
      +    
      +class Ui_Dialog(object):
      +    def setupUi(self, Dialog):
      +        self.view = FreeCADGui.ActiveDocument.ActiveView
      +        self.stack = []
      +        self.callback = self.view.addEventCallbackPivy(pvy.SoMouseButtonEvent.getClassTypeId(),self.getpoint)
      +        self.callmouse=self.view.addEventCallbackPivy(pvy.SoLocation2Event.getClassTypeId(),self.getmousepoint)
      +        self.distance=0
      +        self.dialog=Dialog
      +        Dialog.setObjectName(_fromUtf8("Dialog"))
      +        Dialog.setWindowFlags(QtCore.Qt.WindowStaysOnTopHint)
      +        Dialog.resize(300, 102)
      +        self.buttonBox = QtGui.QDialogButtonBox(Dialog)
      +        self.buttonBox.setGeometry(QtCore.QRect(50, 70, 191, 32))
      +        self.buttonBox.setOrientation(QtCore.Qt.Horizontal)
      +        self.buttonBox.setStandardButtons(QtGui.QDialogButtonBox.Cancel.__or__(QtGui.QDialogButtonBox.Ok))
      +        self.buttonBox.setObjectName(_fromUtf8("buttonBox"))
      +        self.buttonBox.button(QtGui.QDialogButtonBox.Ok).setEnabled(False)
      +        self.label = QtGui.QLabel(Dialog)
      +        self.label.setGeometry(QtCore.QRect(30, 10, 66, 17))
      +        self.label.setObjectName(_fromUtf8("label"))
      +        self.lineEdit = QtGui.QLineEdit(Dialog)
      +        self.lineEdit.setGeometry(QtCore.QRect(100, 10, 113, 29))
      +        self.lineEdit.setObjectName(_fromUtf8("lineEdit"))
      +        self.label1 = QtGui.QLabel(Dialog)
      +        self.label1.setGeometry(QtCore.QRect(20, 45, 260, 17))
      +        self.label1.setObjectName(_fromUtf8("label1"))
      +        self.retranslateUi(Dialog)
      +        QtCore.QObject.connect(self.buttonBox, QtCore.SIGNAL(_fromUtf8("accepted()")), self.accept)
      +        QtCore.QObject.connect(self.buttonBox, QtCore.SIGNAL(_fromUtf8("rejected()")), self.reject)
      +        QtCore.QMetaObject.connectSlotsByName(Dialog)
      +        self.tracker = DraftTrackers.lineTracker(scolor=(1,0,0))
      +        self.tracker.raiseTracker()
      +        self.tracker.on()
      +        self.dialog.show()
      +
      +    def retranslateUi(self, Dialog):
      +        Dialog.setWindowTitle(_translate("Dialog", "Dialog", None))
      +        self.label.setText(_translate("Dialog", "Distance", None))
      +        self.label1.setText(_translate("Dialog", "Select first point", None))
      +        
      +    def accept(self):
      +        sel = FreeCADGui.Selection.getSelection()
      +        try:
      +            locale=QtCore.QLocale.system()
      +            d, ok = locale.toFloat(self.lineEdit.text())
      +            if not ok:
      +                raise ValueError
      +            s=d/self.distance
      +            sel[0].XSize.Value=sel[0].XSize.Value*s
      +            sel[0].YSize.Value=sel[0].YSize.Value*s
      +            FreeCAD.Console.PrintMessage("Scale="+str(s))
      +            self.tracker.off()
      +            self.tracker.finalize()
      +            self.dialog.hide()
      +        except ValueError, ZeroDivisionError:
      +            self.label1.setText(_translate("Dialog", "<font color='red'>Enter distance</font>", None))
      +            return
      +        except IndexError, AttributeError:
      +            self.label1.setText(_translate("Dialog", "<font color='red'>Select ImagePlane</font>", None))
      +            return
      +        
      +    def reject(self):
      +        self.stack=[]
      +        self.view.removeEventCallbackPivy(pvy.SoMouseButtonEvent.getClassTypeId(),self.callback)
      +        self.view.removeEventCallbackPivy(pvy.SoLocation2Event.getClassTypeId(),self.callmouse)
      +        self.tracker.off()
      +        self.tracker.finalize()
      +        self.dialog.hide()
      +    
      +    def getmousepoint(self, event_cb):
      +        event = event_cb.getEvent()
      +        if len(self.stack)==1:
      +            pos = event.getPosition()
      +            point = self.view.getPoint(pos[0],pos[1])
      +            self.tracker.p2(point)
      +               
      +    def getpoint(self,event_cb):
      +        event = event_cb.getEvent()           
      +        if event.getState() == pvy.SoMouseButtonEvent.DOWN:
      +            pos = event.getPosition()
      +            point = self.view.getPoint(pos[0],pos[1])
      +            self.stack.append(point)
      +            self.label1.setText(_translate("Dialog", "Select second point", None))
      +            if len(self.stack)==1:
      +                self.tracker.p1(point)
      +            elif len(self.stack) == 2:
      +                self.distance=distance(self.stack[0], self.stack[1])
      +                self.tracker.p2(point)
      +                self.view.removeEventCallbackPivy(pvy.SoMouseButtonEvent.getClassTypeId(),self.callback)
      +                self.view.removeEventCallbackPivy(pvy.SoLocation2Event.getClassTypeId(),self.callmouse)
      +                self.buttonBox.button(QtGui.QDialogButtonBox.Ok).setEnabled(True)
      +                self.label1.setText(_translate("Dialog", "Select Image Plane and type distance", None))
      +                
      +#Init               
      +d = QtGui.QWidget()
      +ui = Ui_Dialog()
      +ui.setupUi(d) 
      +

      Links

      + +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Macro_Install_HowTo_09.png b/localwiki/Macro_Install_HowTo_09.png new file mode 100644 index 0000000..c4642f5 Binary files /dev/null and b/localwiki/Macro_Install_HowTo_09.png differ diff --git a/localwiki/Macro_Install_HowTo_10.png b/localwiki/Macro_Install_HowTo_10.png new file mode 100644 index 0000000..ae6e447 Binary files /dev/null and b/localwiki/Macro_Install_HowTo_10.png differ diff --git a/localwiki/Macro_Install_HowTo_11.png b/localwiki/Macro_Install_HowTo_11.png new file mode 100644 index 0000000..60a2c3d Binary files /dev/null and b/localwiki/Macro_Install_HowTo_11.png differ diff --git a/localwiki/Macro_Install_HowTo_12.png b/localwiki/Macro_Install_HowTo_12.png new file mode 100644 index 0000000..e8df6b8 Binary files /dev/null and b/localwiki/Macro_Install_HowTo_12.png differ diff --git a/localwiki/Macro_Install_HowTo_13.png b/localwiki/Macro_Install_HowTo_13.png new file mode 100644 index 0000000..5b58b25 Binary files /dev/null and b/localwiki/Macro_Install_HowTo_13.png differ diff --git a/localwiki/Macro_JointWire.html b/localwiki/Macro_JointWire.html new file mode 100644 index 0000000..74295f6 --- /dev/null +++ b/localwiki/Macro_JointWire.html @@ -0,0 +1,130 @@ +Macro JointWire

      Macro JointWire

      + +
      + + + + + + + + + + + + + + + + + + + + + + + + + + +
      +

      Text-x-python.png JointWire

      +
      Description +
      This macro allow to find and joint all non connected edge to the closest non connected one using a line. It take a shape matrix in entry ( [shape1,shape2,...]) +
      Author +
      Tremblou +
      Links +
      Macros recipes
      How to install macros
      How to customize toolbars +
      Version +
      1.0 +
      Date last modification +
      2011-08-24 +
      +

      Contents

      + +
      + +
      +


      +

      This macro allow to find and joint all non connected edge to the closest non connected one using a line. It take a shape matrix in entry ( [shape1,shape2,...]) +


      +

      +
      def findWires(edges):
      +    def verts(shape):
      +                return [shape.Vertexes[0].Point,shape.Vertexes[-1].Point]
      +        def group(shapes):
      +                shapesIn = shapes[:]
      +                pointTst = []
      +        pointOut =[]
      +        for s in shapesIn :
      +            pointTst=pointTst+[s.Vertexes[0].Point]
      +            pointTst=pointTst+[s.Vertexes[-1].Point]
      +        print pointTst               
      +        changed = False
      +                for s in shapesIn:
      +                        if len(s.Vertexes) < 2:
      +                print "one vertex, its a circle, just add"
      +                        else:                             
      +                                for v in verts(s):
      +                    twoDot=0
      +                                        for vv in pointTst:
      +                                                if v == vv:
      +                            twoDot=twoDot+1                           
      +                        if v==vv and twoDot==2 :                   
      +                            changed = True
      +                            print "found matching vert"
      +                            break
      +                                    if twoDot<2:
      +                        print "didn't find any matching vert..."
      +                        pointOut.append(v)
      +         print "Dots non connected", pointOut
      +                return(changed,pointOut)
      +    def joint(point):
      +        for p in range(len(point)/2) :
      +            print point
      +            deltI=Part.Vertex(100,100,100).Point
      +            pos=1
      +            for pp in range(len(point)-1) :
      +                print "position:",pp+1
      +                if len(point)-1>1:
      +                    deltN=(point[0]-point[pp+1])
      +                    if deltN.Length<deltI.Length:
      +                        deltI=deltN
      +                        pos=pp+1
      +                        print "changement",pos
      +                else:
      +                    pos=1   
      +            print "points a joindre",point[0],point[pos]
      +            if point[0]!=point[pos]:
      +                Part.show(Part.makePolygon([point[0],point[pos]]))
      +            else:
      +                print "WARNING les points ont la meme valeurs "
      +            point.pop(0)
      +            point.pop(pos-1)
      +        point=0 #to have a return normally void
      +        return(point)
      +    working = True
      +        edgeSet = edges
      +    result = group(edgeSet)
      +        working = result[0]
      +        edgeSet = result[1]
      +    joint(result[1])
      +        return result[1] 
      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Macro_Line_Length.html b/localwiki/Macro_Line_Length.html new file mode 100644 index 0000000..9a450f6 --- /dev/null +++ b/localwiki/Macro_Line_Length.html @@ -0,0 +1,105 @@ +Macro Line Length

      Macro Line Length

      + +
      + + + + + + + + + + + + + + + + + + + + + + + + + + +
      +

      Text-x-python.png Macro Line Length

      +
      Description +
      Creates a line giving as an argument the XYZ coordinates, length, and angle. +
      Author +
      mario52 +
      Links +
      Macros recipes
      How to install macros
      How to customize toolbars +
      Version +
      02.00 +
      Date last modification +
      2014-08-08 +
      +

      + +
      +


      +

      This small macro create a line giving as an argument the XYZ coordinates, length, and angle +

      +

      Use

      +

      Can be used from the Freecad macro editor. +

      If the macro is copied in the Python console, you can you can use it by: +

      +
      >>> line_length(x1 = 0, y1 = 0, z1 = 0, length = 10, angle = 45)
      +

      or choice +

      +
      >>> line_length(x1 = 10, y1 = 10, z1 = 0, length = 50)
      +
      +>>> line_length(length = 50, angle = 45)
      +

      the default values are : x1 = 0, y1 = 0, z1 = 0, length = 10, angle = 0 +

      +

      Script

      +

      Macro Line_Length.py +

      +
      # -*- coding: utf-8 -*-
      +# créer une ligne avec une coordonnée une longueur et un angle sur le plan X Y
      +# create line with coordinate length and angle to plane X Y
      +import FreeCAD, FreeCADGui, Draft
      +from math import cos, sin, radians
      +#from FreeCAD import Base
      + 
      +def line_length(x1 = 0.0, y1 = 0.0, z1 = 0.0, length = 10.0, angle = 0.0):
      +    x2 = x1 + (length * cos(radians(angle)))
      +    y2 = y1 + (length * sin(radians(angle)))
      +    z2 = z1 #+ ()
      +    Draft.makeWire([FreeCAD.Vector(x1,y1,z1),FreeCAD.Vector(x2,y2,z2)])
      + 
      +x1 = 0.0          # Edit coordinate x1 origin
      +y1 = 0.0          # Edit coordinate y1 origin
      +z1 = 0.0          # Edit coordinate z1 origin
      +length = 50.0       # Edit length
      +angle  = 45.0       # Edit angle plane XY
      + 
      +line_length(x1, y1, z1, length, angle)
      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Macro_Loft.html b/localwiki/Macro_Loft.html new file mode 100644 index 0000000..2593e67 --- /dev/null +++ b/localwiki/Macro_Loft.html @@ -0,0 +1,111 @@ +Macro Loft

      Macro Loft

      + +
      + + + + + + + + + + + + + + + + + + + + + + + + + + +
      +

      FCCreaLoft.png Macro Loft

      +
      Description +
      Creates a loft wit wires selected. +
      Author +
      Mario52 +
      Links +
      Macros recipes
      How to install macros
      How to customize toolbars +
      Version +
      00.03 +
      Date last modification +
      2016-02-09 +
      +

      + +
      +


      +

      +

      Description

      +

      specially written for easy lofting with lines generated by the Macro Texture (but may be suitable and used for common lofts)
      +

      Texture_001_Logo +

      +
      +


      +

      +

      Use

      +

      Copy the macro and the icon in your macro directory. +

      +
      • Sort : Sort the data entries.
      • +
      • Reverse : Reverse the order of data.
      • +
      • Reset / Upgrade: This button as many function: +
        1. If any selection in 3Dview this button Upgrade is displayed.
          Select your object in the 3Dview or in the Combo view and click this button for upgrade the data in the macro, the button changes in Reset.
        2. +
        3. If one or many object(s) are selected before the run macro this button Reset is displayed.
          Alls objects selected are displayed in the macro window.
          After having Sort or Reverse the data displayed, this button Reset is used to return to the original order.
          If you click in the 3DView or unselected all objects this button is used for reset to macro.
          If you adding one or more object(s) in the list this button is used.
      • +
      • Select all : Select all objects in the document.
      • +
      • SpinBox : Increment the jump x Elements (Default 1 all objects are used).
      • +
      • Quit : Quit the macro.
      • +
      • CheckBox If the CheckBox is checked the work progress is displayed if not only the ProgressBar work (this method is faster) (Checked by default).
      • +
      • Launch the Lofting : Launch the Lofting and reset the macro. The number of selection are displayed and the real number lofted if the spinBox "jump" is used
      +

      The interface

      +
      FCCreaLoft002
      +
      +

      Script

      +

      The icons for you toolBar FCCreaLoft.png +

      Download the macro to Gist Macro_FCCreaLoft.FCMacro +

      +

      Links

      +

      The forum discussion Texture +

      The Macro Texture +

      +

      Version

      +

      ver 00.00 : 06/02/2016 +

      ver 00.02 : 09/02/2016 : Add button "Select all" and little option displayed in the button Launch (number selections) and (real number loft) +

      ver 00.03 : 09/02/2016 : minor (display on button) +

      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Macro_MacroMenu.html b/localwiki/Macro_MacroMenu.html new file mode 100644 index 0000000..f26b55b --- /dev/null +++ b/localwiki/Macro_MacroMenu.html @@ -0,0 +1,99 @@ +Macro MacroMenu

      Macro MacroMenu

      + +
      + + + + + + + + + + + + + + + + + + + + + + + + + + +
      +

      Text-x-python.png Macro MacroMenu

      +
      Description +
      Adds the macros found in the macros folder to the FreeCAD Macros menu +
      Author +
      Yorik +
      Links +
      Macros recipes
      How to install macros
      How to customize toolbars +
      Version +
      1.0 +
      Date last modification +
      2014-08-07 +
      +

      Contents

      + +
      + +
      +


      +


      +This code was part of the Draft Module and has been removed cf issue #490. +


      +Macro MacroMenu.FCMacro +

      +
      import os,FreeCAD,FreeCADGui
      + 
      +macrosList = []
      +macroPath = FreeCAD.ParamGet("User parameter:BaseApp/Preferences/Macro").GetString("MacroPath") 
      + 
      +class MacroCommand():
      +    "A template for macro commands"
      +    def __init__(self,macroname):
      +        self.macroname = macroname
      + 
      +    def GetResources(self):
      +        return {'Pixmap'  : 'Draft_Macro',
      +                'MenuText': self.macroname,
      +                'ToolTip': 'Executes the '+self.macroname+' macro'}
      + 
      +    def Activated(self):
      +        target = macroPath+os.sep+self.macroname+'.FCMacro'
      +        if os.path.exists(target): execfile(target)
      +            
      +if macroPath and os.path.isdir(macroPath):
      +    macros = []
      +    for f in os.listdir(macroPath):
      +        if ".FCMacro" in f:
      +            macros.append(f[:-8])
      +    for m in macros:
      +        cmd = 'Macro_'+m
      +        FreeCADGui.addCommand(cmd,MacroCommand(m))
      +        macrosList.append(cmd) 
      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Macro_Make_Arc_3_Points.html b/localwiki/Macro_Make_Arc_3_Points.html new file mode 100644 index 0000000..ea90c38 --- /dev/null +++ b/localwiki/Macro_Make_Arc_3_Points.html @@ -0,0 +1,119 @@ +Macro Make Arc 3 Points

      Macro Make Arc 3 Points

      + +
      + + + + + + + + + + + + + + + + + + + + + + + + + + +
      +

      Macro Make Arc 3 Points.png Macro Make Arc 3 Points

      +
      Description +
      Creates a arc from 3 selected points. +
      Author +
      Mario52 +
      Links +
      Macros recipes
      How to install macros
      How to customize toolbars +
      Version +
      01.00 +
      Date last modification +
      2016-07-14 +
      +

      + +
      +


      +

      +

      Description

      +

      This macro creates a arc on 3 selected points. +

      +

      Use

      +

      Launch the macro, select 3 points, the arc is created and the coordinates and the length of the arc are displayed in the report view. +

      (PS: It is not required to hold down the Ctrl key) +

      +

      Script

      +

      The icon for the toolBar Macro Make Arc 3 Points.png +

      Macro_Make_Arc_3_Points.FCMacro +

      +
      # -*- coding: utf-8 -*-
      +from FreeCAD import Base
      +
      +__title__   = "Macro_Make_Arc_3_points"
      +__author__  = "Mario52"
      +__url__     = "http://www.freecadweb.org/index-fr.html"
      +__version__ = "00.01"
      +__date__    = "14/07/2016"
      +
      +global selected; selected = []
      +App = FreeCAD
      +
      +class SelObserver:
      +    print "Create Arc to 3 points ..."
      +    def addSelection(self,doc,obj,sub,pnt):  # Selection 
      +        global selected
      +        selected.append(pnt)
      +        if len(selected) == 1:
      +            print "Point 1 : ",FreeCAD.Vector(selected[0])
      +        elif len(selected) == 2:
      +            print "Point 2 : ",FreeCAD.Vector(selected[1])
      +        elif len(selected) == 3:
      +            print "Point 3 : ",FreeCAD.Vector(selected[2])
      +            try:
      +                C1 = Part.Arc(FreeCAD.Vector(selected[0]),FreeCAD.Vector(selected[1]),FreeCAD.Vector(selected[2]))
      +                S1 = Part.Shape([C1])
      +                W = Part.Wire(S1.Edges)
      +                Part.show(W)
      +                App.ActiveDocument.ActiveObject.Label   = "Arc_3_Points"
      +                print "Length  : ",W.Length
      +            except Exception:
      +                print "Three points are collinear or bad selection"
      +            del selected[:]
      +            FreeCADGui.Selection.removeObserver(s)
      +            print "End Make_Arc_3_Points"
      +            print "_____________________"
      +
      +s=SelObserver()
      +FreeCADGui.Selection.addObserver(s) 
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Macro_Make_Circle_3_Points.html b/localwiki/Macro_Make_Circle_3_Points.html new file mode 100644 index 0000000..14c3a28 --- /dev/null +++ b/localwiki/Macro_Make_Circle_3_Points.html @@ -0,0 +1,696 @@ +Macro Make Circle 3 Points

      Macro Make Circle 3 Points

      + +
      + + + + + + + + + + + + + + + + + + + + + + + + + + +
      +

      Macro Draft Circle 3 Points.png Macro Make Circle 3 Points

      +
      Description +
      Creates a circle from 3 points or shapes selected. +
      Author +
      Mario52 +
      Links +
      Macros recipes
      How to install macros
      How to customize toolbars +
      Version +
      1.0 +
      Date last modification +
      2014-08-08 +
      +

      + +
      +


      +

      +

      Description

      +

      This macro creates a circle circumscribed on 3 selected points, orthogonal manner or in 3D at the option space. Points can be objects such as cubes, cylinders,... then selected coordinates will be the centre of these forms. +


      +Circle built on 3 selected points +

      +
      +

      Use

      +

      Select 3 points, or forms in the 3D view and run the macro.
      +If the shape is a line, the coordinate will be the center of the line. +

      Circle_on_3_points +

      +
      +


      +

      +

      Options

      +

      Mode :

      +

      Defaut : +

      +
      Mode by default, creates a circle on the three points or shapes in 3d space.
      +
      The order of selection of fear forms influencing the angle AXIS and reverse the inclination of the circle. In this case, reverse or change the order of selection of the shapes.
      +
      Coordinates X, Y, Z value 0 or alignment does not allow calculation, can return a division by zero error, and translated by The three points are aligned
      +

      Vue Face : +

      +
      Creates the circle in the front views of the form chosen, 1, 2 or 3
      +

      Vue Dessus : +

      +
      Creates the circle in the top on the form chosen view, 1, 2 or 3
      +

      Vue Droite : +

      +
      Creates the circle in the view of right on the form chosen, 1, 2 or 3
      +

      Alignement sur :

      +

      Forme 1, 2, 3 +

      +
      Forms, in the order of their selections.
      +

      Afficher le centre :

      +
      If this box is checked, a point on the centre of the built circle will be created
      +

      Associer les couleurs

      +
      If this box is checked, the circle will take the colour of the relevant view, +
      View-Top (X,Y) = Blue(axe Z)
      +
      View-Front (Z,X) = Green(Axe Y)
      +
      View-Left (Z,Y) = Red(Axe X)
      +


      +

      +
      +
      + +
      +


      +

      +

      Script

      +

      The file should be copied to " C:/Program Files/FreeCAD0.13/ " If you want to put it in another directory, modify the path to line 53 +

      +
      path = FreeCAD.ConfigGet("AppHomePath") # chemin 
      +

      View-Top.png View-Left.png View-Front.png View-C3P.png +

      The three icons must be in the same directory as the module.
      +To download them, resting your mouse over the icon and then right-click and save image as... +

      The file Make_Circle_3_Points/fr.FCMacro: +


      +

      +
      # -*- coding: utf-8 -*-
      +# Cercle sur 3 points.py
      +# create a circle from 3 points selected
      +# combination of the two programs 'create a circle from 3 points selected'
      +# with as options (orthogonal) circle can be built on a choice plans
      +# to coordinate one of the three selected choice shapes
      +# mode by default, creates the circle in 3D space
      +# the options create the circle of orthogonal way on the map and view the choice
      +# with the creation of a central color related to the axes Y/N Y/N
      +# 04/03/2013 # 24/03/2013 # 08/08/2014 by mario52
      +# the formula adapted (with permission of its author) by "mario52" for orthogonal circles comes from
      +# http://www-obs.univ-lyon1.fr/labo/fc/Ateliers_archives/ateliers_2005-06/cercle_3pts.pdf
      +# read the note in pdf, on the order of selection points,
      +# If the formula returns an error (example the 3 points in the same alignment)
      +# the formula adapted by "galou_breizh" for the cecle in 3D space comes from
      +# http://en.wikipedia.org/wiki/Circumscribed_circle
      +# the window is always visible and allows you to work on other programs
      +# as for example to select other items in FreeCAD
      +
      +#08/08/2014 PyQt4 and PySide
      +
      +#OS: Windows Vista
      +#Word size: 32-bit
      +#Version: 0.14.3700 (Git)
      +#Branch: releases/FreeCAD-0-14
      +#Hash: 32f5aae0a64333ec8d5d160dbc46e690510c8fe1
      +#Python version: 2.6.2
      +#Qt version: 4.5.2
      +#Coin version: 3.1.0
      +#SoQt version: 1.4.1
      +#OCC version: 6.5.1
      +
      +try:
      +    import PyQt4
      +    from PyQt4 import QtCore, QtGui
      +except Exception:
      +    import PySide
      +    from PySide import QtCore, QtGui
      +
      +import Draft, Part, FreeCAD, math, PartGui, FreeCADGui
      +from math import sqrt, pi, sin, cos, asin
      +from FreeCAD import Base
      + 
      +                    # vueChoix = 0 et alignerSur = 0 , mode par défaut
      +global vueChoix# choix de la vue Dessus=1 XY, vue Face=2 ZX, vue Droite=3 ZY (Orthogonal)
      +global alignerSur   # aligne le cercle sur une forme au choix (1,2 ou 3) ou sur Z=0 (Orthogonal)
      +global afficherPoint# affiche le point central du cercle
      +global colorer     # colorer suivant l'axe 1=Ok 0=Couleur courante uniquement Orthogonal !
      +vueChoix = 0
      +alignerSur = 0
      +afficherPoint = 1
      +colorer = 1
      + 
      +try:
      +    _fromUtf8 = QtCore.QString.fromUtf8
      +except AttributeError:
      +    def _fromUtf8(s):
      +        return s
      + 
      +try:
      +    _encoding = QtGui.QApplication.UnicodeUTF8
      +    def _translate(context, text, disambig):
      +        return QtGui.QApplication.translate(context, text, disambig, _encoding)
      +except AttributeError:
      +    def _translate(context, text, disambig):
      +        return QtGui.QApplication.translate(context, text, disambig)
      + 
      +class Ui_MainWindow(object):
      + 
      +    def __init__(self, MainWindow):
      +        self.window = MainWindow
      +        path = FreeCAD.ConfigGet("AppHomePath") # chemin 
      + 
      +        MainWindow.setObjectName(_fromUtf8("MainWindow"))
      +        MainWindow.resize(490, 302)
      +        MainWindow.setWindowIcon(QtGui.QIcon(path+'View-C3P.png'))
      +        self.centralWidget = QtGui.QWidget(MainWindow)
      +        self.centralWidget.setObjectName(_fromUtf8("centralWidget"))
      + 
      +        self.groupBox = QtGui.QGroupBox(self.centralWidget)
      +        self.groupBox.setGeometry(QtCore.QRect(20, 10, 130, 161))
      +        self.groupBox.setObjectName(_fromUtf8("groupBox_1"))
      + 
      +        self.radioButton_1 = QtGui.QRadioButton(self.groupBox)
      +        self.radioButton_1.setGeometry(QtCore.QRect(10, 30, 130, 20))
      +        self.radioButton_1.setChecked(True)
      +        self.radioButton_1.setObjectName(_fromUtf8("radioButton_1"))
      +        self.radioButton_1.clicked.connect(self.on_radioButton_1_clicked) #connection radioButton_1
      +        self.radioButton_1.setToolTip(_translate("MainWindow", "Cercle sur 3 points dans l'espace", None))
      + 
      +        self.radioButton_2 = QtGui.QRadioButton(self.groupBox)
      +        self.radioButton_2.setGeometry(QtCore.QRect(10, 60, 130, 20))
      +        self.radioButton_2.setObjectName(_fromUtf8("radioButton_2"))
      +        self.radioButton_2.clicked.connect(self.on_radioButton_2_clicked) #connection radioButton_2
      +        self.radioButton_2.setToolTip(_translate("MainWindow", "Cercle orthogonal sur la vue de face", None))
      +        #self.image_01 = "C:\Program Files\FreeCAD0.13\View-Front.png"
      +        self.image_01 = path+"View-Front.png"
      +        icon01 = QtGui.QIcon() 
      +        icon01.addPixmap(QtGui.QPixmap(self.image_01),QtGui.QIcon.Normal, QtGui.QIcon.Off)
      +        self.radioButton_2.setIcon(icon01) 
      + 
      +        self.radioButton_3 = QtGui.QRadioButton(self.groupBox)
      +        self.radioButton_3.setGeometry(QtCore.QRect(10, 90, 130, 20))
      +        self.radioButton_3.setObjectName(_fromUtf8("radioButton_3"))
      +        self.radioButton_3.clicked.connect(self.on_radioButton_3_clicked) #connection radioButton_3
      +        self.radioButton_3.setToolTip(_translate("MainWindow", "Cercle orthogonal sur la vue de dessus", None))
      +        #self.image_02 = "C:\Program Files\FreeCAD0.13\View-Top.png"
      +        self.image_02 = path+"View-Top.png"
      +        icon02 = QtGui.QIcon() 
      +        icon02.addPixmap(QtGui.QPixmap(self.image_02),QtGui.QIcon.Normal, QtGui.QIcon.Off)
      +        self.radioButton_3.setIcon(icon02) 
      + 
      +        self.radioButton_4 = QtGui.QRadioButton(self.groupBox)
      +        self.radioButton_4.setGeometry(QtCore.QRect(10, 120, 130, 20))
      +        self.radioButton_4.setObjectName(_fromUtf8("radioButton_4"))
      +        self.radioButton_4.clicked.connect(self.on_radioButton_4_clicked) #connection radioButton_4
      +        self.radioButton_4.setToolTip(_translate("MainWindow", "Cercle orthogonal sur la vue de droite", None))
      +        #self.image_03 = "C:\Program Files\FreeCAD0.13\View-Left.png"
      +        self.image_03 = path+"View-Left.png"
      +        icon03 = QtGui.QIcon() 
      +        icon03.addPixmap(QtGui.QPixmap(self.image_03),QtGui.QIcon.Normal, QtGui.QIcon.Off)
      +        self.radioButton_4.setIcon(icon03) 
      + 
      +        self.groupBox_2 = QtGui.QGroupBox(self.centralWidget)
      +        self.groupBox_2.setGeometry(QtCore.QRect(170, 10, 120, 161))
      +        self.groupBox_2.setObjectName(_fromUtf8("groupBox_2"))
      + 
      +        self.radioButton_5 = QtGui.QRadioButton(self.groupBox_2)
      +        self.radioButton_5.setGeometry(QtCore.QRect(10, 30, 95, 20))
      +        self.radioButton_5.setChecked(True)
      +        self.radioButton_5.setObjectName(_fromUtf8("radioButton_5"))
      +        self.radioButton_5.clicked.connect(self.on_radioButton_5_clicked) #connection radioButton_5
      +        self.radioButton_5.setToolTip(_translate("MainWindow", "Cercle sur 3 points dans l'espace", None))
      + 
      +        self.radioButton_6 = QtGui.QRadioButton(self.groupBox_2)
      +        self.radioButton_6.setGeometry(QtCore.QRect(10, 60, 95, 20))
      +        self.radioButton_6.setObjectName(_fromUtf8("radioButton_6"))
      +        self.radioButton_6.clicked.connect(self.on_radioButton_6_clicked) #connection radioButton_6
      +        self.radioButton_6.setToolTip(_translate("MainWindow", "Cercle orthogonal sur la forme 1", None))
      + 
      +        self.radioButton_7 = QtGui.QRadioButton(self.groupBox_2)
      +        self.radioButton_7.setGeometry(QtCore.QRect(10, 90, 95, 20))
      +        self.radioButton_7.setObjectName(_fromUtf8("radioButton_7"))
      +        self.radioButton_7.clicked.connect(self.on_radioButton_7_clicked) #connection radioButton_7
      +        self.radioButton_7.setToolTip(_translate("MainWindow", "Cercle orthogonal sur la forme 2", None))
      + 
      +        self.radioButton_8 = QtGui.QRadioButton(self.groupBox_2)
      +        self.radioButton_8.setGeometry(QtCore.QRect(10, 120, 95, 20))
      +        self.radioButton_8.setObjectName(_fromUtf8("radioButton_8"))
      +        self.radioButton_8.clicked.connect(self.on_radioButton_8_clicked) #connection radioButton_8
      +        self.radioButton_8.setToolTip(_translate("MainWindow", "Cercle orthogonal sur la forme 3", None))
      + 
      +        self.checkBox_1 = QtGui.QCheckBox(self.centralWidget)
      +        self.checkBox_1.setGeometry(QtCore.QRect(20, 190, 140, 20))
      +        self.checkBox_1.setChecked(True)
      +        self.checkBox_1.setObjectName(_fromUtf8("checkBox_1"))
      +        self.checkBox_1.setToolTip(_translate("MainWindow", "Affiche un point sur le centre du cercle", None))
      +#        self.checkBox_1.clicked.connect(self.on_checkBox_1_clicked) #connection checkBox_1
      + 
      +        self.checkBox_2 = QtGui.QCheckBox(self.centralWidget)
      +        self.checkBox_2.setGeometry(QtCore.QRect(170, 190, 150, 20))
      +        self.checkBox_2.setChecked(True)
      +        self.checkBox_2.setObjectName(_fromUtf8("checkBox_2"))
      +        self.checkBox_2.setToolTip(_translate("MainWindow", "Associe la couleur du cercle à la couleur des axes X,Y,Z (Orthogonal)", None))
      +#        self.checkBox_2.clicked.connect(self.on_checkBox_2_clicked) #connection checkBox_1
      + 
      +        self.lineEdit_1 = QtGui.QLineEdit(self.centralWidget)
      +        self.lineEdit_1.setGeometry(QtCore.QRect(320, 30, 151, 22))
      +        self.lineEdit_1.setObjectName(_fromUtf8("lineEdit_1"))
      +        self.lineEdit_1.setReadOnly(True)
      + 
      +        self.lineEdit_2 = QtGui.QLineEdit(self.centralWidget)
      +        self.lineEdit_2.setGeometry(QtCore.QRect(320, 80, 151, 22))
      +        self.lineEdit_2.setObjectName(_fromUtf8("lineEdit_2"))
      +        self.lineEdit_2.setReadOnly(True)
      + 
      +        self.lineEdit_3 = QtGui.QLineEdit(self.centralWidget)
      +        self.lineEdit_3.setGeometry(QtCore.QRect(320, 130, 151, 22))
      +        self.lineEdit_3.setObjectName(_fromUtf8("lineEdit_3"))
      +        self.lineEdit_3.setReadOnly(True)
      + 
      +        self.lineEdit_4 = QtGui.QLineEdit(self.centralWidget)
      +        self.lineEdit_4.setGeometry(QtCore.QRect(320, 180, 151, 22))
      +        self.lineEdit_4.setObjectName(_fromUtf8("lineEdit_4"))
      +        self.lineEdit_4.setReadOnly(True)
      + 
      +        self.lineEdit_5 = QtGui.QLineEdit(self.centralWidget)
      +        self.lineEdit_5.setGeometry(QtCore.QRect(320, 230, 151, 22))
      +        self.lineEdit_5.setObjectName(_fromUtf8("lineEdit_5"))
      +        self.lineEdit_5.setReadOnly(True)
      + 
      +        self.label_1 = QtGui.QLabel(self.centralWidget)
      +        self.label_1.setGeometry(QtCore.QRect(320, 10, 91, 16))
      +        self.label_1.setObjectName(_fromUtf8("label_1"))
      + 
      +        self.label_2 = QtGui.QLabel(self.centralWidget)
      +        self.label_2.setGeometry(QtCore.QRect(320, 60, 91, 16))
      +        self.label_2.setObjectName(_fromUtf8("label_2"))
      + 
      +        self.label_3 = QtGui.QLabel(self.centralWidget)
      +        self.label_3.setGeometry(QtCore.QRect(320, 110, 91, 16))
      +        self.label_3.setObjectName(_fromUtf8("label_3"))
      + 
      +        self.label_4 = QtGui.QLabel(self.centralWidget)
      +        self.label_4.setGeometry(QtCore.QRect(320, 160, 53, 16))
      +        self.label_4.setObjectName(_fromUtf8("label_4"))
      + 
      +        self.label_5 = QtGui.QLabel(self.centralWidget)
      +        self.label_5.setGeometry(QtCore.QRect(320, 210, 81, 16))
      +        self.label_5.setObjectName(_fromUtf8("label_5"))
      + 
      +        self.pushButton_1 = QtGui.QPushButton(self.centralWidget)
      +        self.pushButton_1.setGeometry(QtCore.QRect(20, 230, 90, 28))
      +        self.pushButton_1.setObjectName(_fromUtf8("pushButton_1"))
      +        self.pushButton_1.clicked.connect(self.on_pushButton_1_clicked) #connection pushButton_1
      +        self.pushButton_1.setToolTip(_translate("MainWindow", "Quitte la fonction", None))
      + 
      +        self.pushButton_2 = QtGui.QPushButton(self.centralWidget)
      +        self.pushButton_2.setGeometry(QtCore.QRect(110, 230, 90, 28))
      +        self.pushButton_2.setObjectName(_fromUtf8("pushButton_2"))
      +        self.pushButton_2.clicked.connect(self.on_pushButton_2_clicked) #connection pushButton_2
      +        self.pushButton_2.setToolTip(_translate("MainWindow", "Applique la fonction sans quitter", None))
      +        #self.pushButton_2.setStyleSheet("background-color: red") #cette fonction donne une couleur au bouton
      +        #self.pushButton_2.setStyleSheet("color : #ff0000") #cette fonction donne une couleur au texte du bouton
      +        #self.pushButton_2.setStyleSheet("color : #ff0000; background-color : #0000ff;" ) #combinaison des deux
      + 
      +        self.pushButton_3 = QtGui.QPushButton(self.centralWidget)
      +        self.pushButton_3.setGeometry(QtCore.QRect(200, 230, 90, 28))
      +        self.pushButton_3.setObjectName(_fromUtf8("pushButton_3"))
      +        self.pushButton_3.clicked.connect(self.on_pushButton_3_clicked) #connection pushButton_3
      +        self.pushButton_3.setToolTip(_translate("MainWindow", "Définit le mode par défaut (Cercle sur 3 points dans l'espace)", None))
      + 
      +        MainWindow.setCentralWidget(self.centralWidget)
      +        self.statusBar = QtGui.QStatusBar(MainWindow)
      +        self.statusBar.setObjectName(_fromUtf8("statusBar"))
      +        MainWindow.setStatusBar(self.statusBar)
      + 
      +        self.retranslateUi(MainWindow)
      +        QtCore.QMetaObject.connectSlotsByName(MainWindow)
      + 
      +    def retranslateUi(self, MainWindow):
      +        try:
      +            MainWindow.setWindowFlags(PyQt4.QtCore.Qt.WindowStaysOnTopHint) # PyQt4 cette fonction met la fenêtre en avant
      +        except Exception:
      +            MainWindow.setWindowFlags(PySide.QtCore.Qt.WindowStaysOnTopHint) # PySide cette fonction met la fenêtre en avant
      +        #MainWindow.setStyleSheet("background-color: red") #cette fonction donne une couleur à la fenêtre
      +        #MainWindow.setWindowOpacity(0.5)    #cette fonction donne une transparence à la fenêtre
      +        MainWindow.setWindowTitle(_translate("MainWindow", "Cercle sur 3 points", None))
      +        self.groupBox.setTitle(_translate("MainWindow", "Mode", None))
      +        self.radioButton_1.setText(_translate("MainWindow", "Défaut", None))
      +        self.radioButton_2.setText(_translate("MainWindow", "Vue  Face", None))
      +        self.radioButton_3.setText(_translate("MainWindow", "Vue Dessus", None))
      +        self.radioButton_4.setText(_translate("MainWindow", "Vue Droite", None))
      +        self.groupBox_2.setTitle(_translate("MainWindow", "Alignement sur", None))
      +        self.radioButton_5.setText(_translate("MainWindow", "Défaut", None))
      +        self.radioButton_6.setText(_translate("MainWindow", "Forme 1", None))
      +        self.radioButton_7.setText(_translate("MainWindow", "Forme 2", None))
      +        self.radioButton_8.setText(_translate("MainWindow", "Forme 3", None))
      +        self.checkBox_1.setText(_translate("MainWindow", "Afficher le centre", None))
      +        self.checkBox_2.setText(_translate("MainWindow", "Associer les couleurs", None))
      +        self.label_1.setText(_translate("MainWindow", "Coordonnée X", None))
      +        self.label_2.setText(_translate("MainWindow", "Coordonnée Y", None))
      +        self.label_3.setText(_translate("MainWindow", "Coordonnée Z", None))
      +        self.label_4.setText(_translate("MainWindow", "Rayon", None))
      +        self.label_5.setText(_translate("MainWindow", "Angle", None))
      +        self.pushButton_1.setText(_translate("MainWindow", "Quitter", None))
      +        self.pushButton_2.setText(_translate("MainWindow", "Appliquer", None))
      +        self.pushButton_3.setText(_translate("MainWindow", "Défaut", None))
      +    # première série de radioboutons
      +    def on_radioButton_1_clicked(self):
      +        if self.radioButton_1.isChecked():
      +            self.radioButton_5.setChecked(True)
      +    def on_radioButton_2_clicked(self):
      +        if self.radioButton_5.isChecked():
      +            self.radioButton_6.setChecked(True)
      +    def on_radioButton_3_clicked(self):
      +        if self.radioButton_5.isChecked():
      +            self.radioButton_6.setChecked(True)
      +    def on_radioButton_4_clicked(self):
      +        if self.radioButton_5.isChecked():
      +            self.radioButton_6.setChecked(True)
      +    # deuxième série de radioboutons
      +    def on_radioButton_5_clicked(self):
      +        if self.radioButton_5.isChecked():
      +            self.radioButton_1.setChecked(True)
      +    def on_radioButton_6_clicked(self):
      +        if self.radioButton_1.isChecked():
      +            self.radioButton_2.setChecked(True)
      +    def on_radioButton_7_clicked(self):
      +        if self.radioButton_1.isChecked():
      +            self.radioButton_2.setChecked(True)
      +    def on_radioButton_8_clicked(self):
      +        if self.radioButton_1.isChecked():
      +            self.radioButton_2.setChecked(True)
      +    # Boutons
      +    def on_pushButton_1_clicked(self):    # Bouton Quitte la fonction
      +        App.Console.PrintMessage("Terminé\r\n")
      +        self.window.hide()
      + 
      +    def on_pushButton_2_clicked(self):    # Bouton Appliquer
      +        if self.radioButton_1.isChecked():
      +            vueChoix=0
      +        if self.radioButton_2.isChecked():
      +            vueChoix=1
      +        if self.radioButton_3.isChecked():
      +            vueChoix=2
      +        if self.radioButton_4.isChecked():
      +            vueChoix=3
      + 
      +        if self.radioButton_5.isChecked():
      +            alignerSur=0
      +        if self.radioButton_6.isChecked():
      +            alignerSur=1
      +        if self.radioButton_7.isChecked():
      +            alignerSur=2
      +        if self.radioButton_8.isChecked():
      +            alignerSur=3
      + 
      +        if self.checkBox_1.checkState()==0:
      +            afficherPoint=0
      +        else:
      +            afficherPoint=1
      +        if self.checkBox_2.checkState()==0:
      +            colorer=0
      +        else:
      +            colorer=1
      + 
      +        # App.Console.PrintMessage("Appliquer\r\n")
      +        # App.Console.PrintMessage(str(vueChoix)+" \t")
      +        # App.Console.PrintMessage(str(alignerSur)+" \t")
      +        # App.Console.PrintMessage(str(afficherPoint)+" \t")
      +        # App.Console.PrintMessage(str(colorer)+" \r\n")
      + 
      +        def errorDialog(msg):
      +            # Create a simple dialog QMessageBox
      +            # The first argument indicates the icon used: one of QtGui.QMessageBox.{NoIcon, Information, Warning, Critical, Question} 
      +            diag = QtGui.QMessageBox(QtGui.QMessageBox.Critical,u"Error Message",msg)
      +            try:
      +                diag.setWindowFlags(PyQt4.QtCore.Qt.WindowStaysOnTopHint) # PyQt4 cette fonction met la fenêtre en avant
      +            except Exception:
      +                diag.setWindowFlags(PySide.QtCore.Qt.WindowStaysOnTopHint) # PySide cette fonction met la fenêtre en avant
      +            #diag.setWindowModality(QtCore.Qt.ApplicationModal) # la fonction a été désactivée pour favoriser "WindowStaysOnTopHint"
      +            diag.exec_()
      + 
      +        def affiche(x,y,z,rayon,r,v,b,afficherPoint,angle):
      +            pl.Base=FreeCAD.Vector(x,y,z)
      +            Draft.makeCircle((rayon),placement=pl,face=False,support=None)
      +            if colorer==1:    
      +                FreeCADGui.activeDocument().activeObject().LineColor = (r,v,b)
      +            if afficherPoint==1:
      +                Draft.makePoint(x,y,z)
      +                if colorer==1:
      +                    FreeCADGui.activeDocument().activeObject().PointColor = (r,v,b)
      +            str(self.lineEdit_1.setText(str(x)))
      +            str(self.lineEdit_2.setText(str(y)))
      +            str(self.lineEdit_3.setText(str(z)))
      +            str(self.lineEdit_4.setText(str(rayon)))
      +            str(self.lineEdit_5.setText(str(angle)))
      + 
      +        # prendre les objets selectionnes
      +        sel = FreeCADGui.Selection.getSelection()           
      +        i=0
      +        centreX=0;centreY=0;rayon=0
      + 
      +        # S'il y a 3 points sélectionnés alors..
      +        if len(sel)==3 :
      +            i=0
      +            ta=[0,0,0,0,0,0,0,0,0]
      +            for obj in sel:
      +                x=(obj.Shape.BoundBox.Center)
      +                ta[i+0]=(x.x)
      +                ta[i+1]=(x.y)
      +                ta[i+2]=(x.z)
      +                i=i+3
      + 
      +            if vueChoix==3:        # Vue de droite ZY (Rouge)
      +                z_point_1=ta[0]
      +                x_point_1=ta[1]
      +                y_point_1=ta[2]
      + 
      +                z_point_2=ta[3]
      +                x_point_2=ta[4]
      +                y_point_2=ta[5]
      + 
      +                z_point_3=ta[6]
      +                x_point_3=ta[7]
      +                y_point_3=ta[8]
      + 
      +            elif vueChoix==2:    # Vue de face ZX (Vert)
      +                y_point_1=ta[0]
      +                z_point_1=ta[1]
      +                x_point_1=ta[2]
      + 
      +                y_point_2=ta[3]
      +                z_point_2=ta[4]
      +                x_point_2=ta[5]
      + 
      +                y_point_3=ta[6]
      +                z_point_3=ta[7]
      +                x_point_3=ta[8]
      + 
      +            else:                # Vue de dessus XY (Bleu)
      +                x_point_1=ta[0]
      +                y_point_1=ta[1]
      +                z_point_1=ta[2]
      + 
      +                x_point_2=ta[3]
      +                y_point_2=ta[4]
      +                z_point_2=ta[5]
      + 
      +                x_point_3=ta[6]
      +                y_point_3=ta[7]
      +                z_point_3=ta[8]
      + 
      +            # Calcul des coordonnées du centre du cercle    
      +            try:
      +                centreX =((x_point_3**2-x_point_2**2+y_point_3**2-y_point_2**2)/(2*(y_point_3-y_point_2))-(x_point_2**2-x_point_1**2+y_point_2**2-y_point_1**2)/(2*(y_point_2-y_point_1)))/((x_point_3-x_point_2)/(y_point_3-y_point_2)-(x_point_2-x_point_1)/(y_point_2-y_point_1))
      +                centreY =-(x_point_2-x_point_1)/(y_point_2-y_point_1)*centreX+(x_point_2**2-x_point_1**2+y_point_2**2-y_point_1**2)/(2*(y_point_2-y_point_1))
      +                rayon =sqrt((x_point_1-centreX)**2+(y_point_1-centreY)**2)
      +            except:
      +                errorDialog(u"Calcul impossible trop d'élements alignés")
      +            else:
      +            #finally: # si finally est présent, il sera TOUJOURS exécuté
      +               # Définition de la coordonnée Z
      +                centreZ=0
      +                # Création du cercle
      +                pl=FreeCAD.Placement()
      +                if vueChoix==1:    # Plan XY Dessus
      +                    pl.Rotation.Q=(0,0,0,1.0)
      +                    if alignerSur==1:    
      +                        affiche(centreX,centreY,z_point_1,rayon,0.0,0.0,1.0,afficherPoint,0)
      +                    elif alignerSur==2:
      +                        affiche(centreX,centreY,z_point_2,rayon,0.0,0.0,1.0,afficherPoint,0)
      +                    elif alignerSur==3:
      +                        affiche(centreX,centreY,z_point_3,rayon,0.0,0.0,1.0,afficherPoint,0)
      +                elif vueChoix==2:    # Plan XZ Face
      +                    pl.Rotation.Q=(1,0,0,1.0)
      +                    if alignerSur==1:    
      +                        affiche(centreY,z_point_1,centreX,rayon,0.0,1.0,0.0,afficherPoint,0)
      +                    elif alignerSur==2:
      +                        affiche(centreY,z_point_2,centreX,rayon,0.0,1.0,0.0,afficherPoint,0)
      +                    elif alignerSur==3:
      +                        affiche(centreY,z_point_3,centreX,rayon,0.0,1.0,0.0,afficherPoint,0)
      +                elif vueChoix==3:    # Plan YZ Droite
      +                    pl.Rotation.Q=(0,1,0,1.0)
      +                    if alignerSur==1:    
      +                        affiche(z_point_1,centreX,centreY,rayon,1.0,0.0,0.0,afficherPoint,0)
      +                    elif alignerSur==2:
      +                        affiche(z_point_2,centreX,centreY,rayon,1.0,0.0,0.0,afficherPoint,0)
      +                    elif alignerSur==3:
      +                        affiche(z_point_3,centreX,centreY,rayon,1.0,0.0,0.0,afficherPoint,0)
      +                else:    # 3D XYZ
      +                    P1 = sel[0].Shape.BoundBox.Center
      +                    P2 = sel[1].Shape.BoundBox.Center
      +                    P3 = sel[2].Shape.BoundBox.Center
      + 
      +                    P1P2 = (P2 - P1).Length
      +                    P2P3 = (P3 - P2).Length
      +                    P3P1 = (P1 - P3).Length
      + 
      +                    # Circle radius.
      +                    l = ((P1 - P2).cross(P2 - P3)).Length
      +                    try:
      +                    #if l < 1e-8:
      +                    #    errorDialog("The three points are aligned")
      +                        r = P1P2 * P2P3 * P3P1 / 2 / l
      +                    except:
      +                        errorDialog("The three points are aligned")
      +                    else:
      +                        # Sphere center.
      +                        a = P2P3**2 * (P1 - P2).dot(P1 - P3) / 2 / l**2
      +                        b = P3P1**2 * (P2 - P1).dot(P2 - P3) / 2 / l**2
      +                        c = P1P2**2 * (P3 - P1).dot(P3 - P2) / 2 / l**2
      +                        P1.multiply(a)
      +                        P2.multiply(b)
      +                        P3.multiply(c)
      +                        PC = P1 + P2 + P3
      + 
      +                        # Creation of a circle
      +                        pl = Base.Placement()
      +                        v = (P1 - P2).cross(P3 - P2)
      +                        v.normalize()
      +                        axis = Base.Vector(0, 0, 1).cross(v)
      +                        angle = asin(axis.Length) * 180 / pi
      +                        axis.normalize()
      +                        pl = Base.Placement(PC, axis, angle)
      +                        affiche((PC.x),(PC.y),(PC.z),r,0.0,0.0,0.0,afficherPoint,angle)
      + 
      +        else:
      +            # Si la condition n'est pas remplie, recommencer
      +            errorDialog(u"Sélectionnez 3 points et recommencez")
      +            #FreeCAD.Console.PrintError("Sélectionnez 3 points et recommencez\r\n")
      +#________________________________________________________________________________
      +    def on_pushButton_3_clicked(self):    # Valeurs d'origine
      +        App.Console.PrintMessage("Défaut\r\n")
      +        vueChoix=0# choix de la vue Dessus=1 XY, vue Face=2 ZX, vue Droite=3 ZY
      +        self.radioButton_1.setChecked(True)
      +        alignerSur=0# aligne le cercle sur une forme au choix (1,2 ou 3) ou sur Z=0
      +        self.radioButton_5.setChecked(True)
      +        afficherPoint=1# affiche le point central du cercle
      +        self.checkBox_1.setChecked(True)
      +        colorer=1# colorer suivant l'axe 1=Ok 0=Couleur courante uniquement Orthogonal !
      +        self.checkBox_2.setChecked(True)
      + 
      +#______________________________________________________________________________________
      + 
      +MainWindow = QtGui.QMainWindow()
      +ui = Ui_MainWindow(MainWindow)
      +MainWindow.show() 
      +


      +

      +

      Anaglyphe

      +

      Here an Anaglyph view that allows you to see two different positions of the view by using glasses with filters red and Cyan Anaglyph Tango.png.
      +Watch alternately with the left eye and the right eye to see the views separately.
      +

      +
      +

      Anaglyphe +

      +
      +
      +


      +

      +

      Crédits

      +

      The genesis of the macro Draft_Circle_3_Points sur le forum (PYTHON) coordonnées d'un point helped flachyjoe thanks.
      +The formula comes from cercle_3pts.pdf and used with the kind permission of its author.
      +The formula adapted by " galou_breizh " circle in 3D space comes from +Circumscribed_circle
      +Separate programs are located here,
      +Macro Draft Circle 3 Points
      +Macro Draft Circle 3 Points 3D +

      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Macro_Make_Cube.html b/localwiki/Macro_Make_Cube.html new file mode 100644 index 0000000..ea63692 --- /dev/null +++ b/localwiki/Macro_Make_Cube.html @@ -0,0 +1,192 @@ +Macro Make Cube

      Macro Make Cube

      + +
      + + + + + + + + + + + + + + + + + + + + + + + + + + +
      +

      Macro makeCube.png Make Cube

      +
      Description +
      This macro creates a cube by asking for 4 points +
      Author +
      Yorik +
      Links +
      Macros recipes
      How to install macros
      How to customize toolbars +
      Version +
      2.0 +
      Date last modification +
      2011-08-01 +
      +

      Contents

      + +
      + +
      +


      +

      +
      # first we import the needed Draft modules
      +import draftTools, WorkingPlane
      +from draftlibs import fcvec
      +
      +class myCommand(draftTools.Creator):
      +"A class to define our custom command"
      +# this command is based on the generic draftTools Creator template
      +# it will ask for 4 points, defining our cube
      +
      +def __init__(self):
      +# general setup, we define everything we'll need at startup
      +print "Starting command..."
      +# The Activated function of the Creator defines several variables such as self.view
      +draftTools.Creator.Activated(self,"Cube")
      +# we use the point UI of the draft Toolbar, which has X,Y and Z input fields
      +self.ui.pointUi()
      +self.points = [] # here we will store our points
      +self.linetracker = draftTools.lineTracker()
      +# we build a special cube tracker which is a list of 4 rectangle trackers
      +self.cubetracker = []
      +for i in range(4): 
      +self.cubetracker.append(draftTools.rectangleTracker())
      +self.constraintracker = draftTools.lineTracker(dotted=True)
      +self.call = self.view.addEventCallback("SoEvent",self.action)
      +
      +def action(self,arg):
      +# 3D scene handler. This function will be called by the 3D view on
      +# special events such as keypress or mouse movements. We must take
      +# care of treating what we want. All the hard work will be here!
      +point,ctrlPoint = draftTools.getPoint(self,arg)
      +if arg["Type"] == "SoKeyboardEvent": 
      +if arg["Key"] == "ESCAPE":
      +# important! if ESC is pressed, we cancel everything
      +self.finish()
      +elif arg["Type"] == "SoLocation2Event":
      +# this will be executed in case of mouse movement
      +if len(self.points) == 1:
      +# this will be executed after we got our first point
      +self.linetracker.p2(point)
      +self.length = self.linetracker.getLength()
      +self.ui.setRadiusValue(self.length)
      +elif len(self.points) == 2:
      +# now we already have our base line, we update the 1st rectangle
      +self.cubetracker[0].p3(point)
      +self.width = self.cubetracker[0].getSize()[1]
      +self.ui.setRadiusValue(self.width)
      +elif len(self.points) == 3:
      +# we must first find our height point by projecting on the normal
      +w = fcvec.project(point,self.normal)
      +# then we update all rectangles
      +self.cubetracker[1].p3((self.cubetracker[0].p2()).add(w))
      +self.cubetracker[2].p3((self.cubetracker[0].p4()).add(w))
      +self.cubetracker[3].p1((self.cubetracker[0].p1()).add(w))
      +self.cubetracker[3].p3((self.cubetracker[0].p3()).add(w))
      +self.height = w.Length
      +self.ui.setRadiusValue(self.height)
      +
      +elif arg["Type"] == "SoMouseButtonEvent":
      +if (arg["State"] == "DOWN") and (arg["Button"] == "BUTTON1"):
      +# this will be executed in case of mouse button 1 pressed
      +print "Got point: ",point
      +if len(self.points) == 0:
      +# this is our first clicked point
      +self.linetracker.p1(point)
      +self.linetracker.on()
      +# we set the radius UI, which has only a length input field
      +# but we change the "radius" name
      +self.ui.radiusUi()
      +self.ui.labelRadius.setText("Width")
      +elif len(self.points) == 1:
      +# this is our second point
      +# first we turn off our line tracker
      +self.linetracker.off()
      +# then we turn on only one of the rectangles
      +baseline = point.sub(self.points[0])
      +self.cubetracker[0].setPlane(baseline)
      +self.cubetracker[0].p1(self.linetracker.p1())
      +self.cubetracker[0].on()
      +self.ui.labelRadius.setText("Length")
      +elif len(self.points) == 2:
      +# this is our third point
      +# we can get the cubes Z axis from our first rectangle
      +self.normal = self.cubetracker[0].getNormal()
      +# we can therefore define the (u,v) planes of all rectangles
      +u = self.cubetracker[0].u
      +v = self.cubetracker[0].v
      +self.cubetracker[1].setPlane(u,self.normal)
      +self.cubetracker[2].setPlane(u,self.normal)
      +self.cubetracker[3].setPlane(u,v)
      +# and the origin points of the vertical rectangles
      +self.cubetracker[1].p1(self.cubetracker[0].p1())
      +self.cubetracker[2].p1(self.cubetracker[0].p3())
      +# finally we turn all rectangles on
      +for r in self.cubetracker:
      +r.on()
      +self.ui.labelRadius.setText("Heigth")
      +elif len(self.points) == 3:
      +# finally we have all our points! Let's create the actual cube.
      +cube = self.doc.addObject("Part::Box","Cube")
      +cube.Length = self.length
      +cube.Width = self.width
      +cube.Height = self.height
      +# we get 3 points that define our cube orientation
      +p1 = self.cubetracker[0].p1()
      +p2 = self.cubetracker[0].p2()
      +p3 = self.cubetracker[0].p4()
      +cube.Placement = WorkingPlane.getPlacementFromPoints([p1,p2,p3])
      +self.finish()
      +self.points.append(point)
      +
      +def finish(self):
      +# this will be executed when finishing the command
      +# first thing, we remove our callback function
      +self.view.removeEventCallback("SoEvent",self.call)
      +# then we turn off the draft toolbar
      +self.ui.offUi()
      +# important! we must remove all coin stuff
      +self.linetracker.finalize()
      +for r in self.cubetracker:
      +r.finalize()
      +# then we call the generic finish function of our creator object
      +draftTools.Creator.finish(self)
      +print "Finished!"
      +
      +#  finally, we execute our code!
      +myCommand() 
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Macro_Manage_Navigational_Style.html b/localwiki/Macro_Manage_Navigational_Style.html new file mode 100644 index 0000000..cbf0f3d --- /dev/null +++ b/localwiki/Macro_Manage_Navigational_Style.html @@ -0,0 +1,101 @@ +Macro Manage Navigational Style

      Macro Manage Navigational Style

      + +
      + + + + + + + + + + + + + + + + + + + + + + + + + + +
      +

      Text-x-python.png Macro Manage Navigational Styles

      +
      Description +
      This pair of macros allow you to alter the Navigation Style while using the Sketcher. +
      Author +
      PiffPoof +
      Links +
      Macros recipes
      How to install macros
      How to customize toolbars +
      Version +
      1.0 +
      Date last modification +
      2015-01-17 +
      +

      + +
      +


      +

      +

      Description

      +

      When using the Sketcher the right-button menu is redefined to hold options relevant to the Sketcher. Consequently the option to change the Navigational Style, which is available when outside the Sketcher, is not available when in the Sketcher. +

      +

      Installation

      +

      There are two brief code snippets, each of which is a separate Macro. Installation is comprised of copying the two pieces code to the appropriate Macro directory and invoking them from the Macro menu. It is much preferable to add them both to a toolbar so as to be easily available while using the Sketcher. +

      + +

      Usage

      +

      Click on the associated toolbar button, or invoke from the Macro menu. There is no visible confirmation of their executing, aside from the Navigational Style will change. +

      +

      User Interface

      +

      There really isn't any user interface, not even any confirmation that the Navigational Style has been changed. The confirmation will be when you next manipulate the view, your mouse movements will interpreted in the Navigational Style you selected. +

      +

      Scripts

      +

      There are two scripts, one to change to each of 'Cad' and 'Inventor' Navigational Styles. There are also 2 icons, one for each Macro: +

      +
      • icon and macro code to change the Navigational Style to 'CAD'
      +

      Macro Manage Navigational Styles1.png +

      +
      # change to CAD Navigational Style
      +p=App.ParamGet("User parameter:BaseApp/Preferences/View")
      +p.SetString("NavigationStyle","Gui::CADNavigationStyle") 
      +
      • icon and macro code to change the Navigational Style to 'Inventor'
      +

      Macro Manage Navigational Styles2.png +

      +
      # change to Inventor Navigational Style
      +p=App.ParamGet("User parameter:BaseApp/Preferences/View")
      +p.SetString("NavigationStyle","Gui::InventorNavigationStyle") 
      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Macro_Manage_Navigational_Styles1.png b/localwiki/Macro_Manage_Navigational_Styles1.png new file mode 100644 index 0000000..41a6031 Binary files /dev/null and b/localwiki/Macro_Manage_Navigational_Styles1.png differ diff --git a/localwiki/Macro_Manage_Navigational_Styles2.png b/localwiki/Macro_Manage_Navigational_Styles2.png new file mode 100644 index 0000000..de7acf1 Binary files /dev/null and b/localwiki/Macro_Manage_Navigational_Styles2.png differ diff --git a/localwiki/Macro_MatrixTransform.html b/localwiki/Macro_MatrixTransform.html new file mode 100644 index 0000000..6fad24e --- /dev/null +++ b/localwiki/Macro_MatrixTransform.html @@ -0,0 +1,278 @@ +Macro MatrixTransform

      Macro MatrixTransform

      + +
      + + + + + + + + + + + + + + + + + + + + + + + + + + +
      +

      Text-x-python.png MatrixTransform

      +
      Description +
      Transforms a shape using a 3x3 matrix (parametric) +
      Author +
      DeepSOIC +
      Links +
      Macros recipes
      How to install macros
      How to customize toolbars +
      Version +
      1.0 +
      Date last modification +
      2016-05-25 +
      +

      + +
      +


      +

      Applies linear transformation to a shape, defined by a 3x3 matrix. It is possible to: +

      +
      • apply non-linear scaling to a shape
      • +
      • shear a shape
      • +
      • rotate a shape
      +

      Installation:

      +

      download these two files and save them in macro directory: +

      https://github.com/DeepSOIC/FreeCAD-Macros/raw/master/MatrixTransform/MatrixTransform.FCMacro +

      https://github.com/DeepSOIC/FreeCAD-Macros/raw/master/MatrixTransform/MatrixTransform.py +

      +

      How to use:

      +
      1. Select the shape to be transformed
      2. +
      3. In FreeCAD menu: Macro -> Macros... -> double-click MatrixTransform.FCMacro . A new object will be created.
      4. +
      5. Select the new object, and edit v1,v2,v3 properties on data tab to set the transformation matrix.
      +

      Matrix is defined by three vectors: +

      +
                v1x   v2x   v3x                  
      +   M = (  v1y   v2y   v3y )                  
      +          v1z   v2z   v3z                  
      +
      +

      Here, v1,v2,v3 are vectors that can be defined in properties. They correspond +to new directions of what was originally X,Y,Z axes. +

      +

      example matrices

      +

      No transformation

      +
         1  0  0
      +   0  1  0
      +   0  0  1
      +
      +

      non-uniform scaling

      +
         scaleX    0      0
      +      0   scaleY    0
      +      0      0   scaleZ
      +
      +

      shearing

      +

      (operation that makes regular text into italic; assuming text is in XY plane) +

      +
         1  shear  0
      +   0    1    0
      +   0    0    1
      +
      +

      'Shear' coefficient defines the amount of shearing. 0 is no shearing. 1 makes +the text italic by 45 degrees. -1 shears in backslash-like fashion. +


      +Warning. All geometry is converted to B-splines, even if it doesn't have to. +This can cause all sorts of trouble. Use only if absolutely necessary. +


      +

      +
      +


      +MatrixTransform.py: +

      +
      #***************************************************************************
      +#*                                                                         *
      +#*   Copyright (c) 2015 - Victor Titov (DeepSOIC)                          *
      +#*                                               <vv.titov@gmail.com>      *  
      +#*                                                                         *
      +#*   This program is free software; you can redistribute it and/or modify  *
      +#*   it under the terms of the GNU Lesser General Public License (LGPL)    *
      +#*   as published by the Free Software Foundation; either version 2 of     *
      +#*   the License, or (at your option) any later version.                   *
      +#*   for detail see the LICENCE text file.                                 *
      +#*                                                                         *
      +#*   This program is distributed in the hope that it will be useful,       *
      +#*   but WITHOUT ANY WARRANTY; without even the implied warranty of        *
      +#*   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the         *
      +#*   GNU Library General Public License for more details.                  *
      +#*                                                                         *
      +#*   You should have received a copy of the GNU Library General Public     *
      +#*   License along with this program; if not, write to the Free Software   *
      +#*   Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  *
      +#*   USA                                                                   *
      +#*                                                                         *
      +#***************************************************************************
      +
      +__title__="Macro MatrixTransform"
      +__author__ = "DeepSOIC"
      +__doc__ = '''
      +Macro MatrixTransform.
      +Distorts geometry according to vector transformation defined by the matrix.
      +
      +Matrix is defined by three vectors:
      +       v1x   v2x   v3x                  
      +M = (  v1y   v2y   v3y )                  
      +       v1z   v2z   v3z                  
      +Here, v1,v2,v3 are vectors that can be defined in properties. They correspond
      +to new directions of what was originally X,Y,Z axes.
      +
      +exmaple matrices:
      +
      +No transformation:
      +1  0  0
      +0  1  0
      +0  0  1
      +
      +non-uniform scaling:
      +scaleX    0      0
      +   0   scaleY    0
      +   0      0   scaleZ
      +
      +shearing (operation that makes regular text into italic; assuming text is in XY
      +plane):
      +1  shear  0
      +0    1    0
      +0    0    1
      +('shear' coefficient defines the amount of shearing. 0 is no shearing. 1 makes
      +the text italic by 45 degrees. -1 shears in backslash-like fashion.)
      +
      +
      +Warning. All geometry is converted to B-splines, even if it doesn't have to.
      +This can cause all sorts of trouble. Use only if absolutely necessary.
      +'''
      +
      +import FreeCAD as App
      +if App.GuiUp:
      +    import FreeCADGui as Gui
      +import Part
      +
      +def makeMatrixTransformFeature():
      +    '''makeMatrixTransformFeature(): makes a MatrixTransform parametric feature object. Returns the new object.'''
      +    obj = App.ActiveDocument.addObject("Part::FeaturePython","Transform")
      +    MatrixTransform(obj)
      +    ViewProviderMatrixTransform(obj.ViewObject)
      +    return obj
      +
      +class MatrixTransform:
      +    "The FuseCompound object"
      +    def __init__(self,obj):
      +        obj.addProperty("App::PropertyLink","Base","MatrixTransform","Input shape")
      +        obj.addProperty("App::PropertyVector","v1","MatrixTransform","Vector for new X axis; first column of transform matrix.")
      +        obj.addProperty("App::PropertyVector","v2","MatrixTransform","Vector for new Y axis; second column of transform matrix.")
      +        obj.addProperty("App::PropertyVector","v3","MatrixTransform","Vector for new Z axis; third column of transform matrix.")
      +        obj.v1 = App.Vector(1,0,0)
      +        obj.v2 = App.Vector(1,1,0)
      +        obj.v3 = App.Vector(0,0,1)
      +        obj.Proxy = self
      +        
      +
      +    def execute(self,obj):
      +        v1 = obj.v1
      +        v2 = obj.v2
      +        v3 = obj.v3
      +        m = App.Matrix(  v1.x, v2.x, v3.x, 0,
      +                         v1.y, v2.y, v3.y, 0,
      +                         v1.z, v2.z, v3.z, 0,
      +                         0,    0,    0,    1   )
      +        obj.Shape = obj.Base.Shape.transformGeometry(m)
      +
      +class ViewProviderMatrixTransform:
      +    
      +    def __init__(self,vobj):
      +        vobj.Proxy = self
      +       
      +    def getIcon(self):
      +        return ""
      +
      +    def attach(self, vobj):
      +        self.ViewObject = vobj
      +        self.Object = vobj.Object
      +  
      +    def setEdit(self,vobj,mode):
      +        return False
      +    
      +    def unsetEdit(self,vobj,mode):
      +        return
      +
      +    def __getstate__(self):
      +        return None
      +
      +    def __setstate__(self,state):
      +        return None
      +
      +    def claimChildren(self):
      +        return [self.Object.Base]
      +        
      +    def onDelete(self, feature, subelements): # subelements is a tuple of strings
      +        try:
      +            self.Object.Base.ViewObject.show()
      +        except Exception as err:
      +            App.Console.PrintError("Error in onDelete: " + err.message)
      +        return True
      +
      +def run():
      +    sel = Gui.Selection.getSelection()
      +    try:
      +        if len(sel) != 1:
      +            raise Exception("Select a shape to transform, first! Then run this macro.")
      +        obj = makeMatrixTransformFeature()
      +        obj.Base = sel[0]
      +        obj.Proxy.execute(obj)
      +    except Exception as err:
      +        from PySide import QtGui
      +        mb = QtGui.QMessageBox()
      +        mb.setIcon(mb.Icon.Warning)
      +        mb.setText(err.message)
      +        mb.setWindowTitle("Macro MatrixTransform")
      +        mb.exec_() 
      +

      MatrixTransform.FCMacro: +

      +
      import MatrixTransform
      +MatrixTransform.run() 
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Macro_MeasureCircle.html b/localwiki/Macro_MeasureCircle.html new file mode 100644 index 0000000..2c38b0c --- /dev/null +++ b/localwiki/Macro_MeasureCircle.html @@ -0,0 +1,87 @@ +Macro MeasureCircle

      Macro MeasureCircle

      + +
      + + + + + + + + + + + + + + + + + + + + + + + + + + +
      +

      Macro MeasureCircle.png Macro MeasureCircle

      +
      Description +
      Compute the radius of a circle by 3 points or a circular edge +
      Author +
      galou_breizh +
      Links +
      Macros recipes
      How to install macros
      How to customize toolbars +
      Version +
      1.0 +
      Date last modification +
      2016-04-08 +
      +

      + +
      +


      +

      +

      Description

      +

      This macro will report the computed radius and center of a circle given 3 vertices or a circular edge. +A line is drawn from the center of the circle to the first vertex, which may be used for future measurements. +


      +

      +

      How To Use

      +

      Copy the macro in your macros' folder and run (see How to install macros for further details). +

      Just select the vertices and the result will be shown in the Report View. +Edges may also be selected and count as two vertices. +A circular edge can also be selected. +If two edges are selected the end vertex of the second edge is not used in the calculation. +

      You can either select elements and then launch the macro or launch the macro without selection and select elements after launch. +If not enough elements are selected before launching the macro, you must select the missing elements. +

      +

      Code

      +

      The lastest version of the macro is to be found at https://github.com/FreeCAD/FreeCAD-macros/blob/master/Utility/MeasureCircle.FCMacro +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Macro_MeshToPart.html b/localwiki/Macro_MeshToPart.html new file mode 100644 index 0000000..6b47330 --- /dev/null +++ b/localwiki/Macro_MeshToPart.html @@ -0,0 +1,111 @@ +Macro MeshToPart

      Macro MeshToPart

      + +
      + + + + + + + + + + + + + + + + + + + + + + + + + + +
      +

      Text-x-python.png MeshToPart

      +
      Description +
      This macro converts selected meshes to parts. It has a broad tolerance, so use it only with objects that have no curves otherwise you'll get weird results +
      Author +
      Wmayer +
      Links +
      Macros recipes
      How to install macros
      How to customize toolbars +
      Version +
      1.0 +
      Date last modification +
      2011-08-01 +
      +

      + +
      +


      +

      +

      Description

      +

      This macro converts selected meshes to parts. It has a broad tolerance, so use it only with objects that have no curves otherwise you'll get errors or weird results +


      +

      +
      import FreeCAD,FreeCADGui,Mesh,Part,MeshPart
      + 
      +for obj in FreeCADGui.Selection.getSelection():
      +    if "Mesh" in obj.PropertiesList:
      +        faces = []      
      +        mesh = obj.Mesh
      +        segments = mesh.getPlanarSegments(0.01) # use rather strict tolerance here
      + 
      +        for i in segments:
      +          if len(i) > 0:
      +             # a segment can have inner holes
      +             wires = MeshPart.wireFromSegment(mesh, i)
      +             # we assume that the exterior boundary is that one with the biggest bounding box
      +             if len(wires) > 0:
      +                ext = None
      +                max_length = 0
      +                for i in wires:     
      +                   if i.BoundBox.DiagonalLength > max_length:
      +                      max_length = i.BoundBox.DiagonalLength
      +                      ext = i
      +                wires.remove(ext)
      +                # all interior wires mark a hole and must reverse their orientation, otherwise Part.Face fails
      +                for i in wires:
      +                   i.reverse()
      +                # make sure that the exterior wires comes as first in the lsit
      +                wires.insert(0, ext)
      +                faces.append(Part.Face(wires))
      + 
      +        shell=Part.Compound(faces)
      +        solid = Part.Solid(Part.Shell(faces))
      +        name = obj.Name
      +        FreeCAD.ActiveDocument.removeObject(name)
      +        FreeCAD.ActiveDocument.addObject("Part::Feature",name).Shape = solid 
      +
      +


      +

      +

      Link

      +

      The discussion on the forum Convert mesh to solid? +

      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Macro_MessageBox.html b/localwiki/Macro_MessageBox.html new file mode 100644 index 0000000..5598c17 --- /dev/null +++ b/localwiki/Macro_MessageBox.html @@ -0,0 +1,102 @@ +Macro MessageBox

      Macro MessageBox

      + +
      + + + + + + + + + + + + + + + + + + + + + + + + + + +
      +

      Text-x-python.png MessageBox

      +
      Description +
      Show how to give information to the user in macros +
      Author +
      Gaël Ecorchard +
      Links +
      Macros recipes
      How to install macros
      How to customize toolbars +
      Version +
      1.0 +
      Date last modification +
      2011-09-19 +
      +

      Contents

      + +
      + +
      +


      +

      Show how to give information to the user in macros +

      MessageBox +


      +

      +
      #! /usr/bin/env python
      +# -*- coding: utf-8 -*-
      + 
      +"""Show how to give information to the user in macros
      +"""
      +from PySide import QtCore, QtGui
      + 
      +def errorDialog(msg):
      +    # Create a simple dialog QMessageBox
      +    # The first argument indicates the icon used: one of QtGui.QMessageBox.{NoIcon, Information, Warning, Critical, Question} 
      +    diag = QtGui.QMessageBox(QtGui.QMessageBox.Warning, 'Error in macro MessageBox', msg)
      +    diag.setWindowModality(QtCore.Qt.ApplicationModal)
      +    diag.exec_()
      + 
      +msg = 'Example of warning message'
      +errorDialog(msg)
      +raise(Exception(msg)) 
      +


      +In order to use the accented characters in the text field from Qt, using the tag #-*-coding: utf-8-*- must be added a u before the message to display
      +Example : +

      +
      diag = QtGui.QMessageBox(QtGui.QMessageBox.Warning, u'Trop d'éléments désignés', msg)
      +    ...
      +    ...
      +msg = u'Élément sélectionnés affichés' 
      +


      +To display multiple lines in a dialog box Qt, must be added "\n" (quotation, valid also between apostrophes) between each line.
      +Valid also "\r\n" which correspond to CR carriage return, and LF end of line, valid also " \t" is a tab, characters should be between quotation marks (and apostrophes) as a character string, the tags can be found next to the text to display " \nRayon\t: ", the tag " \ " (reversed slash) defines the command.
      +Example : +

      +
      diag = QtGui.QMessageBox(QtGui.QMessageBox.Information,u"Coordonnées",u"Coordonnée X : "+str(x)+"\r\n"+u"Coordonnée Y : "+str(y)+"\n"+u"Coordonnée Z :<br>
      + "+str(z)+"\nRayon\t     : "+str(r)) 
      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Macro_Mouse_Cross.html b/localwiki/Macro_Mouse_Cross.html new file mode 100644 index 0000000..0b07775 --- /dev/null +++ b/localwiki/Macro_Mouse_Cross.html @@ -0,0 +1,218 @@ +Macro Mouse Cross

      Macro Mouse Cross

      + +
      + + + + + + + + + + + + + + + + + + + + + + + + + + +
      +

      Text-x-python.png Macro_Mouse_Cross

      +
      Description +
      This macro turns the arrow of the mouse in a precision cross. +
      Author +
      Mario52 +
      Links +
      Macros recipes
      How to install macros
      How to customize toolbars +
      Version +
      00.03 +
      Date last modification +
      2016-01-25 +
      +

      + +
      +


      +

      +

      Description

      +

      This small macro turns the arrow of the mouse in a precision cross.
      +Small example of using the class ViewObserver() and the use of the keyboard with SoKeyboardEvent +

      Macro_Mouse_Cross +

      +
      +


      +

      +

      How to use

      +
      1. Press the C button to activate the cross.
      2. +
      3. Press the A button to activate the arrow.
      4. +
      5. Press the G button to activate the grid.
      6. +
      7. Press the X button for visualise all cursor.
      8. +
      9. Press the Q button to quit the macro.
      +

      Script

      +

      Macro_Mouse_Cross.FCMacro +

      +
      # -*- coding: utf-8 -*-
      +# mouse cursor to Cross or Arrow + Grig 
      +# ver 0.2 08/08/2014  PyQt4 and PySide
      +__title__   = "Macro_Mouse_Cross"
      +__author__  = "Mario52"
      +__url__     = "http://www.freecadweb.org/index-fr.html"
      +__version__ = "00.03"
      +__date__    = "25/01/2016"
      +
      +try:
      +    from PyQt4 import QtCore, QtGui
      +except Exception:
      +    from PySide import QtCore, QtGui
      +from pivy import coin
      +
      +global xx ;xx = -1
      +
      +#################### create document if not exist #######################
      +doc = FreeCAD.ActiveDocument                                         ####
      +if doc == None:                                                      ####
      +    doc = FreeCAD.newDocument()                                      ####
      +#########################################################################
      +class ViewObserver:
      +   def logPosition(self, info):
      +       global xx
      +       self.pos = info["Key"]
      +       if (self.pos.upper() == "Q"):
      +           v.removeEventCallback("SoKeyboardEvent",c)
      +           print "End Macro_Mouse_Cross"
      +       if (self.pos.upper() == "C"):
      +           # change the cursor cross ( + )
      +           QtGui.QApplication.setOverrideCursor(QtGui.QCursor(QtCore.Qt.CrossCursor))
      +       elif (self.pos.upper() == "A"):
      +           # change the cursor in Arrow
      +           QtGui.QApplication.setOverrideCursor(QtGui.QCursor(QtCore.Qt.ArrowCursor))
      +       elif (self.pos.upper() == "X") and (info["State"] == "DOWN"):
      +           # change the cursor and visualise all model 
      +           xx += 1
      +           if xx == 0:
      +               QtGui.QApplication.setOverrideCursor(QtGui.QCursor(QtCore.Qt.ArrowCursor))
      +               FreeCAD.Console.PrintMessage("ArrowCursor"+"\n")
      +           if xx == 1:
      +               QtGui.QApplication.setOverrideCursor(QtGui.QCursor(QtCore.Qt.UpArrowCursor))
      +               FreeCAD.Console.PrintMessage("UpArrowCursor"+"\n")
      +           if xx == 2:
      +               QtGui.QApplication.setOverrideCursor(QtGui.QCursor(QtCore.Qt.CrossCursor))
      +               FreeCAD.Console.PrintMessage("CrossCursor"+"\n")
      +           if xx == 3:
      +               QtGui.QApplication.setOverrideCursor(QtGui.QCursor(QtCore.Qt.WaitCursor))
      +               FreeCAD.Console.PrintMessage("WaitCursor"+"\n")
      +           if xx == 4:
      +               QtGui.QApplication.setOverrideCursor(QtGui.QCursor(QtCore.Qt.IBeamCursor))
      +               FreeCAD.Console.PrintMessage("IBeamCursor"+"\n")
      +           if xx == 5:
      +               QtGui.QApplication.setOverrideCursor(QtGui.QCursor(QtCore.Qt.SizeVerCursor))
      +               FreeCAD.Console.PrintMessage("SizeVerCursor"+"\n")
      +           if xx == 6:
      +               QtGui.QApplication.setOverrideCursor(QtGui.QCursor(QtCore.Qt.SizeHorCursor))
      +               FreeCAD.Console.PrintMessage("SizeHorCursor"+"\n")
      +           if xx == 7:
      +               QtGui.QApplication.setOverrideCursor(QtGui.QCursor(QtCore.Qt.SizeBDiagCursor))
      +               FreeCAD.Console.PrintMessage("SizeBDiagCursor"+"\n")
      +           if xx == 8:
      +               QtGui.QApplication.setOverrideCursor(QtGui.QCursor(QtCore.Qt.SizeFDiagCursor))
      +               FreeCAD.Console.PrintMessage("SizeFDiagCursor"+"\n")
      +           if xx == 9:
      +               QtGui.QApplication.setOverrideCursor(QtGui.QCursor(QtCore.Qt.SizeAllCursor))
      +               FreeCAD.Console.PrintMessage("SizeAllCursor"+"\n")
      +           if xx == 10:
      +               QtGui.QApplication.setOverrideCursor(QtGui.QCursor(QtCore.Qt.BlankCursor))
      +               FreeCAD.Console.PrintMessage("BlankCursor"+"\n")
      +           if xx == 11:
      +               QtGui.QApplication.setOverrideCursor(QtGui.QCursor(QtCore.Qt.SplitVCursor))
      +               FreeCAD.Console.PrintMessage("SplitVCursor"+"\n")
      +           if xx == 12:
      +               QtGui.QApplication.setOverrideCursor(QtGui.QCursor(QtCore.Qt.SplitHCursor))
      +               FreeCAD.Console.PrintMessage("SplitHCursor"+"\n")
      +           if xx == 13:
      +               QtGui.QApplication.setOverrideCursor(QtGui.QCursor(QtCore.Qt.PointingHandCursor))
      +               FreeCAD.Console.PrintMessage("PointingHandCursor"+"\n")
      +           if xx == 14:
      +               QtGui.QApplication.setOverrideCursor(QtGui.QCursor(QtCore.Qt.ForbiddenCursor))
      +               FreeCAD.Console.PrintMessage("ForbiddenCursor"+"\n")
      +           if xx == 15:
      +               QtGui.QApplication.setOverrideCursor(QtGui.QCursor(QtCore.Qt.OpenHandCursor))
      +               FreeCAD.Console.PrintMessage("OpenHandCursor"+"\n")
      +           if xx == 16:
      +               QtGui.QApplication.setOverrideCursor(QtGui.QCursor(QtCore.Qt.ClosedHandCursor))
      +               FreeCAD.Console.PrintMessage("ClosedHandCursor"+"\n")
      +           if xx == 17:
      +               QtGui.QApplication.setOverrideCursor(QtGui.QCursor(QtCore.Qt.WhatsThisCursor))
      +               FreeCAD.Console.PrintMessage("WhatsThisCursor"+"\n")
      +           if xx == 18:
      +               QtGui.QApplication.setOverrideCursor(QtGui.QCursor(QtCore.Qt.BusyCursor))
      +               FreeCAD.Console.PrintMessage("BusyCursor"+"\n")
      +           if xx == 19:
      +               QtGui.QApplication.setOverrideCursor(QtGui.QCursor(QtCore.Qt.BitmapCursor))
      +               FreeCAD.Console.PrintMessage("BitmapCursor"+"\n")
      +               xx = -1
      +       elif (self.pos.upper() == "G"):
      +           # "wmayer" http://forum.freecadweb.org/viewtopic.php?f=3&t=1065&hilit=cross#p8818
      +           # Create Grida
      +           grid=coin.SoType.fromName("SoDrawingGrid").createInstance()
      +           Gui.ActiveDocument.ActiveView.getSceneGraph().addChild(grid)
      +xx = -1 
      +
      +try:
      +    v=Gui.activeDocument().activeView()
      +    o = ViewObserver()
      +    c = v.addEventCallback("SoKeyboardEvent",o.logPosition)
      +    App.Console.PrintMessage("Type Key C to Cross"+"\n")
      +    App.Console.PrintMessage("Type Key A to Arrow"+"\n")
      +    App.Console.PrintMessage("Type Key X to Visualise all cursor"+"\n")
      +    App.Console.PrintMessage("Type Key G to Grid (not editable)"+"\n")
      +    App.Console.PrintMessage("Type Key Q to Quit"+"\n")
      +except Exception:
      +    FreeCAD.Console.PrintError("\n"+"Not document open"+"\n") 
      +

      Cursors that can be used

      +

      ArrowCursor, UpArrowCursor, CrossCursor, WaitCursor, IBeamCursor, SizeVerCursor, SizeHorCursor +SizeBDiagCursor, SizeFDiagCursor, SizeAllCursor, BlankCursor, SplitVCursor, SplitHCursor +PointingHandCursor, ForbiddenCursor, OpenHandCursor, ClosedHandCursor, WhatsThisCursor, BusyCursor, BitmapCursor +

      +

      Limitation

      +

      The cursor can change appearance depending on the used Workbench, he must repeat the operation.
      +The cursor can be subtituer to the other sliders (ex: expansion of a window, corner...).
      +The grid is permanent.
      +

      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Macro_Normal_Vector.html b/localwiki/Macro_Normal_Vector.html new file mode 100644 index 0000000..45eabb4 --- /dev/null +++ b/localwiki/Macro_Normal_Vector.html @@ -0,0 +1,82 @@ +Macro Normal Vector

      Macro Normal Vector

      + +
      + + + + + + + + + + + + + + + + + + + + + + + + + + +
      +

      Text-x-python.png Normal Vector Macro

      +
      Description +
      Get normal vector of preselected face +
      Author +
      ulrich1a +
      Links +
      Macros recipes
      How to install macros
      How to customize toolbars +
      Version +
      1.0 +
      Date last modification +
      2016-09-26 +
      +

      + +
      +


      +

      Simple macro to extract normal vector of previously within the 3D-View chosen face and give the output to the python console +

      +

      Use

      +
      • Choose Face in 3D View.
      • +
      • Copy Macro code to python console.
      • +
      • FreeCAD will then display normal vector information in python console.
      • +
      • Use these values for setting up direction when creating a drawing view.
      +

      Script

      +
      Gui.Selection.getSelectionEx()[0].SubObjects[0].Faces[0].normalAt(0,0) 
      +

      Link

      +

      Link to dicussion thread (german) +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Macro_ObjectInfo.html b/localwiki/Macro_ObjectInfo.html new file mode 100644 index 0000000..abf79e9 --- /dev/null +++ b/localwiki/Macro_ObjectInfo.html @@ -0,0 +1,86 @@ +Macro ObjectInfo

      Macro ObjectInfo

      + +
      + + + + + + + + + + + + + + + + + + + + + + + + + + +
      +

      Text-x-python.png Macro ObjectInfo

      +
      Description +
      provides information on the selected object +
      Author +
      keithsloan52 +
      Links +
      Macros recipes
      How to install macros
      How to customize toolbars +
      Version +
      1.0 +
      Date last modification +
      2012-11-09 +
      +

      + +
      +


      +

      +

      Description

      +

      This macro lets you know the volume information surface area, center of mass and moment of intertia of the selected object.

      +ObjectInfoIt.png

      +

      +

      Installation

      +

      If you're on Linux, you need to create a folder named "Mod" in the .FreeCAD hidden folder which is located in your Home folder. Then create a folder named "Info" in the "Mod" folder, and extract the content of the archive in it. On Windows, I have no idea where that would be. Use the same procedure to Windows in C:\Program Files\FreeCAD\Mod. +

      +

      How to use

      +

      Then start FreeCAD, open your STEP file and switch to the "Info" workbench with the workbench switcher or by going to the View --> Workbench menu. Now select your solid, and click on the "Info" icon; the left taskbar will show some information on the model, including volume, surface area, center of mass and moment of intertia. +

      +

      Links

      +

      A FreeCAD user created a user-friendly "Info" module which you can get here: http://www.sloan-home.co.uk/FreeCAD/Info/Info.html +

      From Forum Info Workbench - Help with icons please. +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Macro_Overlap.html b/localwiki/Macro_Overlap.html new file mode 100644 index 0000000..22acd4f --- /dev/null +++ b/localwiki/Macro_Overlap.html @@ -0,0 +1,225 @@ +Macro Overlap

      Macro Overlap

      + +
      + + + + + + + + + + + + + + + + + + + + + + + + + + +
      +

      Macro Overlap.png Boolean Overlap

      +
      Description +
      Boolean tool in between Part Union and Part Common. Parametric. +
      Author +
      DeepSOIC +
      Links +
      Macros recipes
      How to install macros
      How to customize toolbars +
      Version +
      0.1 +
      Date last modification +
      2016-10-12 +
      +

      + +
      Macro Boolean Overlap Screenshot.png +


      +Boolean Overlap constructs a shape that covers the space occupied by no less than 'OverlapIndex' shapes. 'OverlapIndex' is a property that can be modified. Value of 1 gives the result equivalent to Part Union. Value equal to number of shapes makes the tool equivalent to Part Common. Default value is 2, meaning the result will fill space where there is any overlap. +

      Requires FreeCAD v0.17+ built against OCC no less than 6.9.0 (tested on 7.0.0). +

      +

      Installation:

      +

      download these two files and save them in macro directory: +

      https://github.com/DeepSOIC/FreeCAD-Macros/raw/master/Overlap/Overlap.FCMacro +

      https://github.com/DeepSOIC/FreeCAD-Macros/raw/master/Overlap/MacroOverlap.py +

      +

      How to use:

      +
      1. Select three* or more shapes to compute overlap between. You can also select a single compound containing the argument shapes.
      2. +
      3. In FreeCAD menu: Macro -> Macros... -> double-click Overlap.FCMacro . A new object will be created.
      4. +
      5. Select the new object, and modify 'Overlap Index' property in property editor (Data tab), if necessary.
      +
      • two shapes will do, too, but the action of tool will be equivalent to either Part Common or Part Fuse, and so it is recommended to use Part tools instead.
      +


      +

      +
      +


      +MacroOverlap.py: +

      +
      import FreeCAD as App
      +if App.GuiUp:
      +    import FreeCADGui as Gui
      +import Part
      +
      +def makeOverlapFeature():
      +    '''makeOverlapFeature(): makes a Overlap parametric feature object. Returns the new object.'''
      +    selfobj = App.ActiveDocument.addObject("Part::FeaturePython","Overlap")
      +    Overlap(selfobj)
      +    ViewProviderOverlap(selfobj.ViewObject)
      +    return selfobj
      +
      +class Overlap:
      +    "The Overlap feature object"
      +    def __init__(self,selfobj):
      +        selfobj.addProperty("App::PropertyLinkList","Objects","Overlap","Input shape")
      +        selfobj.addProperty("App::PropertyInteger", "OverlapIndex", "Overlap", "minimum overlap order to output")
      +        selfobj.OverlapIndex = 2
      +        selfobj.Proxy = self
      +
      +    def execute(self,selfobj):
      +        import BOPTools
      +        import BOPTools.Utils as Utils
      +        from BOPTools.GeneralFuseResult import GeneralFuseResult
      +        
      +        list_of_shapes = [obj.Shape for obj in selfobj.Objects]
      +        if len(list_of_shapes) == 1 and list_of_shapes[0].ShapeType == "Compound":
      +            list_of_shapes = list_of_shapes[0].childShapes()
      +
      +        list_of_shapes = Utils.upgradeToAggregateIfNeeded(list_of_shapes)
      +        pieces, map = list_of_shapes[0].generalFuse(list_of_shapes[1:])
      +        gr = GeneralFuseResult(list_of_shapes, (pieces,map))
      +        gr.explodeCompounds()
      +        gr.splitAggregates()
      +        pieces_to_keep = []
      +        for piece in gr.pieces:
      +            if len(gr.sourcesOfPiece(piece)) >= selfobj.OverlapIndex:
      +                pieces_to_keep.append(piece)
      +        selfobj.Shape = BOPTools.ShapeMerge.mergeShapes(pieces_to_keep)
      +
      +class ViewProviderOverlap:
      +    def __init__(self,vobj):
      +        vobj.Proxy = self
      +       
      +    def getIcon(self):
      +        return ":/icons/Part_Overlap.svg"
      +
      +    def attach(self, vobj):
      +        self.ViewObject = vobj
      +        self.Object = vobj.Object
      +  
      +    def setEdit(self,vobj,mode):
      +        return False
      +    
      +    def unsetEdit(self,vobj,mode):
      +        return
      +
      +    def __getstate__(self):
      +        return None
      +
      +    def __setstate__(self,state):
      +        return None
      +
      +    def claimChildren(self):
      +        return self.Object.Objects
      +        
      +    def onDelete(self, feature, subelements): # subelements is a tuple of strings
      +        try:
      +            for f in self.Object.Objects:
      +                f.ViewObject.show()
      +        except Exception as err:
      +            App.Console.PrintError("Error in onDelete: " + err.message)
      +        return True
      +
      +class CommandMacroOverlap:
      +    "Command to create Overlap feature"
      +    def GetResources(self):
      +        return {'Pixmap'  : ":/icons/Part_Overlap.svg",
      +                'MenuText': "Overlap",
      +                'Accel': "",
      +                'ToolTip': "Macro_Overlap: alternative implementation of Part Overlap tool"}
      +
      +    def Activated(self):
      +        run()
      +    def IsActive(self):
      +        if App.ActiveDocument:
      +            return True
      +        else:
      +            return False
      +
      +if App.GuiUp:
      +    Gui.addCommand("Macro_Overlap", CommandMacroOverlap())
      +
      +def run():
      +    sel = Gui.Selection.getSelectionEx()
      +    try:
      +        if len(sel) < 1:
      +            raise Exception("Select two shapes to compute Overlap between, first! Then run this macro.")
      +        try:
      +            App.ActiveDocument.openTransaction("Macro Overlap")
      +            selfobj = makeOverlapFeature()
      +            selfobj.Objects = [it.Object for it in sel]
      +            for f in selfobj.Objects:
      +                f.ViewObject.hide()
      +            
      +            selfobj.Proxy.execute(selfobj)
      +        finally:
      +            App.ActiveDocument.commitTransaction()
      +    except Exception as err:
      +        from PySide import QtGui
      +        mb = QtGui.QMessageBox()
      +        mb.setIcon(mb.Icon.Warning)
      +        mb.setText(err.message)
      +        mb.setWindowTitle("Macro Overlap")
      +        mb.exec_() 
      +

      Overlap.FCMacro: +

      +
      __Title__ = "Macro Overlap"
      +__Author__ = "DeepSOIC"
      +__Version__ = "0.1"
      +__Date__    = "12/10/2016"
      +
      +__Comment__ = "Extension of Part Common boolean operation"
      +__Web__ = "http://forum.freecadweb.org/viewtopic.php?f=8&t=17755"
      +__Wiki__ = "http://www.freecadweb.org/wiki/index.php?title=Macro_Boolean_Overlap"
      +__Status__ = "experimental"
      +__Requires__ = "freecad 0.17.8053 with OCC 6.9.0+"
      +__Communication__ = "http://www.freecadweb.org/wiki/index.php?title=User:DeepSOIC" 
      +__Help__ = '''
      +Macro Overlap.
      +Requires FreeCAD v0.17.8053+ and OCC 6.9.0+
      +
      +Instructions:
      +Select three or more shapes to compute Overlap between. A single compound will do, too.
      +Then, run this macro. Parametric Overlap object is created.
      +'''
      +
      +import MacroOverlap
      +MacroOverlap.run() 
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Macro_PartToVRML.html b/localwiki/Macro_PartToVRML.html new file mode 100644 index 0000000..1ae07aa --- /dev/null +++ b/localwiki/Macro_PartToVRML.html @@ -0,0 +1,297 @@ +Macro PartToVRML

      Macro PartToVRML

      + +
      + + + + + + + + + + + + + + + + + + + + + + + + + + +
      +

      PartToVRML.png Macro Macro PartToVRML

      +
      Description +
      This macro converts selected parts to VRML meshes. +
      Author +
      Easyw-fc +
      Links +
      Macros recipes
      How to install macros
      How to customize toolbars +
      Version +
      1.9.2 +
      Date last modification +
      2016-02-22 +
      +

      + +
      +


      +

      +

      Description

      +

      This macro converts selected parts to VRML meshes for small size and faster loading (VRML models Kicad and Blender compatible) +

      +

      Script

      +

      The icone PartToVRML.png +

      Macro_PartToVRML.FCMacro +

      +
      +
      +# -*- coding: utf-8 -*-
      +
      +# PartToVRML.FCMacro
      +# creates VRML model of selected object(s), with colors (for Kicad and Blender compatibility)
      +# useful messages on Report view
      +#
      +
      +__title__ = "PartToVRML"
      +__author__ = "easyw-fc, hyOzd"
      +__url__     = "http://www.freecadweb.org/"
      +__version__ = "1.9.2"
      +__date__    = "22/02/2016"
      +
      +__Comment__ = "This macro creates VRML model of selected object(s), with colors (for Kicad and Blender compatibility)"
      +__Web__ = "http://www.freecadweb.org/"
      +__Wiki__ = "http://www.freecadweb.org/wiki/index.php?title=Macro_PartToVRML"
      +__Icon__  = "/usr/lib/freecad/Mod/plugins/icons/Macro_PartToVRML.png"
      +__IconW__  = "C:/Users/User Name/AppData/Roaming/FreeCAD/Macro_PartToVRML.png"
      +__Help__ = "start the macro and follow the instructions"
      +__Status__ = "stable"
      +__Requires__ = "Freecad"
      +
      +# FreeCAD VRML python exporter is free software: you can redistribute it
      +# and/or modify it under the terms of the GNU General Public License
      +# as published by the Free Software Foundation, either version 3 of
      +# the License, or (at your option) any later version.
      +#
      +# This sw is distributed in the hope that it will be
      +# useful, but WITHOUT ANY WARRANTY; without even the implied warranty
      +# of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
      +# General Public License for more details.
      +#
      +# You should have received a copy of the GNU General Public License
      +# along with expVrmlColor.FCMacro.  If not, see
      +# <http://www.gnu.org/licenses/>.
      +
      +## export VRML from FreeCAD is a python macro that will export simplified VRML of 
      +## a (multi)selected Part or fused Part to VRML optimized to Kicad and compatible with Blender
      +## the size of VRML is much smaller compared to the one exported from FC Gui
      +## and the loading/rendering time is smaller too
      +## change mesh deviation to increase quality of VRML
      +
      +## to do 
      +#  export material properties to vrml
      +
      +import FreeCAD,FreeCADGui,Part,Mesh
      +import PySide
      +from PySide import QtGui, QtCore
      +from collections import namedtuple
      +import sys, os
      +from os.path import expanduser
      +
      +#clearing previous messages
      +mw=Gui.getMainWindow()
      +c=mw.findChild(QtGui.QPlainTextEdit, "Python console")
      +c.clear()
      +r=mw.findChild(QtGui.QTextEdit, "Report view")
      +r.clear()
      +
      +def say(msg):
      +    FreeCAD.Console.PrintMessage(msg)
      +    FreeCAD.Console.PrintMessage('\n')
      +
      +# points: [Vector, Vector, ...]
      +# faces: [(pi, pi, pi), ], pi: point index
      +# color: (Red, Green, Blue), values range from 0 to 1.0
      +Mesh = namedtuple('Mesh', ['points', 'faces', 'color', 'transp'])
      +
      +def shapeToMesh(shape, color, transp, scale=None):
      +    mesh_deviation=0.03 #the smaller the best quality, 1 coarse; 0.03 good compromise :)
      +    mesh_data = shape.tessellate(mesh_deviation)
      +    points = mesh_data[0]
      +    if scale != None:
      +        points = map(lambda p: p*scale, points)
      +    newMesh= Mesh(points = points,
      +                faces = mesh_data[1],
      +                color = color, transp=transp)
      +    return newMesh
      +        
      +def exportVRML(objects, filepath):
      +    """Export given list of Mesh objects to a VRML file.
      +
      +    `Mesh` structure is defined at root."""
      +
      +    with open(filepath, 'w') as f:
      +        # write the standard VRML header
      +        f.write("#VRML V2.0 utf8\n\n")
      +        for obj in objects:
      +            f.write("Shape { geometry IndexedFaceSet \n{ coordIndex [")
      +            # write coordinate indexes for each face
      +            f.write(','.join("%d,%d,%d,-1" % f for f in obj.faces))
      +            f.write("]\n") # closes coordIndex
      +            f.write("coord Coordinate { point [")
      +            # write coordinate points for each vertex
      +            #f.write(','.join('%.3f %.3f %.3f' % (p.x, p.y, p.z) for p in obj.points))
      +            f.write(','.join('%.3f %.3f %.3f' % (p.x, p.y, p.z) for p in obj.points))
      +            f.write("]\n}") # closes Coordinate
      +            #shape_col=(1.0, 0.0, 0.0)#, 0.0)
      +            f.write("}\n") # closes points
      +            #say(obj.color)
      +            shape_col=obj.color[:-1] #remove last item
      +            #say(shape_col)
      +            shape_transparency=obj.transp
      +            f.write("appearance Appearance{material Material{diffuseColor %f %f %f\n" % shape_col)
      +            f.write("transparency %f}}" % shape_transparency)
      +            f.write("}\n") # closes Shape
      +        say(filepath+' written')
      +###
      +
      +def export(componentObjs, fullfilePathName, scale=None):
      +    """ Exports given ComponentModel object using FreeCAD.
      +
      +    `componentObjs` : a ComponentObjs list
      +    `fullfilePathName` : name of the FC file, extension is important
      +    
      +    """
      +    
      +    exp_name=componentObjs[0].Label
      +    path, fname = os.path.split(fullfilePathName)
      +    fname=os.path.splitext(fname)[0]
      +    if scale != None:
      +        filename=path+os.sep+exp_name+'.wrl'
      +    else:
      +        filename=path+os.sep+exp_name+'_1_1.wrl'
      +    say(filename)    
      +    color=[]
      +    Diffuse_color=[]
      +    transparency=[]
      +    for obj in componentObjs:
      +        say(obj.Label)
      +        color.append(Gui.ActiveDocument.getObject(obj.Name).ShapeColor)
      +        transparency.append(Gui.ActiveDocument.getObject(obj.Name).Transparency/100.0)
      +        #say("color")
      +        #say(Gui.ActiveDocument.getObject(obj.Name).DiffuseColor)
      +        Diffuse_color.append(Gui.ActiveDocument.getObject(obj.Name).DiffuseColor)
      +    i=0
      +    meshes=[]
      +    #say("diffuse color")
      +    #say(Diffuse_color)
      +    indexColor=0;
      +    color_vector=[]
      +    applyDiffuse=0
      +    for obj in componentObjs:
      +        shape1=obj.Shape
      +        single_color=Diffuse_color[i];
      +        #check lenght color
      +        #say("len color")
      +        #say(len(single_color))
      +        #colors less then faces
      +        if(len(single_color)!=len(shape1.Faces)):
      +            applyDiffuse=0;
      +            #copy color to all faces
      +        #else copy singolar colors for faces
      +        else:
      +            applyDiffuse=1;
      +            for color in single_color:
      +                color_vector.append(color)
      +        #say("color_vector")
      +        #say(color_vector)
      +        for index in range(len(shape1.Faces)):
      +            #say("color x")
      +            #say(color_vector[indexColor])
      +            singleFace=shape1.Faces[index]
      +            if(applyDiffuse):
      +                #say(color_vector[indexColor])
      +                meshes.append(shapeToMesh(singleFace, color_vector[indexColor], transparency[i], scale))
      +            else:
      +                #say(single_color[0])
      +                meshes.append(shapeToMesh(singleFace, single_color[0], transparency[i], scale))
      +            indexColor=indexColor+1
      +            #meshes.append(shapeToMesh(face, Diffuse_color[i], transparency[i], scale))
      +        color_vector=[]
      +        indexColor=0;
      +        i=i+1            
      +    exportVRML(meshes, filename)
      +    return
      +###
      +
      +def go_export():
      +    sel = FreeCADGui.Selection.getSelection()
      +    if not sel:
      +        FreeCAD.Console.PrintWarning("Select something first!\n\n")
      +        msg="export VRML from FreeCAD is a python macro that will export simplified VRML of "
      +        msg+="a (multi)selected Part or fused Part to VRML optimized to Kicad and compatible with Blender "
      +        msg+="the size of VRML is much smaller compared to the one exported from FC Gui "
      +        msg+="and the loading/rendering time is also smaller\n"
      +        msg+="change mesh deviation to increase quality of VRML"
      +        say(msg)
      +    else:
      +        objs = []
      +        for obj in sel:
      +                objs.append(obj)
      +                #say(obj.Label)
      +                #say(obj.Name)
      +        say(fullFilePathName)
      +        #say(objs)
      +        export(objs, fullFilePathName, scale=None)
      +        export(objs, fullFilePathName, 0.3937)
      +    
      +doc = FreeCAD.ActiveDocument
      +if doc!=None:
      +    fullFilePathName=doc.FileName
      +    if fullFilePathName=="":
      +        home = expanduser("~")
      +        fullFilePathName=home+os.sep+doc.Label+'.FCStd'
      +        say('path not found, saving to '+fullFilePathName)
      +        #say(fullFilePathName)
      +    else:
      +        fullFilePathName = os.path.dirname(os.path.abspath(fullFilePathName))
      +        fullFilePathName=fullFilePathName+os.sep+doc.Label+'.FCStd'
      +        say(fullFilePathName)
      +    go_export()
      +
      +
      +

      Links

      +

      The forum discussion export VRML from FreeCAD with python for smaller size, kicad and Blender compatible +

      The macro reverse, Macro_MeshToPart +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Macro_PartsLibrary.html b/localwiki/Macro_PartsLibrary.html new file mode 100644 index 0000000..a182991 --- /dev/null +++ b/localwiki/Macro_PartsLibrary.html @@ -0,0 +1,72 @@ +Macro PartsLibrary

      Macro PartsLibrary

      + +
      + + + + + + + + + + + + + + + + + + + + + + + + + + +
      +

      FreeCAD Doc.png Parts Library

      +
      Description +
      Starts the Parts Library browser FreeCAD +
      Author +
      yorik +
      Links +
      Macros recipes
      How to install macros
      How to customize toolbars +
      Version +
      01.00 +
      Date last modification +
      2014-03-25 +
      +

      Contents

      + +
      + +
      +


      +

      The FreeCAD Parts Library is a community effort to provide a free library of reusable Parts to be inserted into your projects. You are welcome to participate and submit parts to the library, but keep in mind you must have rights to share them. See the readme file for more details. +

      This macro, which is also included in the library, will show a browser panel inside the FreeCAD interface, from which you can easily browse the contents of the library, and insert a part into the current document, by double-clicking it. +

      Freecad-parts-library.jpg +

      Get the macro here: +

      http://github.com/yorikvanhavre/FreeCAD-library/blob/master/PartsLibrary.FCMacro +


      +

      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Macro_Perpendicular_To_Wire.gif b/localwiki/Macro_Perpendicular_To_Wire.gif new file mode 100644 index 0000000..6866369 Binary files /dev/null and b/localwiki/Macro_Perpendicular_To_Wire.gif differ diff --git a/localwiki/Macro_Perpendicular_To_Wire.html b/localwiki/Macro_Perpendicular_To_Wire.html new file mode 100644 index 0000000..9fe383e --- /dev/null +++ b/localwiki/Macro_Perpendicular_To_Wire.html @@ -0,0 +1,163 @@ +Macro Perpendicular To Wire

      Macro Perpendicular To Wire

      + +
      + + + + + + + + + + + + + + + + + + + + + + + + + + +
      +

      Macro Perpendicular To Wire.png Macro Perpendicular To Wire

      +
      Description +
      This macro positioned your object perpendicularly to wire selected. +
      Author +
      Mario52 +
      Links +
      Macros recipes
      How to install macros
      How to customize toolbars +
      Version +
      00.01 +
      Date last modification +
      2017-01-29 +
      +

      + +
      +


      +

      +

      Description

      +

      This macro positioned your object perpendicularly to wire selected. +

      +

      Use

      +
      1.  : select the path (May be an element or sub-element)
      2. +
      3.  : select the object to align
      4. +
      5.  : run the macro
      +

      Script

      +

      The icon toolBar Macro Perpendicular To Wire.png +

      Macro Perpendicular To Wire.FCMacro +

      +
      # -*- coding: utf-8 -*-
      +__title__   = "Macro Perpendicular To Wire"
      +__author__  = "Mario52"
      +__url__     = "https://www.freecadweb.org/wiki/index.php?title=Macro_Perpendicular_To_Wire"
      +__version__ = "00.01"
      +__date__ = "29/01/2017"
      +
      +import Draft, Part
      +
      +try:
      +    sel = FreeCADGui.Selection.getSelection()                               # Select an object
      +    
      +    lineSelected = FreeCADGui.Selection.getSelectionEx()[0].SubObjects[0]   # first object the Path object or SubObjects
      +    myCircle     = sel[1]                                                   # second object
      +    
      +    pointsDirection  = []
      +    
      +    pointsDirection = lineSelected.discretize(Number=500)                   # discretize the path line first selection
      +    
      +    v=pointsDirection[0].sub(pointsDirection[1])                            # avec vecteurs 1 et 2 (direction debut ligne)
      +    r=App.Rotation(App.Vector(0,0,1),v)
      +    
      +    pl=FreeCAD.Placement()                                                  # placement object
      +    pl.Rotation.Q = r.Q
      +    pl.Base = pointsDirection[0]
      +    myCircle.Placement = pl
      +    
      +    del pointsDirection[:]
      +    FreeCAD.ActiveDocument.recompute()
      +except Exception:
      +    print "Select twoo objects 1:The path 2:The objet to align" 
      +

      Options

      +

      Principle : +

      the line is cut in x points with "discretize()" (here Number=500 cuts begin 0 to 499 you can modify) +

      +
      pointsDirection = lineSelected.Shape.discretize(Number=500)             # discretize the path line first selection 
      +

      the perpendicularity is calculate between 2 points modify : +

      1: +

      +
      v=pointsDirection[0].sub(pointsDirection[1])          # perpendicular of first > second point 
      +

      Macro Perpendicular To Wire 01.png +

      +
      +

      2: +

      +
      v=pointsDirection[-1].sub(pointsDirection[-2])       # perpendicular of last > before last point
      +pl.Base = pointsDirection[-1]                        # position base last point 
      +

      Macro Perpendicular To Wire 02.png +

      +
      +

      3: +

      +
      v=pointsDirection[100].sub(pointsDirection[101])   # perpendicular of point 100 > point 101
      +pl.Base = pointsDirection[100]                     # position base point 100 
      +

      Macro Perpendicular To Wire 03.png +

      +
      +

      4: +

      +
      v=pointsDirection[0].sub(pointsDirection[-1])         # perpendicular of first point > last point
      +pl.Base = pointsDirection[0]                          # position base first point 
      +

      Macro Perpendicular To Wire 04.png +

      +
      +

      Example

      +

      Macro Perpendicular To Wire.gif +

      for discretize other parameters +

      +
      #http://forum.freecadweb.org/viewtopic.php?f=12&t=16336#p129468
      +#Discretizes the edge and returns a list of points.
      +#The function accepts keywords as argument:
      +#discretize(Number=n) => gives a list of 'n' equidistant points
      +#discretize(QuasiNumber=n) => gives a list of 'n' quasi equidistant points (is faster than the method above)
      +#discretize(Distance=d) => gives a list of equidistant points with distance 'd'
      +#discretize(Deflection=d) => gives a list of points with a maximum deflection 'd' to the edge
      +#discretize(QuasiDeflection=d) => gives a list of points with a maximum deflection 'd' to the edge (faster)
      +#discretize(Angular=a,Curvature=c,[Minimum=m]) => gives a list of points with an angular deflection of 'a'
      +#and a curvature deflection of 'c'. Optionally a minimum number of points
      +#can be set which by default is set to 2. 
      +

      The discussion on the forum [Spiralbohrer] +

      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Macro_Perpendicular_To_Wire.png b/localwiki/Macro_Perpendicular_To_Wire.png new file mode 100644 index 0000000..f18aabd Binary files /dev/null and b/localwiki/Macro_Perpendicular_To_Wire.png differ diff --git a/localwiki/Macro_Perpendicular_To_Wire_01.png b/localwiki/Macro_Perpendicular_To_Wire_01.png new file mode 100644 index 0000000..a0cb0b7 Binary files /dev/null and b/localwiki/Macro_Perpendicular_To_Wire_01.png differ diff --git a/localwiki/Macro_Perpendicular_To_Wire_02.png b/localwiki/Macro_Perpendicular_To_Wire_02.png new file mode 100644 index 0000000..d6bf01f Binary files /dev/null and b/localwiki/Macro_Perpendicular_To_Wire_02.png differ diff --git a/localwiki/Macro_Perpendicular_To_Wire_03.png b/localwiki/Macro_Perpendicular_To_Wire_03.png new file mode 100644 index 0000000..b976df2 Binary files /dev/null and b/localwiki/Macro_Perpendicular_To_Wire_03.png differ diff --git a/localwiki/Macro_Perpendicular_To_Wire_04.png b/localwiki/Macro_Perpendicular_To_Wire_04.png new file mode 100644 index 0000000..382f855 Binary files /dev/null and b/localwiki/Macro_Perpendicular_To_Wire_04.png differ diff --git a/localwiki/Macro_Print_SceneGraph.html b/localwiki/Macro_Print_SceneGraph.html new file mode 100644 index 0000000..c782715 --- /dev/null +++ b/localwiki/Macro_Print_SceneGraph.html @@ -0,0 +1,159 @@ +Macro Print SceneGraph

      Macro Print SceneGraph

      + +
      + + + + + + + + + + + + + + + + + + + + + + + + + + +
      +

      Text-x-python.png Macro_Print_SceneGraph

      +
      Description +
      Prints the SceneGraph +
      Author +
      Aleph0 +
      Links +
      Macros recipes
      How to install macros
      How to customize toolbars +
      Version +
      00.03 +
      Date last modification +
      2017-10-24 +
      +

      + +
      +


      +

      +

      Description

      +

      This macro traverses the SceneGraph and prints all the nodes and their fields in the Report View window. It can be used just for information or you can add code to modify parts of the SceneGraph in some way or print more details for particular types of node. +

      +
      # -*- coding: utf-8 -*-
      +"""
      +***************************************************************************
      +*                                                                         *
      +*   This macro traverses the SceneGraph and prints all the nodes and      *
      +*   their fields in the Report View window. It can be used just for       *
      +*   information or you can add code to modify parts of the SceneGraph in  *
      +*   some way or print more details for particular types of node.          *
      +*                                                                         *
      +***************************************************************************
      +*   Copyright © 2017 Richard P. Parkins, M. A.                          *
      +*                                                                         *
      +*   This file is a supplement to the FreeCAD CAx development system.      *
      +*                                                                         *
      +*   This program is free software; you can redistribute it and/or modify  *
      +*   it under the terms of the GNU Lesser General Public License (LGPL)    *
      +*   as published by the Free Software Foundation; either version 2 of     *
      +*   the License, or (at your option) any later version.                   *
      +*   for detail see the LICENCE text file.                                 *
      +*                                                                         *
      +*   This software is distributed in the hope that it will be useful,      *
      +*   but WITHOUT ANY WARRANTY; without even the implied warranty of        *
      +*   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the         *
      +*   GNU Library General Public License for more details.                  *
      +*                                                                         *
      +*   You should have received a copy of the GNU Library General Public     *
      +*   License along with this macro; if not, write to the Free Software     *
      +*   Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  *
      +*   USA                                                                   *
      +***************************************************************************
      +"""
      +__title__   = "Print_SceneGraph"
      +__author__  = "Aleph0"
      +__version__ = "00.03"
      +__date__    = "24/10/2017"
      +__Comment__ = "SceneGraph explorer"
      +__Wiki__ = "http://www.freecadweb.org/wiki/index.php?title=Macro_Print_SceneGraph"
      +__Help__ = "see first few lines of macro text"
      +__Status__ = "stable"
      +__Requires__ = "freecad 0.16"
      +#OS: Ubuntu 14.04.5 LTS
      +#Word size of OS: 64-bit
      +#Word size of FreeCAD: 64-bit
      +#Version: 0.16.6703 (Git)
      +#Build type: None
      +#Branch: releases/FreeCAD-0-16
      +#Hash: 2ce5c8d2e3020d05005ed71f710e09e9aa561f40
      +#Python version: 2.7.6
      +#Qt version: 4.8.6
      +#Coin version: 4.0.0a
      +#OCC version: 6.8.0.oce-0.17
      +
      +import FreeCAD
      +from pivy import coin
      +
      +def printFields(node,indent):
      +    nm = node.getName().__str__()
      +    if nm != "":
      +        FreeCAD.Console.PrintLog(indent+"name: "+nm+"\n") 
      +    fl = node.getFieldData()
      +    for i in range(fl.getNumFields()):
      +        name = fl.getFieldName(i)
      +        if name.__str__() != "point":
      +            val = node.getField(fl.getFieldName(i)).get()
      +            FreeCAD.Console.PrintLog(indent+str(name)+" -> "+str(val)+"\n")
      +
      +def printTree(node,indent):
      +    FreeCAD.Console.PrintLog(indent+node.__str__()+"\n")
      +    if node.getTypeId().getName().__str__() == "Coordinate3":
      +        points=node.point
      +        for i in range(points.getNum()):
      +            FreeCAD.Console.PrintLog(indent+" "+str(i)+": "+str(points[i].getValue())+"\n")
      +    if node.getTypeId().getName().__str__() == "Coordinate4":
      +        points=node.point
      +        for i in range(points.getNum()):
      +            FreeCAD.Console.PrintLog(indent+" "+str(i)+": "+str(points[i].getValue())+"\n")
      +    printFields(node,indent+" ")
      +    if node.getChildren().__str__() != "None":
      +        for i in range(node.getNumChildren()):
      +            printTree(node.getChild(i),indent+" ")
      +
      +ad = FreeCADGui.ActiveDocument
      +if ad == None:
      +    FreeCAD.Console.PrintLog("No active document\n")
      +else:
      +    QtGui.QApplication.setOverrideCursor(QtGui.QCursor(QtCore.Qt.WaitCursor))
      +    printTree(ad.ActiveView.getViewer().getSoEventManager().getSceneGraph(), "")
      +    QtGui.QApplication.restoreOverrideCursor() 
      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Macro_PropertyMemo.html b/localwiki/Macro_PropertyMemo.html new file mode 100644 index 0000000..631ec24 --- /dev/null +++ b/localwiki/Macro_PropertyMemo.html @@ -0,0 +1,401 @@ +Macro PropertyMemo

      Macro PropertyMemo

      + +
      + + + + + + + + + + + + + + + + + + + + + + + + + + +
      +

      PropertyMemo.png Macro_PropertyMemo

      +
      Description +
      This little macro create one Property additional (memo or other text) for you object (only Draft). +
      Author +
      Mario52 +
      Links +
      Macros recipes
      How to install macros
      How to customize toolbars +
      Version +
      00.02 +
      Date last modification +
      2015-10-19 +
      +

      + +
      +


      +

      +

      Description

      +

      This little macro create one Property additional (memo or other text) for you object (only Draft) +

      Addin one property Memo > Name +

      +

      Uses

      +

      Launch the macro select one object Draft complete the fields and apply. One new property is created in Combo view > Property > Data tab +

      +
      • Property title = title of new property (Default: Memo)
      • +
      • Property name = name of field property
      +
      One Property Memo is adding
      +
      • Memo : Property title here Memo
      • +
      • Name : Property name here Name
      • +
      • The field is free to manually complete
      +
      +

      I the checkBox is checked you ave one memo in list, click to teh tree point for open the list window +

      +
      + +
      +
      +


      +

      +

      Script

      +

      Macro_FCPropertyMemo.FCMacro +

      The icon for the ToolBar PropertyMemo.png +

      +
      # -*- coding: utf-8 -*-
      +from __future__ import unicode_literals
      +"""
      +***************************************************************************
      +*   Copyright (c) 2015 <mario52>                                          *
      +*                                                                         *
      +*   This file is a supplement to the FreeCAD CAx development system.      *
      +*                                                                         *
      +*   This program is free software; you can redistribute it and/or modify  *
      +*   it under the terms of the GNU Lesser General Public License (LGPL)    *
      +*   as published by the Free Software Foundation; either version 2 of     *
      +*   the License, or (at your option) any later version.                   *
      +*   for detail see the LICENCE text file.                                 *
      +*                                                                         *
      +*   This software is distributed in the hope that it will be useful,      *
      +*   but WITHOUT ANY WARRANTY; without even the implied warranty of        *
      +*   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the         *
      +*   GNU Library General Public License for more details.                  *
      +*                                                                         *
      +*   You should have received a copy of the GNU Library General Public     *
      +*   License along with this macro; if not, write to the Free Software     *
      +*   Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  *
      +*   USA                                                                   *
      +***************************************************************************
      +*           WARNING! All changes in this file will be lost and            *  
      +*                  may cause malfunction of the program                   *
      +***************************************************************************
      +"""
      +#Macro_FCMemo 28/09/2015 /19/10/2015
      +#
      +
      +#OS: Windows 8
      +#Word size of OS: 64-bit
      +#Word size of FreeCAD: 64-bit
      +#Version: 0.15.4671 (Git)
      +#Branch: releases/FreeCAD-0-15
      +#Hash: 244b3aef360841646cbfe80a1b225c8b39c8380c
      +#Python version: 2.7.8
      +#Qt version: 4.8.6
      +#Coin version: 4.0.0a
      +#OCC version: 6.8.0.oce-0.17
      +#
      +
      +__title__="Macro_FCPropertyMemo"
      +__author__ = "Mario52"
      +__url__     = "http://www.freecadweb.org/index-fr.html"
      +__version__ = "00.02"
      +__date__    = "19/10/2015"
      +
      +try:
      +    import PyQt4
      +    from PyQt4 import QtGui ,QtCore
      +    from PyQt4.QtGui import *
      +    from PyQt4.QtCore import *
      +except Exception:
      +    import PySide
      +    from PySide import QtGui ,QtCore
      +    from PySide.QtGui import *
      +    from PySide.QtCore import *
      +#import Draft, Part, FreeCAD, math, PartGui, FreeCADGui, FreeCAD
      +
      +global path
      +#path = FreeCAD.ConfigGet("AppHomePath")
      +path = FreeCAD.ConfigGet("UserAppData")
      +
      +global title_01 ; title_01  = "Memo"    # title of menu
      +global title_02 ; title_02  = ""        # title of propriety
      +global memo_01  ; memo_01   = ""        # memo
      +global forString; forString = 0         # memo for String or List
      +
      +try:
      +    _fromUtf8 = QtCore.QString.fromUtf8
      +except AttributeError:
      +    def _fromUtf8(s):
      +        return s
      +
      +try:
      +    _encoding = QtGui.QApplication.UnicodeUTF8
      +    def _translate(context, text, disambig):
      +        return QtGui.QApplication.translate(context, text, disambig, _encoding)
      +except AttributeError:
      +    def _translate(context, text, disambig):
      +        return QtGui.QApplication.translate(context, text, disambig)
      +
      +class Ui_MainWindow(object):
      +
      +    def setupUi(self, MainWindow):
      +        self.window = MainWindow
      +        global path
      +        global title_01
      +        global title_02
      +        global memo_01
      +
      +        MainWindow.setObjectName(_fromUtf8("MainWindow"))
      +        MainWindow.resize(254, 163)
      +#        MainWindow.resize(241, 211)
      +        MainWindow.setMinimumSize(QtCore.QSize(254, 163))
      +        MainWindow.setMaximumSize(QtCore.QSize(254, 163))
      +        self.centralwidget = QtGui.QWidget(MainWindow)
      +        self.centralwidget.setObjectName(_fromUtf8("centralwidget"))
      +
      +        self.PB_Button_01 = QtGui.QPushButton(self.centralwidget)
      +        self.PB_Button_01.setGeometry(QtCore.QRect(20, 130, 61, 23))
      +#        self.PB_Button_01.setGeometry(QtCore.QRect(20, 180, 61, 23))
      +        self.PB_Button_01.setObjectName(_fromUtf8("PB_Button_01"))
      +        self.PB_Button_01.clicked.connect(self.on_PB_Button_01_clicked)    #
      +
      +        self.PB_Button_02 = QtGui.QPushButton(self.centralwidget)
      +        self.PB_Button_02.setGeometry(QtCore.QRect(95, 130, 61, 23))
      +#        self.PB_Button_02.setGeometry(QtCore.QRect(90, 180, 61, 23))
      +        self.PB_Button_02.setObjectName(_fromUtf8("PB_Button_02"))
      +        self.PB_Button_02.clicked.connect(self.on_PB_Button_02_clicked)    #
      +
      +        self.PB_Button_03 = QtGui.QPushButton(self.centralwidget)
      +        self.PB_Button_03.setGeometry(QtCore.QRect(170, 130, 61, 23))
      +#        self.PB_Button_03.setGeometry(QtCore.QRect(160, 180, 61, 23))
      +        self.PB_Button_03.setObjectName(_fromUtf8("PB_Button_03"))
      +        self.PB_Button_03.clicked.connect(self.on_PB_Button_03_clicked)    #
      +
      +        self.LE_Edit_01 = QtGui.QLineEdit(self.centralwidget)              # title
      +        self.LE_Edit_01.setGeometry(QtCore.QRect(20, 50, 211, 20))
      +#        self.LE_Edit_01.setGeometry(QtCore.QRect(20, 50, 201, 20))
      +        self.LE_Edit_01.setObjectName(_fromUtf8("LE_Edit_01"))
      +        self.LE_Edit_01.setText(_fromUtf8(title_01))
      +        self.LE_Edit_01.setToolTip("Title of menu property")
      +        self.LE_Edit_01.textChanged.connect(self.on_LE_Edit_01_Pressed)    # title property
      +
      +        self.LE_Edit_02 = QtGui.QLineEdit(self.centralwidget)
      +        self.LE_Edit_02.setGeometry(QtCore.QRect(20, 100, 211, 20))
      +#        self.LE_Edit_02.setGeometry(QtCore.QRect(20, 100, 201, 20))
      +        self.LE_Edit_02.setObjectName(_fromUtf8("LE_Edit_02"))
      +        self.LE_Edit_02.setText(_fromUtf8(""))
      +        self.LE_Edit_02.setToolTip("Title of property")
      +        self.LE_Edit_02.textChanged.connect(self.on_LE_Edit_02_Pressed)    #
      +
      +#        self.LE_Edit_03 = QtGui.QLineEdit(self.centralwidget)              # memo 
      +#        self.LE_Edit_03.setGeometry(QtCore.QRect(20, 150, 201, 20))
      +#        self.LE_Edit_03.setObjectName(_fromUtf8("LE_Edit_03"))
      +#        self.LE_Edit_03.setText(_fromUtf8(""))
      +#        self.LE_Edit_03.setToolTip("Text memo for property")
      +#        self.LE_Edit_03.textChanged.connect(self.on_LE_Edit_03_Pressed)    #
      +
      +        MainWindow.setCentralWidget(self.centralwidget)
      +
      +        self.label_00 = QtGui.QLabel(self.centralwidget)
      +        self.label_00.setGeometry(QtCore.QRect(70, 10, 120, 21))
      +        font = QtGui.QFont()
      +        font.setPointSize(10)
      +        font.setBold(True)
      +        font.setUnderline(True)
      +        font.setWeight(75)
      +        self.label_00.setFont(font)
      +        self.label_00.setObjectName(_fromUtf8("label_00"))
      +
      +        self.label_01 = QtGui.QLabel(self.centralwidget)
      +        self.label_01.setGeometry(QtCore.QRect(20, 30, 111, 16))
      +        self.label_01.setObjectName(_fromUtf8("label_01"))
      +
      +        self.label_02 = QtGui.QLabel(self.centralwidget)
      +        self.label_02.setGeometry(QtCore.QRect(20, 80, 111, 16))
      +        self.label_02.setObjectName(_fromUtf8("label_02"))
      +
      +#        self.label_03 = QtGui.QLabel(self.centralwidget)
      +#        self.label_03.setGeometry(QtCore.QRect(20, 130, 121, 16))
      +#        self.label_03.setObjectName(_fromUtf8("label_03"))
      +
      +        self.CB_String = QtGui.QCheckBox(self.centralwidget)                # for String or List
      +#        self.CB_String.setGeometry(QtCore.QRect(130, 130, 91, 20))
      +        self.CB_String.setGeometry(QtCore.QRect(120, 80, 120, 20))
      +        self.CB_String.setObjectName(_fromUtf8("CB_String"))
      +        self.CB_String.setToolTip("The memo is a string by default"+"\n"+"If the checkBox is checked the memo is a list in one window"+"\n"+"Clic the '...' in ComboView > Data")
      +        self.CB_String.clicked.connect(self.on_CB_String_clicked)           # connect on def "on_checkBox_1_clicked"
      +
      +        self.retranslateUi(MainWindow)
      +        QtCore.QMetaObject.connectSlotsByName(MainWindow)
      +
      +    def retranslateUi(self, MainWindow):
      +        try:
      +            MainWindow.setWindowFlags(PyQt4.QtCore.Qt.WindowStaysOnTopHint)         # PyQt4 cette fonction met la fenêtre en avant
      +        except Exception:
      +            MainWindow.setWindowFlags(PySide.QtCore.Qt.WindowStaysOnTopHint)        # PySide cette fonction met la fenêtre en avant
      +        MainWindow.setWindowTitle("FCPropertyMemo")
      +        self.PB_Button_01.setText("Reset")
      +        self.PB_Button_01.setToolTip("Reset the TextEdit")
      +        self.PB_Button_02.setText("Validate")
      +        self.PB_Button_02.setToolTip("Validate and apply")
      +        self.PB_Button_03.setText("Quit")
      +
      +        self.PB_Button_03.setToolTip("Quit the FCPropertyMemo")
      +        self.label_00.setText("FCPropertyMemo")
      +        self.label_01.setText("Property title")
      +        self.label_02.setText("Property name")
      +#        self.label_03.setText("Memo")
      +        self.CB_String.setText("Chek for List")
      +
      +    def on_LE_Edit_01_Pressed(self):        # Line edit 01 title
      +        global title_01
      +        title_01 = self.LE_Edit_01.text()
      +#        App.Console.PrintMessage(title_01+"\n")
      +
      +    def on_LE_Edit_02_Pressed(self):        # Line edit 02 title property
      +        global title_02
      +        title_02 = self.LE_Edit_02.text()
      +#        App.Console.PrintMessage(title_02+"\n")
      +
      +#    def on_LE_Edit_03_Pressed(self):        # Line edit 03 memo
      +#        global memo_01
      +#        memo_01 = self.LE_Edit_03.text()
      +#        App.Console.PrintMessage(memo_01+"\n")
      +
      +    def on_CB_String_clicked(self):         # connection on_checkBox_1_clicked
      +        global forString
      +        if self.CB_String.isChecked():      # if checkbox_01 is checked then ....
      +            forString = 1
      +            self.CB_String.setText("UnCheck for String")
      +        else :
      +            forString = 0
      +            self.CB_String.setText("Check for List")
      +#        App.Console.PrintMessage("on_CB_String_clicked "+str(forString)+"\n")
      +
      +    def on_PB_Button_01_clicked(self):      # Button Reset
      +        global title_01
      +        global title_02
      +        global memo_01
      +        global forString
      +        self.LE_Edit_01.clear()
      +        title_01 = "Memo"
      +        self.LE_Edit_01.setText(_fromUtf8(title_01))
      +        self.LE_Edit_02.clear()
      +        title_02 = ""
      +#        self.LE_Edit_03.clear()
      +#        memo_01 = ""
      +        self.CB_String.setChecked(False)                                                    # Check by default True or False
      +        self.CB_String.setText("Check for List")
      +        forString = 0
      +#        App.Console.PrintMessage("on_PB_Button_01_clicked\n")
      +
      +    def on_PB_Button_02_clicked(self):      # Button Validate
      +        global title_01
      +        global title_02
      +        global memo_01
      +        global forString
      +        try:
      +            obj = FreeCADGui.Selection.getSelection()[0]
      +            obj = App.ActiveDocument.ActiveObject
      +            op  = obj.PropertiesList
      +            pas = 0
      +            if (title_02 != ""):
      +                for p in op:
      +                    if str(p) == title_02:
      +                        App.Console.PrintWarning("This Property is already present"+"\n")
      +                        pas = 0
      +                        break
      +                    else :
      +                        pas = 1
      +                if pas == 1:
      +                        if forString == 0 :
      +                            a = obj.addProperty("App::PropertyString",title_02,title_01,"_Memo")        # create a memo string
      +                        else :
      +                            a = obj.addProperty("App::PropertyStringList",title_02,title_01,"_Memo")    # Create a list in window
      +                        Gui.Selection.clearSelection(obj.Name)
      +                        Gui.Selection.addSelection(obj)
      +                        App.activeDocument().recompute()
      +                ff = ui                         # Reset
      +                ff.on_PB_Button_01_clicked()    # Reset
      +            else:
      +                App.Console.PrintMessage("Field empty"+"\n")
      +
      +        except Exception:
      +                    App.Console.PrintWarning("Object not selected or not Draft object"+"\n")
      +                
      +#        App.Console.PrintMessage("on_PB_Button_02_clicked\n")
      +
      +    def on_PB_Button_03_clicked(self):      # Button Quit
      +        App.Console.PrintMessage("End FCPropertyMemo"+"\n\n")
      +        self.window.hide()
      +
      +MainWindow = QtGui.QMainWindow()
      +ui = Ui_MainWindow()
      +ui.setupUi(MainWindow)
      +MainWindow.show() 
      +

      Link

      +

      The discussion on the forum Object description field +

      My macros on mario52a gists +

      +

      Version

      +
      • ver 00.02 19/10/2015 : add checkBox for choice memo String or memo List
      +


      +

      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Macro_Python_Assistant_Window.html b/localwiki/Macro_Python_Assistant_Window.html new file mode 100644 index 0000000..6d47a29 --- /dev/null +++ b/localwiki/Macro_Python_Assistant_Window.html @@ -0,0 +1,458 @@ +Macro Python Assistant Window

      Macro Python Assistant Window

      + +
      + + + + + + + + + + + + + + + + + + + + + + + + + + +
      +

      Macro Python Assistant Window.png Macro Python Assistant Window

      +
      Description +
      This macro provides a cut/copy/paste workspace for Python code, it is segmented so different sections can be selected and it is persistent between FreeCAD sessions. +
      Author +
      Piffpoof +
      Links +
      Macros recipes
      How to install macros
      How to customize toolbars +
      Version +
      1.0 +
      Date last modification +
      2015-01-21 +
      +

      + +
      +


      +

      One of Python's powerful aspects is the Python Console which serves both as an output device and a dynamic interpreter of source code. The Python Assistant Window (subsequently referred to as 'PAW') provides additional functionality to the Python Console. +

      PythonAssistantWindowScreenSnapshot.jpg +

      +

      Description

      +

      As a modern development environment, Python has a lot of advantages over older languages and their development environments. One large benefit is the Python Console where code can be interactively entered and the results received. Those results can then be copied and used to either build up Python source code (in a source editor) or pasted back into the Python Console in an altered form to receive further output. This is a very powerful method of developing code. +

      As powerful as it may be, two readily apparent shortcomings with the Python Console are: +

      +
      • the console is of limited size and the results of your work from 20 minutes ago may be scrolled far off the screen, they are not lost but they are awkward to retrieve
      • +
      • the console is cleared each time you quite your FreeCAD session, the console is empty (aside from the Python startup message) next time you start FreeCAD
      +

      The PAW provides the following: +

      +
      • it is persistent between FreeCAD sessions, things will not "disappear" from it unless the user removes them
      • +
      • it has a contextual menu that allows the following: +
        • the standard editing operands: Copy & Paste & Select All
        • +
        • Copy a selection to the Python Console
        • +
        • Copy the complete contents of the PAW to the Python Console
        • +
        • Append the contents of the Python Console to the PAW
        • +
        • insert textual markers that facilitate management of the text
        • +
        • selection between any two consecutive markers
        • +
        • remove the prefix ">>> " which the Python Console uses to denote output
        • +
        • reduce multiple blank lines to single blank lines
        • +
        • personalise the working environment by managing the PAW (as well as the main FreeCAD window) by a slider-based GUI
      +

      Installation

      +

      All the code for pythonAssistantWindow.FCMacro is in one macro. So installation is comprised of copying the code to the appropriate Macro directory and invoking pythonAssistantWindow from the Macro menu, the Python console or a toolbar button (the preferred method). +

      + +

      Note: A global variable within FreeCAD is used to coordinate the persistent storage. +

      Note: A text file in the "UserAppData" directory is used to store the textual contents of the PAW between FreeCAD sessions. +

      +

      Usage

      +

      The PAW is best used as a button on a toolbar. It can be run from the Macro Menu or the code pasted onto the Python Console but the latter two options really detract from it's ease of use. +

      When FreeCAD is started there will be no sign of the PAW, other than a button on a toolbar. Clicking the button will cause: +

      +
      • the PAW to open in the lower right corner +
        • the default settings are for the about 1/3 of the screen width to be dedicated to the PAW with the remainder being used by the main FreeCAD window, the height of the PAW will be about 1/3 of the window height
      • +
      • the contents of the PAW when it last ran will appear in the window - there should be no difference from the last time it was used +
        • if the PAW has not run before then the contents will be empty
      • +
      • if the PAW is already open but hidden by other windows then it will be raised to the top so that it becomes visible
      • +
      • closing the PAW will cause the contents to be written to file and the window will close - there is no Dialog asking whether to save or not
      • +
      • however there is a Dialog asking whether to save if FreeCAD is quit (Menu->Quit FreeCAD) with unsaved changes in thePAW
      +

      Most of the functionality for the PAW is provided by the contextual menu, the options are: +

      +
      • Copy
        - provide the standard Copy function
      • +
      • Copy selection to console
        - the current selection is copied to the end of the Python Console
      • +
      • Copy contents to console
        - the complete contents of the PAW is copied to the end of the Python Console
      • +
      • Paste
        - provide the standard Paste function
      • +
      • Append contents of Python Console to PAW
        - the copies of the Python Console are placed at the end of the PAW - note that the contents of the Python Console may be a mixture of Python Code, output from Python Code, error message text, output from any part of FreeCAD
      • +
      • Select between Markers
        - markers are used to divide up the text of the PAW into sections, once the contents are in sections then a section can be selected individually and worked with (e.g. Copy, Copy to the Python Console, Delete). The intention of Markers is to allow separate and unrelated sequences of Python statement to exist in the PAW, and then be managed and worked with individually.
      • +
      • Select all
        - provide the standard Select All function
      • +
      • Clearbr
        - provide the standard Clear function where all the text in the PAW is deleted
      • +
      • Insert marker
        - insert a textual Marker at the current cursor location
      • +
      • Remove ">>> "
        - after Python Console output is copied to the PAW, any lines which were output from executed Python commands will be prefixed with ">>> ", this option removed those prefixes so the output can be used as context free data
      • +
      • Reduce multiple blank lines to single blank lines
        - compacts the text by removing multiple blank lines
      • +
      • Alter GUI settings
        - brings up a modal window with three controls:
      • +
      • PythonAssistantWindowGui2.jpg +
        • a slider to set the percentage of the screen width dedicated to the PAW (remembering that there is a certain width which the FreeCAD main window will not go below)
        • +
        • a slider to set the percentage of the height of the screen dedicated to the PAW
        • +
        • a pair of radio buttons to indicate whether the PAW should be placed at the top or bottom of the left hand side of the screen
      • +
      • Save as file
        - the contents of the PAW window are written out to a user selected file - the contents of the PAW are not altered
      • +
      • Close window
        - the PAW window is closed and the contents written out to the persistent storage file
        Note: there is no Dialog asking about saving, it is done automatically
      +

      User Interface

      +

      The user interface is a simple text editing window, there is one button to start the PAW and a contextual menu of options to perform on the text in the text editing window. The options are described in the Usage section. +

      +

      Examples

      +

      A First Example +

      In January your co-worker needs some help with the Python code to update a file. You write and debug it on your computer and send him the source code. You have come up with 3 different ways to do the job and are not sure which is the best to keep. You copy all 3 finished versions to the PAW and separate them by Markers. +

      As the month of May starts, you are happily working on the bottle project using FreeCAD. There is some problem getting the exact Python code to generate what is required so you model this graphically and the equivalent Python code is generated on the Python Console. Using PAW you copy the contents of the Python Console to the PAW. You shape it by moving it back and running, copying the results, modifying them in PAW and copying them back until you are happy. +

      The next Monday your boss rushed over to say that there is a big requirement for a CAD operator at the plant where they are having problems with the folding sequence for the new packaging stream. You will fly there the same day and be there for 2 weeks. You complete your assignment and return to your normal office space. +

      When you get back it is obvious that people have been using your area for a lunch area so you have to clean up a bit. Upon starting FreeCAD and clicking the PAW button on the toolbar, your work from before is sitting there as if it is from the day before. You realise that the solution to your bottle design lies in the file code you wrote back in January along with what you left 2 weeks earlier. Quickly you can select and copy the code segments to the Python Console to execute and fine tune them. +

      Once the code is stable then you can save it to a file for either e Python file or a FreeCAD macro file. +

      Another Example +

      You are trying to find out what is going wrong with the Rotation values of various objects in an Assembly. Out of 27 objects you can't see any pattern as to which objects will be affected. So you put a few lines of Python together to isolate the incorrect objects, paste it into the PAW. Then take a couple of lines of Python to get the Label and Rotation values, paste that code to the PAW as well. Copy the code to detail all the objects you need to see listed and repeat it for each object - all in the PAW. The Python Console will have all these results (including any typing errors and error messages) but it will have scrolled off the visible portion of the window long ago. So now you have a concise set of Python lines, you copy it from the PAW, paste it into the Python Console and there is the exact list of the objects which need debugging - along with their specific values. If needed you could then paste the results from the Python Console back into the PAW - prefix it with the Python comment character ('#') if you want to save it in the Python code and keep it executable. Finally you can save this conglomeration to a file from the PAW so it is secure on disk. Ready for the next time you need to steal or adapt the logic in the code. +

      +

      Options

      +

      About the only option for the PAW is the ability to alter it's initial display size and shape in accordance with the size and shape fo the main FreeCAD window. There are 3 constant values in the Python code which initial size and placement of the PAW. +

      +

      Remarks

      +

      There is a very simple proof of concept for a persistent storage work in this code. It may be of use to anyone else requiring such a capacity. +

      +

      Links

      +

      none (so far) +

      +

      Script

      +
      If the script listing does not end with FreeCAD version information and a last line of "thus ends the macro..." then the Wiki has eaten the script again and you will have to download or copy it from [unabbreviated script on pastebin.com]
      +


      +

      +
      #
      +#
      +#Python Assistant Window
      +#v 0.1 initial release
      +#
      +#
      +#***********************************************************************************
      +#
      +# provide a text editing window with functions to aid in coding Python within FreeCAD
      +#
      +############ To Do ############
      +# - contextual window doesn't fire if cursor is on last position in file
      +# - executing "from PySide import QtGui, QtCore" on console seems to close window
      +# - is it possible to copy code to console and then select and execute it?
      +##############################
      +#***********************************************************************************
      +# The next three variables define the width and height and vertical positioning
      +# of the Python Assistant Window
      +# 'pawWidthPercent' specifies the percentage of the screen width to be assigned to the Python Assistant Window
      +# 'pawHeightPercent' specifies the percentage of the screen height to be assigned to the Python Assistant Window
      +# 'pawAtBottomFlag' specifies if the Python Assistant Window is at the top or the bottom
      +# The Python Assistant Window is automatically placed at the left,
      +# so pawWidthPercent = 26, pawHeightPercent = 41, pawAtBottomFlag = False will cause the
      +# following:
      +# 1) the main FreeCAD window will be placed in the upper left corner of the screen,
      +# it's height will be 100% of the screen height,
      +# it's width will be 74% (=100%-26%) of the screen
      +# 2) the Python Assistant Window will be placed in the left side of the screen,
      +# it's height will be 41% of the screen height,
      +# it's width will be 26% of the screen
      +# it will be at the top (leaving empty space below it)
      +# The empty space (either above or below the Python Assistant Window),
      +# is left for the text editor (for editing the Macros) to be placed in.
      +#
      +pawWidthPercentInitial= 37.5 # percent of the screen width
      +pawHeightPercentInitial= 32.0 # percent of the screen height
      +pawAtBottomFlagInitial= True
      +#***********************************************************************************
      +# import statements
      +import sys, operator, os
      +from os.path import expanduser
      +from PySide import QtGui, QtCore
      +
      +# UI Class definitions
      +
      +class PythonAssistantWindow(QtGui.QMainWindow):
      +""""""
      +def __init__(self, pythonTextToEdit):
      +self.textIn = pythonTextToEdit
      +super(PythonAssistantWindow, self).__init__()
      +self.initUI(pythonTextToEdit)
      +def initUI(self, pythonTextToEdit):
      +"""Constructor"""
      +# set default return value and pointer to subsequent child window
      +self.result= userCancelled
      +self.childWindow= None
      +self.alertWindow= None
      +# set window dimensions for Python Advisor Window from the constants at the top of Macro file
      +self.pawWinWidth= pawWidthPercentInitial/100.0 * availableWidth
      +self.pawWinHeight= pawHeightPercentInitial/100.0 * availableHeight
      +self.left= screenWidth - self.pawWinWidth
      +if pawAtBottomFlagInitial:
      +self.top= screenHeight - self.pawWinHeight
      +else:
      +self.top= 0
      +self.editorHeight= self.pawWinHeight
      +# set dimensions for main FreeCAD window
      +self.mainWinWidth= availableWidth - (self.pawWinWidth+interWindowGap)
      +self.mainWinHeight= availableHeight
      +# define main window
      +FreeCADGui.getMainWindow().setGeometry(0, 0, self.mainWinWidth, self.mainWinHeight)
      +# now set up this window
      +self.setGeometry(self.left, self.top, self.pawWinWidth, self.pawWinHeight)
      +self.setWindowTitle("Python Assistant Window")
      +#
      +centralWidget =  QtGui.QWidget(self)
      +layout =  QtGui.QGridLayout()
      +centralWidget.setLayout(layout)
      +# set up text editing widget
      +self.text_editor = QtGui.QPlainTextEdit(self)
      +self.text_editor.move(0,0)
      +self.text_editor.resize(self.pawWinWidth,self.editorHeight)
      +self.text_editor.appendPlainText(self.textIn)
      +self.text_editor.setSizePolicy(QtGui.QSizePolicy.Expanding,QtGui.QSizePolicy.Expanding)
      +self.text_editor.textChanged.connect(self.onTextChanged)
      +# set up a monospace font for the text editor to match the Python console
      +font = QtGui.QFont()
      +font.setFamily("Courier")
      +font.setStyleHint(QtGui.QFont.Monospace)
      +font.setFixedPitch(True)
      +font.setPointSize(12)
      +self.text_editor.setFont(font)
      +#self.text_editor.cursorPositionChanged.connect(self.onCursorPosition)
      +self.cursor = self.text_editor.textCursor()
      +# populate layout
      +layout.addWidget(self.text_editor,0,0)
      +self.setCentralWidget(centralWidget)
      +# set contextual menu options for text editing widget
      +# menu dividers
      +mnuDivider1 = QtGui.QAction(self)
      +mnuDivider1.setText(menuDividerText)
      +mnuDivider1.triggered.connect(self.onMenuDivider)
      +mnuDivider2 = QtGui.QAction(self)
      +mnuDivider2.setText(menuDividerText)
      +mnuDivider2.triggered.connect(self.onMenuDivider)
      +mnuDivider3 = QtGui.QAction(self)
      +mnuDivider3.setText(menuDividerText)
      +mnuDivider3.triggered.connect(self.onMenuDivider)
      +mnuDivider4 = QtGui.QAction(self)
      +mnuDivider4.setText(menuDividerText)
      +mnuDivider4.triggered.connect(self.onMenuDivider)
      +# clear text
      +mnuClear = QtGui.QAction(self)
      +mnuClear.setText("Clear")
      +mnuClear.triggered.connect(self.onClear)
      +# paste copy/paste buffer
      +mnuPaste = QtGui.QAction(self)
      +mnuPaste.setText("Paste")
      +mnuPaste.triggered.connect(self.onPaste)
      +# paste contents of console
      +mnuAppendFromConsole = QtGui.QAction(self)
      +mnuAppendFromConsole.setText("Append contents of console")
      +mnuAppendFromConsole.triggered.connect(self.onAppendFromConsole)
      +# select between markers
      +mnuSelectMarkers = QtGui.QAction(self)
      +mnuSelectMarkers.setText("Select between markers")
      +mnuSelectMarkers.triggered.connect(self.onSelectMarkers)
      +# select all
      +mnuSelectAll = QtGui.QAction(self)
      +mnuSelectAll.setText("Select all")
      +mnuSelectAll.triggered.connect(self.onSelectAll)
      +# insert marker
      +mnuInsertMarker = QtGui.QAction(self)
      +mnuInsertMarker.setText("Insert marker")
      +mnuInsertMarker.triggered.connect(self.onInsertMarker)
      +# remove console generated ">>> " character strings
      +mnuStripPrefix = QtGui.QAction(self)
      +mnuStripPrefix.setText("Remove '>>> '")
      +mnuStripPrefix.triggered.connect(self.onStripPrefix)
      +# remove blank lines
      +mnuReduceBlankLines = QtGui.QAction(self)
      +mnuReduceBlankLines.setText("Delete multiple blank lines")
      +mnuReduceBlankLines.triggered.connect(self.onReduceBlankLines)
      +# copy selection
      +mnuCopy = QtGui.QAction(self)
      +mnuCopy.setText("Copy")
      +mnuCopy.triggered.connect(self.onCopy)
      +# copy selection to console
      +mnuCopySelectionToConsole = QtGui.QAction(self)
      +mnuCopySelectionToConsole.setText("Copy selection to console")
      +mnuCopySelectionToConsole.triggered.connect(self.onCopySelectionToConsole)
      +# copy to console
      +mnuCopyToConsole = QtGui.QAction(self)
      +mnuCopyToConsole.setText("Copy contents to console")
      +mnuCopyToConsole.triggered.connect(self.onCopyToConsole)
      +# save as file
      +mnuSaveAsFile = QtGui.QAction(self)
      +mnuSaveAsFile.setText("Save contents to file")
      +mnuSaveAsFile.triggered.connect(self.onSaveAsFile)
      +# close window
      +mnuCloseWindow = QtGui.QAction(self)
      +mnuCloseWindow.setText("Close window")
      +mnuCloseWindow.triggered.connect(self.onCloseWindow)
      +# alter GUI settings
      +mnuSettings = QtGui.QAction(self)
      +mnuSettings.setText("=Alter GUI settings=")
      +mnuSettings.triggered.connect(self.onSettings)
      +# define menu and add options
      +self.text_editor.setContextMenuPolicy(QtCore.Qt.ActionsContextMenu)
      +self.text_editor.addAction(mnuCopy)
      +self.text_editor.addAction(mnuCopySelectionToConsole)
      +self.text_editor.addAction(mnuCopyToConsole)
      +self.text_editor.addAction(mnuDivider1)
      +self.text_editor.addAction(mnuPaste)
      +self.text_editor.addAction(mnuAppendFromConsole)
      +self.text_editor.addAction(mnuSelectMarkers)
      +self.text_editor.addAction(mnuSelectAll)
      +self.text_editor.addAction(mnuClear)
      +self.text_editor.addAction(mnuDivider2)
      +self.text_editor.addAction(mnuInsertMarker)
      +self.text_editor.addAction(mnuStripPrefix)
      +self.text_editor.addAction(mnuReduceBlankLines)
      +self.text_editor.addAction(mnuDivider3)
      +self.text_editor.addAction(mnuSaveAsFile)
      +self.text_editor.addAction(mnuSettings)
      +self.text_editor.addAction(mnuCloseWindow)
      +#
      +self.show()
      +#----------------------------------------------------------------------
      +def onMenuDivider(self):
      +# just a divider in the menu so we don't do anything
      +pass
      +def onClear(self):
      +# clear editing field
      +self.text_editor.clear()
      +def onPaste(self):
      +# paste contents of system copy/paste buffer into QPlainTextEdit field
      +self.text_editor.paste()
      +def onAppendFromConsole(self):
      +# copy text from "Python console"
      +mainWindow= FreeCADGui.getMainWindow()
      +pcDW= mainWindow.findChild(QtGui.QDockWidget, "Python console")
      +pcPTE= pcDW.findChild(QtGui.QPlainTextEdit, "Python console")
      +consoleStr= pcPTE.document().toPlainText()
      +self.text_editor.appendPlainText(copyFromConsoleText)
      +self.text_editor.appendPlainText("")
      +self.text_editor.appendPlainText(consoleStr)
      +def onCopy(self):
      +# copy selected text to system copy/paste buffer
      +self.text_editor.copy()
      +def onCopySelectionToConsole(self):
      +# copy selected text to "Python console"
      +mainWindow= FreeCADGui.getMainWindow()
      +pcDW= mainWindow.findChild(QtGui.QDockWidget, "Python console")
      +pcPTE= pcDW.findChild(QtGui.QPlainTextEdit, "Python console")
      +#
      +cursor= self.text_editor.textCursor()
      +cursorText= self.text_editor.toPlainText()
      +textToCopy = cursorText[cursor.selectionStart():cursor.selectionEnd()]
      +if len(textToCopy)>0:
      +pcPTE.appendPlainText(textToCopy)
      +def onCopyToConsole(self):
      +# copy text to "Python console"
      +mainWindow= FreeCADGui.getMainWindow()
      +pcDW= mainWindow.findChild(QtGui.QDockWidget, "Python console")
      +pcPTE= pcDW.findChild(QtGui.QPlainTextEdit, "Python console")
      +pcPTE.appendPlainText(copyToConsoleText)
      +pcPTE.appendPlainText()
      +def onInsertMarker(self):
      +# insert marker
      +self.text_editor.insertPlainText(markerText)
      +def onStripPrefix(self):
      +# strip out ">>> " from text edit window
      +self.text_editor.selectAll()
      +if len(self.text_editor.toPlainText())>0:
      +self.text_editor.selectAll()
      +tmp = self.text_editor.toPlainText()
      +self.text_editor.clear()
      +self.text_editor.appendPlainText(tmp.replace(">>> ",""))
      +def onReduceBlankLines(self):
      +# reduce multiple blank lines to single blank lines
      +contents = self.text_editor.toPlainText()
      +self.text_editor.clear()
      +self.text_editor.appendPlainText(os.linesep.join([s for s in contents.splitlines() if s]))
      +def onSelectMarkers(self):
      +cursor= self.text_editor.textCursor()
      +cursorText= self.text_editor.toPlainText()
      +bNum = cursor.blockNumber(); cNum = cursor.columnNumber()
      +pos = cursor.position(); cursorTextLength = len(cursorText)
      +occurrences = [i for i in range(len(cursorText)) if cursorText.startswith(markerText, i)]
      +if len(occurrences)==0:
      +self.alertWindow = QtGui.QMessageBox()
      +self.alertWindow.setText("There are no markers...")
      +self.alertWindow.show()
      +elif len(occurrences)==1:
      +hdrStart = occurrences[0]
      +hdrEnd = hdrStart + markerTextLength
      +if pos<hdrStart:
      +selectStart = 0; selectEnd = hdrStart
      +self.cursor.setPosition(selectStart)
      +self.cursor.setPosition(selectEnd, QtGui.QTextCursor.KeepAnchor)
      +self.text_editor.setTextCursor(self.cursor)
      +if pos>hdrEnd:
      +selectStart = hdrEnd; selectEnd = cursorTextLength
      +self.cursor.setPosition(selectStart)
      +self.cursor.setPosition(selectEnd, QtGui.QTextCursor.KeepAnchor)
      +self.text_editor.setTextCursor(self.cursor)
      +else:
      +startOccurrences = list(); endOccurrences = list(occurrences)
      +for i in range(len(occurrences)):
      +startOccurrences.append(occurrences[i] + markerTextLength + 1)
      +startOccurrences.insert( 0, 0)
      +endOccurrences.insert( len(occurrences), cursorTextLength)
      +for i in range(len(occurrences)+1):
      +if startOccurrences[i]<pos<endOccurrences[i]:
      +if i==0:
      +selectStart = startOccurrences[i]
      +else:
      +selectStart = startOccurrences[i]-1
      +selectEnd = endOccurrences[i]
      +self.cursor.setPosition(selectStart)
      +self.cursor.setPosition(selectEnd, QtGui.QTextCursor.KeepAnchor)
      +self.text_editor.setTextCursor(self.cursor)
      +break
      +def onSelectAll(self):
      +self.text_editor.selectAll()
      +def onCloseWindow(self):
      +self.close()
      +def onSettings(self):
      +# get new width (as %), height (as %), vertical flag
      +self.childWindow = GetGuiConfigParams(self)
      +pass
      +def onTextChanged(self):
      +FreeCAD.PythonAssistantWindowStatus[1] = True
      +def onCursorPosition(self):
      +#print ("Line: {} 
      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Macro_Recompute_Profiler.html b/localwiki/Macro_Recompute_Profiler.html new file mode 100644 index 0000000..90b21ae --- /dev/null +++ b/localwiki/Macro_Recompute_Profiler.html @@ -0,0 +1,260 @@ +Macro Recompute Profiler

      Macro Recompute Profiler

      + +
      + + + + + + + + + + + + + + + + + + + + + + + + + + +
      +

      Text-x-python.png Macro Recompute Profiler

      +
      Description +
      Measures time it takes to recompute each feature in your project +
      Author +
      DeepSOIC +
      Links +
      Macros recipes
      How to install macros
      How to customize toolbars +
      Version +
      0.1 +
      Date last modification +
      2017-04-03 +
      +

      + +
      +


      +

      +

      Description

      +

      This macro is to help you find, what features cause long delays in updates to the project. It performs a recompute, measuring the time it takes to recompute each feature. +

      +

      How to use

      +

      This macro requires FreeCAD no less than 0.17.10644 +

      Save the macro to a file. +

      1. Open your project +

      2. Right-click an object in model tree, pick "Mark to recompute" +

      3. Run this macro. +

      A progress bar will appear. As each object is recomputed, a line is printed to Report View, containing the time and the label of the object. If any object fails to recompute, the macro will display an error message and terminate the process. +

      +

      Post-processing results

      +

      The output of the macro will be interleaved with general messages produced by recomputing features. It generally looks like this: +

      +
      Recomputing... (time in seconds, label)
      +Sketcher::setUpSketch()-T:0
      +Sketcher::Solve()-DogLeg-T:0
      +0.00999999046326Sketch - master section
      +0.0199999809265Clone of Sketch - master section (2D)001
      +Sketcher::setUpSketch()-T:0
      +Sketcher::Solve()-DogLeg-T:0
      +0.00999999046326Sketch013
      +Sketcher::setUpSketch()-T:0
      +Sketcher::Solve()-DogLeg-T:0
      +0.00999999046326Sketch011
      +0.0Clone of Sketch - master section (2D)
      +Sketcher::setUpSketch()-T:0
      +Sketcher::Solve()-DogLeg-T:0
      +0.0Sketch008
      +0.130000114441LinearArray
      +Sketcher::setUpSketch()-T:0
      +Sketcher::Solve()-DogLeg-T:0
      +... 
      +

      The result lines have an easy signature to separate them off: they start with a tab. So, if you copy-paste the whole chunk to a spreadsheet program, generic messages will end up in column 1, while the results are in columns 2 and 3. So, you can sort by column 2, to get a nice table like that: +

      +
      0.59100008Slice
      +0.352999926Populate LinearArray with Compound
      +0.160000086CompoundFilter
      +0.138999939Cut
      +0.130000114LinearArray
      +0.108999968Fusion
      +0.069999933Moved CompoundFilter
      +0.067000151Module - spokes
      +0.029999971Sweep
      +0.019999981Clone of Sketch - master section (2D)001
      +0.010999918ArrayFilter003
      +... 
      +

      (For MS-Excel, pasting right after copying text from report view doesn't split it into columns, don't know why... pasting the text to Notepad and re-copying it from Notepad and pasting to excel helps.) +

      +

      Macro

      +

      RecomputeProfiler.FCMacro +

      +
      __Title__="Macro Recompute Profiler"
      +__Author__ = "DeepSOIC"
      +__Version__ = "0.1"
      +__Date__    = "03.04.2017"
      +
      +__Comment__ = "Measures time it takes to recmpute features in a project"
      +__Wiki__ = "https://www.freecadweb.org/wiki/index.php?title=Macro_Recompute_Profiler"
      +__Help__ = "Right-click an object, and pick 'Mark to recompute', then run this macro. This will only profile recomputing the subgraph. To profile the whole project, right-click the project in tree view, and pick 'Mark to recompute', then run this macro. Results will be printed to report view."
      +__Status__ = "experimental"
      +__Requires__ = "freecad 0.17.10644"
      +__Communication__ = "https://forum.freecadweb.org/memberlist.php?mode=viewprofile&u=3888" 
      +
      +import FreeCAD as App
      +
      +import FreeCADGui as Gui
      +
      +class ExecutionError(Exception):
      +    pass
      +
      +class CancelError(Exception):
      +    pass
      +
      +def execute(feature):
      +    feature.recompute()
      +    if 'Invalid' in feature.State:
      +        raise ExecutionError("Feature '{label}' failed to recompute".format(label= feature.Label))
      +
      +def msgbox(title, text):
      +    from PySide import QtGui
      +    mb = QtGui.QMessageBox()
      +    mb.setIcon(mb.Icon.Information)
      +    mb.setText(text)
      +    mb.setWindowTitle(title)
      +    mb.exec_()
      +
      +def log(string):
      +    App.Console.PrintWarning(string+"\n")
      +
      +def getAllDependent(feat_list):
      +    '''getAllDependent(feat_list): gets all features that depend on features in feat_list, directly or indirectly.
      +    Returns a set. Features from feat_list are not included, unless there are interdependencies between them.'''
      +
      +    list_traversing_now = feat_list
      +    set_of_deps = set()
      +    list_of_deps = []
      +
      +    while len(list_traversing_now) > 0:
      +        list_to_be_traversed_next = []
      +        for feat in list_traversing_now:
      +            for dep in feat.InList:
      +                if not (dep in set_of_deps):
      +                    set_of_deps.add(dep)
      +                    list_of_deps.append(dep)
      +                    list_to_be_traversed_next.append(dep)
      +
      +        list_traversing_now = list_to_be_traversed_next
      +
      +    return set_of_deps
      +
      +
      +def run():
      +    touched = [obj for obj in App.ActiveDocument.Objects if 'Touched' in obj.State]
      +
      +    if len(touched) == 0:
      +        App.ActiveDocument.RecomputesFrozen = True
      +        msgbox("Macro Recompute Profiler", "Project was switched to suspend recomputes. Please modify an object that triggers a recompute, and run this macro again. The macro will perform a step-by-step recompute, and measure the time it takes to recompute features.")
      +        return
      +
      +    log("{n} features are touched".format(n= len(touched)))
      +
      +    log("Generating execution order...")
      +
      +    to_be_executed = set.union(getAllDependent(touched), set(touched))
      +    log("Number of features to execute: {n}".format(n= len(to_be_executed)))
      +
      +    exec_list = []
      +    for obj in App.ActiveDocument.TopologicalSortedObjects[::-1]:
      +        if obj in to_be_executed:
      +            exec_list.append(obj)
      +    assert(len(exec_list) == len(to_be_executed))
      +    n = len(exec_list)
      +
      +    log("Execution order:")
      +    for obj in exec_list:
      +        log("    "+obj.Label)
      +
      +
      +    import PySide
      +    progress = PySide.QtGui.QProgressDialog(u"Preparing to recompute....", u"Abort", 0, n+1)
      +    progress.setModal(True)
      +    progress.show()
      +    
      +    try:
      +        log("Recomputing... (time in seconds, label)")
      +        import time
      +        for obj in exec_list:
      +            progress.setValue(progress.value()+1)
      +            progress.setLabelText("Recomputing {feature}...".format(feature= obj.Label))
      +            if progress.wasCanceled():
      +                raise CancelError()
      +
      +            time_start = time.time()
      +            try:
      +                execute(obj)
      +            finally:
      +                exec_time = time.time()-time_start
      +                log("\t{time}\t{label}".format(time= exec_time, label= obj.Label))
      +
      +        progress.setValue(n+1)
      +        msgbox("Macro Recompute Profiler", "Recompute completed. Results are in report view.")
      +
      +        for obj in exec_list:
      +            obj.purgeTouched()
      +
      +    except Exception as err:
      +        msgbox("Macro Recompute Profiler", "An error occured: {err}".format(err= str(err)))
      +    finally:
      +        progress.hide()
      +        App.ActiveDocument.RecomputesFrozen = False
      +
      +run() 
      +

      FC version

      +

      This macro requires FreeCAD no less than 0.17.10644, which was the version where App.ActiveDocument.RecomputesFrozen became available. It might be functional with a bit older FreeCAD, but certainly won't work with v0.16. +

      This macro was created using this version of FreeCAD: +

      +
      OS: Windows 10
      +Word size of OS: 64-bit
      +Word size of FreeCAD: 64-bit
      +Version: 0.17.10665 (Git)
      +Build type: Release
      +Branch: master
      +Hash: 47847513a85ff6615774ef628230f79e37471daf
      +Python version: 2.7.8
      +Qt version: 4.8.7
      +Coin version: 4.0.0a
      +OCC version: 7.0.0 
      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Macro_Rectellipse.html b/localwiki/Macro_Rectellipse.html new file mode 100644 index 0000000..ab56eff --- /dev/null +++ b/localwiki/Macro_Rectellipse.html @@ -0,0 +1,130 @@ +Macro Rectellipse

      Macro Rectellipse

      + +
      + + + + + + + + + + + + + + + + + + + + + + + + + + +
      +

      Text-x-python.png Rectellipse Macro

      +
      Description +
      Creates a parametric rectellipse +
      Author +
      fcaponi78 +
      Links +
      Macros recipes
      How to install macros
      How to customize toolbars +
      Version +
      1.0 +
      Date last modification +
      2013-12-24 +
      +

      Contents

      + +
      + +
      +


      +

      Creates a parametric rectellipse +

      Rectellipse.png +

      +
      +
      from __future__ import division # allows floating point division from integers
      +import FreeCAD, Part, math
      +from FreeCAD import Base
      +
      +class RectEllipseShape:
      +   def __init__(self, obj):
      +      ''' Add the properties: Radius, Eccentricity, Height, Segments (see Property View) '''
      +      obj.addProperty("App::PropertyLength","a","Rectellipse","A - horizontal radius").a = 16.0
      +      obj.addProperty("App::PropertyLength","b","Rectellipse","B - vertical radius").b = 9.0
      +      obj.addProperty("App::PropertyFloat","n","Rectellipse","N ").n=0.2
      +      obj.addProperty("App::PropertyBool","createFace","Rectellipse","Wheter to create a face or not").createFace=True
      +      obj.Proxy = self
      +
      +   def onChanged(self, fp, prop):
      +      if prop == "a" or prop == "b" or prop == "n" or prop == "segments" or prop == "height" or prop == "createFace":
      +         #if one of these is changed
      +         self.execute(fp)
      +
      +   def execute(self, fp):
      +      r1=fp.a
      +      r2=fp.b
      +      s=fp.n
      +      z=0.0
      +      p=1.0
      +      ####w=2**0.5/2.0 #Ellipse
      +      w=2**0.5/2.0/(1-s**p)
      +      curve=Part.BSplineCurve()
      +      curve.setPeriodic()
      +      curve.increaseDegree(2) #quadratic
      +      curve.insertKnots([i*1.0/(4) for i in (1,2,3)],[2]*(3)) #5Knots 8 Poles
      +      curve.setPole(1,FreeCAD.Vector(0,-r2,z),1)
      +      curve.setPole(2,FreeCAD.Vector(-r1,-r2,z),w)
      +      curve.setPole(3,FreeCAD.Vector(-r1,0,z),1)
      +      curve.setPole(4,FreeCAD.Vector(-r1,r2,z),w)
      +      curve.setPole(5,FreeCAD.Vector(0,r2,z),1)
      +      curve.setPole(6,FreeCAD.Vector(r1,r2,z),w)
      +      curve.setPole(7,FreeCAD.Vector(r1,0,z),1)
      +      curve.setPole(8,FreeCAD.Vector(r1,-r2,z),w)
      +      if fp.createFace == True:
      +         fp.Shape = Part.Face(Part.Wire(curve.toShape()))
      +      else:
      +         fp.Shape = curve.toShape()
      +
      +def makeRectellipseBlock():
      +   doc = FreeCAD.activeDocument()
      +   if doc == None:
      +      doc = FreeCAD.newDocument()
      +   obj=doc.addObject("Part::FeaturePython","RectEllipseShape") #add object to document
      +   obj.Label = "RectEllipsse"
      +   RectEllipseShape(obj)
      +   obj.ViewObject.Proxy=0
      +   viewObject = Gui.ActiveDocument.getObject(obj.Name)
      +   viewObject.ShapeColor = (0.00,0.33,1.00)
      +   viewObject.DisplayMode = "Flat Lines"
      +   obj.Shape.check()
      +
      +if __name__ == "__main__":
      +   #feature will be generated after macro execution
      +   makeRectellipseBlock() 
      +

      Get the code from Github here! +

      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Macro_Remove_parametric_history.html b/localwiki/Macro_Remove_parametric_history.html new file mode 100644 index 0000000..ef89ee5 --- /dev/null +++ b/localwiki/Macro_Remove_parametric_history.html @@ -0,0 +1,86 @@ +Macro Remove parametric history

      Macro Remove parametric history

      + +
      + + + + + + + + + + + + + + + + + + + + + + + + + + +
      +

      Text-x-python.png Remove parametric history

      +
      Description +
      This will remove all parametric associativity from an object, leaving it as a "dumb" shape +
      Author +
      Yorik +
      Links +
      Macros recipes
      How to install macros
      How to customize toolbars +
      Version +
      1.0 +
      Date last modification +
      2011-08-01 +
      +

      + +
      +


      +

      +

      Description

      +

      This will remove all parametric associativity from an object, leaving it as a "dumb" shape +


      +Before and after: +


      +

      +
      RPH before.png
      RPH after.png +
      +

      Script

      +

      Remove parametric history.FCMacro +

      +
      originalObject = FreeCAD.ActiveDocument.ActiveObject
      +newShape = originalObject.Shape.copy()
      +newName = FreeCAD.ActiveDocument.ActiveObject.Name
      +FreeCAD.ActiveDocument.removeObject(newName)
      +newObject = FreeCAD.ActiveDocument.addObject("Part::Feature",newName)
      +newObject.Shape = newShape 
      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Macro_Replace_Part_in_Assembly.html b/localwiki/Macro_Replace_Part_in_Assembly.html new file mode 100644 index 0000000..2a5bbc4 --- /dev/null +++ b/localwiki/Macro_Replace_Part_in_Assembly.html @@ -0,0 +1,662 @@ +Macro Replace Part in Assembly

      Macro Replace Part in Assembly

      + +
      + + + + + + + + + + + + + + + + + + + + + + + + + + +
      +

      Replace Part.png Macro Replace Part in Assembly

      +
      Description +
      Replaces Part in Assembly +
      Author +
      ralvejd +
      Links +
      Macros recipes
      How to install macros
      How to customize toolbars +
      Version +
      1.0 +
      Date last modification +
      2014-09-10 +
      +

      + +
      +


      +

      Especially when doing "Assemblies" with simple copies of parts, one needs to replace one part by another from time to time. +Then you can use this macro do do this. +

      +

      Use

      +

      Be sure to have your files containing the old part and the new part open. +

      +
      1. Run the macro.
      2. +
      3. Select the appropriate FreeCAD-document and select the new part in the tree-view.
      4. +
      5. Then click on "Select New Part".
      6. +
      7. Select the appropriate FreeCAD-document and select the part to be replaced in the tree-view.
      8. +
      9. Then click on "Select Old Part".
      10. +
      11. Use the other options to your liking.
      12. +
      13. Then click on "Replace Old Part".
      +


      +Macro Replace Part in Assembly.jpg +

      See also Demo on Youtube. +

      +

      Script

      +

      Macro Replace_Part_in_Assembly.py +

      +
      #!/usr/bin/env python
      +# -*- coding: utf-8 -*-
      +
      +"""
      +Macro to replace parts in assembly FreeCAD.
      +Version 0.1 from 20140910
      +
      +********************************************************************************************
      +*   Copyright (c) 2013 Joakim Isaksson <ralvejd[at]users.sourceforge.net>          *
      +*                                                                                                                                       *
      +*   This file is a supplement to the FreeCAD CAx development system.                *
      +*                                                                                                                                       *
      +*   This program is free software; you can redistribute it and/or modify                  *
      +*   it under the terms of the GNU Lesser General Public License (LGPL)               *
      +*   as published by the Free Software Foundation; either version 2 of                    *
      +*   the License, or (at your option) any later version.                                                  *
      +*   for detail see the LICENCE text file.                                                                        *
      +*                                                                                                                                        *
      +*   This software is distributed in the hope that it will be useful,                                  *
      +*   but WITHOUT ANY WARRANTY; without even the implied warranty of                *
      +*   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the *
      +*   GNU Library General Public License for more details.                                           *
      +*                                                                                                                                          *
      +*   You should have received a copy of the GNU Library General Public                    *
      +*   License along with this macro; if not, write to the Free Software                            *
      +*   Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307              *
      +*   USA                                                                                                                                *
      +*                                                                                                                                           *
      +***********************************************************************************************
      +"""
      +
      +__author__ = "Joakim Isaksson <ralvejd[at]users.sourceforge.net>"
      +
      +
      +import FreeCAD, Part, math
      +from FreeCAD import Base
      +import DraftVecUtils
      +import sys
      +try:
      +   from PySide import QtCore, QtGui
      +   from PySide.QtCore import SIGNAL, QTimer
      +   from PySide.QtGui import QApplication
      +except:
      +   from PyQt4 import QtCore, QtGui
      +   from PyQt4.QtCore import SIGNAL, QTimer
      +   from PyQt4.QtGui import QApplication
      +
      +try:
      +   _fromUtf8 = QtCore.QString.fromUtf8
      +except AttributeError:
      +   _fromUtf8 = lambda s: s
      +
      +try:
      +   _encoding = QtGui.QApplication.UnicodeUTF8
      +   def _translate(context, text, disambig):
      +      return QtGui.QApplication.translate(context, text, disambig, _encoding)
      +except AttributeError:
      +   def _translate(context, text, disambig):
      +      return QtGui.QApplication.translate(context, text, disambig)
      +
      +#                     [document , name, label, position, rotation, group]
      +global newpart ; newpart = [ "" , "", "" , "", "" , "" ] ;
      +global oldpart ; oldpart = [ "" , "", "" , "", "" , "" ] ;
      +global newPartName ; newPartName = ""
      +global newPartLabel ; newPartLabel = ""
      +global uiRowOffset ; uiRowOffset = 30
      +global uiColWidth ; uiColWidth = 150
      +global uiPad ; uiPad = 5
      +global uiMainWidth ; uiMainWidth = 400
      +
      +class Ui_ReplacePart(object):
      +
      +   def setupUi(self, ReplacePart):
      +      global uiMainWidth
      +      global uiRowOffset
      +      global uiColWidth
      +      global uiPad
      +      uiTextPartWidth = uiMainWidth -(3*uiPad)-uiColWidth
      +
      +      ReplacePart.setObjectName(_fromUtf8("ReplacePart"))
      +      ReplacePart.setLocale(QtCore.QLocale(QtCore.QLocale.English, QtCore.QLocale.UnitedKingdom))   
      +
      +      captionFont = QtGui.QFont()
      +      captionFont.setBold(True)
      +
      +      self.centralWidget = QtGui.QWidget(ReplacePart)
      +      self.centralWidget.setObjectName(_fromUtf8("centralWidget"))
      +      
      +      """
      +      #*** FIXME ***----------------------------
      +      #self.centralWidget.setAttribute(QtCore.Qt.WA_DeleteOnClose)
      +      self.centralWidget.setAttribute(QtCore.Qt.WA_DeleteOnClose, True)
      +      #*** FIXME ***----------------------------
      +      """
      +      
      +      self.groupBoxNewName = QtGui.QButtonGroup()
      +      self.groupBoxNewLabel = QtGui.QButtonGroup()
      +      self.groupBoxColorFrom = QtGui.QButtonGroup()
      +
      +      self.labelCapSelected = QtGui.QLabel(self.centralWidget)
      +      self.labelCapSelected.setGeometry(QtCore.QRect(uiPad, uiPad, uiColWidth, uiRowOffset-10))
      +      self.labelCapSelected.setAlignment(QtCore.Qt.AlignRight)
      +      self.labelCapSelected.setFont(captionFont)
      +      self.labelCapSelected.setObjectName(_fromUtf8("labelCapSelected"))
      +
      +      self.labelSelected = QtGui.QLabel(self.centralWidget)
      +      self.labelSelected.setGeometry(QtCore.QRect(uiColWidth+(2*uiPad), uiPad, uiTextPartWidth, uiRowOffset-10))
      +      self.labelSelected.setObjectName(_fromUtf8("labelSelected"))
      +
      +      row = uiPad+uiRowOffset   
      +      self.pushButtonNew = QtGui.QPushButton(self.centralWidget)
      +      self.pushButtonNew.setGeometry(QtCore.QRect(uiPad, row, uiColWidth, uiRowOffset-2))
      +      self.pushButtonNew.setObjectName(_fromUtf8("pushButtonNew"))
      +      self.pushButtonNew.clicked.connect(self.on_pushButtonNew_clicked)   
      +
      +      self.labelNew = QtGui.QLabel(self.centralWidget)
      +      self.labelNew.setGeometry(QtCore.QRect(uiColWidth+(2*uiPad), row, uiTextPartWidth, uiRowOffset-2))
      +      self.labelNew.setObjectName(_fromUtf8("labelNew"))
      +
      +      row = row+uiRowOffset
      +      self.pushButtonOld = QtGui.QPushButton(self.centralWidget)
      +      self.pushButtonOld.setGeometry(QtCore.QRect(uiPad, row, uiColWidth, uiRowOffset-2))
      +      self.pushButtonOld.setObjectName(_fromUtf8("pushButtonOld"))
      +      self.pushButtonOld.clicked.connect(self.on_pushButtonOld_clicked)
      +
      +      self.LabelOld = QtGui.QLabel(self.centralWidget)
      +      self.LabelOld.setGeometry(QtCore.QRect(uiColWidth+(2*uiPad), row, uiTextPartWidth, uiRowOffset-2))
      +      self.LabelOld.setObjectName(_fromUtf8("labelOld"))
      +
      +      row = row+uiRowOffset
      +      self.pushButtonOk = QtGui.QPushButton(self.centralWidget)
      +      self.pushButtonOk.setGeometry(QtCore.QRect(uiPad, row, uiColWidth, uiRowOffset-2))
      +      self.pushButtonOk.setObjectName(_fromUtf8("pushButtonOk"))
      +      self.pushButtonOk.setEnabled(False)
      +      self.pushButtonOk.clicked.connect(self.on_pushButtonOk_clicked)
      +
      +      row = row+uiRowOffset+uiPad
      +      self.labelCapNewName = QtGui.QLabel(self.centralWidget)
      +      self.labelCapNewName.setGeometry(QtCore.QRect(uiPad, row, uiColWidth, uiRowOffset-10))
      +      self.labelCapNewName.setFont(captionFont)
      +      self.labelCapNewName.setObjectName(_fromUtf8("labelCapNewName"))
      +
      +      self.labelCapNewLabel = QtGui.QLabel(self.centralWidget)
      +      self.labelCapNewLabel.setGeometry(QtCore.QRect(uiColWidth+(2*uiPad), row, uiColWidth, uiRowOffset-10))
      +      self.labelCapNewLabel.setFont(captionFont)
      +      self.labelCapNewLabel.setObjectName(_fromUtf8("labelCapNewLabel"))
      +
      +      row = row+uiRowOffset
      +      self.radioButtonNameFromNewDoc = QtGui.QRadioButton(self.centralWidget)
      +      self.radioButtonNameFromNewDoc.setGeometry(QtCore.QRect(uiPad, row, uiColWidth, uiRowOffset-2))
      +      self.radioButtonNameFromNewDoc.setObjectName(_fromUtf8("radioButtonNameFromNewDoc"))
      +      self.radioButtonNameFromNewDoc.clicked.connect(self.on_radioButtonNameFromNewDoc_clicked)
      +
      +      self.radioButtonLabelFromNewDoc = QtGui.QRadioButton(self.centralWidget)
      +      self.radioButtonLabelFromNewDoc.setGeometry(QtCore.QRect(uiColWidth+(2*uiPad), row, uiColWidth, uiRowOffset-2))
      +      self.radioButtonLabelFromNewDoc.setObjectName(_fromUtf8("radioButtonLabelFromNewDoc"))
      +      self.radioButtonLabelFromNewDoc.clicked.connect(self.on_radioButtonLabelFromNewDoc_clicked)
      +
      +      row = row+uiRowOffset
      +      self.radioButtonNameFromNewName = QtGui.QRadioButton(self.centralWidget)
      +      self.radioButtonNameFromNewName.setGeometry(QtCore.QRect(uiPad, row, uiColWidth, uiRowOffset-2))
      +      self.radioButtonNameFromNewName.setObjectName(_fromUtf8("radioButtonNameFromNewName"))
      +      self.radioButtonNameFromNewName.clicked.connect(self.on_radioButtonNameFromNewName_clicked)
      +
      +      self.radioButtonLabelFromNewName = QtGui.QRadioButton(self.centralWidget)
      +      self.radioButtonLabelFromNewName.setGeometry(QtCore.QRect(uiColWidth+(2*uiPad), row, uiColWidth, uiRowOffset-2))
      +      self.radioButtonLabelFromNewName.setObjectName(_fromUtf8("radioButtonLabelFromNewName"))
      +      self.radioButtonLabelFromNewName.clicked.connect(self.on_radioButtonLabelFromNewName_clicked)
      +
      +      row = row+uiRowOffset
      +      self.radioButtonNameFromNewLabel = QtGui.QRadioButton(self.centralWidget)
      +      self.radioButtonNameFromNewLabel.setGeometry(QtCore.QRect(uiPad, row, uiColWidth, uiRowOffset-2))
      +      self.radioButtonNameFromNewLabel.setObjectName(_fromUtf8("radioButtonNameFromNewLabel"))
      +      self.radioButtonNameFromNewLabel.clicked.connect(self.on_radioButtonNameFromNewLabel_clicked)
      +
      +      self.radioButtonLabelFromNewLabel = QtGui.QRadioButton(self.centralWidget)
      +      self.radioButtonLabelFromNewLabel.setGeometry(QtCore.QRect(uiColWidth+(2*uiPad), row, uiColWidth, uiRowOffset-2))
      +      self.radioButtonLabelFromNewLabel.setObjectName(_fromUtf8("radioButtonLabelFromNewLabel"))
      +      self.radioButtonLabelFromNewLabel.clicked.connect(self.on_radioButtonLabelFromNewLabel_clicked)
      +
      +      row = row+uiRowOffset
      +      self.radioButtonNameFromOldName = QtGui.QRadioButton(self.centralWidget)
      +      self.radioButtonNameFromOldName.setGeometry(QtCore.QRect(uiPad, row, uiColWidth, uiRowOffset-2))
      +      self.radioButtonNameFromOldName.setObjectName(_fromUtf8("radioButtonNameFromOldName"))
      +      self.radioButtonNameFromOldName.clicked.connect(self.on_radioButtonNameFromOldName_clicked)
      +
      +      self.radioButtonLabelFromOldName = QtGui.QRadioButton(self.centralWidget)
      +      self.radioButtonLabelFromOldName.setGeometry(QtCore.QRect(uiColWidth+(2*uiPad), row, uiColWidth, uiRowOffset-2))
      +      self.radioButtonLabelFromOldName.setObjectName(_fromUtf8("radioButtonLabelFromOldName"))
      +      self.radioButtonLabelFromOldName.clicked.connect(self.on_radioButtonLabelFromOldName_clicked)
      +
      +      row = row+uiRowOffset
      +      self.radioButtonNameFromOldLabel = QtGui.QRadioButton(self.centralWidget)
      +      self.radioButtonNameFromOldLabel.setGeometry(QtCore.QRect(uiPad, row, uiColWidth, uiRowOffset-2))
      +      self.radioButtonNameFromOldLabel.setObjectName(_fromUtf8("radioButtonNameFromOldLabel"))
      +      self.radioButtonNameFromOldLabel.clicked.connect(self.on_radioButtonNameFromOldLabel_clicked)
      +
      +      self.radioButtonLabelFromOldLabel = QtGui.QRadioButton(self.centralWidget)
      +      self.radioButtonLabelFromOldLabel.setGeometry(QtCore.QRect(uiColWidth+(2*uiPad), row, uiColWidth, uiRowOffset-2))
      +      self.radioButtonLabelFromOldLabel.setObjectName(_fromUtf8("radioButtonLabelFromOldLabel"))
      +      self.radioButtonLabelFromOldLabel.clicked.connect(self.on_radioButtonLabelFromOldLabel_clicked)
      +
      +      row = row+uiRowOffset
      +      self.radioButtonNameFromText = QtGui.QRadioButton(self.centralWidget)
      +      self.radioButtonNameFromText.setGeometry(QtCore.QRect(uiPad, row, 20, uiRowOffset-2))
      +      self.radioButtonNameFromText.setObjectName(_fromUtf8("radioButtonNameFromText"))
      +      self.radioButtonNameFromText.clicked.connect(self.on_radioButtonNameFromText_clicked)
      +
      +      self.lineEditNameFromText = QtGui.QLineEdit(self.centralWidget)
      +      self.lineEditNameFromText.setGeometry(QtCore.QRect(uiPad+20, row, uiColWidth-20, uiRowOffset-2))
      +      self.lineEditNameFromText.setObjectName(_fromUtf8("lineEditNameFromText"))
      +      self.lineEditNameFromText.textChanged.connect(self.on_lineEditNameFromText_changed)
      +
      +      self.radioButtonLabelFromText = QtGui.QRadioButton(self.centralWidget)
      +      self.radioButtonLabelFromText.setGeometry(QtCore.QRect(uiColWidth+(2*uiPad), row, 20, uiRowOffset-2))
      +      self.radioButtonLabelFromText.setObjectName(_fromUtf8("radioButtonLabelFromText"))
      +      self.radioButtonLabelFromText.clicked.connect(self.on_radioButtonLabelFromText_clicked)
      +
      +      self.lineEditLabelFromText = QtGui.QLineEdit(self.centralWidget)
      +      self.lineEditLabelFromText.setGeometry(QtCore.QRect(uiColWidth+(2*uiPad)+20, row, uiColWidth-20, uiRowOffset-2))
      +      self.lineEditLabelFromText.setObjectName(_fromUtf8("lineEditLabelFromText"))
      +      self.lineEditLabelFromText.textChanged.connect(self.on_lineEditLabelFromText_changed)
      +
      +      row = row+uiRowOffset+uiPad
      +      self.labelCapColorFrom = QtGui.QLabel(self.centralWidget)
      +      self.labelCapColorFrom.setGeometry(QtCore.QRect(uiPad, row, uiColWidth, uiRowOffset-10))
      +      self.labelCapColorFrom.setFont(captionFont)
      +      self.labelCapColorFrom.setObjectName(_fromUtf8("labelCapColorFrom"))
      +
      +      row = row+uiRowOffset
      +      self.radioButtonColorFromNew = QtGui.QRadioButton(self.centralWidget)
      +      self.radioButtonColorFromNew.setGeometry(QtCore.QRect(uiPad, row, uiColWidth, uiRowOffset-2))
      +      self.radioButtonColorFromNew.setObjectName(_fromUtf8("radioButtonColorFromNew"))
      +
      +      self.radioButtonColorFromOld = QtGui.QRadioButton(self.centralWidget)
      +      self.radioButtonColorFromOld.setGeometry(QtCore.QRect(uiColWidth+(2*uiPad), row, uiColWidth, uiRowOffset-2))
      +      self.radioButtonColorFromOld.setObjectName(_fromUtf8("radioButtonColorFromOld"))
      +
      +      row = row+uiRowOffset+uiPad
      +      ReplacePart.resize(uiMainWidth,row)
      +
      +      self.groupBoxNewName.addButton(self.radioButtonNameFromNewDoc)
      +      self.groupBoxNewName.addButton(self.radioButtonNameFromNewName)
      +      self.groupBoxNewName.addButton(self.radioButtonNameFromNewLabel)
      +      self.groupBoxNewName.addButton(self.radioButtonNameFromOldName)
      +      self.groupBoxNewName.addButton(self.radioButtonNameFromOldLabel)
      +      self.groupBoxNewName.addButton(self.radioButtonNameFromText)
      +
      +      self.groupBoxNewLabel.addButton(self.radioButtonLabelFromNewDoc)
      +      self.groupBoxNewLabel.addButton(self.radioButtonLabelFromNewName)
      +      self.groupBoxNewLabel.addButton(self.radioButtonLabelFromNewLabel)
      +      self.groupBoxNewLabel.addButton(self.radioButtonLabelFromOldName)
      +      self.groupBoxNewLabel.addButton(self.radioButtonLabelFromOldLabel)
      +      self.groupBoxNewLabel.addButton(self.radioButtonLabelFromText)
      +
      +      self.groupBoxColorFrom.addButton(self.radioButtonColorFromNew)
      +      self.groupBoxColorFrom.addButton(self.radioButtonColorFromOld)
      +
      +      self.radioButtonNameFromNewDoc.setChecked(True)  #Set the default name to your preference
      +      self.radioButtonLabelFromOldLabel.setChecked(True) #Set the default label to your preference
      +      self.radioButtonColorFromOld.setChecked(True) #Set the default color inherit to your preference
      +
      +      """
      +      #*** FIXME ***----------------------------
      +      self.timer = QtCore.QTimer()
      +      QtCore.QObject.connect(self.timer, QtCore.SIGNAL("timeout()"), self.my_update)
      +      self.timer.start(2000)
      +
      +      #*** FIXME ***----------------------------
      +      """
      +      self.retranslateUi(ReplacePart)
      +      
      +      QtCore.QMetaObject.connectSlotsByName(ReplacePart)
      +
      +   def retranslateUi(self, ReplacePart):
      +      ReplacePart.setWindowFlags(QtCore.Qt.WindowStaysOnTopHint)
      +      ReplacePart.setAttribute(QtCore.Qt.WA_DeleteOnClose, True)
      +      ReplacePart.setWindowTitle(_translate("ReplacePart", "Replace part", None))
      +      self.labelCapSelected.setText(_translate("ReplacePart", "Selected Part :", None))
      +      self.labelSelected.setText(_translate("ReplacePart", "No Selected Part", None))
      +      self.labelNew.setText(_translate("ReplacePart", "Select New Part", None))
      +      self.LabelOld.setText(_translate("ReplacePart", "Select Old Part", None))
      +      self.pushButtonNew.setText(_translate("ReplacePart", "Select New Part", None))
      +      self.pushButtonOld.setText(_translate("ReplacePart", "Select Old Part", None))
      +      self.pushButtonOk.setText(_translate("ReplacePart", "Replace Old Part", None))
      +      self.labelCapNewName.setText(_translate("ReplacePart", "New Name from", None))
      +      self.radioButtonNameFromNewDoc.setText(_translate("ReplacePart", "New document", None))
      +      self.radioButtonNameFromNewName.setText(_translate("ReplacePart", "New name", None))
      +      self.radioButtonNameFromNewLabel.setText(_translate("ReplacePart", "New label", None))
      +      self.radioButtonNameFromOldName.setText(_translate("ReplacePart", "Old name", None))
      +      self.radioButtonNameFromOldLabel.setText(_translate("ReplacePart", "Old label", None))
      +      self.radioButtonNameFromText.setText(_translate("ReplacePart", "t", None))
      +      self.lineEditNameFromText.setText(_translate("ReplacePart", "name", None))
      +      self.labelCapNewLabel.setText(_translate("ReplacePart", "New Label from", None))
      +      self.radioButtonLabelFromNewDoc.setText(_translate("ReplacePart", "New document", None))
      +      self.radioButtonLabelFromNewName.setText(_translate("ReplacePart", "New name", None))
      +      self.radioButtonLabelFromNewLabel.setText(_translate("ReplacePart", "New label", None))
      +      self.radioButtonLabelFromOldName.setText(_translate("ReplacePart", "Old name", None))
      +      self.radioButtonLabelFromOldLabel.setText(_translate("ReplacePart", "Old label", None))
      +      self.radioButtonLabelFromText.setText(_translate("ReplacePart", "t", None))
      +      self.lineEditLabelFromText.setText(_translate("ReplacePart", "label", None))
      +      self.labelCapColorFrom.setText(_translate("ReplacePart", "Inherit color from", None))
      +      self.radioButtonColorFromNew.setText(_translate("ReplacePart", "New part", None))
      +      self.radioButtonColorFromOld.setText(_translate("ReplacePart", "Old part", None))
      +
      +   """
      +   #*** FIXME ***----------------------------
      +
      +   def my_update(self):
      +      selectedPart = self.getSelectedPart()
      +      self.labelSelected.setText(selectedPart[0] + "," + selectedPart[1] + ","+ selectedPart[2])
      +      FreeCAD.Console.PrintMessage("Selected part: " + selectedPart[0] + "," + selectedPart[1] + ","+ selectedPart[2] + "," + "\n")
      +
      +   def closeEvent(self, event):
      +      FreeCAD.Console.PrintMessage("closeEvent\n")
      +      if self.timer.stop():
      +         self.timer.stop()
      +         event.accept() # let the window close
      +      else:
      +         event.ignore()
      +
      +   def on_exit(self, event):
      +      FreeCAD.Console.PrintMessage("exitEvent\n")
      +      if self.timer.stop():
      +         self.timer.stop()
      +         event.accept() # let the window close
      +      else:
      +         event.ignore()
      +
      +   def hideEvent(self, event):
      +      FreeCAD.Console.PrintMessage("hideEvent\n")
      +      if self.timer.stop():
      +         self.timer.stop()
      +         event.accept() # let the window close
      +      else:
      +         event.ignore()
      +
      +   #--------------------------------------
      +   """
      +
      +   def on_pushButtonNew_clicked(self):
      +      global oldpart
      +      global newpart
      +      newpart = self.getSelectedPart()
      +      if str(newpart[0]) == "":
      +         self.labelNew.setText("No part selected")
      +      else:
      +         self.labelNew.setText(str(newpart[0])+ " , " + str(newpart[1]))
      +         self.radioButtonName()
      +         self.radioButtonLabel()
      +         Gui.Selection.clearSelection()
      +      if str(oldpart[0]) == str(newpart[0]):
      +         self.pushButtonOk.setEnabled(False)
      +      elif str(oldpart[0]) == "":
      +         self.pushButtonOk.setEnabled(False)
      +      elif str(newpart[0]) == "":
      +         self.pushButtonOk.setEnabled(False)
      +      else:
      +         self.pushButtonOk.setEnabled(True)
      +
      +   def on_pushButtonOld_clicked(self):
      +      global oldpart
      +      global newpart
      +      oldpart = self.getSelectedPart()
      +      if str(oldpart[0]) == "":
      +         self.LabelOld.setText("No part selected")
      +      else:
      +         self.LabelOld.setText(str(oldpart[0])+ " , " + str(oldpart[1]))
      +         self.radioButtonName()
      +         self.radioButtonLabel()
      +         Gui.Selection.clearSelection()
      +      if str(oldpart[0]) == str(newpart[0]):
      +         self.pushButtonOk.setEnabled(False)
      +      elif str(oldpart[0]) == "":
      +         self.pushButtonOk.setEnabled(False)
      +      elif str(newpart[0]) == "":
      +         self.pushButtonOk.setEnabled(False)
      +      else:
      +         self.pushButtonOk.setEnabled(True)
      +
      +   def on_pushButtonOk_clicked(self):
      +      if self.radioButtonColorFromNew.isChecked():
      +         colors = self.getColors("new")
      +      if self.radioButtonColorFromOld.isChecked():
      +         colors = self.getColors("old")
      +      self.deleteOldPart()
      +      newPartName = self.makeSimple(colors)
      +      self.moveNew2Old(newPartName)
      +      self.move2Group(newPartName)
      +      App.ActiveDocument.recompute()
      +      App.Console.PrintMessage("Part replaced\n")
      +      #self.window.hide()
      +
      +   def on_radioButtonNameFromNewDoc_clicked(self):
      +      self.radioButtonName()
      +
      +   def on_radioButtonNameFromNewName_clicked(self):
      +      self.radioButtonName()
      +
      +   def on_radioButtonNameFromNewLabel_clicked(self):
      +      self.radioButtonName()
      +
      +   def on_radioButtonNameFromOldName_clicked(self):
      +      self.radioButtonName()
      +
      +   def on_radioButtonNameFromOldLabel_clicked(self):
      +      self.radioButtonName()
      +
      +   def on_radioButtonNameFromText_clicked(self):
      +      self.radioButtonName()
      +
      +   def on_lineEditNameFromText_changed(self):
      +      self.radioButtonName()
      +
      +   def on_radioButtonLabelFromNewDoc_clicked(self):
      +      self.radioButtonLabel()
      +
      +   def on_radioButtonLabelFromNewName_clicked(self):
      +      self.radioButtonLabel()
      +
      +   def on_radioButtonLabelFromNewLabel_clicked(self):
      +      self.radioButtonLabel()
      +
      +   def on_radioButtonLabelFromOldName_clicked(self):
      +      self.radioButtonLabel()
      +
      +   def on_radioButtonLabelFromOldLabel_clicked(self):
      +      self.radioButtonLabel()
      +
      +   def on_radioButtonLabelFromText_clicked(self):
      +      self.radioButtonLabel()
      +
      +   def on_lineEditLabelFromText_changed(self):
      +      self.radioButtonLabel()
      +
      +   def radioButtonName(self):
      +      global newPartName
      +      if self.radioButtonNameFromNewDoc.isChecked():
      +         newPartName=self.getFromNew(0)
      +      elif self.radioButtonNameFromNewName.isChecked():
      +         newPartName=self.getFromNew(1)
      +      elif self.radioButtonNameFromNewLabel.isChecked():
      +         newPartName=self.getFromNew(2)
      +      elif self.radioButtonNameFromOldName.isChecked():
      +         newPartName=self.getFromOld(1)
      +      elif self.radioButtonNameFromOldLabel.isChecked():
      +         newPartName=self.getFromOld(2)
      +      elif self.radioButtonNameFromText.isChecked():
      +         newPartName=str(self.lineEditNameFromText.displayText())
      +      else:
      +         FreeCAD.Console.PrintError("Error: Unknown Name error\n")
      +
      +   def radioButtonLabel(self):
      +      global newPartLabel
      +      if self.radioButtonLabelFromNewDoc.isChecked():
      +         newPartLabel=self.getFromNew(0)
      +      elif self.radioButtonLabelFromNewName.isChecked():
      +         newPartLabel=self.getFromNew(1)
      +      elif self.radioButtonLabelFromNewLabel.isChecked():
      +         newPartLabel=self.getFromNew(2)
      +      elif self.radioButtonLabelFromOldName.isChecked():
      +         newPartLabel=self.getFromOld(1)
      +      elif self.radioButtonLabelFromOldLabel.isChecked():
      +         newPartLabel=self.getFromOld(2)
      +      elif self.radioButtonLabelFromText.isChecked():
      +         newPartLabel=str(self.lineEditLabelFromText.displayText())
      +      else:
      +         FreeCAD.Console.PrintError("Error: Unknown Label error\n")
      +
      +   def getFromNew(self, index):
      +      global newpart
      +      return newpart[index];
      +
      +   def getFromOld(self, index):
      +      global oldpart
      +      return oldpart[index];
      +
      +   def getSelectedPart(self):
      +      sel = FreeCADGui.Selection.getSelection()
      +      if sel:
      +         sel = sel[0]
      +         name = sel.Name
      +         label = sel.Label
      +         doc = FreeCAD.ActiveDocument.Name
      +         pos = App.ActiveDocument.getObject(name).Placement.Base   
      +         rot = App.ActiveDocument.getObject(name).Placement.Rotation
      +         grp = self.inGroup(name)
      +         the_part=[doc , name, label, pos, rot, grp];
      +         return the_part;
      +      else:
      +         FreeCAD.Console.PrintError("Error: One object must be selected\n")
      +         the_part=["" , ""];
      +         return the_part;
      +
      +   def makeSimple(self, colors):
      +      global oldpart
      +      global newpart
      +      global newPartName
      +      global newPartLabel
      +      fixPartName = newPartName
      +      #newPartLabel = newPartLabel
      +      newPartName = self.uniqeName(fixPartName)
      +      App.setActiveDocument(oldpart[0])
      +      Gui.ActiveDocument=Gui.getDocument(oldpart[0])
      +      App.ActiveDocument=App.getDocument(oldpart[0])
      +      App.ActiveDocument.addObject('Part::Feature',newPartName).Shape=App.getDocument(newpart[0]).getObject(newpart[1]).Shape
      +      App.ActiveDocument.ActiveObject.Label = newPartLabel
      +      App.ActiveDocument.getObject(newPartName).Label = newPartLabel
      +      Gui.getDocument(oldpart[0]).getObject(newPartName).ShapeColor = colors[0]
      +      Gui.getDocument(oldpart[0]).getObject(newPartName).LineColor =  colors[1]
      +      Gui.getDocument(oldpart[0]).getObject(newPartName).PointColor = colors[2]
      +      return newPartName;
      +
      +   def moveNew2Old(self, newPartName):
      +      global oldpart
      +      global newpart
      +      App.ActiveDocument.getObject(newPartName).Placement = App.Placement(oldpart[3], oldpart[4])
      +
      +   def deleteOldPart(self):
      +      global oldpart
      +      App.setActiveDocument(oldpart[0])
      +      Gui.ActiveDocument=Gui.getDocument(oldpart[0])
      +      App.ActiveDocument=App.getDocument(oldpart[0])
      +      App.ActiveDocument.removeObject(oldpart[1])
      +
      +   def inGroup(self, partName):
      +      try:
      +         grp = App.ActiveDocument.getObject(partName).InList
      +         grpName = grp[0].Name
      +      except:
      +         grpName = ""
      +      return grpName;
      +
      +   def move2Group(self,  newPartName):
      +      global oldpart
      +      grp = App.ActiveDocument.getObject(oldpart[5])
      +      part = App.ActiveDocument.getObject(newPartName)
      +      grp.addObject(part)
      +
      +   def getColors(self, newORold):
      +      global oldpart
      +      global newpart
      +      if newORold == "new":
      +         shape = Gui.getDocument(newpart[0]).getObject(newpart[1]).ShapeColor
      +         line = Gui.getDocument(newpart[0]).getObject(newpart[1]).LineColor
      +         point = Gui.getDocument(newpart[0]).getObject(newpart[1]).PointColor
      +      elif newORold == "old":
      +         shape = Gui.getDocument(oldpart[0]).getObject(oldpart[1]).ShapeColor
      +         line = Gui.getDocument(oldpart[0]).getObject(oldpart[1]).LineColor
      +         point = Gui.getDocument(oldpart[0]).getObject(oldpart[1]).PointColor
      +      else:
      +         FreeCAD.Console.PrintMessage("Error! Color from newpart or old?\n")
      +      colors = [ shape, line, point ];
      +      return colors;
      +
      +   def uniqeName(self, newPartName):
      +      global oldpart
      +      objs = App.getDocument(oldpart[0]).Objects
      +      for obj in objs:
      +         if obj.Name  == newPartName:
      +            if obj.Name != oldpart[1]:
      +               i = 0
      +               for iobj in objs:
      +                  if iobj.Name == newPartName + "_" + str(i) and iobj.Name != oldpart[1]:
      +                     i += 1
      +               return newPartName + "_" + str(i);
      +      return newPartName;
      +
      +class replace():
      +   Gui.Selection.clearSelection()
      +   d = QtGui.QWidget()
      +   d.ui = Ui_ReplacePart()
      +   d.ui.setupUi(d)
      +   d.show() 
      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Macro_Replace_Part_in_Assembly.jpg b/localwiki/Macro_Replace_Part_in_Assembly.jpg new file mode 100644 index 0000000..981c7ef Binary files /dev/null and b/localwiki/Macro_Replace_Part_in_Assembly.jpg differ diff --git a/localwiki/Macro_ReproWire.html b/localwiki/Macro_ReproWire.html new file mode 100644 index 0000000..06a13bd --- /dev/null +++ b/localwiki/Macro_ReproWire.html @@ -0,0 +1,149 @@ +Macro ReproWire

      Macro ReproWire

      (Redirected from Macro ReproWire)
      + +
      + + + + + + + + + + + + + + + + + + + + + + + + + + +
      +

      Macro ReproWire.png Macro Repro Wire

      +
      Description +
      This macro create on duplicate to wire subObject ... selected. +
      Author +
      Mario52 +
      Links +
      Macros recipes
      How to install macros
      How to customize toolbars +
      Version +
      00.01 +
      Date last modification +
      2015-10-24 +
      +

      + +
      +


      +

      +

      Description

      +

      This macro create on duplicate to wire, face, object or subObject ... selected. +

      +
      ReproWire
      +
      +


      +

      +

      Use

      +

      Select your object and run the macro for create your copy, you can extrude created faces. +

      The copies are coloured red and renamed with the Shapexxx + original names +

      +

      Script

      +

      Macro_ReproWire.FCMacro the icon for the toolbar icon for the button +

      +
      # -*- coding: utf-8 -*-
      +from __future__ import unicode_literals
      +import codecs   #https://docs.python.org/2/howto/unicode.html
      +import Part,Draft
      +#
      +#__title__="Macro_ReproWire"
      +#__author__ = "Mario52"
      +#__url__     = "http://www.freecadweb.org/index-fr.html"
      +#__version__ = "00.01"
      +#__date__    = "24/10/2015"
      +#
      +
      +sel = Gui.Selection.getSelection()
      +s   = Gui.Selection.getSelectionEx()
      +
      +try:
      +    if len(sel) != 0:
      +            print "Object(s) : ", len(sel), " , SubObject(s) : ", len(s)
      +            i2 = ii2 = -1 
      +            for i in s:
      +                i2 += 1
      +                ii2 = -1
      +                try:
      +                    FreeCADGui.Selection.getSelectionEx()[i2].SubObjects[ii2]
      +                    for ii in i.SubElementNames:
      +#                        print "SubObject"
      +                        ii2 += 1
      +                        Part.show(FreeCADGui.Selection.getSelectionEx()[i2].SubObjects[ii2].copy())   # create repro shape subObject
      +                        print i2+1 ,"/", ii2+1 ,"/", len(s) ," ", i.ObjectName ," ", ii               # display the info SubObject
      +                        a = App.ActiveDocument.ActiveObject
      +                        #    object Name  / original object Name / SubObject Name
      +                        a.Label = a.Name + " " + i.ObjectName + " " + ii                              # Label for the repro shape
      +                        try:
      +                            FreeCADGui.activeDocument().activeObject().LineColor  = (1.0,0.0,0.0)     # give LineColor
      +                            FreeCADGui.activeDocument().activeObject().PointColor = (1.0,0.0,0.0)     # give PointColor
      +                            FreeCADGui.activeDocument().activeObject().ShapeColor = (1.0,0.0,0.0)     # give ShapeColor
      +                        except Exception:
      +                            None
      +                except Exception:
      +#                    print "Not SubObject"
      +                    Part.show(sel[i2].Shape)                                                          # create repro shape object
      +                    print i2+1 ,"/", ii2+1 ,"/", len(s) ," ", sel[i2].Name                            # display the info SubObject
      +                    a = App.ActiveDocument.ActiveObject
      +                    #        object Name  /  original object Name
      +                    a.Label =a.Name + " " +  sel[i2].Name                                             # Label for the repro shape
      +                    try:
      +                        FreeCADGui.activeDocument().activeObject().LineColor  = (1.0,0.0,0.0)         # give LineColor
      +                        FreeCADGui.activeDocument().activeObject().PointColor = (1.0,0.0,0.0)         # give PointColor
      +                        FreeCADGui.activeDocument().activeObject().ShapeColor = (1.0,0.0,0.0)         # give ShapeColor
      +                    except Exception:
      +                        None
      +    else :
      +        print "Select one object"
      +except Exception:
      +    print "Unexpected error" 
      +

      Version

      +

      00.01 24/10/2015 : extension to all objects +

      00.00 22/10/2015 : +

      +

      Links

      +

      The forum are there any tools to extrude only selected surface from a sketch? +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Macro_ReproWire.png b/localwiki/Macro_ReproWire.png new file mode 100644 index 0000000..f603e98 Binary files /dev/null and b/localwiki/Macro_ReproWire.png differ diff --git a/localwiki/Macro_Repro_Wire.html b/localwiki/Macro_Repro_Wire.html new file mode 100644 index 0000000..ef7b7de --- /dev/null +++ b/localwiki/Macro_Repro_Wire.html @@ -0,0 +1,149 @@ +Macro Repro Wire

      Macro Repro Wire

      + +
      + + + + + + + + + + + + + + + + + + + + + + + + + + +
      +

      Macro ReproWire.png Macro Repro Wire

      +
      Description +
      This macro create on duplicate to wire subObject ... selected. +
      Author +
      Mario52 +
      Links +
      Macros recipes
      How to install macros
      How to customize toolbars +
      Version +
      00.01 +
      Date last modification +
      2015-10-24 +
      +

      + +
      +


      +

      +

      Description

      +

      This macro create on duplicate to wire, face, object or subObject ... selected. +

      +
      ReproWire
      +
      +


      +

      +

      Use

      +

      Select your object and run the macro for create your copy, you can extrude created faces. +

      The copies are coloured red and renamed with the Shapexxx + original names +

      +

      Script

      +

      Macro_ReproWire.FCMacro the icon for the toolbar icon for the button +

      +
      # -*- coding: utf-8 -*-
      +from __future__ import unicode_literals
      +import codecs   #https://docs.python.org/2/howto/unicode.html
      +import Part,Draft
      +#
      +#__title__="Macro_ReproWire"
      +#__author__ = "Mario52"
      +#__url__     = "http://www.freecadweb.org/index-fr.html"
      +#__version__ = "00.01"
      +#__date__    = "24/10/2015"
      +#
      +
      +sel = Gui.Selection.getSelection()
      +s   = Gui.Selection.getSelectionEx()
      +
      +try:
      +    if len(sel) != 0:
      +            print "Object(s) : ", len(sel), " , SubObject(s) : ", len(s)
      +            i2 = ii2 = -1 
      +            for i in s:
      +                i2 += 1
      +                ii2 = -1
      +                try:
      +                    FreeCADGui.Selection.getSelectionEx()[i2].SubObjects[ii2]
      +                    for ii in i.SubElementNames:
      +#                        print "SubObject"
      +                        ii2 += 1
      +                        Part.show(FreeCADGui.Selection.getSelectionEx()[i2].SubObjects[ii2].copy())   # create repro shape subObject
      +                        print i2+1 ,"/", ii2+1 ,"/", len(s) ," ", i.ObjectName ," ", ii               # display the info SubObject
      +                        a = App.ActiveDocument.ActiveObject
      +                        #    object Name  / original object Name / SubObject Name
      +                        a.Label = a.Name + " " + i.ObjectName + " " + ii                              # Label for the repro shape
      +                        try:
      +                            FreeCADGui.activeDocument().activeObject().LineColor  = (1.0,0.0,0.0)     # give LineColor
      +                            FreeCADGui.activeDocument().activeObject().PointColor = (1.0,0.0,0.0)     # give PointColor
      +                            FreeCADGui.activeDocument().activeObject().ShapeColor = (1.0,0.0,0.0)     # give ShapeColor
      +                        except Exception:
      +                            None
      +                except Exception:
      +#                    print "Not SubObject"
      +                    Part.show(sel[i2].Shape)                                                          # create repro shape object
      +                    print i2+1 ,"/", ii2+1 ,"/", len(s) ," ", sel[i2].Name                            # display the info SubObject
      +                    a = App.ActiveDocument.ActiveObject
      +                    #        object Name  /  original object Name
      +                    a.Label =a.Name + " " +  sel[i2].Name                                             # Label for the repro shape
      +                    try:
      +                        FreeCADGui.activeDocument().activeObject().LineColor  = (1.0,0.0,0.0)         # give LineColor
      +                        FreeCADGui.activeDocument().activeObject().PointColor = (1.0,0.0,0.0)         # give PointColor
      +                        FreeCADGui.activeDocument().activeObject().ShapeColor = (1.0,0.0,0.0)         # give ShapeColor
      +                    except Exception:
      +                        None
      +    else :
      +        print "Select one object"
      +except Exception:
      +    print "Unexpected error" 
      +

      Version

      +

      00.01 24/10/2015 : extension to all objects +

      00.00 22/10/2015 : +

      +

      Links

      +

      The forum are there any tools to extrude only selected surface from a sketch? +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Macro_Rotate_To_Point.html b/localwiki/Macro_Rotate_To_Point.html new file mode 100644 index 0000000..8ce73b9 --- /dev/null +++ b/localwiki/Macro_Rotate_To_Point.html @@ -0,0 +1,985 @@ +Macro Rotate To Point

      Macro Rotate To Point

      + +
      + + + + + + + + + + + + + + + + + + + + + + + + + + +
      +

      Macro Rotate To Point.png Macro Rotate To Point

      +
      Description +
      Macro for rotate on object on itself with the axis of rotation +
      Author +
      Mario52 +
      Links +
      Macros recipes
      How to install macros
      How to customize toolbars +
      Version +
      00.03 +
      Date last modification +
      2018-03-29 +
      +

      + +
      +


      +

      +

      Description

      +

      Macro for rotate on object on itself with the axis of rotation the boundbox center, center of mass or last point clicked +

      +

      How To Use

      +

      Run the macro and select one object and choice: +

      Interface Rotate to point +

      +
      +
      • Point Rotation +
        • Bounbox Center : Select the boundBox center to axis rotation
        • +
        • Center of Mass : Select the Center of Mass to axis rotation
        • +
        • Point Clicked : Select the last point mouse to axis rotation 1: select the object 2: use the CTRL for choice point extra object
      • +
      • Axis Rotation +
        • Rotation(Z) Yaw : Yaw axis
        • +
        • Rotation(Y) Pitch : Pitch axis
        • +
        • Rotation(X) Roll : Roll axis
      • +
      • Coordinates Point clicked +
        • DoubleSpinBox : Coordinate X on click mouse (modifiable only with the mode "Point Clicked")
        • +
        • DoubleSpinBox : Coordinate Y on click mouse (modifiable only with the mode "Point Clicked")
        • +
        • DoubleSpinBox : Coordinate Z on click mouse (modifiable only with the mode "Point Clicked")
      • +
      • Position : If this checkBox is checked the rotation is disabled, the object placement is done on the axis seleted
      • +
      • Point : If this checkBox is checked one point is created for visualise the point rotation axis : red X, green Y, blue Z
      • +
      • Line Edit : The line edit display the original coordinate to axis selected + the input data give in the spinBox
      • +
      • Free : If this checkBox is checked the Apply is switched ans the rotation or translation is executed in real time
      • +
      • DoubleSpinBox : enter the modification
      • +
      • Apply : Apply the modification to the object
      • +
      • Quit : Quit the macro
      • +
      • Original : After modify the data of the object you can return to the original placement, If you have not deselected the current object
      • +
      • 0,0,0  : This option place the object in base coordinate 0, 0, 0
      • +
      • Reset : Reset the data in the macro and deselect the current object (same click mouse in the 3DView)
      +

      Script

      +

      The icon for you toolbar PNG Macro Rotate To Point.png SVG Macro Rotate To Point.svg +

      Macro Rotate To Point.FCMacro +

      +
      # -*- coding: utf-8 -*-
      +from __future__ import unicode_literals
      +"""
      +***************************************************************************
      +*   Copyright (c) 2017 <mario52>                                          *
      +*                                                                         *
      +*   This file is a supplement to the FreeCAD CAx development system.      *
      +*                                                                         *
      +*   This program is free software; you can redistribute it and/or modify  *
      +*   it under the terms of the GNU Lesser General Public License (LGPL)    *
      +*   as published by the Free Software Foundation; either version 2 of     *
      +*   the License, or (at your option) any later version.                   *
      +*   for detail see the LICENCE text file.                                 *
      +*                                                                         *
      +*   This software is distributed in the hope that it will be useful,      *
      +*   but WITHOUT ANY WARRANTY; without even the implied warranty of        *
      +*   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the         *
      +*   GNU Library General Public License for more details.                  *
      +*                                                                         *
      +*   You should have received a copy of the GNU Library General Public     *
      +*   License along with this macro; if not, write to the Free Software     *
      +*   Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  *
      +*   USA                                                                   *
      +***************************************************************************
      +*           WARNING! All changes in this file will be lost and            *  
      +*                  may cause malfunction of the program                   *
      +***************************************************************************
      +"""
      +#
      +#
      +#OS: Windows 10                                     #OS: Windows 10
      +#Word size of OS: 64-bit                            #Word size of OS: 64-bit
      +#Word size of FreeCAD: 64-bit                       #Word size of FreeCAD: 64-bit
      +#Version: 0.16.6706 (Git)                           #Version: 0.17.13387 (Git)
      +#Build type: Release                                #Build type: Release
      +#Branch: releases/FreeCAD-0-16                      #Branch: master
      +#Hash: f86a4e411ff7848dea98d7242f43b7774bee8fa0     #Hash: c5f4079252b11e3c54cd603be7d3697fa9f9d922
      +#Python version: 2.7.8                              #Python version: 2.7.14
      +#Qt version: 4.8.7                                  #Qt version: 4.8.7
      +#Coin version: 4.0.0a                               #Coin version: 4.0.0a
      +#OCC version: 6.8.0.oce-0.17                        #OCC version: 7.1.0
      +#
      +#
      +__title__   = "Macro_Rotate_To_Point"
      +__author__  = "Mario52"
      +__url__     = "http://www.freecadweb.org/index-fr.html"
      +__Wiki__    = "https://www.freecadweb.org/wiki/Macro_Rotate_To_Point"
      +__version__ = "00.03"
      +__date__    = "29/03/2018"
      +#
      +import PySide
      +from PySide import QtGui ,QtCore
      +from PySide.QtGui import *
      +from PySide.QtCore import *
      + 
      +import Draft, Part, PartGui, FreeCADGui, FreeCAD
      +from FreeCAD import Base
      +import DraftVecUtils
      +import time
      +
      +Gui = FreeCADGui
      +App = FreeCAD
      +
      +global ui            ; ui             = ""
      +global sourisPass    ; sourisPass     = 0
      +global positionMouse ; positionMouse  = ""
      +
      +global originalObject; originalObject = ""
      +global myObject      ; myObject       = ""
      +global originalPlacement; originalPlacement = ""
      +global valeur        ; valeur         = 0.0
      +
      +global axisX         ; axisX          = 0.0
      +global axisY         ; axisY          = 0.0
      +global axisZ         ; axisZ          = 0.0
      +
      +global posX          ; posX           = 0.0
      +global posY          ; posY           = 0.0
      +global posZ          ; posZ           = 0.0
      +
      +global rotAngleX     ; rotAngleX      = 0.0
      +global rotAngleY     ; rotAngleY      = 0.0
      +global rotAngleZ     ; rotAngleZ      = 0.0
      +
      +try:
      +    _fromUtf8 = QtCore.QString.fromUtf8
      +except AttributeError:
      +    def _fromUtf8(s):
      +        return s
      +
      +try:
      +    _encoding = QtGui.QApplication.UnicodeUTF8
      +    def _translate(context, text, disambig):
      +        return QtGui.QApplication.translate(context, text, disambig, _encoding)
      +except AttributeError:
      +    def _translate(context, text, disambig):
      +        return QtGui.QApplication.translate(context, text, disambig)
      +
      +def errorDialog(msg):
      +    diag = QtGui.QMessageBox(QtGui.QMessageBox.Critical,u"Error Message",msg )
      +    diag.setWindowFlags(PySide.QtCore.Qt.WindowStaysOnTopHint) # PySide # cette fonction met la fenetre en avant
      +    diag.exec_()
      +        
      +class Ui_MainWindow(object):
      +    def __init__(self ):
      +        self.window = MainWindow
      +        ################################################
      +        #self.path  = FreeCAD.ConfigGet("AppHomePath")
      +        #self.path  = FreeCAD.ConfigGet("UserAppData")
      +        #self.path  = "your path"
      +        param = FreeCAD.ParamGet("User parameter:BaseApp/Preferences/Macro")# macro path
      +        self.path = param.GetString("MacroPath","") + "/"                   # macro path
      +        self.path = self.path.replace("\\","/")
      +        print "Path for the icons : " , self.path
      +        ################################################
      +        self.vueActive = FreeCADGui.ActiveDocument.ActiveView
      +        self.click = self.vueActive.addEventCallback("SoMouseButtonEvent",self.souris)
      +
      +    def souris(self,info):
      +        global sourisPass
      +        if (info["Button"] == "BUTTON1") and (info["State"] == "DOWN"):
      +            time.sleep(0.02)
      +            sourisPass = 0
      +            #print "ok"
      +
      +    def setupUi(self, MainWindow):
      +        self.window = MainWindow
      +        MainWindow.setObjectName(_fromUtf8("MainWindow"))
      +        MainWindow.resize(330, 330)
      +        MainWindow.setMinimumSize(QtCore.QSize(330, 10))
      +        MainWindow.setMaximumSize(QtCore.QSize(330, 330))
      +        self.centralwidget = QtGui.QWidget(MainWindow)
      +        self.centralwidget.setObjectName(_fromUtf8("centralwidget"))
      +
      +        self.fontGlobal_08 = QtGui.QFont()            # pour compatibilite
      +        self.fontGlobal_08.setFamily("Arial")         # pour compatibilite
      +        self.fontGlobal_08.setPointSize(8.0)          # pour compatibilite
      +
      +        ####
      +        self.groupBox_Rotation = QtGui.QGroupBox(self.centralwidget)
      +        self.groupBox_Rotation.setGeometry(QtCore.QRect(20, 20, 121, 91))
      +        self.groupBox_Rotation.setFont(self.fontGlobal_08)       # 
      +        self.groupBox_Rotation.setEnabled(False)
      +        self.groupBox_Rotation.setObjectName(_fromUtf8("groupBox_Rotation"))
      +
      +        self.RB_Bond_Box_Center = QtGui.QRadioButton(self.groupBox_Rotation)
      +        self.RB_Bond_Box_Center.setGeometry(QtCore.QRect(10, 20, 111, 17))
      +        self.RB_Bond_Box_Center.setFont(self.fontGlobal_08)       # 
      +        self.RB_Bond_Box_Center.setChecked(True)
      +        self.RB_Bond_Box_Center.setObjectName(_fromUtf8("RB_Bond_Box_Center"))
      +        self.RB_Bond_Box_Center.setToolTip("Point rotation on BoundBox Center")
      +        self.RB_Bond_Box_Center.clicked.connect(self.on_RB_CenterRot)
      +
      +        self.RB_Center_Mass = QtGui.QRadioButton(self.groupBox_Rotation)
      +        self.RB_Center_Mass.setGeometry(QtCore.QRect(10, 40, 111, 17))
      +        self.RB_Center_Mass.setFont(self.fontGlobal_08)       # 
      +        self.RB_Center_Mass.setObjectName(_fromUtf8("RB_Center_Mass"))
      +        self.RB_Center_Mass.setToolTip("Point rotation on Center Mass")
      +        self.RB_Center_Mass.clicked.connect(self.on_RB_CenterRot)
      +
      +        self.RB_Point_Clicked = QtGui.QRadioButton(self.groupBox_Rotation)
      +        self.RB_Point_Clicked.setGeometry(QtCore.QRect(10, 60, 111, 17))
      +        self.RB_Point_Clicked.setFont(self.fontGlobal_08)       # 
      +        self.RB_Point_Clicked.setObjectName(_fromUtf8("RB_Point_Clicked"))
      +        self.RB_Point_Clicked.setToolTip("Point rotation on Point Mouse clicked on the object"+"\n"
      +                                         "If twoo points are clicked, the second point is used for axis rotation"+"\n"
      +                                         "The point axis rotation Can be changed during the work as long as the object is selected"+"\n"
      +                                         "For this press the CTRL KEY and click the new point rotation")
      +        self.RB_Point_Clicked.clicked.connect(self.on_RB_CenterRot)
      +
      +        ####
      +
      +        self.groupBox_Axis = QtGui.QGroupBox(self.centralwidget)
      +        self.groupBox_Axis.setGeometry(QtCore.QRect(150, 20, 161, 91))
      +        self.groupBox_Axis.setFont(self.fontGlobal_08)       # 
      +        self.groupBox_Axis.setEnabled(False)
      +        self.groupBox_Axis.setObjectName(_fromUtf8("groupBox_Axis"))
      +
      +        self.RB_Rotation_0 = QtGui.QRadioButton(self.groupBox_Axis)
      +        self.RB_Rotation_0.setGeometry(QtCore.QRect(10, 60, 111, 17))
      +        self.RB_Rotation_0.setFont(self.fontGlobal_08)       # 
      +        self.RB_Rotation_0.setObjectName(_fromUtf8("RB_Rotation_0"))
      +        self.RB_Rotation_0.setVisible(False)
      +#        self.RB_Rotation_0.clicked.connect(self.on_RB_Rotation_0)
      +
      +        self.RB_Rotation_X = QtGui.QRadioButton(self.groupBox_Axis)
      +        self.RB_Rotation_X.setGeometry(QtCore.QRect(10, 20, 111, 17))
      +        self.RB_Rotation_X.setFont(self.fontGlobal_08)       # 
      +        self.RB_Rotation_X.setChecked(True)
      +        self.RB_Rotation_X.setObjectName(_fromUtf8("RB_Rotation_X"))
      +        self.RB_Rotation_X.setToolTip("Rotation on Axis Yaw (Z)")
      +        self.RB_Rotation_X.clicked.connect(self.on_RB_Rotation_X)
      +
      +        self.RB_Rotation_Y = QtGui.QRadioButton(self.groupBox_Axis)
      +        self.RB_Rotation_Y.setGeometry(QtCore.QRect(10, 40, 111, 17))
      +        self.RB_Rotation_Y.setFont(self.fontGlobal_08)       # 
      +        self.RB_Rotation_Y.setObjectName(_fromUtf8("RB_Rotation_Y"))
      +        self.RB_Rotation_Y.setToolTip("Rotation on Axis Pitch (Y)")
      +        self.RB_Rotation_Y.clicked.connect(self.on_RB_Rotation_Y)
      +
      +        self.RB_Rotation_Z = QtGui.QRadioButton(self.groupBox_Axis)
      +        self.RB_Rotation_Z.setGeometry(QtCore.QRect(10, 60, 111, 17))
      +        self.RB_Rotation_Z.setFont(self.fontGlobal_08)       # 
      +        self.RB_Rotation_Z.setObjectName(_fromUtf8("RB_Rotation_Z"))
      +        self.RB_Rotation_Z.setToolTip("Rotation on Axis Roll (X)")
      +        self.RB_Rotation_Z.clicked.connect(self.on_RB_Rotation_Z)
      +
      +        ####
      +
      +        self.groupBox_Pos_Mouse = QtGui.QGroupBox(self.centralwidget)
      +        self.groupBox_Pos_Mouse.setGeometry(QtCore.QRect(20, 120, 291, 51))
      +        self.groupBox_Pos_Mouse.setFont(self.fontGlobal_08)       # 
      +        self.groupBox_Pos_Mouse.setEnabled(False)
      +        self.groupBox_Pos_Mouse.setObjectName(_fromUtf8("groupBox_Pos_Mouse"))
      +        self.groupBox_Pos_Mouse.setToolTip("Position click mouse modification possible only with mode Point clicked")
      +
      +        self.DS_Pos_Mouse_X = QtGui.QDoubleSpinBox(self.groupBox_Pos_Mouse)
      +        self.DS_Pos_Mouse_X.setGeometry(QtCore.QRect(10,20,82,22))
      +        self.DS_Pos_Mouse_X.setFont(self.fontGlobal_08)       # 
      +        self.DS_Pos_Mouse_X.setDecimals(6)
      +        self.DS_Pos_Mouse_X.setSuffix(" X")
      +        self.DS_Pos_Mouse_X.setObjectName(_fromUtf8("DS_Pos_Mouse_X"))
      +        self.DS_Pos_Mouse_X.setToolTip("Position click mouse X" + "\n" +
      +                                       "modification only with mode Point clicked")
      +        self.DS_Pos_Mouse_X.valueChanged.connect(self.on_DS_Pos_Mouse_X)
      +
      +        self.DS_Pos_Mouse_Y = QtGui.QDoubleSpinBox(self.groupBox_Pos_Mouse)
      +        self.DS_Pos_Mouse_Y.setGeometry(QtCore.QRect(105,20,91,22))
      +        self.DS_Pos_Mouse_Y.setFont(self.fontGlobal_08)       # 
      +        self.DS_Pos_Mouse_Y.setDecimals(6)
      +        self.DS_Pos_Mouse_Y.setSuffix(" Y")
      +        self.DS_Pos_Mouse_Y.setObjectName(_fromUtf8("DS_Pos_Mouse_Y"))
      +        self.DS_Pos_Mouse_Y.setToolTip("Position click mouse Y" + "\n" +
      +                                       "modification only with mode Point clicked")
      +        self.DS_Pos_Mouse_Y.valueChanged.connect(self.on_DS_Pos_Mouse_Y)
      +
      +        self.DS_Pos_Mouse_Z = QtGui.QDoubleSpinBox(self.groupBox_Pos_Mouse)
      +        self.DS_Pos_Mouse_Z.setGeometry(QtCore.QRect(200,20,82,22))
      +        self.DS_Pos_Mouse_Z.setFont(self.fontGlobal_08)       # 
      +        self.DS_Pos_Mouse_Z.setDecimals(6)
      +        self.DS_Pos_Mouse_Z.setSuffix(" Z")
      +        self.DS_Pos_Mouse_Z.setObjectName(_fromUtf8("DS_Pos_Mouse_Z"))
      +        self.DS_Pos_Mouse_Z.setToolTip("Position click mouse Z" + "\n" +
      +                                       "modification only with mode Point clicked")
      +        self.DS_Pos_Mouse_Z.valueChanged.connect(self.on_DS_Pos_Mouse_Z)
      +
      +        ####
      +
      +        self.SC_Slider_Bar = QtGui.QSlider(self.centralwidget)
      +        self.SC_Slider_Bar.setGeometry(QtCore.QRect(20, 240, 291, 22))
      +        self.SC_Slider_Bar.setFont(self.fontGlobal_08)       # 
      +        self.SC_Slider_Bar.setMinimum(-360.0)
      +        self.SC_Slider_Bar.setMaximum(360.0)
      +        self.SC_Slider_Bar.setValue(0.0)
      +        self.SC_Slider_Bar.setSliderPosition(0)
      +        self.SC_Slider_Bar.setOrientation(QtCore.Qt.Horizontal)
      +        self.SC_Slider_Bar.setObjectName(_fromUtf8("SC_Slider_Bar"))
      +        self.SC_Slider_Bar.valueChanged.connect(self.on_SC_Slider_Bar)
      +
      +        self.LE_Increment = QtGui.QLineEdit(self.centralwidget)
      +        self.LE_Increment.setGeometry(QtCore.QRect(20,210,121,22))
      +        self.LE_Increment.setFont(self.fontGlobal_08)       # 
      +        self.LE_Increment.setObjectName(_fromUtf8("LE_Increment"))
      +        self.LE_Increment.setToolTip("Display the original Data + the modification")
      +        self.LE_Increment.setReadOnly(True)
      +        self.LE_Increment.setText(str(0.0))
      +        #self.LE_Increment.returnPressed.connect(self.on_LE_Increment_Pressed)
      +        self.LE_Increment.textChanged.connect(self.on_LE_Increment_Pressed)
      +
      +        self.DS_Scroll_Bar = QtGui.QDoubleSpinBox(self.centralwidget)
      +        self.DS_Scroll_Bar.setGeometry(QtCore.QRect(150,210,91,22))
      +        self.DS_Scroll_Bar.setFont(self.fontGlobal_08)       # 
      +        self.DS_Scroll_Bar.setMinimum(-360.0)
      +        self.DS_Scroll_Bar.setMaximum(360.0)
      +        self.DS_Scroll_Bar.setDecimals(4)
      +        self.DS_Scroll_Bar.setObjectName(_fromUtf8("DS_Scroll_Bar"))
      +        self.DS_Scroll_Bar.setToolTip("Enter the modification")
      +        self.DS_Scroll_Bar.valueChanged.connect(self.on_DS_Scroll_Bar)
      +
      +        self.PB_Apply = QtGui.QPushButton(self.centralwidget)
      +        self.PB_Apply.setGeometry(QtCore.QRect(250, 210, 61, 23))
      +        self.PB_Apply.setFont(self.fontGlobal_08)       # 
      +        self.PB_Apply.setObjectName(_fromUtf8("PB_Apply"))
      +        self.PB_Apply.setToolTip("Apply the modification")
      +        self.PB_Apply.clicked.connect(self.on_PB_Apply_clicked)
      +
      +        self.CB_Position = QtGui.QCheckBox(self.centralwidget)
      +        self.CB_Position.setGeometry(QtCore.QRect(20, 180, 71, 17))
      +        self.CB_Position.setFont(self.fontGlobal_08)       # 
      +        self.CB_Position.setEnabled(False)
      +        self.CB_Position.setObjectName(_fromUtf8("CB_Position"))
      +        self.CB_Position.setToolTip("Move the object to axis choice X, Y or Z")
      +        self.CB_Position.clicked.connect(self.on_CB_Position)
      +
      +        self.CB_Point = QtGui.QCheckBox(self.centralwidget)
      +        self.CB_Point.setGeometry(QtCore.QRect(150, 180, 51, 17))
      +        self.CB_Point.setFont(self.fontGlobal_08)       # 
      +        self.CB_Point.setEnabled(False)
      +        self.CB_Point.setObjectName(_fromUtf8("CB_Point"))
      +        self.CB_Point.setToolTip("If checked, create one point to visualise the point rotation")
      +        self.CB_Point.clicked.connect(self.on_CB_Point)
      +
      +        self.CB_Free = QtGui.QCheckBox(self.centralwidget)
      +        self.CB_Free.setGeometry(QtCore.QRect(270, 180, 71, 17))
      +        self.CB_Free.setFont(self.fontGlobal_08)       # 
      +        self.CB_Free.setEnabled(False)
      +        self.CB_Free.setObjectName(_fromUtf8("CB_Free"))
      +        self.CB_Free.setToolTip("This checkBox switch the Application button")
      +#        self.CB_Free.clicked.connect(self.on_CB_Free)
      +
      +        self.label_00 = QtGui.QLabel(self.centralwidget)
      +        self.label_00.setGeometry(QtCore.QRect(22, 261, 291, 16))
      +        self.label_00.setFont(self.fontGlobal_08)       # 
      +        self.label_00.setStyleSheet("color : #ffffff; background-color: red; font: bold 10px;")   # white red bold
      +        #self.label_00.setToolTip("Display the modification Axis and Rotation or Position")
      +        self.label_00.setObjectName(_fromUtf8("label_00"))
      +
      +        self.PB_Quit = QtGui.QPushButton(self.centralwidget)
      +        self.PB_Quit.setGeometry(QtCore.QRect(20, 280, 65, 23))
      +        self.PB_Quit.setFont(self.fontGlobal_08)       # 
      +        self.PB_Quit.setObjectName(_fromUtf8("PB_Quit"))
      +        self.PB_Quit.setToolTip("Quite the macro")
      +        self.PB_Quit.clicked.connect(self.on_PB_Quit_clicked)
      +
      +        self.PB_Original = QtGui.QPushButton(self.centralwidget)
      +        self.PB_Original.setGeometry(QtCore.QRect(95, 280, 65, 23))
      +        self.PB_Original.setFont(self.fontGlobal_08)       # 
      +        self.PB_Original.setObjectName(_fromUtf8("PB_Original"))
      +        self.PB_Original.setToolTip("Move the object to the original position")
      +        self.PB_Original.clicked.connect(self.on_PB_Original_clicked)
      +
      +        self.PB_Zero = QtGui.QPushButton(self.centralwidget)
      +        self.PB_Zero.setGeometry(QtCore.QRect(171, 280, 65, 23))
      +        self.PB_Zero.setFont(self.fontGlobal_08)       # 
      +        self.PB_Zero.setObjectName(_fromUtf8("PB_Zero"))
      +        self.PB_Zero.setToolTip("Move the object to the base coordinates 0, 0, 0")
      +        self.PB_Zero.clicked.connect(self.on_PB_Zero_clicked)
      +
      +        self.PB_Reset = QtGui.QPushButton(self.centralwidget)
      +        self.PB_Reset.setGeometry(QtCore.QRect(247, 280, 65, 23))
      +        self.PB_Reset.setFont(self.fontGlobal_08)       # 
      +        self.PB_Reset.setObjectName(_fromUtf8("PB_Reset"))
      +        self.PB_Reset.setToolTip("Reset the complete data macro")
      +        self.PB_Reset.clicked.connect(self.on_PB_Reset_clicked)
      +
      +        MainWindow.setCentralWidget(self.centralwidget)
      +
      +        self.retranslateUi(MainWindow)
      +        QtCore.QMetaObject.connectSlotsByName(MainWindow)
      +
      +    def retranslateUi(self, MainWindow):
      +        MainWindow.setWindowFlags(PySide.QtCore.Qt.WindowStaysOnTopHint)                   # this function turns the front window (stay to hint)
      +        MainWindow.setWindowTitle("Macro_Rotate_To_Point")
      +        self.groupBox_Axis.setTitle("Axis Rotation")
      +        self.RB_Rotation_Z.setText("Rotation(X) Roll")
      +        self.RB_Rotation_Y.setText("Rotation(Y) Pitch")
      +        self.RB_Rotation_X.setText("Rotation(Z) Yaw")
      +        self.groupBox_Rotation.setTitle("Point Rotation")
      +        self.groupBox_Pos_Mouse.setTitle("Coordinates Point clicked")
      +        self.RB_Center_Mass.setText("Center of Mass")
      +        self.RB_Point_Clicked.setText("Point clicked")
      +        self.RB_Bond_Box_Center.setText("Bounbox Center")
      +        self.CB_Position.setText("Position")
      +        self.CB_Point.setText("Point")
      +        self.CB_Free.setText("Free")
      +        self.PB_Apply.setText("Apply")
      +        self.PB_Original.setText("Original")
      +        self.PB_Reset.setText("Reset")
      +        self.PB_Quit.setText("Quit")
      +        self.PB_Zero.setText("0,0,0")
      +        self.label_00.setText(" Select one Object")
      +
      +    def on_DS_Pos_Mouse_X(self,val):
      +        global positionMouse
      +        global axisX
      +        positionMouse = [val, positionMouse[1], positionMouse[2]]
      +        axisX = positionMouse[0]
      +#        print "on_DS_Pos_Mouse_X ", val
      +
      +    def on_DS_Pos_Mouse_Y(self,val):
      +        global positionMouse
      +        global axisY
      +        positionMouse = [positionMouse[0], val, positionMouse[2]]
      +        axisY = positionMouse[1]
      +#        print "on_DS_Pos_Mouse_Y ", val
      +
      +    def on_DS_Pos_Mouse_Z(self,val):
      +        global positionMouse
      +        global axisZ
      +        positionMouse = [positionMouse[0], positionMouse[1], val]
      +        axisZ = positionMouse[2]
      +#        print "on_DS_Pos_Mouse_Z ", val
      +
      +    def on_SC_Slider_Bar(self,val):
      +        global ui
      +        global valeur
      +        global myObject
      +
      +        if myObject != "":
      +            valeur = val
      +            self.DS_Scroll_Bar.setValue(valeur)
      +            self.SC_Slider_Bar.setValue(valeur)
      +
      +            if self.CB_Free.isChecked():
      +                ff = ui
      +                ff.on_PB_Apply_clicked()
      +        else:
      +            self.DS_Scroll_Bar.setValue(0.0)
      +            self.SC_Slider_Bar.setValue(0.0)
      +#        print "on_SC_Scroll_Bar ", valeur
      +
      +    def on_DS_Scroll_Bar(self,val):
      +        global valeur
      +        global myObject
      +        global axisX, axisY, axisZ
      +        global posX, posY, posZ
      +        global rotAngleX, rotAngleY, rotAngleZ
      +
      +        if myObject == "":
      +            self.DS_Scroll_Bar.setValue(0.0)
      +            self.SC_Slider_Bar.setValue(0.0)
      +            None
      +        else:
      +            valeur = val
      +            self.SC_Slider_Bar.setValue(valeur)
      +            if self.CB_Position.isChecked():                 # translate
      +
      +                if self.RB_Rotation_X.isChecked():
      +                    posX = valeur
      +                    posY = posZ = 0.0
      +                    self.LE_Increment.setText(str(round(myObject.Placement.Base[0],4) + valeur))
      +                elif self.RB_Rotation_Y.isChecked():
      +                    posY = valeur
      +                    posX = posZ = 0.0
      +                    self.LE_Increment.setText(str(round(myObject.Placement.Base[1],4) + valeur))
      +                elif self.RB_Rotation_Z.isChecked():
      +                    posZ = valeur
      +                    posX = posY = 0.0
      +                    self.LE_Increment.setText(str(round(myObject.Placement.Base[2],4) + valeur))
      +
      +                self.label_00.setText("[Pos=(" + str(round(myObject.Placement.Base[0],2))+" , " + 
      +                                                 str(round(myObject.Placement.Base[1],2))+" , " + 
      +                                                 str(round(myObject.Placement.Base[2],2))+")] " +
      +                                      "[Axis=("+ str(round(axisX,2)) + " , " + str(round(axisY,2)) + " , " + str(round(axisZ,2)) + ")]")
      +
      +            else:                                            # rotation
      +
      +                if self.RB_Rotation_X.isChecked():
      +                    rotAngleX = valeur
      +                    rotAngleY = rotAngleZ = 0.0
      +                    self.LE_Increment.setText(str(round(myObject.Placement.Rotation.toEuler()[0],4) + valeur))
      +                elif self.RB_Rotation_Y.isChecked():
      +                    rotAngleY = valeur
      +                    rotAngleZ = rotAngleX = 0.0
      +                    self.LE_Increment.setText(str(round(myObject.Placement.Rotation.toEuler()[1],4) + valeur))
      +                elif self.RB_Rotation_Z.isChecked():
      +                    rotAngleZ = valeur
      +                    rotAngleX = rotAngleY = 0.0
      +                    self.LE_Increment.setText(str(round(myObject.Placement.Rotation.toEuler()[2],4) + valeur))
      +
      +#                self.label_00.setText("[Rot=(" + str(round(rotAngleX,2)) + " , " + str(round(rotAngleY,2)) + " , " + str(round(rotAngleZ,2)) + ")] " +
      +#                                      "[Axis=("+ str(round(axisX,2)) + " , " + str(round(axisY,2)) + " , " + str(round(axisZ,2)) + ")]")
      +#        print "on_DS_Scroll_Bar ", valeur
      +
      +    def on_LE_Increment_Pressed(self,text):
      +        None
      +#        print "on_lineEdit_1_Pressed"
      +
      +    def on_PB_Apply_clicked(self):
      +        global valeur
      +        global myObject
      +        global positionMouse
      +        global originalPlacement
      +        global originalObject
      +
      +        global axisX, axisY, axisZ
      +        global posX, posY, posZ
      +        global rotAngleX, rotAngleY, rotAngleZ
      +
      +        if (myObject == "") :
      +            self.label_00.setStyleSheet("color : #ffffff; background-color: red; font: bold 10px;")   # white red bold
      +            self.label_00.setText(" Select one Object")
      +            FreeCAD.Console.PrintError("Select one Object" + "\n")
      +        else:
      +            if self.CB_Position.isChecked():                 # translate
      +
      +                myObject.Placement = App.Placement(App.Vector(posX, posY, posZ), App.Rotation(0.0,0.0,0.0), App.Vector(0.0,0.0,0.0)).multiply(App.ActiveDocument.getObject(myObject.Name).Placement)
      +
      +                if self.RB_Rotation_X.isChecked():
      +                    self.LE_Increment.setText(str(round(myObject.Placement.Base[0],4)))
      +                elif self.RB_Rotation_Y.isChecked():
      +                    self.LE_Increment.setText(str(round(myObject.Placement.Base[1],4)))
      +                elif self.RB_Rotation_Z.isChecked():
      +                    self.LE_Increment.setText(str(round(myObject.Placement.Base[2],4)))
      +
      +                self.label_00.setText("[Pos=(" + str(round(myObject.Placement.Base[0],2))+" , " + 
      +                                                 str(round(myObject.Placement.Base[1],2))+" , " + 
      +                                                 str(round(myObject.Placement.Base[2],2))+")] " +
      +                                      "[Axis=("+ str(round(axisX,2)) + " , " + str(round(axisY,2)) + " , " + str(round(axisZ,2)) + ")]")
      +
      +            else:                                            # rotation
      +
      +                myObject.Placement = App.Placement(App.Vector(0.0,0.0,0.0), App.Rotation(rotAngleX, rotAngleY, rotAngleZ), App.Vector(axisX, axisY, axisZ)).multiply(App.ActiveDocument.getObject(myObject.Name).Placement)
      +
      +                if self.RB_Rotation_X.isChecked():
      +                    self.LE_Increment.setText(str(round(myObject.Placement.Rotation.toEuler()[0],4)))
      +                elif self.RB_Rotation_Y.isChecked():
      +                    self.LE_Increment.setText(str(round(myObject.Placement.Rotation.toEuler()[1],4)))
      +                elif self.RB_Rotation_Z.isChecked():
      +                    self.LE_Increment.setText(str(round(myObject.Placement.Rotation.toEuler()[2],4)))
      +
      +                self.label_00.setText("[Rot=(" + str(round(myObject.Placement.Rotation.toEuler()[0],2)) + " , " +
      +                                                 str(round(myObject.Placement.Rotation.toEuler()[1],2)) + " , " + 
      +                                                 str(round(myObject.Placement.Rotation.toEuler()[2],2)) + ")] " +
      +                                      "[Axis=("+ str(round(axisX,2))+" , "+ str(round(axisY,2))+" , "+ str(round(axisZ,2))+")]")
      +       
      +#            FreeCAD.ActiveDocument.recompute()
      +#        print "on_PB_Apply_clicked"
      +
      +    def on_RB_Rotation_0(self):
      +        None
      +#        print "on_RB_Rotation_0"
      +
      +    def on_RB_Rotation_X(self):
      +        global myObject
      +        if self.CB_Position.isChecked():              
      +            self.LE_Increment.setText(str(round(myObject.Placement.Base[0],4)))                  # pos X
      +        else:
      +            self.LE_Increment.setText(str(round(myObject.Placement.Rotation.toEuler()[0],4)))    # yaw = Z
      +        self.DS_Scroll_Bar.setValue(0.0)
      +#        print "on_RB_Rotation_X"
      +
      +    def on_RB_Rotation_Y(self):
      +        global myObject
      +        if self.CB_Position.isChecked():              
      +            self.LE_Increment.setText(str(round(myObject.Placement.Base[1],4)))                  # pos Y
      +        else:
      +            self.LE_Increment.setText(str(round(myObject.Placement.Rotation.toEuler()[1],4)))    # pitch= Y
      +        self.DS_Scroll_Bar.setValue(0.0)
      +#        print "on_RB_Rotation_Y"
      +
      +    def on_RB_Rotation_Z(self):
      +        global myObject
      +        if self.CB_Position.isChecked():              
      +            self.LE_Increment.setText(str(round(myObject.Placement.Base[2],4)))                  #  pos Z
      +        else:
      +            self.LE_Increment.setText(str(round(myObject.Placement.Rotation.toEuler()[2],4)))    # roll = X
      +        self.DS_Scroll_Bar.setValue(0.0)
      +#        print "on_RB_Rotation_Z"
      +
      +    def on_RB_CenterRot(self):                                # zero
      +        global myObject
      +        global positionMouse
      +        global axisX, axisY, axisZ
      +        
      +        try:
      +            self.groupBox_Pos_Mouse.setEnabled(False)
      +            if self.RB_Bond_Box_Center.isChecked():           # axis
      +                axisX = myObject.Shape.BoundBox.Center.x 
      +                axisY = myObject.Shape.BoundBox.Center.y
      +                axisZ = myObject.Shape.BoundBox.Center.z
      +                if self.CB_Point.isChecked():
      +                    point = Draft.makePoint(myObject.Shape.BoundBox.Center.x, myObject.Shape.BoundBox.Center.y, myObject.Shape.BoundBox.Center.z)
      +                    point.ViewObject.PointColor = (1.0,0.0,0.0)
      +                    point.Label = "Point_BoundBox_Center"
      +
      +            elif self.RB_Center_Mass.isChecked():
      +                axisX = myObject.Shape.CenterOfMass.x
      +                axisY = myObject.Shape.CenterOfMass.y
      +                axisZ = myObject.Shape.CenterOfMass.z
      +                if self.CB_Point.isChecked():
      +                    point = Draft.makePoint(myObject.Shape.CenterOfMass.x, myObject.Shape.CenterOfMass.y, myObject.Shape.CenterOfMass.z)
      +                    point.ViewObject.PointColor = (0.0,1.0,0.0)
      +                    point.Label = "Point_CenterOfMass"
      +    
      +            elif self.RB_Point_Clicked.isChecked():
      +                axisX = positionMouse[0]
      +                axisY = positionMouse[1]
      +                axisZ = positionMouse[2]
      +                self.groupBox_Pos_Mouse.setEnabled(True)
      +
      +                if self.CB_Point.isChecked():
      +                    point = Draft.makePoint(positionMouse[0], positionMouse[1], positionMouse[2])
      +                    point.ViewObject.PointColor = (0.0,0.0,1.0)
      +                    point.Label = "Point_positionMouse"
      +
      +        except Exception:
      +            self.label_00.setText("Error CenterRot_0")
      +            FreeCAD.Console.PrintError("Error CenterRot_0" + "\n" + "or Bad selection" + "\n")
      +#        print "on_RB_CenterRot"
      +
      +    def on_CB_Position(self):
      +        global myObject
      +        global posX, posY, posZ
      +        global axisX, axisY, axisZ
      +
      +        if self.CB_Position.isChecked():              
      +            self.groupBox_Rotation.setEnabled(False)
      +            self.RB_Bond_Box_Center.setChecked(True)
      +            self.SC_Slider_Bar.setMinimum(-1000)
      +            self.SC_Slider_Bar.setMaximum(1000)
      +            self.DS_Scroll_Bar.setMinimum(-1000)
      +            self.DS_Scroll_Bar.setMaximum(1000)
      +
      +            self.groupBox_Axis.setTitle("Axis Direction")
      +            self.RB_Rotation_Z.setText("Direction Z ")          # translate
      +            self.RB_Rotation_Y.setText("Direction Y ")
      +            self.RB_Rotation_X.setText("Direction X ")
      +
      +            try:
      +                self.label_00.setText("[Pos=(" + str(round(myObject.Placement.Base[0],2)) + " , " + 
      +                                                 str(round(myObject.Placement.Base[1],2)) + " , " + 
      +                                                 str(round(myObject.Placement.Base[2],2)) + ")] " +
      +                                      "[Axis=("+ str(round(axisX,2)) + " , " + str(round(axisY,2)) + " , " + str(round(axisZ,2)) + ")]")
      +                if self.RB_Rotation_X.isChecked():
      +                    self.LE_Increment.setText(str(round(myObject.Placement.Base[0],4)))
      +                elif self.RB_Rotation_Y.isChecked():
      +                    self.LE_Increment.setText(str(round(myObject.Placement.Base[1],4)))
      +                elif self.RB_Rotation_Z.isChecked():
      +                    self.LE_Increment.setText(str(round(myObject.Placement.Base[2],4)))
      +            except Exception:
      +                self.label_00.setText("Error Position_0")
      +                FreeCAD.Console.PrintError("Error Position_0" + "\n" + "or Bad selection" + "\n")
      +        else:
      +            self.groupBox_Rotation.setEnabled(True)
      +            self.SC_Slider_Bar.setMinimum(-360)
      +            self.SC_Slider_Bar.setMaximum(360)
      +            self.DS_Scroll_Bar.setMinimum(-360)
      +            self.DS_Scroll_Bar.setMaximum(360)
      +
      +            self.groupBox_Axis.setTitle("Axis Rotation")
      +            self.RB_Rotation_Z.setText("Rotation(X) Roll")      # rotation
      +            self.RB_Rotation_Y.setText("Rotation(Y) Pitch")
      +            self.RB_Rotation_X.setText("Rotation(Z) Yaw")
      +
      +            try:
      +                self.label_00.setText("[Rot=(" + str(round(myObject.Placement.Rotation.toEuler()[0],2)) + " , " +
      +                                                 str(round(myObject.Placement.Rotation.toEuler()[1],2)) + " , " + 
      +                                                 str(round(myObject.Placement.Rotation.toEuler()[2],2)) + ")] " +
      +                                      "[Axis=("+str(round(axisX,2))+" , "+ str(round(axisY,2))+" , "+ str(round(axisZ,2))+")]")
      +                if self.RB_Rotation_X.isChecked():
      +                    self.LE_Increment.setText(str(round(myObject.Placement.Rotation.toEuler()[0],4)))
      +                elif self.RB_Rotation_Y.isChecked():
      +                    self.LE_Increment.setText(str(round(myObject.Placement.Rotation.toEuler()[1],4)))
      +                elif self.RB_Rotation_Z.isChecked():
      +                    self.LE_Increment.setText(str(round(myObject.Placement.Rotation.toEuler()[2],4)))
      +            except Exception:
      +                self.label_00.setText("Error Position_1")
      +                FreeCAD.Console.PrintError("Error Position_0" + "\n" + "or Bad selection" + "\n")
      +
      +        self.DS_Scroll_Bar.setValue(0.0)
      +#        print "on_CB_Position"
      +
      +    def on_CB_Point(self):
      +        global ui
      +        ff = ui
      +        ff.on_RB_CenterRot()
      +#        print "on_CB_Point"
      +
      +    def on_PB_Zero_clicked(self):
      +        global myObject
      +
      +        if (myObject != ""):
      +            try:
      +               # pl = App.Placement(App.Vector(10.0,10.0,10.0), App.Rotation(0.0, 0.0, 0.0), App.Vector(0.0, 0.0, 0.0))
      +                pl = App.Placement(App.Vector(0.0,0.0,0.0), App.Rotation(0.0, 0.0, 0.0), App.Vector(0.0, 0.0, 0.0))
      +    
      +                myObject.Placement = pl
      +#                FreeCAD.ActiveDocument.recompute()
      +            
      +                if self.RB_Rotation_X.isChecked():
      +                    self.LE_Increment.setText(str(round(myObject.Placement.Rotation.toEuler()[0],4)))
      +                elif self.RB_Rotation_Y.isChecked():
      +                    self.LE_Increment.setText(str(round(myObject.Placement.Rotation.toEuler()[1],4)))
      +                elif self.RB_Rotation_Z.isChecked():
      +                    self.LE_Increment.setText(str(round(myObject.Placement.Rotation.toEuler()[2],4)))
      +            
      +                self.label_00.setText("[Rot=(" +str(round(myObject.Placement.Rotation.toEuler()[0],2))+" , "+str(round(myObject.Placement.Rotation.toEuler()[1],2))+" , "+ str(round(myObject.Placement.Rotation.toEuler()[2],2))+")] "+
      +                                      "[Axis=("+str(round(myObject.Placement.Base.x,2))+" , "+ str(round(myObject.Placement.Base.y,2))+" , "+ str(round(myObject.Placement.Base.z,2))+")]")
      +                
      +                self.DS_Scroll_Bar.setValue(0.0)
      +                self.LE_Increment.setText(str(0.0))
      +            
      +#                FreeCAD.ActiveDocument.recompute()
      +                Gui.activeDocument().activeView().viewTop()
      +                Gui.SendMsgToActiveView("ViewFit")
      +    
      +            except Exception:
      +                self.label_00.setText("Error Zero_0")
      +                FreeCAD.Console.PrintError("Error Zero_0" + "\n" + "or Bad selection" + "\n")
      +        else:
      +            self.label_00.setStyleSheet("color : #ffffff; background-color: red; font: bold 10px;")   # white red bold
      +            self.label_00.setText(" Select one Object")
      +            FreeCAD.Console.PrintError("Select one Object" + "\n")
      +#        print "on_PB_Zero_clicked"
      +
      +    def on_PB_Original_clicked(self):
      +        global ui
      +        global myObject
      +        global originalPlacement
      +        global axisX, axisY, axisZ
      +        global rotAngleX, rotAngleY, rotAngleZ
      +
      +        if (myObject != ""):
      +            try:
      +                rotAngleX  = rotAngleY = rotAngleZ = 0.0
      +                myObject.Placement     = originalPlacement
      +                self.DS_Scroll_Bar.setValue(0.0)
      +            
      +                if self.RB_Rotation_X.isChecked():
      +                    self.LE_Increment.setText(str(round(myObject.Placement.Rotation.toEuler()[0],4)))    # yaw Z
      +                elif self.RB_Rotation_Y.isChecked():
      +                    self.LE_Increment.setText(str(round(myObject.Placement.Rotation.toEuler()[1],4)))    # pitch Y
      +                elif self.RB_Rotation_Z.isChecked():
      +                    self.LE_Increment.setText(str(round(myObject.Placement.Rotation.toEuler()[2],4)))    # roll Z
      +            
      +                ff = ui
      +                ff.on_RB_CenterRot()
      +            
      +                self.label_00.setText("[Rot=(" +str(round(myObject.Placement.Rotation.toEuler()[0],2))+" , "+str(round(myObject.Placement.Rotation.toEuler()[1],2))+" , "+ str(round(myObject.Placement.Rotation.toEuler()[2],2))+")] "+
      +                                      "[Axis=("+str(round(axisX,2))+" , "+ str(round(axisY,2))+" , "+ str(round(axisZ,2))+")]")
      +#                FreeCAD.ActiveDocument.recompute()
      +            except Exception:
      +                self.label_00.setText("Error Original_0")
      +                FreeCAD.Console.PrintError("Error Original_0" + "\n" + "or Bad selection" + "\n")
      +        else:
      +            self.label_00.setStyleSheet("color : #ffffff; background-color: red; font: bold 10px;")   # white red bold
      +            self.label_00.setText(" Select one Object")
      +            FreeCAD.Console.PrintError("Select one Object" + "\n")
      +
      +#        print "on_PB_Original_clicked"
      +
      +    def on_PB_Reset_clicked(self):
      +        global originalObject
      +        global myObject
      +        
      +        global valeur
      +        global posX, posY, posZ
      +        global rotAngleX, rotAngleY, rotAngleZ
      +        global axisX, axisY, axisZ
      +
      +        try:
      +            for obj in FreeCAD.ActiveDocument.Objects:         # deslectionne
      +                FreeCADGui.Selection.removeSelection(obj)
      +        except Exception:
      +            None
      +
      +        originalObject = myObject = ""
      +        posX = posY = posZ = rotAngleX = rotAngleY = rotAngleZ = 0.0
      +        axisX = axisY = axisZ = 0.0
      +        valeur  = 0.0
      +
      +        self.DS_Scroll_Bar.setValue(0.0)
      +        self.LE_Increment.setText(str(0.0))
      +
      +        self.groupBox_Axis.setTitle("Axis Rotation")
      +        self.RB_Rotation_Z.setText("Rotation(X) Roll")
      +        self.RB_Rotation_Y.setText("Rotation(Y) Pitch")
      +        self.RB_Rotation_X.setText("Rotation(Z) Yaw")
      +
      +        self.groupBox_Rotation.setEnabled(False)
      +        self.groupBox_Axis.setEnabled(False)
      +        self.groupBox_Pos_Mouse.setEnabled(False)
      +
      +        self.DS_Pos_Mouse_X.setValue(0.0)
      +        self.DS_Pos_Mouse_Y.setValue(0.0)
      +        self.DS_Pos_Mouse_Z.setValue(0.0)
      +
      +        self.CB_Position.setEnabled(False)
      +        self.CB_Position.setChecked(False)
      +        self.CB_Point.setEnabled(False)
      +        self.CB_Point.setChecked(False)
      +        self.CB_Free.setEnabled(False)
      +        self.CB_Free.setChecked(False)
      +
      +        self.label_00.setStyleSheet("color : #ffffff; background-color: red; font: bold 10px;")   # white red bold
      +        self.label_00.setText(" Select one Object")
      +        FreeCAD.Console.PrintError("Select one Object" + "\n")
      +        FreeCAD.Console.PrintMessage("Reset" + "\n")
      +
      +    def on_PB_Quit_clicked(self):
      +        self.vueActive.removeEventCallback("SoMouseButtonEvent",self.click) # desinstalle la fonction souris
      +        FreeCADGui.Selection.removeObserver(s)                              # desinstalle la fonction residente
      +        self.window.hide()                                                  # hide the window and close the macro
      +        FreeCAD.Console.PrintMessage("Quit Rotate_To_Point" + "\n")
      +
      +###################################################################################################
      +class SelObserver:
      +    def addSelection(self, document, object, element, position):  # Selection
      +        global ui
      +        global sourisPass
      +        
      +        global positionMouse
      +        global originalObject
      +        global myObject
      +        global originalPlacement
      +
      +        global posX, posY, posZ
      +        global rotAngleX, rotAngleY, rotAngleZ
      +        global axisX, axisY, axisZ
      +
      +        if sourisPass == 0:                                                                  # pour un seul passage
      +            sourisPass == 1
      +
      +            sel = FreeCADGui.Selection.getSelection()[0]                                     # select object with getSelection()
      +            
      +            positionMouse     = position
      +            originalObject    = myObject = sel   
      +            originalPlacement = sel.Shape.Placement
      +
      +            #longueur = (myObject.Shape.BoundBox.XLength * 0.5)                              # pour Axis
      +            positionBase = originalObject.Shape.Placement.Base                               # Placement Vector XYZ
      +    
      +            posX = positionBase.x
      +            posY = positionBase.y
      +            posZ = positionBase.z
      +    
      +            Yaw   = originalObject.Shape.Placement.Rotation.toEuler()[0]                     # decode angle Euler Yaw
      +            Pitch = originalObject.Shape.Placement.Rotation.toEuler()[1]                     # decode angle Euler Pitch
      +            Roll  = originalObject.Shape.Placement.Rotation.toEuler()[2]                     # decode angle Euler Roll
      +            
      +            rotAngleX = Yaw
      +            rotAngleY = Pitch
      +            rotAngleZ = Roll
      +            axisX = axisY = axisZ = 0.0
      +
      +            ff = ui
      +            ff.DS_Pos_Mouse_X.setValue(positionMouse[0])
      +            ff.DS_Pos_Mouse_Y.setValue(positionMouse[1])
      +            ff.DS_Pos_Mouse_Z.setValue(positionMouse[2])
      +
      +            ff.on_RB_CenterRot()
      +            ff.groupBox_Rotation.setEnabled(True)
      +            ff.groupBox_Axis.setEnabled(True)
      +            #ff.groupBox_Pos_Mouse.setEnabled(True)
      +            ff.CB_Position.setEnabled(True)
      +            ff.CB_Point.setEnabled(True)
      +            ff.CB_Free.setEnabled(True)
      +            ff.label_00.setStyleSheet("Base")                                                # origin system
      +            ff.label_00.setText("[Rot =(" + str(round(rotAngleX,2))+ " , " + str(round(rotAngleY,2)) + " , " + str(round(rotAngleZ,2)) + ")] " +
      +                                "[Axis=("+ str(round(axisX,2)) + " , " + str(round(axisY,2)) + " , " + str(round(axisZ,2)) + ")]")
      +
      +    def clearSelection(self,doc):                                                            # Si clic sur l'ecran, effacer la selection
      +        global ui
      +        ff = ui
      +        ff.on_PB_Reset_clicked()
      +
      +###################################################################################################
      +
      +doc = FreeCAD.ActiveDocument
      +if doc == None:
      +    doc = FreeCAD.newDocument()
      +
      +try:
      +    for obj in FreeCAD.ActiveDocument.Objects:         # deslectionne
      +        FreeCADGui.Selection.removeSelection(obj)
      +except Exception:
      +    None
      +
      +s=SelObserver()
      +FreeCADGui.Selection.addObserver(s)                    # installe la fonction en mode resident
      +
      +MainWindow = QtGui.QMainWindow()
      +ui = Ui_MainWindow()
      +ui.setupUi(MainWindow)
      +MainWindow.show() 
      +

      Example:

      +

      Macro Rotate To Point 01.gif +

      +

      Links

      +

      The forum feature req: placement - rotate part around its midpoint +My macro to Gist mario52a +

      +

      Version

      +

      29/03/2018 ver 00.03 : comment the "FreeCAD.ActiveDocument.recompute()" the change value are too slow with complex element in FreeCAD 0.17.... see FC0.17 recompute strange behaviour (regression) +

      27/03/2017 ver 00.02 : modify the spinbox "Pos" now accept the negative values +

      05/03/2017 ver 00.01 : add 3 spinbox for displayed the coordinates X Y Z on click mouse +

      04/03/2017 ver 00.00 +

      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Macro_Rotate_To_Point.png b/localwiki/Macro_Rotate_To_Point.png new file mode 100644 index 0000000..3632cbe Binary files /dev/null and b/localwiki/Macro_Rotate_To_Point.png differ diff --git a/localwiki/Macro_Rotate_To_Point.svg b/localwiki/Macro_Rotate_To_Point.svg new file mode 100644 index 0000000..cf58d22 --- /dev/null +++ b/localwiki/Macro_Rotate_To_Point.svg @@ -0,0 +1,725 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + Jakub Steiner + + + + + Andreas Nilsson, Garrett LeSage + + + + + + mail + e-mail + send + receive + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Macro_Rotate_To_Point_00.png b/localwiki/Macro_Rotate_To_Point_00.png new file mode 100644 index 0000000..2e1629c Binary files /dev/null and b/localwiki/Macro_Rotate_To_Point_00.png differ diff --git a/localwiki/Macro_Rotate_To_Point_01.gif b/localwiki/Macro_Rotate_To_Point_01.gif new file mode 100644 index 0000000..23d97d0 Binary files /dev/null and b/localwiki/Macro_Rotate_To_Point_01.gif differ diff --git a/localwiki/Macro_Rotate_View.html b/localwiki/Macro_Rotate_View.html new file mode 100644 index 0000000..d29afd3 --- /dev/null +++ b/localwiki/Macro_Rotate_View.html @@ -0,0 +1,129 @@ +Macro Rotate View

      Macro Rotate View

      + +
      + + + + + + + + + + + + + + + + + + + + + + + + + + +
      +

      Text-x-python.png Rotate View by 90°

      +
      Description +
      This macro rotates the current view by 90° to the left. Only works if you are in Top view +
      Author +
      Yorik +
      Links +
      Macros recipes
      How to install macros
      How to customize toolbars +
      Version +
      01.00 +
      Date last modification +
      2010-11-17 +
      +

      + +
      +


      +

      +

      Description

      +

      This macro rotates the current view by 90° to the left. Only works if you are in Top view rotation 90 degrees +


      +

      +
      import math
      +from pivy import coin
      +cam = Gui.ActiveDocument.ActiveView.getCameraNode()
      +rot = coin.SbRotation()
      +rot.setValue(coin.SbVec3f(0,0,1),math.pi/2)
      +nrot = cam.orientation.getValue() * rot
      +cam.orientation = nrot 
      +

      Description

      +

      This code for : +

      +
      1. axonometric view with Y pointing upwards axonometric view with Y pointing upwards mode 1
      2. +
      3. axonometric view with Z pointing upwards axonometric view with Z pointing upwards mode 2
      +

      For FreeCAD Version 0.16 +

      +
      import math
      +import pivy
      +from pivy import coin
      +
      +Gui.activeDocument().activeView().viewAxonometric()
      +Gui.SendMsgToActiveView("ViewFit")
      +
      +cam = Gui.ActiveDocument.ActiveView.getCameraNode()
      +rot = coin.SbRotation()
      +
      +rot.setValue(coin.SbVec3f(1,0,0),-math.pi/2) # Y pointing upwards (mode 1)
      +#rot.setValue(coin.SbVec3f(0,0,1),math.pi/2) # Z pointing upwards (mode 2 uncomment for use)
      +nrot = cam.orientation.getValue() * rot
      +cam.orientation = nrot
      +Gui.SendMsgToActiveView("ViewFit") 
      +

      Description

      +

      This def paste in the Python console FreeCAD (or your macro) allows you to rotate the view in 3-axis and the angle (in degrees) give interesting to create a plan to a desired position +

      +

      Use

      +

      Paste the code in the Python console FreeCAD and type Enter > Enter +

      +

      Script

      +
      def RotateView(axisX=1.0,axisY=0.0,axisZ=0.0,angle=45.0):
      +    import math
      +    from pivy import coin
      +    try:
      +        cam = Gui.ActiveDocument.ActiveView.getCameraNode()
      +        rot = coin.SbRotation()
      +        rot.setValue(coin.SbVec3f(axisX,axisY,axisZ),math.radians(angle))
      +        nrot = cam.orientation.getValue() * rot
      +        cam.orientation = nrot
      +        print axisX," ",axisY," ",axisZ," ",angle
      +    except Exception:
      +        print "Not ActiveView " 
      +

      tip in the console ex : +

      +
      RotateView(0,1,0,45) 
      +

      If there is no open document an error is returned +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Macro_Rotate_View_view_90_Degrees.png b/localwiki/Macro_Rotate_View_view_90_Degrees.png new file mode 100644 index 0000000..29bcb3d Binary files /dev/null and b/localwiki/Macro_Rotate_View_view_90_Degrees.png differ diff --git a/localwiki/Macro_Rotate_View_with_Y_pointing_upwards_.png b/localwiki/Macro_Rotate_View_with_Y_pointing_upwards_.png new file mode 100644 index 0000000..e43adfa Binary files /dev/null and b/localwiki/Macro_Rotate_View_with_Y_pointing_upwards_.png differ diff --git a/localwiki/Macro_Rotate_View_with_Z_pointing_upwards_.png b/localwiki/Macro_Rotate_View_with_Z_pointing_upwards_.png new file mode 100644 index 0000000..c172313 Binary files /dev/null and b/localwiki/Macro_Rotate_View_with_Z_pointing_upwards_.png differ diff --git a/localwiki/Macro_Rubik_Cube.html b/localwiki/Macro_Rubik_Cube.html new file mode 100644 index 0000000..1c226fa --- /dev/null +++ b/localwiki/Macro_Rubik_Cube.html @@ -0,0 +1,1536 @@ +Macro Rubik Cube

      Macro Rubik Cube

      + +
      + + + + + + + + + + + + + + + + + + + + + + + + + + +
      +

      Text-x-python.png Macro_Rubik_Cube

      +
      Description +
      Macro to Display a Rubik Cube and interactively do slice rotations. +
      Author +
      Aleph0 +
      Links +
      Macros recipes
      How to install macros
      How to customize toolbars +
      Version +
      00.04 +
      Date last modification +
      2017-12-05 +
      +

      + +
      +


      +

      +

      Description

      +

      Macro to Display a Rubik Cube and interactively do slice rotations. +

      +
      Macro Rubik Cube.png
      +
      +
      +
      +# -*- coding: utf-8 -*-
      +"""
      +***************************************************************************
      +*                                                                         *
      +*   This macro creates a virtual Rubik Cube and enable you to manipulate  *
      +*   it.                                                                   *
      +*   You can chooose the size (number of small cubes along an edge).       *
      +*   It then makes the cube: large sizes can take a while.                 *
      +*   It then displays several views of the cube.                           *
      +*   The central and largest view is an axonometric projection.            *
      +*   This has arrows around it which you can click on to rotate slices.    *
      +*   There are some text direction labels near the arrows: clicking on one *
      +*   of those rotates the whole cube. You have to click on the actual      *
      +*   letter: FreeCAD doesn't see clicks on the text background             *
      +*   Another view is an axonometric projection from the other side.        *
      +*   Another view combines views towards each face so as to                *
      +*   look like a net of the cube's surface unfolded.                       *
      +*   
      +*   The macro maintains a history of the slice rotations you have done.   *
      +*   It puts three buttons at the top of the window.                       *
      +*   One undoes the last slice rotation and removes it from the history.   *
      +*   One saves the history to the clipboard as a sequence of function      *
      +*   calls which can be pasted into a macro which can then be called       *
      +*   to replay the same set of rotations. Thus you can save an "operator"  *
      +*   (a sequence of slice rotation which does something useful).           *
      +*   The third button resets the cube to its initial state                 *
      +*   and clears the history.                                               *
      +*                                                                         *
      +*   There are also some functions defined which can be called from the    *
      +*   python console window:                                                *
      +*   fix_reload() modifies a restored FreeCAD save file to add the extra   *
      +*   views and interactive controls that this macro and its functions use; *
      +*   ramdomise() randomises the cube;                                      *
      +*   reverse_history(), reflectX_history(), reflectY_history(),            *
      +*   reflectZ_history(), rotpX_history(), rotmX_history(),                 *
      +*   rotpY_history(), rotmY_history(), rotpZ_history(), and                *
      +*   rotmZ_history() each replace the history by a version modified in the *
      +*   manner indicated - these are useful for creating modified operators.  *
      +*                                                                         *
      +***************************************************************************
      +*   Copyright © 2017 Richard P. Parkins, M. A.                            *
      +*                                                                         *
      +*   This file is a supplement to the FreeCAD CAx development system.      *
      +*                                                                         *
      +*   This program is free software; you can redistribute it and/or modify  *
      +*   it under the terms of the GNU Lesser General Public License (LGPL)    *
      +*   as published by the Free Software Foundation; either version 2 of     *
      +*   the License, or (at your option) any later version.                   *
      +*   for detail see the LICENCE text file.                                 *
      +*                                                                         *
      +*   This software is distributed in the hope that it will be useful,      *
      +*   but WITHOUT ANY WARRANTY; without even the implied warranty of        *
      +*   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the         *
      +*   GNU Library General Public License for more details.                  *
      +*                                                                         *
      +*   You should have received a copy of the GNU Library General Public     *
      +*   License along with this macro; if not, write to the Free Software     *
      +*   Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  *
      +*   USA                                                                   *
      +*                                                                         *
      +***************************************************************************
      +"""
      +__title__   = "Rubik_cube"
      +__author__  = "Aleph0"
      +__version__ = "00.04"
      +__date__    = "05/12/2017"
      +__Comment__ = "Virtual Rubik Cube"
      +__Wiki__ = "http://www.freecadweb.org/wiki/index.php?title=Macro_Rubik_Cube"
      +__Help__ = "see first few lines of macro text"
      +__Status__ = "stable"
      +__Requires__ = "freecad 0.16"
      +
      +#OS: Ubuntu 14.04.5 LTS
      +#Word size of OS: 64-bit
      +#Word size of FreeCAD: 64-bit
      +#Version: 0.16.6703 (Git)
      +#Build type: None
      +#Branch: releases/FreeCAD-0-16
      +#Hash: 2ce5c8d2e3020d05005ed71f710e09e9aa561f40
      +#Python version: 2.7.6
      +#Qt version: 4.8.6
      +#Coin version: 4.0.0a
      +#OCC version: 6.8.0.oce-0.17
      +
      +# This parameter determines the speed at which slice rotations are animated
      +# If you have a faster computer you can increase the value
      +# This will make the animation smoother
      +# If you have a slow computer you can decrease the value
      +# This will make the animation faster but more jerky for large cubes
      +slowness = 500
      +
      +import FreeCAD
      +import Part
      +import Draft
      +import time
      +import random
      +from FreeCAD import Base
      +from FreeCAD import Console
      +from pivy import coin
      +from pivy.coin import *
      +import PySide
      +
      +# I copied this code from Macro_Mouse_Cross
      +# It seems a bit version dependent, but it works 
      +try:
      +    from PyQt4 import QtCore, QtGui
      +except Exception:
      +    from PySide import QtCore, QtGui
      +
      +# If this is the first time this macro has been run in this invocation of FreeCAD,
      +# create our dictionary of document-specific data structures
      +if not hasattr(FreeCAD, "Rubik_Cube_executed"):
      +    FreeCAD.Rubik_Cube_executed = 1
      +    Dictionary = {}
      +
      +# Create a new document and make it current
      +App.ActiveDocument = App.newDocument("Rubik_Cube")
      +Gui.ActiveDocument = Gui.getDocument(str(App.ActiveDocument.Name))
      +
      +# This bit of code pops up the dialog to ask for the size
      +width = 300
      +height = 150
      +defaultSize = 3
      +class AskSizeWindow(QtGui.QDialog):
      +    # automagically called when the window is created
      +    def __init__(self):
      +        super(AskSizeWindow, self).__init__()
      +        self.initUI()
      +    # Lay out the interactive elements
      +    def initUI(self):
      +        self.setWindowTitle("Rubik Cube Size")
      +        geom = Gui.getMainWindow().geometry()
      +        xpos = geom.center().x() - width / 2
      +        ypos = geom.center().y() - height / 2
      +        self.setGeometry(xpos, ypos, width, height)
      +        margin = 10
      +        ypos = margin
      +        self.label_1 = QtGui.QLabel(self)
      +        self.label_1.setGeometry(QtCore.QRect(width/2 - 100, ypos, 200, 25)) 
      +        self.label_1.setObjectName("label_1")
      +        self.label_1.setText("Number of small cubes")
      +        self.label_1.setAlignment(QtCore.Qt.AlignCenter)
      +        ypos = ypos + 25
      +        self.label_2 = QtGui.QLabel(self)
      +        self.label_2.setGeometry(QtCore.QRect(width/2 - 100, ypos, 200, 25)) 
      +        self.label_2.setObjectName("label_1")
      +        self.label_2.setText("along an edge")
      +        self.label_2.setAlignment(QtCore.Qt.AlignCenter)
      +        ypos = ypos + 25
      +        self.spinBox = QtGui.QSpinBox(self)
      +        self.spinBox.setGeometry(QtCore.QRect(width/2 - 50, ypos, 100, 30))
      +        self.spinBox.setMinimum(2)
      +        self.spinBox.setMaximum(100)
      +        Dictionary[str(App.ActiveDocument.Name)+"Size"] = defaultSize
      +        self.spinBox.setValue(defaultSize)
      +        self.spinBox.setSingleStep(1)
      +        self.spinBox.setObjectName("spinBox")
      +        self.spinBox.valueChanged.connect(self.on_spinBox_valueChanged)
      +        ypos = ypos + 40
      +        self.OKbutton = QtGui.QPushButton(self)
      +        self.OKbutton.setGeometry(QtCore.QRect(width/2 - 40, ypos, 80, 40))
      +        self.OKbutton.setText("OK")
      +        self.OKbutton.clicked.connect(self.onOK)
      +    def on_spinBox_valueChanged(self, val):
      +        Dictionary[str(App.ActiveDocument.Name)+"Size"] = val
      +    def onOK(self):
      +        self.close()
      +        self.destroy()
      +AskSizeWindow().exec_()
      +
      +# Display a wait cursor while we are making the cube
      +QtGui.QApplication.setOverrideCursor(QtGui.QCursor(QtCore.Qt.WaitCursor))
      +
      +# This bit of code catches clicks on the rotation arrows
      +class ViewObserver:
      +    def __init__(self):
      +        self.view = FreeCADGui.ActiveDocument.ActiveView
      +        self.callback = self.view.addEventCallbackPivy(SoMouseButtonEvent.getClassTypeId(),self.getpoint)  
      +    def getpoint(self,event_cb):
      +        event = event_cb.getEvent()
      +        if event.getButton() == 1:
      +            pos = event.getPosition().getValue()
      +            obInfo = self.view.getObjectInfo((int(pos[0]),int(pos[1])))
      +            if obInfo != None:
      +                obj = App.ActiveDocument.getObject(obInfo["Object"])
      +                obname = obj.Label
      +                if obname[:5] == "arrow":
      +                    if event.getState() == 1:
      +                        wh = obname[5:7]
      +                        i = int(obname[7:])
      +                        if wh == "mX":
      +                            mrotmX(i,i+1)
      +                        elif wh == "pX":
      +                            mrotpX(i,i+1)
      +                        elif wh == "mY":
      +                            mrotmY(i,i+1)
      +                        elif wh == "pY":
      +                            mrotpY(i,i+1)
      +                        elif wh == "mZ":
      +                            mrotmZ(i,i+1)
      +                        elif wh == "pZ":
      +                            mrotpZ(i,i+1)
      +                    event_cb.setHandled()
      +                elif obname[:5] == "label":
      +                    if event.getState() == 1:
      +                        wh = obname[5:7]
      +                        n = Dictionary[str(App.ActiveDocument.Name)+"Size"]
      +                        if wh == "mX":
      +                            mrotmX(0,n)
      +                        elif wh == "pX":
      +                            mrotpX(0,n)
      +                        elif wh == "mY":
      +                            mrotmY(0,n)
      +                        elif wh == "pY":
      +                            mrotpY(0,n)
      +                        elif wh == "mZ":
      +                            mrotmZ(0,n)
      +                        elif wh == "pZ":
      +                            mrotpZ(0,n)
      +                    event_cb.setHandled()
      +
      +Dictionary[str(App.ActiveDocument.Name)+"ViewObserver"] = ViewObserver()
      +
      +# This bit of code creates the basic cube model
      +# It is composed of faces rather than cubes because I haven't found a way of making
      +# a cube with different coloured faces
      +# Each face has a name and a label
      +# The name is persistent regardless of how the face moves about the cube
      +# The label changes and tells where the face is now: this is needed for fix_reload
      +fcd = App.ActiveDocument
      +n = Dictionary[str(App.ActiveDocument.Name)+"Size"]
      +fc = [[[[None for j in range(6)] for ix in range(n)] for iy in range(n)] for ix in range(n)]
      +Dictionary[str(App.ActiveDocument.Name)+"cubies"] = fc
      +for ix in range(n):
      +    fx = ix - (n - 1) / 2.0
      +    for iy in range(n):
      +        fy = iy - (n - 1) / 2.0
      +        for iz in range(n):
      +            fz = iz - (n - 1) / 2.0
      +            fs = str(ix)+"q"+str(iy)+"q"+str(iz)
      +            x0y0z0 = Base.Vector(fx-0.5,fy-0.5,fz-0.5)
      +            x0y0z1 = Base.Vector(fx-0.5,fy-0.5,fz+0.5)
      +            x0y1z0 = Base.Vector(fx-0.5,fy+0.5,fz-0.5)
      +            x0y1z1 = Base.Vector(fx-0.5,fy+0.5,fz+0.5)
      +            x1y0z0 = Base.Vector(fx+0.5,fy-0.5,fz-0.5)
      +            x1y0z1 = Base.Vector(fx+0.5,fy-0.5,fz+0.5)
      +            x1y1z0 = Base.Vector(fx+0.5,fy+0.5,fz-0.5)
      +            x1y1z1 = Base.Vector(fx+0.5,fy+0.5,fz+0.5)
      +            face = Part.Face(Part.makePolygon([x0y0z0,x0y0z1,x0y1z1,x0y1z0,x0y0z0]))
      +            f1 = fcd.addObject("Part::Feature", "ff"+fs+"x0")
      +            f1.Shape = face
      +            f1.Label = "fs"+fs+"x0"
      +            if ix == 0:
      +                f1.ViewObject.DiffuseColor=[(1.0,1.0,1.0)]
      +            else:
      +                f1.ViewObject.DiffuseColor=[(0.0,0.0,0.0)]
      +            f1.ViewObject.RootNode.setName(coin.SbName("ff"+fs+"x0"))
      +            face = Part.Face(Part.makePolygon([x1y0z0,x1y0z1,x1y1z1,x1y1z0,x1y0z0]))
      +            f2 = fcd.addObject("Part::Feature", "ff"+fs+"x1")
      +            f2.Shape = face
      +            f2.Label = "fs"+fs+"x1"
      +            if ix == n - 1:
      +                f2.ViewObject.DiffuseColor=[(1.0,0.0,0.0)]
      +            else:
      +                f2.ViewObject.DiffuseColor=[(0.0,0.0,0.0)]
      +            f2.ViewObject.RootNode.setName(coin.SbName("ff"+fs+"x1"))
      +            face = Part.Face(Part.makePolygon([x0y0z0,x0y0z1,x1y0z1,x1y0z0,x0y0z0]))
      +            f3 = fcd.addObject("Part::Feature", "ff"+fs+"y0")
      +            f3.Shape = face
      +            f3.Label = "fs"+fs+"y0"
      +            if iy == 0:
      +                f3.ViewObject.DiffuseColor=[(0.0,1.0,0.0)]
      +            else:
      +                f3.ViewObject.DiffuseColor=[(0.0,0.0,0.0)]
      +            f3.ViewObject.RootNode.setName(coin.SbName("ff"+fs+"y0"))
      +            face = Part.Face(Part.makePolygon([x0y1z0,x0y1z1,x1y1z1,x1y1z0,x0y1z0]))
      +            f4 = fcd.addObject("Part::Feature", "ff"+fs+"y1")
      +            f4.Shape = face
      +            f4.Label = "fs"+fs+"y1"
      +            if iy == n - 1:
      +                f4.ViewObject.DiffuseColor=[(1.0,0.0,1.0)]
      +            else:
      +                f4.ViewObject.DiffuseColor=[(0.0,0.0,0.0)]
      +            f4.ViewObject.RootNode.setName(coin.SbName("ff"+fs+"y1"))
      +            face = Part.Face(Part.makePolygon([x0y0z0,x0y1z0,x1y1z0,x1y0z0,x0y0z0]))
      +            f5 = fcd.addObject("Part::Feature", "ff"+fs+"z0")
      +            f5.Shape = face
      +            f5.Label = "fs"+fs+"z0"
      +            if iz == 0:
      +                f5.ViewObject.DiffuseColor=[(1.0,1.0,0.0)]
      +            else:
      +                f5.ViewObject.DiffuseColor=[(0.0,0.0,0.0)]
      +            f5.ViewObject.RootNode.setName(coin.SbName("ff"+fs+"z0"))
      +            face = Part.Face(Part.makePolygon([x0y0z1,x0y1z1,x1y1z1,x1y0z1,x0y0z1]))
      +            f6 = fcd.addObject("Part::Feature", "ff"+fs+"z1")
      +            f6.Shape = face
      +            f6.Label = "fs"+fs+"z1"
      +            if iz == n - 1:
      +                f6.ViewObject.DiffuseColor=[(0.0,0.0,1.0)]
      +            else:
      +                f6.ViewObject.DiffuseColor=[(0.0,0.0,0.0)]
      +            f6.ViewObject.RootNode.setName(coin.SbName("ff"+fs+"z1"))
      +            fc[ix][iy][iz]=[f1,f2,f3,f4,f5,f6]
      +
      +# This bit of code creates the clickable arrows
      +# Note we make them not selectable because mouse clicking on them
      +# does a slice rotation instead of selecting the arrow.
      +for i in range(n):
      +    fx = i - (n - 1) / 2.0
      +    fy = -(n / 2.0)
      +    fz = -(0.2 + n / 2.0)
      +    fs = "arrowpX"+str(i)
      +    v0 = Base.Vector(fx-0.1,fy,fz)
      +    v1 = Base.Vector(fx-0.1,fy,fz-0.5)
      +    v2 = Base.Vector(fx-0.2,fy,fz-0.5)
      +    v3 = Base.Vector(fx,fy,fz-0.7)
      +    v4 = Base.Vector(fx+0.2,fy,fz-0.5)
      +    v5 = Base.Vector(fx+0.1,fy,fz-0.5)
      +    v6 = Base.Vector(fx+0.1,fy,fz)
      +    arrow = fcd.addObject("Part::Feature", fs)
      +    arrow.Shape = Part.Face(Part.makePolygon([v0,v1,v2,v3,v4,v5,v6,v0]))
      +    arrow.ViewObject.DiffuseColor = [(0.0,0.0,0.0)]
      +    arrow.ViewObject.RootNode.setName(coin.SbName(fs))
      +    arrow.ViewObject.Selectable = False
      +    fy = 0.2 + n / 2.0
      +    fz = n / 2.0
      +    fs = "arrowmX"+str(i)
      +    v0 = Base.Vector(fx-0.1,fy,fz)
      +    v1 = Base.Vector(fx-0.1,fy+0.5,fz)
      +    v2 = Base.Vector(fx-0.2,fy+0.5,fz)
      +    v3 = Base.Vector(fx,fy+0.7,fz)
      +    v4 = Base.Vector(fx+0.2,fy+0.5,fz)
      +    v5 = Base.Vector(fx+0.1,fy+0.5,fz)
      +    v6 = Base.Vector(fx+0.1,fy,fz)
      +    arrow = fcd.addObject("Part::Feature", fs)
      +    arrow.Shape = Part.Face(Part.makePolygon([v0,v1,v2,v3,v4,v5,v6,v0]))
      +    arrow.ViewObject.DiffuseColor = [(0.0,0.0,0.0)]
      +    arrow.ViewObject.RootNode.setName(coin.SbName(fs))
      +    arrow.ViewObject.Selectable = False
      +    fx = n / 2.0
      +    fy = i - (n - 1) / 2.0
      +    fz = -(0.2 + n / 2.0)
      +    fs = "arrowpY"+str(i)
      +    v0 = Base.Vector(fx,fy-0.1,fz)
      +    v1 = Base.Vector(fx,fy-0.1,fz-0.5)
      +    v2 = Base.Vector(fx,fy-0.2,fz-0.5)
      +    v3 = Base.Vector(fx,fy,fz-0.7)
      +    v4 = Base.Vector(fx,fy+0.2,fz-0.5)
      +    v5 = Base.Vector(fx,fy+0.1,fz-0.5)
      +    v6 = Base.Vector(fx,fy+0.1,fz)
      +    arrow = fcd.addObject("Part::Feature", fs)
      +    arrow.Shape = Part.Face(Part.makePolygon([v0,v1,v2,v3,v4,v5,v6,v0]))
      +    arrow.ViewObject.DiffuseColor = [(0.0,0.0,0.0)]
      +    arrow.ViewObject.RootNode.setName(coin.SbName(fs))
      +    arrow.ViewObject.Selectable = False
      +    fx = -(0.2 + n / 2.0)
      +    fy = i - (n - 1) / 2.0
      +    fz = n / 2.0
      +    fs = "arrowmY"+str(i)
      +    v0 = Base.Vector(fx,fy-0.1,fz)
      +    v1 = Base.Vector(fx-0.5,fy-0.1,fz)
      +    v2 = Base.Vector(fx-0.5,fy-0.2,fz)
      +    v3 = Base.Vector(fx-0.7,fy,fz)
      +    v4 = Base.Vector(fx-0.5,fy+0.2,fz)
      +    v5 = Base.Vector(fx-0.5,fy+0.1,fz)
      +    v6 = Base.Vector(fx,fy+0.1,fz)
      +    arrow = fcd.addObject("Part::Feature", fs)
      +    arrow.Shape = Part.Face(Part.makePolygon([v0,v1,v2,v3,v4,v5,v6,v0]))
      +    arrow.ViewObject.DiffuseColor = [(0.0,0.0,0.0)]
      +    arrow.ViewObject.RootNode.setName(coin.SbName(fs))
      +    arrow.ViewObject.Selectable = False
      +    fx = n / 2.0
      +    fy = 0.2 + n / 2.0
      +    fz = i - (n - 1) / 2.0
      +    fs = "arrowpZ"+str(i)
      +    v0 = Base.Vector(fx,fy,fz-0.1)
      +    v1 = Base.Vector(fx,fy+0.5,fz-0.1)
      +    v2 = Base.Vector(fx,fy+0.5,fz-0.2)
      +    v3 = Base.Vector(fx,fy+0.7,fz)
      +    v4 = Base.Vector(fx,fy+0.5,fz+0.2)
      +    v5 = Base.Vector(fx,fy+0.5,fz+0.1)
      +    v6 = Base.Vector(fx,fy,fz+0.1)
      +    arrow = fcd.addObject("Part::Feature", fs)
      +    arrow.Shape = Part.Face(Part.makePolygon([v0,v1,v2,v3,v4,v5,v6,v0]))
      +    arrow.ViewObject.DiffuseColor = [(0.0,0.0,0.0)]
      +    arrow.ViewObject.RootNode.setName(coin.SbName(fs))
      +    arrow.ViewObject.Selectable = False
      +    fx = -(0.2 + n / 2.0)
      +    fy = -(n / 2.0)
      +    fz = i - (n - 1) / 2.0
      +    fs = "arrowmZ"+str(i)
      +    v0 = Base.Vector(fx,fy,fz-0.1)
      +    v1 = Base.Vector(fx-0.5,fy,fz-0.1)
      +    v2 = Base.Vector(fx-0.5,fy,fz-0.2)
      +    v3 = Base.Vector(fx-0.7,fy,fz)
      +    v4 = Base.Vector(fx-0.5,fy,fz+0.2)
      +    v5 = Base.Vector(fx-0.5,fy,fz+0.1)
      +    v6 = Base.Vector(fx,fy,fz+0.1)
      +    arrow = fcd.addObject("Part::Feature", fs)
      +    arrow.Shape = Part.Face(Part.makePolygon([v0,v1,v2,v3,v4,v5,v6,v0]))
      +    arrow.ViewObject.DiffuseColor = [(0.0,0.0,0.0)]
      +    arrow.ViewObject.RootNode.setName(coin.SbName(fs))
      +    arrow.ViewObject.Selectable = False
      +
      +# This bit of code creates some labels for the arrows
      +# Clicking on one rotates the whole cube
      +def makeLabel(text, mat):
      +    n = Dictionary[str(App.ActiveDocument.Name)+"Size"]
      +    tx = Draft.makeText(text)
      +    tx.Label = "label"+text
      +    tx.ViewObject.TextColor = (0.0,0.0,0.0)
      +    tx.ViewObject.FontSize = 0.2 * n
      +    tx.ViewObject.Justification = 'Center'
      +    node = tx.ViewObject.RootNode
      +    node.setName(coin.SbName("label"+text))
      +    if node.getNumChildren() > 0:
      +        child = node.getChild(0)
      +        if child.getTypeId().getName().__str__() == "Transform":
      +            child.setMatrix(mat)
      +
      +def doLabels():
      +    n = Dictionary[str(App.ActiveDocument.Name)+"Size"]
      +    m = coin.SbMatrix()
      +    m.makeIdentity()
      +    m.setTransform(
      +        coin.SbVec3f(0.0, - n / 2.0, -(1.0 + n * 0.7)),
      +        coin.SbRotation(coin.SbVec3f(1.0, 0.0, 0.0), 3.14159 / 2.0),
      +        coin.SbVec3f(1.0, 1.0, 1.0))
      +    makeLabel("pX", m)
      +    m = coin.SbMatrix()
      +    m.makeIdentity()
      +    m.setTransform(
      +        coin.SbVec3f(0.0, 1.1 + n / 2.0, n / 2.0),
      +        coin.SbRotation(coin.SbVec3f(0.0, 1.0, 0.0), 0.0),
      +        coin.SbVec3f(1.0, 1.0, 1.0))
      +    makeLabel("mX", m)
      +    m = coin.SbMatrix()
      +    m.makeIdentity()
      +    m.setTransform(
      +        coin.SbVec3f(n / 2.0, 0.0, -(1.0 + n * 0.7)),
      +        coin.SbRotation(coin.SbVec3f(0.0, 0.0, 1.0), 3.14159 / 2.0),
      +        coin.SbVec3f(1.0, 1.0, 1.0))
      +    m1 = coin.SbMatrix()
      +    m1.makeIdentity()
      +    m1.setTransform(
      +        coin.SbVec3f(0.0, 0.0, 0.0),
      +        coin.SbRotation(coin.SbVec3f(1.0, 0.0, 0.0), 3.14159 / 2.0),
      +        coin.SbVec3f(1.0, 1.0, 1.0))
      +    m1.multRight(m)
      +    makeLabel("pY", m1)
      +    m = coin.SbMatrix()
      +    m.makeIdentity()
      +    m.setTransform(
      +        coin.SbVec3f(-1.1 - n / 2.0, 0.0, n / 2.0),
      +        coin.SbRotation(coin.SbVec3f(0.0, 0.0, 1.0), 3.14159 / 2.0),
      +        coin.SbVec3f(1.0, 1.0, 1.0))
      +    makeLabel("mY", m)
      +    m = coin.SbMatrix()
      +    m.makeIdentity()
      +    m.setTransform(
      +        coin.SbVec3f(n / 2.0, 0.7 + n * 0.6, 0.0),
      +        coin.SbRotation(coin.SbVec3f(0.0, 1.0, 0.0), 3.14159 / 2.0),
      +        coin.SbVec3f(1.0, 1.0, 1.0))
      +    makeLabel("pZ", m)
      +    m = coin.SbMatrix()
      +    m.makeIdentity()
      +    m.setTransform(
      +        coin.SbVec3f(-1.1 - n / 2.0, - n / 2.0, 0.0),
      +        coin.SbRotation(coin.SbVec3f(1.0, 0.0, 0.0), 3.14159 / 2.0),
      +        coin.SbVec3f(1.0, 1.0, 1.0))
      +    m1 = coin.SbMatrix()
      +    m1.makeIdentity()
      +    m1.setTransform(
      +        coin.SbVec3f(0.0, 0.0, 0.0),
      +        coin.SbRotation(coin.SbVec3f(0.0, 0.0, 1.0), 3.14159 / 2.0),
      +        coin.SbVec3f(1.0, 1.0, 1.0))
      +    m1.multRight(m)
      +    makeLabel("mZ", m1)
      +doLabels()
      +
      +Gui.ActiveDocument.ActiveView.viewAxonometric()
      +Gui.SendMsgToActiveView("ViewFit")
      +# Viewfit doesn't seem to do the right thing with MultiViews
      +# so we adjust the camera height manually before creating them
      +def fixCamera(lift):
      +    # This gets FreeCAD's top level SceneGraph (including camera node),
      +    # not the document's SceneGraph which hangs off of it
      +    v = Gui.ActiveDocument.ActiveView.getViewer()
      +    sceneGraph = v.getSoEventManager().getSceneGraph()
      +    camera = sceneGraph.getChild(2)
      +    if camera.getTypeId().getName().__str__() == "OrthographicCamera":
      +        if lift:
      +            camera.height.setValue((2.0 + n / 20.0) * camera.height.getValue())
      +        return camera.orientation.getValue()
      +rotation = fixCamera(True)
      +
      +# This bit of code finds the widget corresponding to the View3DInventor
      +def findView(widget):
      +    if widget.metaObject().className().__str__() == "Gui::View3DInventor":
      +        return widget
      +    else:
      +        result = None
      +        for child in widget.children():
      +            v = findView(child)
      +            if v != None:
      +                result = v
      +        return result
      +
      +# This bit of code creates the buttons at the top of the view window
      +# The buttons are in a frameless window to save screen space
      +height = 40
      +class ButtonRow(QtGui.QWidget):
      +    def __init__(self):
      +        super(ButtonRow, self).__init__()
      +        view3DWidget = findView(QtGui.qApp.activeWindow().centralWidget())
      +        if view3DWidget != None:
      +            self.setParent(view3DWidget)
      +        self.setAutoFillBackground(True)
      +        xpos = 0
      +        geom = view3DWidget.geometry()
      +        self.setGeometry(xpos, 0, geom.width(), height)
      +        buttonWidth = 80
      +        gap = geom.width() / 4 - buttonWidth
      +        if gap < 0:
      +            gap = 0
      +        xpos = gap
      +        self.undoButton = QtGui.QPushButton(self)
      +        self.undoButton.setGeometry(xpos, 0, buttonWidth, 30)
      +        self.undoButton.setText("Undo")
      +        self.undoButton.clicked.connect(self.onUndo)
      +        xpos = xpos + buttonWidth + gap
      +        self.saveButton = QtGui.QPushButton(self)
      +        self.saveButton.setGeometry(xpos, 0, 3 * buttonWidth, 30)
      +        self.saveButton.setText("Copy history to clipboard")
      +        self.saveButton.clicked.connect(self.onSave)
      +        xpos = xpos + 3 * buttonWidth + gap
      +        self.resetButton = QtGui.QPushButton(self)
      +        self.resetButton.setGeometry(xpos, 0, buttonWidth, 30)
      +        self.resetButton.setText("Reset")
      +        self.resetButton.clicked.connect(self.onReset)
      +        self.show()
      +    def onUndo(self):
      +        undo()
      +    def onReset(self):
      +        reset()
      +    def onSave(self):
      +        saveHistory()
      +Dictionary[str(App.ActiveDocument.Name)+"buttons"] = ButtonRow()
      +
      +# This bit of code disables the default Phong shading
      +# and avoids the face colours appearing to change during rotation
      +def fixLightModel():
      +    v = Gui.ActiveDocument.ActiveView.getViewer()
      +    sceneGraph = v.getSoEventManager().getSceneGraph()
      +    if str(sceneGraph.getChild(0).getName()) <> "LightModel":
      +        lm=coin.SoLightModel()
      +        lm.model.setValue(0)
      +        lm.setName("LightModel")
      +        sceneGraph.insertChild(lm,0)
      +fixLightModel()
      +
      +# This bit of code persuades FreeCAD'a renderer to put
      +# several views of the cube into the same window
      +def MultiViews(parent, child, i, rotation):
      +    n = Dictionary[str(App.ActiveDocument.Name)+"Size"]
      +    newchild=coin.SoMultipleCopy()
      +    newchild.addChild(child)
      +    views=coin.SoMFMatrix()
      +    views.setNum(8)
      +    m1=coin.SbMatrix()
      +    m1.makeIdentity()
      +    views.set1Value(0,m1)
      +    m2=coin.SbMatrix()
      +    m2.setTransform(
      +        coin.SbVec3f(n * 0.9 + 0.4, n * 0.9 + 0.4, 0.0),
      +        coin.SbRotation(coin.SbVec3f(-0.5,0.5,1),3.14159),
      +        coin.SbVec3f(0.5,0.5,0.5))
      +    views.set1Value(1,m2)
      +    m3=coin.SbMatrix()
      +    m3.setTransform(
      +        coin.SbVec3f(- n * 1.15 - 0.7, - n * 1.15 - 0.7, 0.0),
      +        rotation,
      +        coin.SbVec3f(0.5,0.5,0.5))
      +    views.set1Value(2,m3)
      +    m4=coin.SbMatrix()
      +    m4.setTransform(
      +        coin.SbVec3f(0,n,0),
      +        coin.SbRotation(coin.SbVec3f(1,0,0),3.14159*90/180.0),
      +        coin.SbVec3f(1,1,1))
      +    m4.multRight(m3)
      +    views.set1Value(3,m4)
      +    m5=coin.SbMatrix()
      +    m5.setTransform(
      +        coin.SbVec3f(n,0,0),
      +        coin.SbRotation(coin.SbVec3f(0,1,0),-3.14159*90/180.0),
      +        coin.SbVec3f(1,1,1))
      +    m5.multRight(m3)
      +    views.set1Value(4,m5)
      +    m6=coin.SbMatrix()
      +    m6.makeIdentity()
      +    m6.setTransform(
      +        coin.SbVec3f(-n,0,0),
      +        coin.SbRotation(coin.SbVec3f(0,1,0),3.14159*90/180.0),
      +        coin.SbVec3f(1,1,1))
      +    m6.multRight(m3)
      +    views.set1Value(5,m6)
      +    m7=coin.SbMatrix()
      +    m7.setTransform(
      +        coin.SbVec3f(0,-n,0),
      +        coin.SbRotation(coin.SbVec3f(-1,0,0),3.14159*90/180.0),
      +        coin.SbVec3f(1,1,1))
      +    m7.multRight(m3)
      +    views.set1Value(6,m7)
      +    m8=coin.SbMatrix()
      +    m8.setTransform(
      +        coin.SbVec3f(0,-n*2,0),
      +        coin.SbRotation(coin.SbVec3f(-1,0,0),3.14159),
      +        coin.SbVec3f(1,1,1))
      +    m8.multRight(m3)
      +    views.set1Value(7,m8)
      +    newchild.matrix=views
      +    parent.replaceChild(i,newchild)
      +def createMultiViews(rotation):
      +    sg = FreeCADGui.ActiveDocument.ActiveView.getSceneGraph()
      +    if sg.getNumChildren() != 0:
      +        for i in range(sg.getNumChildren()):
      +            child = sg.getChild(i)
      +            type = child.getTypeId().getName().__str__()
      +            if child.getTypeId().getName().__str__() == 'Separator':
      +                name = child.getName().__str__()[:5]
      +                if name != "arrow" and name != "label":
      +                    MultiViews(sg,child,i,rotation)
      +            if child.getTypeId().getName().__str__() == 'MultipleCopy':
      +                if child.getNumChildren() != 0:
      +                    name = child.getChild(0).getName().__str__()
      +                    if fcd.getObject(name) == None:
      +                        child.removeAllChildren()
      +createMultiViews(rotation)
      +
      +# Restore the normal cursor now that we have done all the slow stuff
      +QtGui.QApplication.restoreOverrideCursor()
      +
      +# This bit of code animates a slice rotation
      +def rotate(dir, rs, re, steps):
      +    n = Dictionary[str(App.ActiveDocument.Name)+"Size"]
      +    fc = Dictionary[str(App.ActiveDocument.Name)+"cubies"]
      +    fd = [[[[None for j in range(6)] for ix in range(n)] for iy in range(n)] for ix in range(n)]
      +    fp = [[[[Base.Placement() for j in range(6)] for ix in range(n)] for iy in range(n)] for ix in range(n)]
      +    xyz = ["x0","x1","y0","y1","z0","z1"]
      +    if dir.x > 0:
      +        # We need an explicit matrix for the final rotation step
      +        # to prevent rounding errors accumulating over time
      +        ff = Base.Matrix(1,0,0,0,0,0,-1,0,0,1,0,0,0,0,0,1)
      +        kk =[0,1,5,4,2,3]
      +        for iy in range(n):
      +            for iz in range(n):
      +                for j in range(rs, re):
      +                    for k in range(6):
      +                        c = fc[j][iy][iz][k]
      +                        c.Label = c.Name
      +                        fd[j][iy][iz][k] = c
      +                        fp[j][iy][iz][k] = c.Placement
      +        if steps > 0:
      +            fm = Base.Matrix()
      +            fm.rotateX(1.570795 / steps)
      +            for i in range(steps):
      +                for iy in range(n):
      +                    for iz in range(n):
      +                        for j in range(rs, re):
      +                            for k in range(6):
      +                                c = fc[j][iy][iz][k]
      +                                p = c.Placement
      +                                c.Placement = Base.Placement(fm).multiply(p)
      +                Gui.updateGui()
      +        for iy in range(n):
      +            for iz in range(n):
      +                for j in range(rs, re):
      +                    for k in range(6):
      +                        c = fd[j][iz][n-1-iy][kk[k]]
      +                        p = fp[j][iz][n-1-iy][kk[k]]
      +                        c.Label = "fs"+str(j)+"q"+str(iy)+"q"+str(iz)+xyz[k]
      +                        c.Placement = Base.Placement(ff).multiply(p)
      +                        fc[j][iy][iz][k] = c
      +    elif dir.x < 0:
      +        ff = Base.Matrix(1,0,0,0,0,0,1,0,0,-1,0,0,0,0,0,1)
      +        kk =[0,1,4,5,3,2]
      +        for iy in range(n):
      +            for iz in range(n):
      +                for j in range(rs, re):
      +                    for k in range(6):
      +                        c = fc[j][iy][iz][k]
      +                        c.Label = c.Name
      +                        fd[j][iy][iz][k] = c
      +                        fp[j][iy][iz][k] = c.Placement
      +        if steps > 0:
      +            fm = Base.Matrix()
      +            fm.rotateX(-1.570795 / steps)
      +            for i in range(steps):
      +                for iy in range(n):
      +                    for iz in range(n):
      +                        for j in range(rs, re):
      +                            for k in range(6):
      +                                c = fc[j][iy][iz][k]
      +                                p = c.Placement
      +                                c.Placement = Base.Placement(fm).multiply(p)
      +                Gui.updateGui()
      +        for iy in range(n):
      +            for iz in range(n):
      +                for j in range(rs, re):
      +                    for k in range(6):
      +                        c = fd[j][n-1-iz][iy][kk[k]]
      +                        p = fp[j][n-1-iz][iy][kk[k]]
      +                        c.Label = "fs"+str(j)+"q"+str(iy)+"q"+str(iz)+xyz[k]
      +                        c.Placement = Base.Placement(ff).multiply(p)
      +                        fc[j][iy][iz][k] = c
      +    elif dir.y > 0:
      +        ff = Base.Matrix(0,0,1,0,0,1,0,0,-1,0,0,0,0,0,0,1)
      +        kk =[4,5,2,3,1,0]
      +        for ix in range(n):
      +            for iz in range(n):
      +                for j in range(rs, re):
      +                    for k in range(6):
      +                        c = fc[ix][j][iz][k]
      +                        c.Label = c.Name
      +                        fd[ix][j][iz][k] = c
      +                        fp[ix][j][iz][k] = c.Placement
      +        if steps > 0:
      +            fm = Base.Matrix()
      +            fm.rotateY(1.570795 / steps)
      +            for i in range(steps):
      +                for ix in range(n):
      +                    for iz in range(n):
      +                        for j in range(rs, re):
      +                            for k in range(6):
      +                                c = fc[ix][j][iz][k]
      +                                p = c.Placement
      +                                c.Placement = Base.Placement(fm).multiply(p)
      +                Gui.updateGui()
      +        for ix in range(n):
      +            for iz in range(n):
      +                for j in range(rs, re):
      +                    for k in range(6):
      +                        c = fd[n-1-iz][j][ix][kk[k]]
      +                        p = fp[n-1-iz][j][ix][kk[k]]
      +                        c.Label = "fs"+str(ix)+"q"+str(j)+"q"+str(iz)+xyz[k]
      +                        c.Placement = Base.Placement(ff).multiply(p)
      +                        fc[ix][j][iz][k] = c
      +    elif dir.y < 0:
      +        ff = Base.Matrix(0,0,-1,0,0,1,0,0,1,0,0,0,0,0,0,1)
      +        kk =[5,4,2,3,0,1]
      +        for ix in range(n):
      +            for iz in range(n):
      +                for j in range(rs, re):
      +                    for k in range(6):
      +                        c = fc[ix][j][iz][k]
      +                        c.Label = c.Name
      +                        fd[ix][j][iz][k] = c
      +                        fp[ix][j][iz][k] = c.Placement
      +        if steps > 0:
      +            fm = Base.Matrix()
      +            fm.rotateY(-1.570795 / steps)
      +            for i in range(steps):
      +                for ix in range(n):
      +                    for iz in range(n):
      +                        for j in range(rs, re):
      +                            for k in range(6):
      +                                c = fc[ix][j][iz][k]
      +                                p = c.Placement
      +                                c.Placement = Base.Placement(fm).multiply(p)
      +                Gui.updateGui()
      +        for ix in range(n):
      +            for iz in range(n):
      +                for j in range(rs, re):
      +                    for k in range(6):
      +                        c = fd[iz][j][n-1-ix][kk[k]]
      +                        p = fp[iz][j][n-1-ix][kk[k]]
      +                        c.Label = "fs"+str(ix)+"q"+str(j)+"q"+str(iz)+xyz[k]
      +                        c.Placement = Base.Placement(ff).multiply(p)
      +                        fc[ix][j][iz][k] = c
      +    elif dir.z > 0:
      +        ff = Base.Matrix(0,-1,0,0,1,0,0,0,0,0,1,0,0,0,0,1)
      +        kk = [3,2,0,1,4,5]
      +        for ix in range(n):
      +            for iy in range(n):
      +                for j in range(rs, re):
      +                    for k in range(6):
      +                        c = fc[ix][iy][j][k]
      +                        c.Label = c.Name
      +                        fd[ix][iy][j][k] = c
      +                        fp[ix][iy][j][k] = c.Placement
      +        if steps > 0:
      +            fm = Base.Matrix()
      +            fm.rotateZ(1.570795 / steps)
      +            for i in range(steps):
      +                for ix in range(n):
      +                    for iy in range(n):
      +                        for j in range(rs, re):
      +                            for k in range(6):
      +                                c = fc[ix][iy][j][k]
      +                                p = c.Placement
      +                                c.Placement = Base.Placement(fm).multiply(p)
      +                Gui.updateGui()
      +        for ix in range(n):
      +            for iy in range(n):
      +                for j in range(rs, re):
      +                    for k in range(6):
      +                        c = fd[iy][n-1-ix][j][kk[k]]
      +                        p = fp[iy][n-1-ix][j][kk[k]]
      +                        c.Label = "fs"+str(ix)+"q"+str(iy)+"q"+str(j)+xyz[k]
      +                        c.Placement = Base.Placement(ff).multiply(p)
      +                        fc[ix][iy][j][k] = c
      +    elif dir.z < 0:
      +        ff = Base.Matrix(0,1,0,0,-1,0,0,0,0,0,1,0,0,0,0,1)
      +        kk = [2,3,1,0,5,4]
      +        for ix in range(n):
      +            for iy in range(n):
      +                for j in range(rs, re):
      +                    for k in range(6):
      +                        c = fc[ix][iy][j][k]
      +                        c.Label = c.Name
      +                        fd[ix][iy][j][k] = c
      +                        fp[ix][iy][j][k] = c.Placement
      +        if steps > 0:
      +            fm = Base.Matrix()
      +            fm.rotateZ(-1.570795 / steps)
      +            for i in range(steps):
      +                for ix in range(n):
      +                    for iy in range(n):
      +                        for j in range(rs, re):
      +                            for k in range(6):
      +                                c = fc[ix][iy][j][k]
      +                                p = c.Placement
      +                                c.Placement = Base.Placement(fm).multiply(p)
      +                Gui.updateGui()
      +        for ix in range(n):
      +            for iy in range(n):
      +                for j in range(rs, re):
      +                    for k in range(6):
      +                        c = fd[n-1-iy][ix][j][kk[k]]
      +                        p = fp[n-1-iy][ix][j][kk[k]]
      +                        c.Label = "fs"+str(ix)+"q"+str(iy)+"q"+str(j)+xyz[k]
      +                        c.Placement = Base.Placement(ff).multiply(p)
      +                        fc[ix][iy][j][k] = c
      +
      +def slowrotate(dir, rs, re):
      +    n = Dictionary[str(App.ActiveDocument.Name)+"Size"]
      +    steps = slowness / (n * n)
      +    if re > rs:
      +        rotate(dir, rs, re, steps / (re - rs))
      +        Gui.updateGui()
      +
      +# Quick rotation for use when randomising or modifying history
      +def fastrotate(dir, rs, re):
      +    rotate(dir, rs, re, 0)
      +
      +# These functions manage the history
      +# Once you have created a cube, these functions will be defined and in scope
      +# and you can call them from another macro created by saving history
      +# or by hand from the python console window
      +history = []
      +Dictionary[str(App.ActiveDocument.Name)+"history"] = history
      +def mrotpX(i,j):
      +    slowrotate(Base.Vector(1,0,0),i,j)
      +    Dictionary[str(App.ActiveDocument.Name)+"history"].append("mrotpX("+str(i)+","+str(j)+")")
      +def mrotpY(i,j):
      +    slowrotate(Base.Vector(0,1,0),i,j)
      +    Dictionary[str(App.ActiveDocument.Name)+"history"].append("mrotpY("+str(i)+","+str(j)+")")
      +def mrotpZ(i,j):
      +    slowrotate(Base.Vector(0,0,1),i,j)
      +    Dictionary[str(App.ActiveDocument.Name)+"history"].append("mrotpZ("+str(i)+","+str(j)+")")
      +def mrotmX(i,j):
      +    slowrotate(Base.Vector(-1,0,0),i,j)
      +    Dictionary[str(App.ActiveDocument.Name)+"history"].append("mrotmX("+str(i)+","+str(j)+")")
      +def mrotmY(i,j):
      +    slowrotate(Base.Vector(0,-1,0),i,j)
      +    Dictionary[str(App.ActiveDocument.Name)+"history"].append("mrotmY("+str(i)+","+str(j)+")")
      +def mrotmZ(i,j):
      +    slowrotate(Base.Vector(0,0,-1),i,j)
      +    Dictionary[str(App.ActiveDocument.Name)+"history"].append("mrotmZ("+str(i)+","+str(j)+")")
      +def undo():
      +    history = Dictionary[str(App.ActiveDocument.Name)+"history"]
      +    if len(history) > 0:
      +        fs = history.pop()
      +        wh = fs[:6]
      +        p = fs.index(",")
      +        i = int(fs[7:p])
      +        j = int(fs[(p+1):(len(fs)-1)])
      +        if wh == "mrotmX":
      +            slowrotate(Base.Vector(1,0,0),i,j)
      +        elif wh == "mrotpX":
      +            slowrotate(Base.Vector(-1,0,0),i,j)
      +        elif wh == "mrotmY":
      +            slowrotate(Base.Vector(0,1,0),i,j)
      +        elif wh == "mrotpY":
      +            slowrotate(Base.Vector(0,-1,0),i,j)
      +        elif wh == "mrotmZ":
      +            slowrotate(Base.Vector(0,0,1),i,j)
      +        elif wh == "mrotpZ":
      +            slowrotate(Base.Vector(0,0,-1),i,j)
      +def itostring(i, n):
      +    if 2 * i == n - 1:
      +    return "n/2"
      +    elif i <= n / 2:
      +        return str(i)
      +    elif i == n - 1:
      +        return "n-1"
      +    else:
      +        return "n-" + str(n-i) 
      +def jtostring(j, n):
      +    if j <= n / 2:
      +       return str(j)
      +    elif 2 * j == n + 1:
      +    return "n/2+1"
      +    elif j == n:
      +        return "n"
      +    elif j == n - 1:
      +        return "n-1"
      +    else:
      +        return "n-" + str(n-j) 
      +def saveHistory():
      +    fcd = App.ActiveDocument
      +    history = Dictionary[str(fcd.Name)+"history"]
      +    n = Dictionary[str(fcd.Name)+"Size"]
      +    if len(history) > 0:
      +        # This statement will be needed at the start of any macro
      +        # to get the size of the cube in the currently active document
      +        # in case we have several documents open at once
      +        fs = "n = Dictionary[str(App.ActiveDocument.Name)+'Size']\n"
      +        for s in history:
      +            p = s.index(",")
      +            i = int(s[7:p])
      +            j = int(s[(p+1):(len(s)-1)])
      +            fs = fs + s[:7] + itostring(i, n) + ","
      +            fs = fs + jtostring(j, n) + ")\n"
      +        clip = QtCore.QCoreApplication.instance().clipboard()
      +        clip.setText(fs)
      +def reset():
      +    QtGui.QApplication.setOverrideCursor(QtGui.QCursor(QtCore.Qt.WaitCursor))
      +    fcd = App.ActiveDocument
      +    Dictionary[str(fcd.Name)+"history"] = []
      +    n = Dictionary[str(fcd.Name)+"Size"]
      +    fc = Dictionary[str(fcd.Name)+"cubies"]
      +    for obj in fcd.Objects:
      +        fs = obj.Name
      +        if fs[0:2] == "ff":
      +            obj.Label = fs
      +    for obj in fcd.Objects:
      +        fs = obj.Name
      +        if fs[0:2] == "ff":
      +            obj.Label = "fs"+fs[2:]
      +            obj.Placement = Base.Placement()
      +            l = len(fs)
      +            q1 = fs.find("q")
      +            q2 = fs.find("q",q1+1)
      +            ix = int(fs[2:q1])
      +            iy = int(fs[q1+1:q2])
      +            iz = int(fs[q2+1:l-2])
      +            k = "x0x1y0y1z0z1".find(fs[l-2:])/2
      +            fc[ix][iy][iz][k] = obj
      +    QtGui.QApplication.restoreOverrideCursor()
      +
      +# Randomise the cube
      +def randomise():
      +    QtGui.QApplication.setOverrideCursor(QtGui.QCursor(QtCore.Qt.WaitCursor))
      +    fcd = App.ActiveDocument
      +    history = Dictionary[str(fcd.Name)+"history"]
      +    n = Dictionary[str(fcd.Name)+"Size"]
      +    random.seed()
      +    i = random.randrange(0,6)
      +    for x in range(n*24):
      +        i = (i + 2 - i % 2 +random.randrange(0,4)) % 6
      +        j = random.randrange(0,n)
      +        if i == 0:
      +            fastrotate(Base.Vector(1,0,0),j,j+1)
      +            history.append("mrotpX("+str(j)+","+str(j+1)+")")
      +        elif i == 1:
      +            fastrotate(Base.Vector(-1,0,0),j,j+1)
      +            history.append("mrotmX("+str(j)+","+str(j+1)+")")
      +        elif i == 2:
      +            fastrotate(Base.Vector(0,1,0),j,j+1)
      +            history.append("mrotpY("+str(j)+","+str(j+1)+")")
      +        elif i == 3:
      +            fastrotate(Base.Vector(0,-1,0),j,j+1)
      +            history.append("mrotmY("+str(j)+","+str(j+1)+")")
      +        elif i == 4:
      +            fastrotate(Base.Vector(0,0,1),j,j+1)
      +            history.append("mrotpZ("+str(j)+","+str(j+1)+")")
      +        elif i == 5:
      +            fastrotate(Base.Vector(0,0,-1),j,j+1)
      +            history.append("mrotmZ("+str(j)+","+str(j+1)+")")
      +    QtGui.QApplication.restoreOverrideCursor()
      +
      +# Various macros to modify the history
      +# They all read the history and undo it, and then perform some modified version
      +# of the history. The modifications can be time-reversal, reflection along an
      +# axis (as if the cube were reflected, the history replayed,
      +# and the cube reflected back again), or rotation (as if the cube were rotated,
      +# the history replayed, and the cube rotated back again).
      +def slow_history():
      +    QtGui.QApplication.setOverrideCursor(QtGui.QCursor(QtCore.Qt.WaitCursor))
      +    fcd = App.ActiveDocument
      +    history = Dictionary[str(fcd.Name)+"history"]
      +    n = Dictionary[str(fcd.Name)+"Size"]
      +    nh = []
      +    while len(history) > 0:
      +        nh.append(history.pop())
      +    reset()
      +    Gui.updateGui()
      +    while len(nh) > 0:
      +        fs = nh.pop()
      +        wh = fs[:6]
      +        p = fs.index(",")
      +        i = int(fs[7:p])
      +        j = int(fs[p+1:len(fs)-1])
      +        if wh == "mrotpX":
      +            mrotpX(i,j)
      +        elif wh == "mrotmX":
      +            mrotmX(i,j)
      +        elif wh == "mrotpY":
      +            mrotpY(i,j)
      +        elif wh == "mrotmY":
      +            mrotmY(i,j)
      +        elif wh == "mrotpZ":
      +            mrotpZ(i,j)
      +        elif wh == "mrotmZ":
      +            mrotmZ(i,j)
      +    QtGui.QApplication.restoreOverrideCursor()
      +def reverse_history():
      +    QtGui.QApplication.setOverrideCursor(QtGui.QCursor(QtCore.Qt.WaitCursor))
      +    fcd = App.ActiveDocument
      +    history = Dictionary[str(fcd.Name)+"history"]
      +    n = Dictionary[str(fcd.Name)+"Size"]
      +    nh = []
      +    while len(history) > 0:
      +        nh.append(history.pop())
      +    reset()
      +    history = Dictionary[str(fcd.Name)+"history"]
      +    for fs in nh:
      +        wh = fs[:6]
      +        p = fs.index(",")
      +        i = int(fs[7:p])
      +        j = int(fs[p+1:len(fs)-1])
      +        if wh == "mrotpX":
      +            fastrotate(Base.Vector(1,0,0),i,j)
      +            history.append("mrotpX("+str(i)+","+str(j)+")")
      +        elif wh == "mrotmX":
      +            fastrotate(Base.Vector(-1,0,0),i,j)
      +            history.append("mrotmX("+str(i)+","+str(j)+")")
      +        elif wh == "mrotpY":
      +            fastrotate(Base.Vector(0,1,0),i,j)
      +            history.append("mrotpY("+str(i)+","+str(j)+")")
      +        elif wh == "mrotmY":
      +            fastrotate(Base.Vector(0,-1,0),i,j)
      +            history.append("mrotmY("+str(i)+","+str(j)+")")
      +        elif wh == "mrotpZ":
      +            fastrotate(Base.Vector(0,0,1),i,j)
      +            history.append("mrotpZ("+str(i)+","+str(j)+")")
      +        elif wh == "mrotmZ":
      +            fastrotate(Base.Vector(0,0,-1),i,j)
      +            history.append("mrotmZ("+str(i)+","+str(j)+")")
      +    QtGui.QApplication.restoreOverrideCursor()
      +def undo_history():
      +    QtGui.QApplication.setOverrideCursor(QtGui.QCursor(QtCore.Qt.WaitCursor))
      +    fcd = App.ActiveDocument
      +    history = Dictionary[str(fcd.Name)+"history"]
      +    n = Dictionary[str(fcd.Name)+"Size"]
      +    nh = []
      +    while len(history) > 0:
      +        nh.append(history.pop())
      +    reset()
      +    history = Dictionary[str(fcd.Name)+"history"]
      +    for fs in nh:
      +        wh = fs[:6]
      +        p = fs.index(",")
      +        i = int(fs[7:p])
      +        j = int(fs[p+1:len(fs)-1])
      +        if wh == "mrotpX":
      +            fastrotate(Base.Vector(-1,0,0),i,j)
      +            history.append("mrotmX("+str(i)+","+str(j)+")")
      +        elif wh == "mrotmX":
      +            fastrotate(Base.Vector(1,0,0),i,j)
      +            history.append("mrotpX("+str(i)+","+str(j)+")")
      +        elif wh == "mrotpY":
      +            fastrotate(Base.Vector(0,-1,0),i,j)
      +            history.append("mrotmY("+str(i)+","+str(j)+")")
      +        elif wh == "mrotmY":
      +            fastrotate(Base.Vector(0,1,0),i,j)
      +            history.append("mrotpY("+str(i)+","+str(j)+")")
      +        elif wh == "mrotpZ":
      +            fastrotate(Base.Vector(0,0,-1),i,j)
      +            history.append("mrotmZ("+str(i)+","+str(j)+")")
      +        elif wh == "mrotmZ":
      +            fastrotate(Base.Vector(0,0,1),i,j)
      +            history.append("mrotpZ("+str(i)+","+str(j)+")")
      +    QtGui.QApplication.restoreOverrideCursor()
      +def reflectX_history():
      +    QtGui.QApplication.setOverrideCursor(QtGui.QCursor(QtCore.Qt.WaitCursor))
      +    fcd = App.ActiveDocument
      +    history = Dictionary[str(fcd.Name)+"history"]
      +    n = Dictionary[str(fcd.Name)+"Size"]
      +    nh = []
      +    while len(history) > 0:
      +        nh.append(history.pop())
      +    reset()
      +    history = Dictionary[str(fcd.Name)+"history"]
      +    while len(nh) > 0:
      +        fs = nh.pop()
      +        wh = fs[:6]
      +        p = fs.index(",")
      +        i = int(fs[7:p])
      +        j = int(fs[p+1:len(fs)-1])
      +        if wh == "mrotpX":
      +            fastrotate(Base.Vector(1,0,0),n-j,n-i)
      +            history.append("mrotpX("+str(n-j)+","+str(n-i)+")")
      +        elif wh == "mrotmX":
      +            fastrotate(Base.Vector(-1,0,0),n-j,n-i)
      +            history.append("mrotmX("+str(n-j)+","+str(n-i)+")")
      +        elif wh == "mrotpY":
      +            fastrotate(Base.Vector(0,-1,0),i,j)
      +            history.append("mrotmY("+str(i)+","+str(j)+")")
      +        elif wh == "mrotmY":
      +            fastrotate(Base.Vector(0,1,0),i,j)
      +            history.append("mrotpY("+str(i)+","+str(j)+")")
      +        elif wh == "mrotpZ":
      +            fastrotate(Base.Vector(0,0,-1),i,j)
      +            history.append("mrotmZ("+str(i)+","+str(j)+")")
      +        elif wh == "mrotmZ":
      +            fastrotate(Base.Vector(0,0,1),i,j)
      +            history.append("mrotpZ("+str(i)+","+str(j)+")")
      +    QtGui.QApplication.restoreOverrideCursor()
      +def reflectY_history():
      +    QtGui.QApplication.setOverrideCursor(QtGui.QCursor(QtCore.Qt.WaitCursor))
      +    fcd = App.ActiveDocument
      +    history = Dictionary[str(fcd.Name)+"history"]
      +    n = Dictionary[str(fcd.Name)+"Size"]
      +    nh = []
      +    while len(history) > 0:
      +        nh.append(history.pop())
      +    reset()
      +    history = Dictionary[str(fcd.Name)+"history"]
      +    while len(nh) > 0:
      +        fs = nh.pop()
      +        wh = fs[:6]
      +        p = fs.index(",")
      +        i = int(fs[7:p])
      +        j = int(fs[p+1:len(fs)-1])
      +        if wh == "mrotpX":
      +            fastrotate(Base.Vector(-1,0,0),i,j)
      +            history.append("mrotmX("+str(i)+","+str(j)+")")
      +        elif wh == "mrotmX":
      +            fastrotate(Base.Vector(1,0,0),i,j)
      +            history.append("mrotpX("+str(i)+","+str(j)+")")
      +        elif wh == "mrotpY":
      +            fastrotate(Base.Vector(0,1,0),n-j,n-i)
      +            history.append("mrotpY("+str(n-j)+","+str(n-i)+")")
      +        elif wh == "mrotmY":
      +            fastrotate(Base.Vector(0,-1,0),n-j,n-i)
      +            history.append("mrotmY("+str(n-j)+","+str(n-i)+")")
      +        elif wh == "mrotpZ":
      +            fastrotate(Base.Vector(0,0,-1),i,j)
      +            history.append("mrotmZ("+str(i)+","+str(j)+")")
      +        elif wh == "mrotmZ":
      +            fastrotate(Base.Vector(0,0,1),i,j)
      +            history.append("mrotpZ("+str(i)+","+str(j)+")")
      +    QtGui.QApplication.restoreOverrideCursor()
      +def reflectZ_history():
      +    QtGui.QApplication.setOverrideCursor(QtGui.QCursor(QtCore.Qt.WaitCursor))
      +    fcd = App.ActiveDocument
      +    history = Dictionary[str(fcd.Name)+"history"]
      +    n = Dictionary[str(fcd.Name)+"Size"]
      +    nh = []
      +    while len(history) > 0:
      +        nh.append(history.pop())
      +    reset()
      +    history = Dictionary[str(fcd.Name)+"history"]
      +    while len(nh) > 0:
      +        fs = nh.pop()
      +        wh = fs[:6]
      +        p = fs.index(",")
      +        i = int(fs[7:p])
      +        j = int(fs[p+1:len(fs)-1])
      +        if wh == "mrotpX":
      +            fastrotate(Base.Vector(-1,0,0),i,j)
      +            history.append("mrotmX("+str(i)+","+str(j)+")")
      +        elif wh == "mrotmX":
      +            fastrotate(Base.Vector(1,0,0),i,j)
      +            history.append("mrotpX("+str(i)+","+str(j)+")")
      +        elif wh == "mrotpY":
      +            fastrotate(Base.Vector(0,-1,0),i,j)
      +            history.append("mrotmY("+str(i)+","+str(j)+")")
      +        elif wh == "mrotmY":
      +            fastrotate(Base.Vector(0,1,0),i,j)
      +            history.append("mrotpY("+str(i)+","+str(j)+")")
      +        elif wh == "mrotpZ":
      +            fastrotate(Base.Vector(0,0,1),n-j,n-i)
      +            history.append("mrotpZ("+str(n-j)+","+str(n-i)+")")
      +        elif wh == "mrotmZ":
      +            fastrotate(Base.Vector(0,0,-1),n-j,n-i)
      +            history.append("mrotmZ("+str(n-j)+","+str(n-i)+")")
      +    QtGui.QApplication.restoreOverrideCursor()
      +def rotpX_history():
      +    QtGui.QApplication.setOverrideCursor(QtGui.QCursor(QtCore.Qt.WaitCursor))
      +    fcd = App.ActiveDocument
      +    history = Dictionary[str(fcd.Name)+"history"]
      +    n = Dictionary[str(fcd.Name)+"Size"]
      +    nh = []
      +    while len(history) > 0:
      +        nh.append(history.pop())
      +    reset()
      +    history = Dictionary[str(fcd.Name)+"history"]
      +    while len(nh) > 0:
      +        fs = nh.pop()
      +        wh = fs[:6]
      +        p = fs.index(",")
      +        i = int(fs[7:p])
      +        j = int(fs[p+1:len(fs)-1])
      +        if wh == "mrotpX":
      +            fastrotate(Base.Vector(1,0,0),i,j)
      +            history.append("mrotpX("+str(i)+","+str(j)+")")
      +        elif wh == "mrotmX":
      +            fastrotate(Base.Vector(-1,0,0),i,j)
      +            history.append("mrotmX("+str(i)+","+str(j)+")")
      +        elif wh == "mrotpY":
      +            fastrotate(Base.Vector(0,0,1),i,j)
      +            history.append("mrotpZ("+str(i)+","+str(j)+")")
      +        elif wh == "mrotmY":
      +            fastrotate(Base.Vector(0,0,-1),i,j)
      +            history.append("mrotmZ("+str(i)+","+str(j)+")")
      +        elif wh == "mrotpZ":
      +            fastrotate(Base.Vector(0,-1,0),n-j,n-i)
      +            history.append("mrotmY("+str(n-j)+","+str(n-i)+")")
      +        elif wh == "mrotmZ":
      +            fastrotate(Base.Vector(0,1,0),n-j,n-i)
      +            history.append("mrotpY("+str(n-j)+","+str(n-i)+")")
      +    QtGui.QApplication.restoreOverrideCursor()
      +def rotmX_history():
      +    QtGui.QApplication.setOverrideCursor(QtGui.QCursor(QtCore.Qt.WaitCursor))
      +    fcd = App.ActiveDocument
      +    history = Dictionary[str(fcd.Name)+"history"]
      +    n = Dictionary[str(fcd.Name)+"Size"]
      +    nh = []
      +    while len(history) > 0:
      +        nh.append(history.pop())
      +    reset()
      +    history = Dictionary[str(fcd.Name)+"history"]
      +    while len(nh) > 0:
      +        fs = nh.pop()
      +        wh = fs[:6]
      +        p = fs.index(",")
      +        i = int(fs[7:p])
      +        j = int(fs[p+1:len(fs)-1])
      +        if wh == "mrotpX":
      +            fastrotate(Base.Vector(1,0,0),i,j)
      +            history.append("mrotpX("+str(i)+","+str(j)+")")
      +        elif wh == "mrotmX":
      +            fastrotate(Base.Vector(-1,0,0),i,j)
      +            history.append("mrotmX("+str(i)+","+str(j)+")")
      +        elif wh == "mrotpY":
      +            fastrotate(Base.Vector(0,0,-1),n-j,n-i)
      +            history.append("mrotmZ("+str(n-j)+","+str(n-i)+")")
      +        elif wh == "mrotmY":
      +            fastrotate(Base.Vector(0,0,1),n-j,n-i)
      +            history.append("mrotpZ("+str(n-j)+","+str(n-i)+")")
      +        elif wh == "mrotpZ":
      +            fastrotate(Base.Vector(0,1,0),i,j)
      +            history.append("mrotpY("+str(i)+","+str(j)+")")
      +        elif wh == "mrotmZ":
      +            fastrotate(Base.Vector(0,-1,0),i,j)
      +            history.append("mrotmY("+str(i)+","+str(j)+")")
      +    QtGui.QApplication.restoreOverrideCursor()
      +def rotpY_history():
      +    QtGui.QApplication.setOverrideCursor(QtGui.QCursor(QtCore.Qt.WaitCursor))
      +    fcd = App.ActiveDocument
      +    history = Dictionary[str(fcd.Name)+"history"]
      +    n = Dictionary[str(fcd.Name)+"Size"]
      +    nh = []
      +    while len(history) > 0:
      +        nh.append(history.pop())
      +    reset()
      +    history = Dictionary[str(fcd.Name)+"history"]
      +    while len(nh) > 0:
      +        fs = nh.pop()
      +        wh = fs[:6]
      +        p = fs.index(",")
      +        i = int(fs[7:p])
      +        j = int(fs[p+1:len(fs)-1])
      +        if wh == "mrotpX":
      +            fastrotate(Base.Vector(0,0,-1),n-j,n-i)
      +            history.append("mrotmZ("+str(n-j)+","+str(n-i)+")")
      +        elif wh == "mrotmX":
      +            fastrotate(Base.Vector(0,0,1),n-j,n-i)
      +            history.append("mrotpZ("+str(n-j)+","+str(n-i)+")")
      +        elif wh == "mrotpY":
      +            fastrotate(Base.Vector(0,1,0),i,j)
      +            history.append("mrotpY("+str(i)+","+str(j)+")")
      +        elif wh == "mrotmY":
      +            fastrotate(Base.Vector(0,-1,0),i,j)
      +            history.append("mrotmY("+str(i)+","+str(j)+")")
      +        elif wh == "mrotpZ":
      +            fastrotate(Base.Vector(1,0,0),i,j)
      +            history.append("mrotpX("+str(i)+","+str(j)+")")
      +        elif wh == "mrotmZ":
      +            fastrotate(Base.Vector(-1,0,0),i,j)
      +            history.append("mrotmX("+str(i)+","+str(j)+")")
      +    QtGui.QApplication.restoreOverrideCursor()
      +def rotmY_history():
      +    QtGui.QApplication.setOverrideCursor(QtGui.QCursor(QtCore.Qt.WaitCursor))
      +    fcd = App.ActiveDocument
      +    history = Dictionary[str(fcd.Name)+"history"]
      +    n = Dictionary[str(fcd.Name)+"Size"]
      +    nh = []
      +    while len(history) > 0:
      +        nh.append(history.pop())
      +    reset()
      +    history = Dictionary[str(fcd.Name)+"history"]
      +    while len(nh) > 0:
      +        fs = nh.pop()
      +        wh = fs[:6]
      +        p = fs.index(",")
      +        i = int(fs[7:p])
      +        j = int(fs[p+1:len(fs)-1])
      +        if wh == "mrotpX":
      +            fastrotate(Base.Vector(0,0,1),i,j)
      +            history.append("mrotpZ("+str(i)+","+str(j)+")")
      +        elif wh == "mrotmX":
      +            fastrotate(Base.Vector(0,0,-1),i,j)
      +            history.append("mrotmZ("+str(i)+","+str(j)+")")
      +        elif wh == "mrotpY":
      +            fastrotate(Base.Vector(0,1,0),i,j)
      +            history.append("mrotpY("+str(i)+","+str(j)+")")
      +        elif wh == "mrotmY":
      +            fastrotate(Base.Vector(0,-1,0),i,j)
      +            history.append("mrotmY("+str(i)+","+str(j)+")")
      +        elif wh == "mrotpZ":
      +            fastrotate(Base.Vector(-1,0,0),n-j,n-i)
      +            history.append("mrotmX("+str(n-j)+","+str(n-i)+")")
      +        elif wh == "mrotmZ":
      +            fastrotate(Base.Vector(1,0,0),n-j,n-i)
      +            history.append("mrotpX("+str(n-j)+","+str(n-i)+")")
      +    QtGui.QApplication.restoreOverrideCursor()
      +def rotpZ_history():
      +    QtGui.QApplication.setOverrideCursor(QtGui.QCursor(QtCore.Qt.WaitCursor))
      +    fcd = App.ActiveDocument
      +    history = Dictionary[str(fcd.Name)+"history"]
      +    n = Dictionary[str(fcd.Name)+"Size"]
      +    nh = []
      +    while len(history) > 0:
      +        nh.append(history.pop())
      +    reset()
      +    history = Dictionary[str(fcd.Name)+"history"]
      +    while len(nh) > 0:
      +        fs = nh.pop()
      +        wh = fs[:6]
      +        p = fs.index(",")
      +        i = int(fs[7:p])
      +        j = int(fs[p+1:len(fs)-1])
      +        if wh == "mrotpX":
      +            fastrotate(Base.Vector(0,1,0),i,j)
      +            history.append("mrotpY("+str(i)+","+str(j)+")")
      +        elif wh == "mrotmX":
      +            fastrotate(Base.Vector(0,-1,0),i,j)
      +            history.append("mrotmY("+str(i)+","+str(j)+")")
      +        elif wh == "mrotpY":
      +            fastrotate(Base.Vector(-1,0,0),n-j,n-i)
      +            history.append("mrotmX("+str(n-j)+","+str(n-i)+")")
      +        elif wh == "mrotmY":
      +            fastrotate(Base.Vector(1,0,0),n-j,n-i)
      +            history.append("mrotpX("+str(n-j)+","+str(n-i)+")")
      +        elif wh == "mrotpZ":
      +            fastrotate(Base.Vector(0,0,1),i,j)
      +            history.append("mrotpZ("+str(i)+","+str(j)+")")
      +        elif wh == "mrotmZ":
      +            fastrotate(Base.Vector(0,0,-1),i,j)
      +            history.append("mrotmZ("+str(i)+","+str(j)+")")
      +    QtGui.QApplication.restoreOverrideCursor()
      +def rotmZ_history():
      +    QtGui.QApplication.setOverrideCursor(QtGui.QCursor(QtCore.Qt.WaitCursor))
      +    fcd = App.ActiveDocument
      +    history = Dictionary[str(fcd.Name)+"history"]
      +    n = Dictionary[str(fcd.Name)+"Size"]
      +    nh = []
      +    while len(history) > 0:
      +        nh.append(history.pop())
      +    reset()
      +    history = Dictionary[str(fcd.Name)+"history"]
      +    while len(nh) > 0:
      +        fs = nh.pop()
      +        wh = fs[:6]
      +        p = fs.index(",")
      +        i = int(fs[7:p])
      +        j = int(fs[p+1:len(fs)-1])
      +        if wh == "mrotpX":
      +            fastrotate(Base.Vector(0,-1,0),n-j,n-i)
      +            history.append("mrotmY("+str(n-j)+","+str(n-i)+")")
      +        elif wh == "mrotmX":
      +            fastrotate(Base.Vector(0,1,0),n-j,n-i)
      +            history.append("mrotpY("+str(n-j)+","+str(n-i)+")")
      +        elif wh == "mrotpY":
      +            fastrotate(Base.Vector(1,0,0),i,j)
      +            history.append("mrotpX("+str(i)+","+str(j)+")")
      +        elif wh == "mrotmY":
      +            fastrotate(Base.Vector(-1,0,0),i,j)
      +            history.append("mrotmX("+str(i)+","+str(j)+")")
      +        elif wh == "mrotpZ":
      +            fastrotate(Base.Vector(0,0,1),i,j)
      +            history.append("mrotpZ("+str(i)+","+str(j)+")")
      +        elif wh == "mrotmZ":
      +            fastrotate(Base.Vector(0,0,-1),i,j)
      +            history.append("mrotmZ("+str(i)+","+str(j)+")")
      +    QtGui.QApplication.restoreOverrideCursor()
      +
      +# FreeCAD's file save only saves the state of the camera
      +# and the shapes, positions, orientations, names, and labels
      +# of the objects in the scene 
      +# This function recreates all the other stuff after reloading a saved file
      +# I haven't found a way to make FreeCAD save the history, so it gets reset
      +def fix_reload():
      +    QtGui.QApplication.setOverrideCursor(QtGui.QCursor(QtCore.Qt.WaitCursor))
      +    fcd = App.ActiveDocument
      +    # first we find how big a cube we have
      +    n = 0
      +    for obj in fcd.Objects:
      +        fs = obj.Name
      +        if fs[0:2] == "ff":
      +            i = int(fs[2:fs.index("q")])
      +            if i > n:
      +                n = i
      +        elif fs[0:4] == "Text":
      +            # get rid of this because it's incorrectly positioned
      +            # we'll create a new one later
      +            fcd.removeObject(fs)
      +        elif fs[0:5] == "arrow":
      +            obj.ViewObject.RootNode.setName(coin.SbName(fs))
      +    n = n + 1
      +    fc = [[[[None for j in range(6)] for ix in range(n)] for iy in range(n)] for ix in range(n)]
      +    Dictionary[str(fcd.Name)+"Size"] = n
      +    for obj in fcd.Objects:
      +        fs = obj.Label
      +        if fs[0:2] == "fs":
      +            l = len(fs)
      +            q1 = fs.find("q")
      +            q2 = fs.find("q",q1+1)
      +            ix = int(fs[2:q1])
      +            iy = int(fs[q1+1:q2])
      +            iz = int(fs[q2+1:l-2])
      +            k = "x0x1y0y1z0z1".find(fs[l-2:])/2
      +            fc[ix][iy][iz][k] = obj
      +    Dictionary[str(fcd.Name)+"cubies"] = fc
      +    Dictionary[str(fcd.Name)+"ViewObserver"] = ViewObserver()
      +    doLabels() # create new labels
      +    rotation = fixCamera(False)
      +    Dictionary[str(fcd.Name)+"buttons"] = ButtonRow()
      +    fixLightModel()
      +    createMultiViews(rotation)
      +    history = [] # according to Henry Ford
      +    Dictionary[str(fcd.Name)+"history"] = history
      +    QtGui.QApplication.restoreOverrideCursor()
      +    FreeCAD.Console.PrintLog("fix_reload() done\n")
      +
      +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Macro_Rubik_Cube.png b/localwiki/Macro_Rubik_Cube.png new file mode 100644 index 0000000..d18f17e Binary files /dev/null and b/localwiki/Macro_Rubik_Cube.png differ diff --git a/localwiki/Macro_Section.html b/localwiki/Macro_Section.html new file mode 100644 index 0000000..aec01fd --- /dev/null +++ b/localwiki/Macro_Section.html @@ -0,0 +1,246 @@ +Macro Section

      Macro Section

      + +

      (parametric!) +

      + + + + + + + + + + + + + + + + + + + + + + + + + + + +
      +

      Text-x-python.png Section

      +
      Description +
      Alternative implementation of Part Section tool (parametric) +
      Author +
      DeepSOIC +
      Links +
      Macros recipes
      How to install macros
      How to customize toolbars +
      Version +
      1.1 +
      Date last modification +
      2018-04-28 +
      +

      + +
      Macro Section Screenshot.png +


      +Part Section tool produces edges with C0 continuity and large number of segments (knots), which is not very suitable as Sweep path. +

      This macro does the same by extracting the section edges from result of generalFuse (GFA). The result is C1-continuous and has less knots. It is still not terrific for sweeping, but much better than plain Part Section. +

      Requires FreeCAD v0.17+ built against OCC no less than 6.9.0 (tested on 7.0.0). +

      +

      Installation:

      +

      download the file and save it in macro directory: +

      https://github.com/DeepSOIC/FreeCAD-Macros/raw/master/Section/MacroSection.py +

      +

      How to use:

      +
      1. Select two shapes to compute section between
      2. +
      3. In FreeCAD menu: Macro -> Macros... -> double-click MacroSection.py . A new object will be created.
      +

      After running the macro once, you can add a toolbar button. Go to Tools->Customize, Toolbars, pick MacroSection on left dropdown list, and add the command to any of your custom toolbars. +


      +

      +
      +


      +MacroSection.py: +

      +
      #***************************************************************************
      +#*                                                                         *
      +#*   Copyright (c) 2016 - Victor Titov (DeepSOIC)                          *
      +#*                                               <vv.titov@gmail.com>      *  
      +#*                                                                         *
      +#*   This program is free software; you can redistribute it and/or modify  *
      +#*   it under the terms of the GNU Lesser General Public License (LGPL)    *
      +#*   as published by the Free Software Foundation; either version 2 of     *
      +#*   the License, or (at your option) any later version.                   *
      +#*   for detail see the LICENCE text file.                                 *
      +#*                                                                         *
      +#*   This program is distributed in the hope that it will be useful,       *
      +#*   but WITHOUT ANY WARRANTY; without even the implied warranty of        *
      +#*   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the         *
      +#*   GNU Library General Public License for more details.                  *
      +#*                                                                         *
      +#*   You should have received a copy of the GNU Library General Public     *
      +#*   License along with this program; if not, write to the Free Software   *
      +#*   Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  *
      +#*   USA                                                                   *
      +#*                                                                         *
      +#***************************************************************************
      +
      +__title__="Macro Section"
      +__author__ = "DeepSOIC"
      +__doc__ = '''
      +Macro Section.
      +Alternative implementation of Part Section tool.
      +Requires FreeCAD v0.17+ and OCC 6.9.0+
      +
      +Instructions:
      +First of all, save this macro as MacroSection.py, into a location from where it can be imported. FC's standard macro location is the best place to do that.
      +
      +Select two shapes to compute section between.
      +Then, in Py console:
      +
      +import MacroSection
      +MacroSection.run()
      +
      +OR
      +
      +just run this file as a macro.
      +
      +Parametric Section object is created.
      +'''
      +if __name__ == "__main__": #being run as a macro
      +    import MacroSection
      +    MacroSection.run()
      +
      +import FreeCAD as App
      +if App.GuiUp:
      +    import FreeCADGui as Gui
      +import Part
      +
      +def makeSectionFeature():
      +    '''makeSectionFeature(): makes a Section parametric feature object. Returns the new object.'''
      +    selfobj = App.ActiveDocument.addObject("Part::FeaturePython","Section")
      +    Section(selfobj)
      +    ViewProviderSection(selfobj.ViewObject)
      +    return selfobj
      +
      +class Section:
      +    "The Section feature object"
      +    def __init__(self,selfobj):
      +        selfobj.addProperty("App::PropertyLink","Base","Section","Input shape")
      +        selfobj.addProperty("App::PropertyLink","Tool","Section","Input shape")
      +        selfobj.Proxy = self
      +
      +    def execute(self,selfobj):
      +        import BOPTools
      +        import BOPTools.ShapeMerge
      +        from BOPTools.Utils import HashableShape
      +        
      +        if len(selfobj.Base.Shape.Faces) == 0 or len(selfobj.Tool.Shape.Faces) == 0:
      +            raise ValueError("Shapes must have at least one face each.")
      +        sh1 = Part.Compound(selfobj.Base.Shape.Faces)
      +        sh2 = Part.Compound(selfobj.Tool.Shape.Faces)
      +        pieces, map = sh1.generalFuse([sh2])
      +        pieces = pieces.childShapes()
      +        assert(len(pieces) == 2)
      +        
      +        edges1 = set([HashableShape(edge) for edge in pieces[0].Edges])
      +        edges2 = set([HashableShape(edge) for edge in pieces[1].Edges])
      +        edges_to_return = list(set.intersection(edges1, edges2))
      +        edges_to_return = [edge.Shape for edge in edges_to_return] #convert hashable shapes back to plain shapes
      +        print("returning {num} edges of total {tot}".format(num= len(edges_to_return), tot= len(edges1)+len(edges2)))
      +        
      +        selfobj.Shape = BOPTools.ShapeMerge.mergeWires(edges_to_return)
      +
      +class ViewProviderSection:
      +    def __init__(self,vobj):
      +        vobj.Proxy = self
      +       
      +    def getIcon(self):
      +        return ":/icons/Part_Section.svg"
      +
      +    def attach(self, vobj):
      +        self.ViewObject = vobj
      +        self.Object = vobj.Object
      +  
      +    def __getstate__(self):
      +        return None
      +
      +    def __setstate__(self,state):
      +        return None
      +
      +    def claimChildren(self):
      +        return [self.Object.Base, self.Object.Tool]
      +        
      +    def onDelete(self, feature, subelements): # subelements is a tuple of strings
      +        try:
      +            self.Object.Base.ViewObject.show()
      +            self.Object.Tool.ViewObject.show()
      +        except Exception as err:
      +            App.Console.PrintError("Error in onDelete: " + err.message)
      +        return True
      +
      +class CommandMacroSection:
      +    "Command to create Section feature"
      +    def GetResources(self):
      +        return {'Pixmap'  : ":/icons/Part_Section.svg",
      +                'MenuText': "Section",
      +                'Accel': "",
      +                'ToolTip': "Macro_Section: alternative implementation of Part Section tool"}
      +
      +    def Activated(self):
      +        run()
      +    def IsActive(self):
      +        if App.ActiveDocument:
      +            return True
      +        else:
      +            return False
      +
      +if App.GuiUp:
      +    Gui.addCommand("Macro_Section", CommandMacroSection())
      +
      +def run():
      +    sel = Gui.Selection.getSelectionEx()
      +    try:
      +        if len(sel) != 2:
      +            raise Exception("Select two shapes to compute section between, first! Then run this macro.")
      +        try:
      +            App.ActiveDocument.openTransaction("Macro Section")
      +            selfobj = makeSectionFeature()
      +            selfobj.Base = sel[0].Object
      +            selfobj.Tool = sel[1].Object
      +            selfobj.Base.ViewObject.hide()
      +            selfobj.Tool.ViewObject.hide()
      +            
      +            selfobj.Proxy.execute(selfobj)
      +        finally:
      +            App.ActiveDocument.commitTransaction()
      +    except Exception as err:
      +        from PySide import QtGui
      +        mb = QtGui.QMessageBox()
      +        mb.setIcon(mb.Icon.Warning)
      +        mb.setText(err.message)
      +        mb.setWindowTitle("Macro Section")
      +        mb.exec_() 
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Macro_SelectVisible.html b/localwiki/Macro_SelectVisible.html new file mode 100644 index 0000000..52557f8 --- /dev/null +++ b/localwiki/Macro_SelectVisible.html @@ -0,0 +1,80 @@ +Macro SelectVisible

      Macro SelectVisible

      + +
      + + + + + + + + + + + + + + + + + + + + + + + + + + +
      +

      SelectVisible.png Macro SelectVisible

      +
      Description +
      Select all visible objects. +
      Author +
      galou_breizh +
      Links +
      Macros recipes
      How to install macros
      How to customize toolbars +
      Version +
      1.0 +
      Date last modification +
      2016-04-08 +
      +

      + +
      +


      +

      +

      Description

      +

      All visible objects in the tree and only these will be selected. +

      +

      How To Use

      +

      Copy the macro in your macros' folder and run (see How to install macros for further details). +

      +

      Code

      +

      The lastest version of the macro is to be found at https://github.com/FreeCAD/FreeCAD-macros/blob/master/Utility/SelectVisible.FCMacro +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Macro_Select_Hovering.html b/localwiki/Macro_Select_Hovering.html new file mode 100644 index 0000000..4a7640e --- /dev/null +++ b/localwiki/Macro_Select_Hovering.html @@ -0,0 +1,446 @@ +Macro Select Hovering

      Macro Select Hovering

      + +
      + + + + + + + + + + + + + + + + + + + + + + + + + + +
      +

      Macro Select Hovering.png Macro Select Hovering

      +
      Description +
      This macro select a choice Face, Edge, Vertex hovering by the mouse. +
      Author +
      Mario52 +
      Links +
      Macros recipes
      How to install macros
      How to customize toolbars +
      Version +
      00.03 +
      Date last modification +
      2017-12-26 +
      +

      + +
      Macro Select Hovering +

      Description

      +

      this macro select a choice Face, Edge, Vertex hovering by the mouse. +

      PS: For unselected one face (or other) click the Pause grab and use the standard procedure : CTRL + Click +

      +

      How To Use

      +

      Hovering element by the mouse. +

      +

      Icons

      +

      The icon must be copied into the same directory as the macro +

      +

      Script

      +

      The icon ToolBar Macro Select Hovering +

      Macro Select Hovering.FCMacro +

      +
      # -*- coding: utf-8 -*-
      +from __future__ import unicode_literals
      +#
      +"""
      +***************************************************************************
      +*   Copyright (c) 2017 <mario52>                                          *
      +*                                                                         *
      +*   This file is a supplement to the FreeCAD CAx development system.      *
      +*                                                                         *
      +*   This program is free software; you can redistribute it and/or modify  *
      +*   it under the terms of the GNU Lesser General Public License (LGPL)    *
      +*   as published by the Free Software Foundation; either version 2 of     *
      +*   the License, or (at your option) any later version.                   *
      +*   for detail see the LICENCE text file.                                 *
      +*                                                                         *
      +*   This software is distributed in the hope that it will be useful,      *
      +*   but WITHOUT ANY WARRANTY; without even the implied warranty of        *
      +*   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the         *
      +*   GNU Library General Public License for more details.                  *
      +*                                                                         *
      +*   You should have received a copy of the GNU Library General Public     *
      +*   License along with this macro; if not, write to the Free Software     *
      +*   Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  *
      +*   USA                                                                   *
      +***************************************************************************
      +*           WARNING! All changes in this file will be lost and            *  
      +*                  may cause malfunction of the program                   *
      +***************************************************************************
      +"""
      +#
      +#Macro_ _01-25/12/2017 02-26/12/2017 03-26/12/2017
      +#
      +#OS: Windows 10
      +#Word size of OS: 64-bit
      +#Word size of FreeCAD: 64-bit
      +#Version: 0.16.6712 (Git)
      +#Build type: Release
      +#Branch: releases/FreeCAD-0-16
      +#Hash: da2d364457257a7a8c6fb2137cea12c45becd71a
      +#Python version: 2.7.8
      +#Qt version: 4.8.7
      +#Coin version: 4.0.0a
      +#OCC version: 6.8.0.oce-0.17
      +#
      +__title__   = "Macro_Select_Hovering"
      +__author__  = "Mario52"
      +__url__     = "http://www.freecadweb.org/index-fr.html"
      +__Wiki__    = "http://www.freecadweb.org/wiki/index.php?title=Macro_Select_Hovering"
      +__version__ = "00.03"
      +__date__    = "26/12/2017"
      +
      +import PySide
      +from PySide import QtGui ,QtCore
      +from PySide.QtGui import *
      +from PySide.QtCore import *
      + 
      +import Draft, Part, PartGui, FreeCADGui, FreeCAD
      +
      +Gui = FreeCADGui
      +App = FreeCAD
      +
      +global ui         ; ui           = ""
      +global s          ; s            = ""
      +
      +try:
      +    _fromUtf8 = QtCore.QString.fromUtf8
      +except AttributeError:
      +    def _fromUtf8(s):
      +        return s
      +
      +try:
      +    _encoding = QtGui.QApplication.UnicodeUTF8
      +    def _translate(context, text, disambig):
      +        return QtGui.QApplication.translate(context, text, disambig, _encoding)
      +except AttributeError:
      +    def _translate(context, text, disambig):
      +        return QtGui.QApplication.translate(context, text, disambig)
      +
      +class Ui_MainWindow(object):
      +
      +    def __init__(self, MainWindow):
      +        self.window = MainWindow
      +        #################################################################################
      +        #self.path  = FreeCAD.ConfigGet("AppHomePath")
      +        #self.path  = FreeCAD.ConfigGet("UserAppData")
      +        #self.path  = "your path"
      +        param = FreeCAD.ParamGet("User parameter:BaseApp/Preferences/Macro")# macro path
      +        self.path = param.GetString("MacroPath","") + "/"                   # macro path
      +        self.path = self.path.replace("\\","/")
      +#        print "Path for the icons : " , self.path
      +        #################################################################################
      +        self.FontImpost    = "Arial"
      +        self.fontGlobal_08 = QtGui.QFont()            # pour compatibilite Windows Linux
      +        self.fontGlobal_08.setFamily(self.FontImpost) # pour compatibilite Windows Linux
      +        self.fontGlobal_08.setPointSize(8.0)          # pour compatibilite Windows Linux
      +        #self.xxxx.setFont(self.fontGlobal_08)        # pour W L
      +        #self.xxxx.setFont(QtGui.QFont(self.FontImpost,weight=QtGui.QFont.Bold))  # Bold
      +        #################################################################################
      +
      +        self.comptFace         = 0
      +        self.comptEdge         = 0
      +        self.comptVertex       = 0
      +        self.Stop_Grab         = 1
      +        self.comptSurfaceFace  = 0.0
      +        self.comptSurfaceTotal = 0.0
      +        self.comptLengthObject = 0.0
      +        self.comptLengthTotal  = 0.0
      +
      +    def setupUi(self, MainWindow):
      +        MainWindow.resize(197, 307)
      +        MainWindow.setMinimumSize(QtCore.QSize(197, 307))
      +        MainWindow.setMaximumSize(QtCore.QSize(197, 307))
      +        self.centralwidget = QtGui.QWidget(MainWindow)
      +        self.centralwidget.setObjectName(_fromUtf8("centralwidget"))
      +
      +        self.GBOX_01_Face = QtGui.QGroupBox(self.centralwidget)
      +        self.GBOX_01_Face.setGeometry(QtCore.QRect(10, 10, 176, 91))
      +        self.GBOX_01_Face.setFont(self.fontGlobal_08)         # pour W L
      +        self.GBOX_01_Face.setObjectName(_fromUtf8("GBOX_01_Face"))
      +
      +        self.LE_02_Area_Object = QtGui.QLineEdit(self.GBOX_01_Face)
      +        self.LE_02_Area_Object.setGeometry(QtCore.QRect(90, 60, 75, 20))
      +        self.LE_02_Area_Object.setFont(self.fontGlobal_08)    # pour W L
      +        self.LE_02_Area_Object.setObjectName(_fromUtf8("LE_02_Area_Object"))
      +
      +        self.LAB_05_Area_Object = QtGui.QLabel(self.GBOX_01_Face)
      +        self.LAB_05_Area_Object.setGeometry(QtCore.QRect(90, 40, 71, 16))
      +        self.LAB_05_Area_Object.setFont(self.fontGlobal_08)   # pour W L
      +        self.LAB_05_Area_Object.setObjectName(_fromUtf8("LAB_05_Area_Object"))
      +
      +        self.CB_01_Sel_Face = QtGui.QCheckBox(self.GBOX_01_Face)
      +        self.CB_01_Sel_Face.setGeometry(QtCore.QRect(10, 20, 91, 17))
      +        self.CB_01_Sel_Face.setFont(self.fontGlobal_08)       # pour W L
      +        self.CB_01_Sel_Face.setObjectName(_fromUtf8("CB_01_Sel_Face"))
      +
      +        self.LE_01_Area_Total = QtGui.QLineEdit(self.GBOX_01_Face)
      +        self.LE_01_Area_Total.setGeometry(QtCore.QRect(10, 60, 75, 20))
      +        self.LE_01_Area_Total.setFont(self.fontGlobal_08)     # pour W L
      +        self.LE_01_Area_Total.setObjectName(_fromUtf8("LE_01_Area_Total"))
      +
      +        self.LAB_01_Face = QtGui.QLabel(self.GBOX_01_Face)
      +        self.LAB_01_Face.setGeometry(QtCore.QRect(110, 23, 56, 16))
      +        self.LAB_01_Face.setFont(self.fontGlobal_08)          # pour W L
      +        self.LAB_01_Face.setObjectName(_fromUtf8("LAB_01_Face"))
      +
      +        self.LAB_04_Area_Total = QtGui.QLabel(self.GBOX_01_Face)
      +        self.LAB_04_Area_Total.setGeometry(QtCore.QRect(10, 40, 56, 16))
      +        self.LAB_04_Area_Total.setFont(self.fontGlobal_08)    # pour W L
      +        self.LAB_04_Area_Total.setObjectName(_fromUtf8("LAB_04_Area_Total"))
      +
      +
      +        self.GBOX_02_Edge = QtGui.QGroupBox(self.centralwidget)
      +        self.GBOX_02_Edge.setGeometry(QtCore.QRect(10, 105, 176, 91))
      +        self.GBOX_02_Edge.setFont(self.fontGlobal_08)         # pour W L
      +        self.GBOX_02_Edge.setObjectName(_fromUtf8("GBOX_02_Edge"))
      +
      +        self.LAB_02_Edge = QtGui.QLabel(self.GBOX_02_Edge)
      +        self.LAB_02_Edge.setGeometry(QtCore.QRect(110, 25, 56, 16))
      +        self.LAB_02_Edge.setFont(self.fontGlobal_08)          # pour W L
      +        self.LAB_02_Edge.setObjectName(_fromUtf8("LAB_02_Edge"))
      +
      +        self.CB_02_Sel_Edge = QtGui.QCheckBox(self.GBOX_02_Edge)
      +        self.CB_02_Sel_Edge.setGeometry(QtCore.QRect(10, 20, 91, 17))
      +        self.CB_02_Sel_Edge.setFont(self.fontGlobal_08)       # pour W L
      +        self.CB_02_Sel_Edge.setObjectName(_fromUtf8("CB_02_Sel_Edge"))
      +
      +        self.LE_03_Length_Total = QtGui.QLineEdit(self.GBOX_02_Edge)
      +        self.LE_03_Length_Total.setGeometry(QtCore.QRect(10, 60, 75, 20))
      +        self.LE_03_Length_Total.setFont(self.fontGlobal_08)   # pour W L
      +        self.LE_03_Length_Total.setObjectName(_fromUtf8("LE_03_Length_Total"))
      +
      +        self.LE_04_Length_Object = QtGui.QLineEdit(self.GBOX_02_Edge)
      +        self.LE_04_Length_Object.setGeometry(QtCore.QRect(90, 60, 75, 20))
      +        self.LE_04_Length_Object.setFont(self.fontGlobal_08)  # pour W L
      +        self.LE_04_Length_Object.setObjectName(_fromUtf8("LE_04_Length_Object"))
      +
      +        self.LAB_06_Length_Total = QtGui.QLabel(self.GBOX_02_Edge)
      +        self.LAB_06_Length_Total.setGeometry(QtCore.QRect(10, 40, 71, 16))
      +        self.LAB_06_Length_Total.setFont(self.fontGlobal_08)  # pour W L
      +        self.LAB_06_Length_Total.setObjectName(_fromUtf8("LAB_06_Length_Total"))
      +
      +        self.LAB_07_Length_Obgect = QtGui.QLabel(self.GBOX_02_Edge)
      +        self.LAB_07_Length_Obgect.setGeometry(QtCore.QRect(90, 40, 71, 16))
      +        self.LAB_07_Length_Obgect.setFont(self.fontGlobal_08) # pour W L
      +        self.LAB_07_Length_Obgect.setObjectName(_fromUtf8("LAB_07_Length_Obgect"))
      +
      +
      +        self.GBOX_03_Vertex = QtGui.QGroupBox(self.centralwidget)
      +        self.GBOX_03_Vertex.setGeometry(QtCore.QRect(10, 200, 176, 46))
      +        self.GBOX_03_Vertex.setFont(self.fontGlobal_08)       # pour W L
      +        self.GBOX_03_Vertex.setObjectName(_fromUtf8("GBOX_03_Vertex"))
      +
      +        self.LAB_03_Vertex = QtGui.QLabel(self.GBOX_03_Vertex)
      +        self.LAB_03_Vertex.setGeometry(QtCore.QRect(110, 25, 56, 16))
      +        self.LAB_03_Vertex.setFont(self.fontGlobal_08)        # pour W L
      +        self.LAB_03_Vertex.setObjectName(_fromUtf8("LAB_03_Vertex"))
      +
      +        self.CB_03_Sel_Vertex = QtGui.QCheckBox(self.GBOX_03_Vertex)
      +        self.CB_03_Sel_Vertex.setGeometry(QtCore.QRect(10, 22, 91, 17))
      +        self.CB_03_Sel_Vertex.setFont(self.fontGlobal_08)     # pour W L
      +        self.CB_03_Sel_Vertex.setObjectName(_fromUtf8("CB_03_Sel_Vertex"))
      +
      +
      +        self.GBOX_04_Main = QtGui.QGroupBox(self.centralwidget)
      +        self.GBOX_04_Main.setGeometry(QtCore.QRect(10, 250, 176, 51))
      +        self.GBOX_04_Main.setFont(self.fontGlobal_08)         # pour W L
      +        self.GBOX_04_Main.setObjectName(_fromUtf8("GBOX_04_Main"))
      +
      +        self.PB_02_Stop_Grab = QtGui.QPushButton(self.GBOX_04_Main)
      +        self.PB_02_Stop_Grab.setGeometry(QtCore.QRect(90, 20, 75, 23))
      +        self.PB_02_Stop_Grab.setFont(self.fontGlobal_08)      # pour W L
      +        self.PB_02_Stop_Grab.setObjectName(_fromUtf8("PB_02_Stop_Grab"))
      +        self.PB_02_Stop_Grab.clicked.connect(self.on_PB_02_Stop_Grab_clicked)
      +
      +        self.PB_01_Quit = QtGui.QPushButton(self.GBOX_04_Main)
      +        self.PB_01_Quit.setGeometry(QtCore.QRect(5, 20, 75, 23))
      +        self.PB_01_Quit.setFont(self.fontGlobal_08)           # pour W L
      +        self.PB_01_Quit.setObjectName(_fromUtf8("PB_01_Quit"))
      +        self.PB_01_Quit.clicked.connect(self.on_PB_Quit_clicked)
      +
      +        MainWindow.setCentralWidget(self.centralwidget)
      +        self.retranslateUi(MainWindow)
      +        QtCore.QMetaObject.connectSlotsByName(MainWindow)
      +
      +    def retranslateUi(self, MainWindow):
      +        MainWindow.setWindowTitle("Select_Hovering")
      +        MainWindow.setWindowIcon(QtGui.QIcon(self.path + __title__ +".png"))#
      +        self.GBOX_01_Face.setTitle("Face")
      +        self.CB_01_Sel_Face.setText("Select Face")
      +        self.LAB_01_Face.setText("0")
      +        self.LAB_04_Area_Total.setText("Area Total")
      +        self.LAB_05_Area_Object.setText("Area Object")
      +
      +        self.GBOX_02_Edge.setTitle("Edge")
      +        self.CB_02_Sel_Edge.setText("Select Edge")
      +        self.LAB_02_Edge.setText("0")
      +        self.LAB_06_Length_Total.setText("Length Total")
      +        self.LAB_07_Length_Obgect.setText("Length Object")
      +
      +        self.GBOX_03_Vertex.setTitle("Vertex")
      +        self.CB_03_Sel_Vertex.setText("Select Vertex")
      +        self.LAB_03_Vertex.setText("0")
      +
      +        self.GBOX_04_Main.setTitle("Main")
      +        self.PB_01_Quit.setText("Quit")
      +        self.PB_02_Stop_Grab.setText("Pause grab")
      +
      +        MainWindow.setWindowFlags(PySide.QtCore.Qt.WindowStaysOnTopHint)       # PySide cette fonction met la fenetre en avant
      +
      +
      +    def on_PB_02_Stop_Grab_clicked(self):
      +        global s
      +
      +        if self.Stop_Grab == 1:
      +            FreeCADGui.Selection.removeObserver(s)                             # desinstalle la fonction residente SelObserver
      +            self.Stop_Grab = 0
      +            self.PB_02_Stop_Grab.setText("Active grab")
      +            print "Grab pause"
      +        else:
      +            s=SelObserver()
      +            FreeCADGui.Selection.addObserver(s)                                # installe la fonction en mode resident
      +            self.Stop_Grab = 1
      +            self.PB_02_Stop_Grab.setText("Pause grab")
      +            print "Grab active"
      +
      +    def on_PB_Quit_clicked(self):
      +        global s
      +
      +        FreeCADGui.Selection.removeObserver(s)                              # desinstalle la fonction residente SelObserver
      +        self.window.hide()                                                  # hide the window and close the macro
      +        print "Quit ",__title__
      +
      +##################################################################################################
      +class SelObserver:
      +    global ui
      +
      +    def setPreselection(self,doc,obj,sub): # preselection
      +        global ui
      +
      +        if ui.CB_01_Sel_Face.isChecked():
      +
      +            if (sub[:4] == "Face") and (Gui.Selection.isSelected (FreeCAD.ActiveDocument.getObject(obj), sub) == False):
      +                Gui.Selection.addSelection(FreeCAD.ActiveDocument.getObject(obj), sub)
      +                ui.comptFace += 1
      +                ui.LAB_01_Face.setText(str(ui.comptFace))
      +
      +                ui.comptSurfaceFace = FreeCAD.ActiveDocument.getObject(obj).Shape.Faces[int(sub[4:])-1].Area
      +                ui.comptSurfaceTotal += ui.comptSurfaceFace
      +                ui.LE_01_Area_Total.setText(str(ui.comptSurfaceTotal))
      +                ui.LE_02_Area_Object.setText(str(ui.comptSurfaceFace))
      +
      +
      +        if ui.CB_02_Sel_Edge.isChecked():
      +
      +            if (sub[:4] == "Edge") and (Gui.Selection.isSelected (FreeCAD.ActiveDocument.getObject(obj), sub) == False):
      +                objetSelect = Gui.Selection.addSelection(FreeCAD.ActiveDocument.getObject(obj), sub)
      +
      +                ui.comptEdge += 1
      +                ui.LAB_02_Edge.setText(str(ui.comptEdge))
      +
      +                ui.comptLengthObject = FreeCAD.ActiveDocument.getObject(obj).Shape.Edges[int(sub[4:])-1].Length
      +                ui.comptLengthTotal += ui.comptLengthObject
      +                ui.LE_03_Length_Total.setText(str(ui.comptLengthTotal))
      +                ui.LE_04_Length_Object.setText(str(ui.comptLengthObject))
      +
      +
      +        if ui.CB_03_Sel_Vertex.isChecked():
      +
      +            if sub[:6] == "Vertex" and (Gui.Selection.isSelected (FreeCAD.ActiveDocument.getObject(obj), sub) == False):
      +                Gui.Selection.addSelection(FreeCAD.ActiveDocument.getObject(obj), sub)
      +                ui.comptVertex += 1
      +                ui.LAB_03_Vertex.setText(str(ui.comptVertex))
      +
      +
      +#    def removePreselection(self,doc,obj,sub) # 
      +#        print "removePreselection"
      +#    def addSelection(self,doc,obj,sub,pnt):  # Selection
      +#        print "addSelection"
      +#    def removeSelection(self,doc,obj,sub):   # Effacer l'objet selectionne
      +#        print "removeSelection"
      +#    def setSelection(self,doc):              # Selection dans ComboView
      +#        FreeCADGui.Selection.removeObserver(s)
      +#        print "setSelection quit"
      +
      +    def clearSelection(self,doc):            # Si clic sur l'ecran, effacer la selection
      +        global ui
      +
      +        ui.comptFace   = 0
      +        ui.comptEdge   = 0
      +        ui.comptVertex = 0
      +        ui.comptSurfaceFace  = 0.0
      +        ui.comptSurfaceTotal = 0.0
      +        ui.comptLengthObject = 0.0
      +        ui.comptLengthTotal  = 0.0
      +        ui.LAB_01_Face.setText(str(ui.comptFace))
      +        ui.LAB_02_Edge.setText(str(ui.comptEdge))
      +        ui.LAB_03_Vertex.setText(str(ui.comptVertex))
      +        ui.LE_01_Area_Total.setText(str(ui.comptSurfaceTotal))
      +        ui.LE_02_Area_Object.setText(str(ui.comptSurfaceFace))
      +        ui.LE_03_Length_Total.setText(str(ui.comptLengthTotal))
      +        ui.LE_04_Length_Object.setText(str(ui.comptLengthObject))
      +#        print "clearSelection"
      +
      +s=SelObserver()
      +FreeCADGui.Selection.addObserver(s)          # installe la fonction en mode resident
      +###################################################################################################
      +
      +doc = FreeCAD.ActiveDocument
      +if doc == None:
      +    doc = FreeCAD.newDocument()
      +
      +MainWindow = QtGui.QMainWindow()
      +ui = Ui_MainWindow(MainWindow)
      +ui.setupUi(MainWindow)
      +MainWindow.show() 
      +

      Version

      +

      ver 00.03 (26/12/2017)  : replace test with (FreeCAD.ActiveDocument.getObject(obj), sub) == False) +

      ver 00.02 (26/12/2017)  : +

      ver 00.01 (25/12/2017)  : +

      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Macro_Select_Hovering.png b/localwiki/Macro_Select_Hovering.png new file mode 100644 index 0000000..07e43fb Binary files /dev/null and b/localwiki/Macro_Select_Hovering.png differ diff --git a/localwiki/Macro_Select_Hovering_00.png b/localwiki/Macro_Select_Hovering_00.png new file mode 100644 index 0000000..a917242 Binary files /dev/null and b/localwiki/Macro_Select_Hovering_00.png differ diff --git a/localwiki/Macro_Shake_Sketch.html b/localwiki/Macro_Shake_Sketch.html new file mode 100644 index 0000000..00bce75 --- /dev/null +++ b/localwiki/Macro_Shake_Sketch.html @@ -0,0 +1,213 @@ +Macro Shake Sketch

      Macro Shake Sketch

      + +
      + + + + + + + + + + + + + + + + + + + + + + + + + + +
      +

      Text-x-python.png Macro Shake Sketch

      +
      Description +
      Shake a sketch in order to discover its unconstrained parts +
      Author +
      Gaël Ecorchard +
      Links +
      Macros recipes
      How to install macros
      How to customize toolbars +
      Version +
      1.1 +
      Date last modification +
      2014-10-31 +
      +

      + +
      +


      +

      Shake a sketch in order to discover its unconstrained parts. Enter edit mode for a sketch and launch the macro. The macro will add a random noise on all sketch points. The sketch is then solved, constrained parts will retain their position, free parts will move. +

      But be careful working on a copy of your file because the macro "dismantles all" to display and you may start over. +

      +

      Script

      +

      Macro Shake_Sketch.py +

      +
      # -*- coding: utf-8 -*-
      +
      +# FreeCAD macro to shake a sketch in order to discover its unconstrained parts.
      +#
      +# A Gaussian noise is introduced in all sketch points and the sketch is then
      +# solved.
      +# Beware that the sketch can look different because some constraints have
      +# several solutions. In this case, just undo.
      +#
      +# This file is released under the MIT License.
      +# Author: Gaël Ecorchard
      +# Version:
      +# - 1.1, 2014-10-31
      +#     * correct import for Part
      +# - 1.0, 2014-08, first release.
      +
      +# Amplitude of the point displacements.
      +# The standard deviation of the Gaussian noise is the largest sketch dimension
      +# multiplied by this factor.
      +displacement_amplitude = 0.1
      +
      +# End of configuration.
      +
      +from random import gauss
      +
      +import FreeCADGui as Gui
      +from FreeCAD import Base
      +import Part
      +
      +# For each sketch geometry type, map a list of points to move.
      +g_geom_points = {
      +    Base.Vector: [1],
      +    Part.Line: [1, 2],  # first point, last point
      +    Part.Circle: [0, 3],  # curve, center
      +    Part.ArcOfCircle: [1, 2, 3],  # first point, last point, center
      +}
      +
      +
      +class BoundingBox(object):
      +    xmin = None
      +    xmax = None
      +    ymin = None
      +    ymax = None
      +
      +    def enlarge_x(self, x):
      +        if self.xmin is None:
      +            self.xmin = x
      +            self.xmax = x
      +            return
      +        if self.xmin > x:
      +            self.xmin = x
      +            return
      +        if self.xmax < x:
      +            self.xmax = x
      +            return
      +
      +    def enlarge_y(self, y):
      +        if self.ymin is None:
      +            self.ymin = y
      +            self.ymax = y
      +            return
      +        if self.ymin > y:
      +            self.ymin = y
      +            return
      +        if self.ymax < y:
      +            self.ymax = y
      +            return
      +
      +    def enlarge_point(self, point):
      +        self.enlarge_x(point.x)
      +        self.enlarge_y(point.y)
      +
      +    def enlarge_line(self, line):
      +        self.enlarge_x(line.StartPoint.x)
      +        self.enlarge_x(line.EndPoint.x)
      +        self.enlarge_y(line.StartPoint.y)
      +        self.enlarge_y(line.EndPoint.y)
      +
      +    def enlarge_circle(self, circle):
      +        self.enlarge_x(circle.Center.x - circle.Radius)
      +        self.enlarge_x(circle.Center.x + circle.Radius)
      +        self.enlarge_y(circle.Center.y - circle.Radius)
      +        self.enlarge_y(circle.Center.y + circle.Radius)
      +
      +    def enlarge_arc_of_circle(self, arc):
      +        # TODO: correctly compute the arc extrema (cf. toShape().BoundBox)
      +        self.enlarge_x(arc.Center.x)
      +        self.enlarge_y(arc.Center.y)
      +
      +
      +def get_sketch_dims(sketch):
      +    bbox = BoundingBox()
      +    for geom in sketch.Geometry:
      +        if isinstance(geom, Base.Vector):
      +            bbox.enlarge_point(geom)
      +        elif isinstance(geom, Part.Line):
      +            bbox.enlarge_line(geom)
      +        elif isinstance(geom, Part.Circle):
      +            bbox.enlarge_circle(geom)
      +        elif isinstance(geom, Part.ArcOfCircle):
      +            bbox.enlarge_arc_of_circle(geom)
      +    if (bbox.xmin is not None) and (bbox.ymin is not None):
      +        return bbox.xmax - bbox.xmin, bbox.ymax - bbox.ymin
      +    else:
      +        return 0, 0
      +
      +
      +def add_noise(point, sigma):
      +    """Add a Gaussian noise with standard deviation sigma"""
      +    point.x = gauss(point.x, sigma)
      +    point.y = gauss(point.y, sigma)
      +
      +
      +def move_points(sketch, geom_index, sigma):
      +    point_indexes = g_geom_points[type(sketch.Geometry[i])]
      +    # Direct access to sketch.Geometry[index] does not work. This would,
      +    # however prevent repeated recompute.
      +    for point_index in point_indexes:
      +        point = sketch.getPoint(geom_index, point_index)
      +        add_noise(point, sigma)
      +        sketch.movePoint(geom_index, point_index, point)
      +
      +view_provider = Gui.activeDocument().getInEdit()
      +
      +# Don't know how to exit from a macro.
      +do_move = True
      +if not view_provider:
      +    do_move = False
      +
      +if do_move:
      +    sketch = view_provider.Object
      +
      +    if sketch.TypeId != 'Sketcher::SketchObject':
      +        do_move = False
      +
      +if do_move:
      +    sigma = max(get_sketch_dims(sketch)) * displacement_amplitude
      +
      +    for i in range(len((sketch.Geometry))):
      +        move_points(sketch, i, sigma) 
      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Macro_Sheet_Metal_Unfolder.html b/localwiki/Macro_Sheet_Metal_Unfolder.html new file mode 100644 index 0000000..24a3f09 --- /dev/null +++ b/localwiki/Macro_Sheet_Metal_Unfolder.html @@ -0,0 +1,88 @@ +Macro Sheet Metal Unfolder

      Macro Sheet Metal Unfolder

      + +
      + + + + + + + + + + + + + + + + + + + + + + + + + + +
      +

      Text-x-python.png Sheet Metal Unfolder

      +
      Description +
      This macro unfolds simple sheet-metal-designs. +
      Author +
      ulrich1a +
      Links +
      Macros recipes
      How to install macros
      How to customize toolbars +
      Version +
      1.0 +
      Date last modification +
      2015-01-01 +
      +

      + +
      +


      +

      The macro can unfold simple sheet-metal-parts. The parts must have everywhere the same material thickness as typical for sheet-metal-parts. See example: +

      Unfolding test2.png +

      +

      Usage

      +

      Select a flat face from your part in the 3D-view. Start the macro. +

      +

      Remarks

      +

      The macro creates a lot of text in the report-view. This is still a remains of the debugging process of this macro. The edges of the sheet-metal-part may be round or slanting. But if you "walk" from the upper side to the lower side of the sheet-metal-part you should not cross more than one face. +In best case the macro generates a new flat solid from your part. If the macro has problems, you may get only a flat shell or a bunch of flattened faces or only an error message. +

      The macro can be thought of as a companion to the AddWall tool from JMG published here: FreeCAD: Sheet metal tool "Add Wall" +

      +

      Link

      +

      The forum discussion Sheet metal: add wall tool +

      +

      Script

      +

      The script can be viewed and downloaded from the FreeCAD-macros repository: SheetMetalUnfolder.FCMacro +

      (Right-click on the "Raw" button and select "Save target as..." to download) +

      Direct link (right-click and select "Save target as...") +

      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Macro_Solid_Sweep.html b/localwiki/Macro_Solid_Sweep.html new file mode 100644 index 0000000..c73e488 --- /dev/null +++ b/localwiki/Macro_Solid_Sweep.html @@ -0,0 +1,119 @@ +Macro Solid Sweep

      Macro Solid Sweep

      + +
      + + + + + + + + + + + + + + + + + + + + + + + + + + +
      +

      Text-x-python.png Solid Sweep

      +
      Description +
      Creates a solid by sweeping a profile from a trajectory. +
      Author +
      Normandc +
      Links +
      Macros recipes
      How to install macros
      How to customize toolbars +
      Version +
      1.0 +
      Date last modification +
      2011-12-03 +
      +

      + +
      +


      +

      This macro creates a solid by sweeping a 2D profile along a trajectory previously selected in the 3D view. The 2D elements can be created through the regular tools in FreeCAD's GUI. +

      It should be noted that the resulting solid will not be parametric. If you decide to change your profile or trajectory, you'll need to run the macro again. +

      A few examples of sweeping all using the same oblong section and three kinds of trajectory. +

      +

      How to use

      +
      • Create two 2D elements, one for the section and one for the trajectory, of the types listed below.
      • +
      • Select, either in the Project tree or in the 3D view, first the trajectory, then the profile. The order is important!
      • +
      • Open the Macro manager, select the macro and click "Execute".
      • +
      • A Sweep object will be created in the Project tree.
      +

      Supported 2D elements

      + +

      Tips

      +
      • The section has to be a closed profile or the result will not be a solid.
      • +
      • The section does not need to be located on the trajectory, but it's preferable that it be normal (perpendicular) to the trajectory.
      • +
      • The trajectory can either be an open or closed profile (circle, or line and arc segments) but all elements need to be tangent or the resulting shape will be unexpected. For example, a trajectory with straight corners like a rectangle will not produce a solid.
      • +
      • If the solid gets twisted, edit the macro to change the isFrenet value to 0 (zero) and try again.
      • +
      • Setting the makeSolid variable to 0 (zero) in the macro will produce a set of surfaces with open ends.
      +

      The script

      +
      import Part, FreeCAD, math, PartGui, FreeCADGui
      +from FreeCAD import Base
      +
      +# get the selected objects, with first selection for the trajectory and second for the section
      +s = FreeCADGui.Selection.getSelection()
      +try:
      +     shape1=s[0].Shape
      +     shape2=s[1].Shape
      +except:
      +     print "Wrong selection"
      +
      +traj = Part.Wire([shape1])
      +section = Part.Wire([shape2])
      +
      +# create Part objec in the current document
      +myObject=App.ActiveDocument.addObject("Part::Feature","Sweep")
      +
      +# variable makeSolid = 1 to create solid, 0 to create surfaces
      +makeSolid = True #1
      +isFrenet = True #1
      +
      +# create a 3D shape and assigh it to the current document
      +Sweep = Part.Wire(traj).makePipeShell([section],makeSolid,isFrenet)
      +myObject.Shape = Sweep 
      +

      Credits

      +

      Thanks to Wmayer for his help in writing this script. +

      Two examples of uses can be found in this forum topic, along with download links to the FCStd files. Using a helix as trajectory, a solid sweep can be used to create a bolt thread. +

      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Macro_SpreadsheetTools.html b/localwiki/Macro_SpreadsheetTools.html new file mode 100644 index 0000000..94d5c32 --- /dev/null +++ b/localwiki/Macro_SpreadsheetTools.html @@ -0,0 +1,546 @@ +Macro SpreadsheetTools

      Macro SpreadsheetTools

      + +
      + + + + + + + + + + + + + + + + + + + + + + + + + + +
      +

      Text-x-python.png Macro SpreadsheetTools

      +
      Description +
      This macro helps managing cells inside FreeCAD's Spreadsheet-workbench. +
      Author +
      Wilfried Hortschitz +
      Links +
      Macros recipes
      How to install macros
      How to customize toolbars +
      Version +
      0.2.08 +
      Date last modification +
      2017-11-03 +
      +

      Contents

      + +
      + +
      +


      +

      This macro helps managing cells inside FreeCAD's Spreadsheet-workbench. It helps managing cells inside FreeCAD's Spreadsheet-workbench. With its help one is able to: +

      +
      • Cut/delete data and/or alias information in the selected area of cells.
      • +
      • Copy data and/or an alias information in the selected area of cells to clipboard.
      • +
      • Paste data and/or alias information in the selected area of cells from clipboard.
      +

      More information might be found on FreeCAD forums: http://forum.freecadweb.org/ and particular on https://forum.freecadweb.org/viewtopic.php?f=22&t=20508&hilit=spreadsheet#p158443 and on Github on https://github.com/HoWilgh/FCSpreadsheetTools/blob/master/README.md . +Screenshot from 2017-09-02 20-01-49.png +

      +
      # ============================================================================================================
      +# ============================================================================================================
      +# ==                                                                                                        ==
      +# ==                                       Spreadsheet tools                                                ==
      +# ==                                                                                                        ==
      +# ============================================================================================================
      +# ============================================================================================================
      +# ABOUT
      +# ============================================================================================================
      +# version v0.2.08 !!! This is beta version code so backup your data first!!! The author assumes no liability for data loss.
      +#
      +# Macro developed for FreeCAD (http://www.freecadweb.org/).
      +# This macro helps managing cells inside FreeCAD Spreadsheet workbench. It is able to:
      +#        - Cut/delete data and/or alias fields in a selected area of cells
      +#        - Copy data and/or alias fields in a selected area of cells to clipboard
      +#        - Paste data and/or alias fields in a selected area of cells from cliboard
      +# More information might be found on FreeCAD forums: http://forum.freecadweb.org/
      +#
      +#
      +# LICENSE
      +# ============================================================================================================
      +#
      +# This work is licensed under GNU Lesser General Public License (LGPL).
      +# To view a copy of this license, visit https://www.gnu.org/licenses/lgpl-3.0.html.
      +# 
      +# ============================================================================================================
      +__title__   = "Spreadsheet_tools"
      +__author__  = "HoWil"
      +__version__ = "0.2.08"
      +__date__    = "2017-09-02"
      +
      +__Comment__ = "This macro helps managing cells inside a single spreadsheet of FreeCAD Spreadsheet workbench. It is able to cut/delete, copy and paste an area of cells including format, alias and units. Merged cells are not supported."
      +
      +__Status__ = "stable"
      +__Requires__ = "FreeCAD 0.17"
      +
      +from PySide import QtGui, QtCore
      +
      +import FreeCADGui
      +#import FreeCAD
      +import FreeCAD as App
      +
      +import string
      +
      +
      +'''
      +*Working* Cut/delete the selected area
      +*Working* Copy to clipboard
      +*Working* Paste from clipboard
      +*Working* Copy and paste alias
      +
      +TODO:
      +* Check if something is overwritten and show a warning.
      +* Use shortcuts like Ctrl-c.
      +* Test if pandas is installed and offer import-export if available.
      +
      +* Right click menu??
      +* Copy and paste formating???
      +
      +Known limitations:
      +* Does work only with one opened FC-Spreadsheet.
      +* A cell has to be selected before selecting one of the options of Spreadsheet_tools.
      +* Does not work on merged cells.
      +'''
      +
      +
      +try:
      +    _fromUtf8 = QtCore.QString.fromUtf8
      +except AttributeError:
      +    def _fromUtf8(s):
      +        return s
      +
      +try:
      +    _encoding = QtGui.QApplication.UnicodeUTF8
      +    def _translate(context, text, disambig):
      +        return QtGui.QApplication.translate(context, text, disambig, _encoding)
      +except AttributeError:
      +    def _translate(context, text, disambig):
      +        return QtGui.QApplication.translate(context, text, disambig)
      +
      +
      +# ===== Global variables ==============================================
      +alphabet_list = list(string.ascii_uppercase)
      +
      +column_list = [] # is filled with A, B, C,.... AA, AB, AC,...
      +for i in range(0,26):
      +    column_list.append(alphabet_list[i])
      +
      +for i in range(0,26):
      +    for j in range(0,26):
      +        column_list.append(alphabet_list[i] + alphabet_list[j])
      +
      +
      +class Spreadsheet_Tools(QtGui.QDialog):
      +    """"""
      +    def __init__(self, MainWindow):
      +        super(Spreadsheet_Tools, self).__init__()
      +        self.window = MainWindow
      +
      +        #MainWindow.setObjectName(_fromUtf8("MainWindow"))
      +        #MainWindow.resize(400, 450)
      +        #MainWindow.setMinimumSize(QtCore.QSize(400, 450))
      +        #MainWindow.setMaximumSize(QtCore.QSize(400, 450))
      +        #self.widget = QtGui.QWidget(MainWindow)
      +        #self.widget.setObjectName(_fromUtf8("widget"))
      +
      +
      +        self.init_UI()
      +
      +
      +    def init_UI(self):
      +        FreeCAD.Console.PrintMessage("init_UI")
      +
      +        option3Button = QtGui.QPushButton("Copy to clipboard")
      +        option3Button.clicked.connect(self.copy_to_clipboard)
      +        option1Button = QtGui.QPushButton("Cut to clipboard/Delete selection")
      +        option1Button.clicked.connect(self.cut_delete_selection)
      +        option2Button = QtGui.QPushButton("Paste from clipboard")
      +        option2Button.clicked.connect(self.paste_from_clipboard)
      +        option4Button = QtGui.QPushButton("Close this dialog")
      +        option4Button.clicked.connect(self.close_dialog)
      +
      +        buttonBox = QtGui.QDialogButtonBox()
      +        buttonBox = QtGui.QDialogButtonBox(QtCore.Qt.Vertical)
      +        buttonBox.setGeometry(QtCore.QRect(00, 100, 210, 200))
      +        buttonBox.addButton(option3Button, QtGui.QDialogButtonBox.ActionRole)
      +        buttonBox.addButton(option1Button, QtGui.QDialogButtonBox.ActionRole)
      +        buttonBox.addButton(option2Button, QtGui.QDialogButtonBox.ActionRole)
      +        buttonBox.addButton(option4Button, QtGui.QDialogButtonBox.ActionRole)
      +
      +
      +
      +        self.groupBox = QtGui.QGroupBox()                                        # this is the group for associate
      +        self.groupBox.setGeometry(QtCore.QRect(00, 220, 125, 200))                          # coordinates position
      +        self.groupBox.setObjectName(_fromUtf8("groupBox"))                                  # name of window groupBox
      +
      +#        section checkBox 1
      +        self.checkBox_1 = QtGui.QCheckBox(self.groupBox)                                    # create object QRadioButton in groupBox
      +        self.checkBox_1.setGeometry(QtCore.QRect(0, 0, 150, 20))                         # coordinates position
      +        self.checkBox_1.setObjectName(_fromUtf8("Copy/paste/cut visible cell-content"))                              # name of object
      +        self.checkBox_1.setChecked(True)                                                    # Check by default True or False
      +
      +        self.checkBox_1.setToolTip(_translate("MainWindow", "Copy/paste/cut visible cell-content", None))
      +        self.checkBox_1.setText(_translate("MainWindow", "Use visible content", None))
      +        #self.checkBox_1.clicked.connect(self.on_checkBox_1_clicked)
      +
      +#        section checkBox 2
      +        self.checkBox_2 = QtGui.QCheckBox(self.groupBox)                                    # create object QRadioButton in groupBox
      +        self.checkBox_2.setGeometry(QtCore.QRect(160, 0, 150, 20))                         # coordinates position
      +        self.checkBox_2.setObjectName(_fromUtf8("Copy/paste/cut cell-alias"))                              # name of object
      +        self.checkBox_2.setChecked(True)                                                    # Check by default True or False
      +
      +        self.checkBox_2.setToolTip(_translate("MainWindow", "Use alias", None))
      +        self.checkBox_2.setText(_translate("MainWindow", "Use alias", None))
      +        #self.checkBox_2.clicked.connect(self.on_checkBox_2_clicked)
      +
      +        self.checkBox_3 = QtGui.QCheckBox(self.groupBox)                                    # create object QRadioButton in groupBox
      +        self.checkBox_3.setGeometry(QtCore.QRect(280, 0, 150, 20))                         # coordinates position
      +        self.checkBox_3.setObjectName(_fromUtf8("Copy/paste/cut cell-alias"))                              # name of object
      +        self.checkBox_3.setChecked(True)                                                    # Check by default True or False
      +
      +        self.checkBox_3.setToolTip(_translate("MainWindow", "Use formatting", None))
      +        self.checkBox_3.setText(_translate("MainWindow", "Use formatting", None))
      +        #self.checkBox_3.clicked.connect(self.on_checkBox_3_clicked)
      +
      +        mainLayout = QtGui.QVBoxLayout()
      +
      +        mainLayout.addWidget(self.groupBox)
      +        mainLayout.addWidget(buttonBox)
      +
      +        self.setLayout(mainLayout)
      +        # define window     xLoc,yLoc,xDim,yDim
      +        self.setGeometry(   500, 500, 450, 220)
      +        self.setWindowTitle("Pick a Button")
      +
      +
      +    def get_selection(self):
      +
      +        mw = FreeCADGui.getMainWindow()
      +        mdiarea = mw.findChild(QtGui.QMdiArea)
      +
      +        subw = mdiarea.subWindowList()
      +
      +        for i in subw:
      +            if i.widget().metaObject().className() == "SpreadsheetGui::SheetView":
      +                sheet = i.widget()
      +
      +                table = sheet.findChild(QtGui.QTableView)
      +        ind = table.selectedIndexes()
      +
      +        self.mw = mw    # mainwindow
      +        self.sheet = sheet  # spreadsheet
      +        self.table = table  # table
      +        self.ind = ind
      +
      +        l_elements = len(ind)
      +
      +        first_element = ind.__getitem__(0)
      +        fe_col = first_element.column()
      +        fe_row = first_element.row()
      +        fe_alphanum = column_list[fe_col] + str(fe_row+1)
      +
      +        last_element = ind.__getitem__(l_elements-1)
      +        le_col = last_element.column()
      +        le_row = last_element.row()
      +        le_alphanum = column_list[le_col] + str(le_row+1)
      +
      +        self.fe_alphanum = fe_alphanum
      +        self.fe_col = fe_col # numeric representation of column, D=>3
      +        self.fe_row = fe_row # numeric representation of row
      +
      +        self.le_alphanum = le_alphanum
      +        self.le_col = le_col
      +        self.le_row = le_row
      +
      +
      +    def delete_selection(self):
      +        # Delete selection
      +        self.get_selection()
      +
      +        ind = self.ind
      +
      +        rows = range(self.fe_row, self.le_row+1)
      +        columns = range(self.fe_col, self.le_col+1)
      +
      +
      +        for row in rows:
      +            for column in columns:
      +                cell = column_list[column] + str(row+1)
      +                if self.checkBox_1.isChecked():
      +                    App.ActiveDocument.Spreadsheet.set(cell, str(' ') )
      +                if self.checkBox_2.isChecked():
      +                    try:
      +                        App.ActiveDocument.Spreadsheet.setAlias(cell, None)
      +                    except:
      +                        FreeCAD.Console.PrintMessage("\nCould not delete alias.")
      +                if self.checkBox_3.isChecked():
      +                    try:
      +                        App.ActiveDocument.Spreadsheet.set(cell, '')
      +                    except:
      +                        FreeCAD.Console.PrintMessage("\nCould not delete formatting.")
      +
      +        App.activeDocument().recompute()
      +
      +
      +    def cut_delete_selection(self):
      +        # Cut selection
      +        self.copy_to_clipboard()
      +        self.delete_selection()
      +
      +
      +    def paste_from_clipboard(self):
      +        # Paste from clipboard
      +
      +        self.get_selection()
      +
      +        clipboard = QtGui.QApplication.clipboard()
      +
      +        if clipboard.mimeData().hasText():
      +
      +            cbtext = clipboard.mimeData().text()
      +            cbtext_split = [s.split('\t') for s in cbtext.splitlines()]
      +
      +            if self.checkBox_1.isChecked() and self.checkBox_2.isChecked() and self.checkBox_3.isChecked():
      +
      +                n_cells = len(cbtext_split)/3
      +
      +                index_col = self.fe_col
      +                for n_line, line in zip(range(n_cells), cbtext_split[0:n_cells]):
      +                    for n_word, col in zip(range(len(line)), line):
      +                        cell = column_list[index_col+n_word] + str(self.fe_row+n_line+1)
      +                        App.ActiveDocument.Spreadsheet.set(cell, str(col) )
      +
      +                for n_line, line in zip(range(n_cells), cbtext_split[n_cells:n_cells*2]):
      +                    for n_word, col in zip(range(len(line)), line):
      +                        cell = column_list[index_col+n_word] + str(self.fe_row+n_line+1)
      +                        try:
      +                            App.ActiveDocument.Spreadsheet.setAlias(cell, str(col))
      +                        except:
      +                            FreeCAD.Console.PrintMessage("\nCould not set/paste alias.")
      +
      +                for n_line, line in zip(range(n_cells), cbtext_split[n_cells*2:]):
      +                    for n_word, col in zip(range(len(line)), line):
      +                        cell = column_list[index_col+n_word] + str(self.fe_row+n_line+1)
      +                        import ast
      +                        col = ast.literal_eval(col)
      +
      +                        try:
      +                            if not(col['style'] == 'None'):
      +                                eval("App.ActiveDocument.Spreadsheet.setStyle('"+cell+"', "+col['style']+")")
      +                            if not(col['alignment'] == 'None'):
      +                                eval("App.ActiveDocument.Spreadsheet.setAlignment('"+cell+"', "+col['alignment']+")")
      +                        except:
      +                            FreeCAD.Console.PrintMessage("\nCould not set formatting (style, alignment).")
      +
      +                        try:
      +                            if not(col['foreground'] == 'None'):
      +                                App.ActiveDocument.Spreadsheet.setForeground(cell, ast.literal_eval(col['foreground']))
      +                            if not(col['background'] == 'None'):
      +                                eval("App.ActiveDocument.Spreadsheet.setBackground('"+cell+"', "+col['background']+")")
      +                        except:
      +                            FreeCAD.Console.PrintMessage("\nCould not set formatting ( background, foreground).")
      +
      +                        try:
      +                            if not(col['contents'] == ''):
      +                                App.ActiveDocument.Spreadsheet.set(cell, col['contents'])
      +                            if not(col['displayunit'] == 'None'):
      +                                App.ActiveDocument.Spreadsheet.setDisplayUnit(cell, col['displayunit'])
      +                        except:
      +                            FreeCAD.Console.PrintMessage("\nCould not set formatting (displayunit and contents).")
      +
      +
      +            if self.checkBox_1.isChecked() and (not self.checkBox_2.isChecked()):
      +                n_cells = len(cbtext_split)
      +
      +                index_col = self.fe_col
      +                for n_line, line in zip(range(n_cells), cbtext_split[0:n_cells]):
      +                    for n_word, col in zip(range(len(line)), line):
      +                        cell = column_list[index_col+n_word] + str(self.fe_row+n_line+1)
      +                        App.ActiveDocument.Spreadsheet.set(cell, str(col) )
      +
      +            if (not self.checkBox_1.isChecked()) and self.checkBox_2.isChecked():
      +                n_cells = len(cbtext_split)
      +
      +                index_col = self.fe_col
      +                for n_line, line in zip(range(n_cells), cbtext_split[0:n_cells]):
      +                    for n_word, col in zip(range(len(line)), line):
      +                        cell = column_list[index_col+n_word] + str(self.fe_row+n_line+1)
      +                        try:
      +                            App.ActiveDocument.Spreadsheet.setAlias(cell, str(col))
      +                        except:
      +                            FreeCAD.Console.PrintMessage("\nCould not set/paste alias.")
      +
      +            App.activeDocument().recompute()
      +
      +        else:
      +            clipboard.setText(tr("Cannot display data! No proper information stored in clipboard."))
      +
      +
      +    def copy_to_clipboard(self):
      +        # Copy to clipboard
      +
      +        self.get_selection()
      +
      +        if len(self.ind) > 0:
      +            # sort select indexes into rows and columns
      +            previous = self.ind[0]
      +            columns = []
      +            rows = []
      +            clipboard = ""
      +
      +            if self.checkBox_1.isChecked():
      +
      +                for index in self.ind:
      +                    if previous.column() != index.column():
      +                        columns.append(rows)
      +                        rows = []
      +                    rows.append(index.data())
      +
      +                    idx_col = index.column()
      +                    idx_row = index.row()
      +                    idx_alphanum = column_list[idx_col] + str(idx_row+1)
      +
      +                    previous = index
      +
      +                columns.append(rows)
      +                cell_content = columns
      +                self.cell_content = cell_content
      +
      +                # add rows and columns to clipboard
      +                nrows = len(cell_content[0])
      +                ncols = len(cell_content)
      +                for r in xrange(nrows):
      +                    for c in xrange(ncols):
      +                        if cell_content[c][r] is not None:
      +                            clipboard += cell_content[c][r]
      +                        else:
      +                            clipboard += ''
      +                        if c != (ncols-1):
      +                            clipboard += '\t'
      +                    clipboard += '\n'
      +
      +            previous_alias = self.ind[0]
      +            columns_alias = []
      +            rows_alias = []
      +            clipboard_alias = ""
      +
      +            if self.checkBox_2.isChecked():
      +
      +                for index in self.ind:
      +                    if previous_alias.column() != index.column():
      +                        columns_alias.append(rows_alias)
      +                        rows_alias = []
      +
      +                    idx_col = index.column()
      +                    idx_row = index.row()
      +                    idx_alphanum = column_list[idx_col] + str(idx_row+1)
      +                    rows_alias.append(App.ActiveDocument.Spreadsheet.getAlias(idx_alphanum))
      +
      +                    previous_alias = index
      +
      +                columns_alias.append(rows_alias)
      +                cell_content_alias = columns_alias
      +                self.cell_content_alias = cell_content_alias
      +
      +                # add rows and columns to clipboard
      +                nrows = len(cell_content_alias[0])
      +                ncols = len(cell_content_alias)
      +                for r in xrange(nrows):
      +                    for c in xrange(ncols):
      +                        if cell_content_alias[c][r] is not None:
      +                            clipboard_alias += cell_content_alias[c][r]
      +                        else:
      +                            clipboard_alias += ''
      +                        if c != (ncols-1):
      +                            clipboard_alias += '\t'
      +                    clipboard_alias += '\n'
      +
      +            previous_formatting = self.ind[0]
      +            columns_formatting = []
      +            rows_formatting = []
      +            clipboard_formatting = ""
      +
      +            if self.checkBox_3.isChecked():
      +
      +                for index in self.ind:
      +                    if previous_formatting.column() != index.column():
      +                        columns_formatting.append(rows_formatting)
      +                        rows_formatting = []
      +
      +                    idx_col = index.column()
      +                    idx_row = index.row()
      +                    idx_alphanum = column_list[idx_col] + str(idx_row+1)
      +                    formatting_dict = {'style':str(App.ActiveDocument.Spreadsheet.getStyle(idx_alphanum)),
      +                                        'foreground':str(App.ActiveDocument.Spreadsheet.getForeground(idx_alphanum)),
      +                                        'background':str(App.ActiveDocument.Spreadsheet.getBackground(idx_alphanum)),
      +                                        'contents':str(App.ActiveDocument.Spreadsheet.getContents(idx_alphanum)),
      +                                        'displayunit':str(App.ActiveDocument.Spreadsheet.getDisplayUnit(idx_alphanum)),
      +                                        'alignment':str(App.ActiveDocument.Spreadsheet.getAlignment(idx_alphanum))}
      +                    rows_formatting.append(formatting_dict)
      +
      +                    previous_formatting = index
      +
      +                columns_formatting.append(rows_formatting)
      +                cell_content_formatting = columns_formatting
      +                self.cell_content_formatting = cell_content_formatting
      +                FreeCAD.Console.PrintMessage(cell_content_formatting)
      +                # add rows and columns to clipboard
      +                nrows = len(cell_content_formatting[0])
      +                ncols = len(cell_content_formatting)
      +                for r in xrange(nrows):
      +                    for c in xrange(ncols):
      +
      +                        if cell_content_formatting[c][r] is not None:
      +                            clipboard_formatting += str( cell_content_formatting[c][r] )
      +                        else:
      +                            clipboard_formatting += ''
      +                        if c != (ncols-1):
      +                            clipboard_formatting += '\t'
      +
      +                    clipboard_formatting += '\n'
      +
      +            # copy to the system clipboard
      +            sys_clip = QtGui.QApplication.clipboard()
      +            sys_clip.setText(clipboard + clipboard_alias + clipboard_formatting)
      +
      +    def close_dialog(self):
      +        self.close()
      +
      +MainWindow = QtGui.QMainWindow()
      +form = Spreadsheet_Tools(MainWindow)
      +form.show() 
      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Macro_Spring.html b/localwiki/Macro_Spring.html new file mode 100644 index 0000000..59c1d29 --- /dev/null +++ b/localwiki/Macro_Spring.html @@ -0,0 +1,152 @@ +Macro Spring

      Macro Spring

      + +
      + + + + + + + + + + + + + + + + + + + + + + + + + + +
      +

      Text-x-python.png Spring Simul

      +
      Description +
      Spring simulation. +
      Author +
      Mario52 +
      Links +
      Macros recipes
      How to install macros
      How to customize toolbars +
      Version +
      1.0 +
      Date last modification +
      2014-09-29 +
      +

      + +
      +


      +

      Simulates the compression and decompression of a spring. +

      +
      Spring 00.gif
      +

      Uses

      +

      Open the 2 files below (Spring.FCMacro and Spring.FCStd) in FreeCAD with 2 screens (Menu: Windows → Tile) and click in the window and the macro then press F6 (debug macro) to run the macro or run the macro with Macro-execute.svg +

      +
      Spring 02.png
      +

      The File

      +

      Spring.FCStd +

      +

      Script

      +

      Spring.FCMacro +

      +
      import FreeCAD, FreeCADGui, Draft, Part
      +from FreeCAD import Base
      +import time
      +
      +ii = iib = FreeCAD.getDocument("Spring").getObject("Helix001").Pitch
      +i = ib = FreeCAD.getDocument("Spring").getObject("Helix001").Height
      +
      +pas = 1
      +
      +for ii2 in range(int(60)):
      +    if pas == 0:
      +        if ii > iib-1:
      +            pas = 1
      +        else:
      +            ii += 1
      +            i = (ii * 10)
      +    else:
      +        if ii < 2:
      +            pas = 0
      +        else:
      +            ii -= 1
      +            i = (ii * 10)
      +   
      +    FreeCAD.getDocument("Spring").getObject("Helix001").Pitch = ii
      +    FreeCAD.getDocument("Spring").getObject("Helix001").Height = i
      +    App.Console.PrintMessage(str(ii2)+"  " + str(ii)+"  " + str(i)+"  " + str(pas) +"\n")
      +    Gui.updateGui()
      +    time.sleep(0.1) # modify the time here
      +#FreeCAD.getDocument("Spring").getObject("Helix001").Pitch = iib
      +#FreeCAD.getDocument("Spring").getObject("Helix001").Height = ib 
      +

      Code for FreeCAD version 0.15 +

      +
      # For FreeCAD 0.15
      +import FreeCAD, FreeCADGui, Draft, Part
      +from FreeCAD import Base
      +import time
      +
      +ii = iib = FreeCAD.getDocument("Spring").getObject("Helix001").Pitch.Value
      +i = ib = FreeCAD.getDocument("Spring").getObject("Helix001").Height.Value
      +
      +pas = 1
      +
      +for ii2 in range(int(60)):
      +    if pas == 0:
      +        print pas
      +        if ii > iib-1:
      +            pas = 1
      +        else:
      +            ii += 1
      +            i = (ii * 10)
      +            print i," ",ii," else1"
      +    else:
      +        print pas
      +        if ii < 2:
      +            pas = 0
      +        else:
      +            ii -= 1
      +            i = (ii * 10)
      +            print i," ",ii," else2"
      +    FreeCAD.getDocument("Spring").getObject("Helix001").Pitch.Value = ii
      +    FreeCAD.getDocument("Spring").getObject("Helix001").Height.Value = i
      +#    App.Console.PrintMessage(str(ii2)+"  " + str(ii)+"  " + str(i)+"  " + str(pas) +"\n")
      +    Gui.updateGui()
      +    time.sleep(0.1) # modify the time here
      +#FreeCAD.getDocument("Spring").getObject("Helix001").Pitch.Value = iib
      +#FreeCAD.getDocument("Spring").getObject("Helix001").Height.Value = ib 
      +

      Link

      +

      The forum discussion page: scripting animations +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Macro_Stairs.html b/localwiki/Macro_Stairs.html new file mode 100644 index 0000000..d4fc80a --- /dev/null +++ b/localwiki/Macro_Stairs.html @@ -0,0 +1,149 @@ +Macro Stairs

      Macro Stairs

      + +
      + + + + + + + + + + + + + + + + + + + + + + + + + + +
      +

      Text-x-python.png Macro Stairs

      +
      Description +
      Creates a stair helix. +
      Author +
      Mario52 +
      Links +
      Macros recipes
      How to install macros
      How to customize toolbars +
      Version +
      00.03 +
      Date last modification +
      2015-03-01 +
      +

      + +
      +


      +

      +

      Description

      +

      Create a stair elliptical +

      +
      Macro CircularStair.png
      +
      +

      Use

      +

      Create your stair nosing, select your object and launch the macro +

      +
      • Hmarche  : head marche
      • +
      • nombre  : number objects for 1 turn
      • +
      • rayon  : radius (axe to object)
      • +
      • tours  : nomber turns pitch
      • +
      • cloner  : 1=create clone 0=create copy
      • +
      • cylindre : 1=create cylinder 0=not cylinder
      +

      Script

      +

      Macro_Stairs.FCMacro +

      +
      # Select your object(s) give :
      +#     head marche
      +#     number objects for 1 turn
      +#     radius (axe to object)
      +#     number turns
      +# the original object is not modify
      +# Macro_Stairs.FCMacro
      +
      +import FreeCAD, Draft, Part
      +
      +__title__   = "CircularStair"
      +__author__  = "Mario52"
      +__date__    = "01/03/2015"
      +__url__     = "http://www.freecadweb.org/index-fr.html"
      +__version__ = "00.03"
      +
      +sel = FreeCADGui.Selection.getSelection()
      +
      +############## Modify here ####################
      +Hmarche  = 10  # head marche
      +nombre   = 18  # number objects for 1 turn
      +rayon    = 20  # radius (axe to object)
      +tours    = 5  # nomber turns pitch 
      +cloner   = 1   # 1=clone    0=copy
      +cylindre = 1   # 1=create cylinder  0=not cylinder
      +###############################################
      +
      +vecligne=[FreeCAD.Vector(0.0,0.0,0.0),FreeCAD.Vector(rayon,0.0,0.0)]   # vector for line directrice
      +ligne = Draft.makeWire(vecligne,closed=False,face=False,support=None)  # creation de la ligne de base
      +coor_X = coor_Y = coor_Z = 0.0
      +for i0 in range(tours):
      +    for i in range(0,360,((360/nombre))):                                  # boucle principale 0 to 360 degrees
      +        FreeCAD.ActiveDocument.getObject(ligne.Name).Placement=App.Placement(App.Vector(0,0,coor_Z), App.Rotation(App.Vector(0,0,1),i), App.Vector(0,0,0))
      +        a = ligne.Shape.Edges[0].Vertexes[1]                               # fin de la ligne
      +        coor_X = (a.Point.x)
      +        coor_Y = (a.Point.y)
      +
      +        if cloner == 1:
      +            obj=Draft.clone(sel)
      +        else:
      +            obj = Draft.scale(sel,delta=App.Vector(1, 1, 1),center=App.Vector(),copy=True,legacy=True)
      +        try:
      +            for io in range(len(obj)):
      +                obj[io].Placement=App.Placement(App.Vector(coor_X,coor_Y,coor_Z), App.Rotation(i,0,0), App.Vector(0,0,0))
      +        except Exception:
      +            obj.Placement=App.Placement(App.Vector(coor_X,coor_Y,coor_Z), App.Rotation(i,0,0), App.Vector(0,0,0))
      +
      +        coor_Z += Hmarche
      +App.ActiveDocument.removeObject(ligne.Name)                            # remove ligne de base directrice
      +
      +# create cylinder
      +if cylindre == 1:
      +    App.ActiveDocument.addObject("Part::Cylinder","Cylinder")
      +    App.ActiveDocument.ActiveObject.Label = "Cylindre"
      +    FreeCAD.ActiveDocument.ActiveObject.Height = (Hmarche * nombre * tours)    # heigth of cylinder
      +    FreeCAD.ActiveDocument.ActiveObject.Radius = (rayon)                       # radius of cylinder
      +
      +FreeCAD.ActiveDocument.recompute() 
      +

      Links

      +

      The discussion on the forum Newbie question - spiral staris reloaded +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Macro_SuperWire.html b/localwiki/Macro_SuperWire.html new file mode 100644 index 0000000..b480aad --- /dev/null +++ b/localwiki/Macro_SuperWire.html @@ -0,0 +1,89 @@ +Macro SuperWire

      Macro SuperWire

      + +
      + + + + + + + + + + + + + + + + + + + + + + + + + + +
      +

      Text-x-python.png SuperWire

      +
      Description +
      This macro creates a wire from selected objects (lines and arcs) even where normal wire creation methods (for example the upgrade tool) fail +
      Author +
      Yorik +
      Links +
      Macros recipes
      How to install macros
      How to customize toolbars +
      Version +
      0.1 +
      Date last modification +
      2012-05-22 +
      +

      Contents

      + +
      + +
      +


      +

      This macro creates a wire from selected objects (lines and arcs) even where normal wire creation methods (for example the upgrade tool) fail.
      +Attention, you need a recent version of FreeCAD for this to work +


      +

      +
      import FreeCAD,FreeCADGui,Part
      +try:
      +    import DraftGeomUtils as fcgeo
      +except:
      +    from draftlibs import fcgeo
      +
      +sel = FreeCADGui.Selection.getSelection()
      +if not sel:
      +   FreeCAD.Console.PrintWarning("Select something first!")
      +else:
      +   elist = []
      +   for obj in sel:
      +       if hasattr(obj,"Shape"):
      +           elist.append(obj.Shape.Edges[0])
      +   wire = fcgeo.superWire(elist)
      +   if wire:
      +       Part.show(wire)
      +   else:
      +       FreeCAD.Console.PrintError("SuperWire operation failed!") 
      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Macro_Texture.html b/localwiki/Macro_Texture.html new file mode 100644 index 0000000..d6a4860 --- /dev/null +++ b/localwiki/Macro_Texture.html @@ -0,0 +1,315 @@ +Macro Texture

      Macro Texture

      + +
      + + + + + + + + + + + + + + + + + + + + + + + + + + +
      +

      FCTexture.png Macro Texture

      +
      Description +
      Creates an image 3D from a BMP image. +
      Author +
      Mario52 +
      Links +
      Macros recipes
      How to install macros
      How to customize toolbars +
      Version +
      0.10 +
      Date last modification +
      2016-12-28 +
      +

      + +
      +


      +

      +

      Description

      +

      This small macro allows you to build a project 3D very easily from a bitmap image 256 levels of gray. +

      I hope that this macro will revolutionize the way of thinking the CAD and CNC any image when what can be converted to object 3D without any intervention. +

      Everything becomes possible regardless of the complexity of the image ! +

      The macro Macro Loft for automate the multi loft
      +

      Texture 004 Honda +

      +
      +


      +

      +

      Use

      +

      This macro need an image in 256 gray levels (0-255) therefore before using the macro, convert your image into grayscale (black and white) Lowe. The number of colors is detected automatically, if the image is more than 256 colors another function is expected (to come). Each color (gray level) is regarded as a deep, white (255) the level high and black (0) the lowest level (deep). +

      Configuration is done before the opening of the file, default values are the settings provided to get a project's dimensions: +

      +
      • width of the image in points in the coordinate X,
      • +
      • height of the image in points in the coordinate Y,
      • +
      • depth or thickness of the project leaked 10 mm (in raw mode, on 256 mm) in the coordinate Z.
      +

      The image file unfolds like a scanner x1 x2 x3 ... in 1 mm increments in FreeCAD similarly to the value y of 1 mm at a time. The value of z is given by the value of the color. These values are configurable in the macro. +

      Attention: depending on the size of the image, the project can become very big! for the record an image of 100 px wide and 100 px in height gives 100 x 100 = 10000 points 'and as each point corresponds to a coordinate, so 10000 coordinates XYZ there. +

      +

      The interface

      +
      Texture 002
      +
      • Coordinate
      • +
      • Coordinate X: X coordinate of position of the object, default: 0.
      • +
      • Coordinate Y: Y coordinate of position of the object, default: 0.
      • +
      • Coordinate Z: coordinate Z position of the object, default: 0.
      • +
      • +
      • Stetching
      • +
      • Stetching X: narrowing or enlargement of the length of the object, default: 0.
      • +
      • Stetching Y: narrowing or enlargement of the height of the object, default: 0.
      • +
      • Stetching Z: narrowing or enlargement of the depth of the object, default: 0.
      • +
      • +
      • Inversion
      • +
      • Inversion X: reverse coordinates X image.
      • +
      • Inversion Y: reverse coordinates Y image.
      • +
      • Inversion Z: reverse coordinates Z image.
      • +
      • +
      • Mode 8 Bits
      +

      The beginning of the operation value automatically adapts to the selected function: 0 if the setting is on black (Black) 255 or 20 if the setting is white (White). +

      +
      • +
      • Wire: build your line (vector) in the form of Wire.
      • +
      • Bspline: build your line (vector) in the form of Bspline.
      • +
      • Cloud build the points vectors in the points cloud.
      • +
      • Point: creates a point at each pixel (vector). (the procedure can be long)
      • +
      • Nuance: If the shade option is checked the color of the point is represented as a picture.
      • +
      • +
      • Mode 32 Bits
      • +
      • Photo: the photo mode is automatically activated when a 32-bit image is detected. (the procedure can be long)
      • +
      • Plan: the plan allows you to import a 32-bit image and ignore the background of the plan. By default the map background is black to ignore colors are adjustable with the Capping command. If White is checked, the bottom has ignore will be white. (the procedure can be long)
      • +
      • +
      • Files
      • +
      • pcd: if is checked one file originalName.bmp.pcd is saved in the same directory of the file (pcd v0.7).
      • +
      • asc: if is checked one file originalName.bmp.asc is saved in the same directory of the file. This file can be used as a cloud point (format: X Y Z).
      • +
      • +
      • Capping (10mm)
      • +
      • Slider: give the height of the form the height is displayed on title frame.
      • +
      • Raw mode: to adjust the number of colors (depth). The default mode is 0-20 (which constitutes a filter and to obtain more details according to the complexity of the image) once the checked the mode is 0 to 255 (the entire range of colors).
      • +
      • CheckBox: this checkBox enabled the spinbox.
      • +
      • SpinBox: this spinbox give the contour line do not use (ex: 0 for the base).
      • +
      • Capping: the capping function can be made on the choice of colours, white (default) or black. The degrees of capping rule 20 to 0 (or 255 to 0) if the checkbox is set on W (unchecked) or 0 to 20 (or 0 to 255) if the checkbox is set on B (checked).
      • +
      • SpinBox: this spinbox give the degrees of capping.
      +
      • +
      • File and lauch: opens the image file and launches the conversion.
      • +
      • Quit: exits the function.
      +

      Script

      +

      The icons .png FCTexture.png and .svgFCTexture.svg +


      +Macro_Texture.FCMacro +

      Download the macro to Gist Macro FCTexture.FCMacro +

      +

      Example

      +

      The images were inclined to enhance the 3D effect. +

      +
      + +
      +
      + +
      +
      + +
      +


      +

      +
      + +
      +


      +

      +
      + +
      +


      +

      +
      + +
      +


      +

      +
      + +
      +


      +

      +
      + +
      +


      +

      +
      + +
      +


      +

      +
      + +
      +


      +

      +

      Links

      +

      The discussion on the forum to give your impressions or contact me. +

      The macro Macro Loft for automate the multi loft +

      apply hair cell texture +

      How to handle pdf import properly and feasibly? +

      +

      Revision

      +
      • ver 0.10 : 28/12/2016 add save point in .pcd, .asc display a points cloud, height form, contour
      • +
      • ver 0.9 : 12/12/2016 adding save file .asc for cloud point
      • +
      • ver 0.8 : 16/03/2016 adding progressBar
      • +
      • ver 0.7 : 03/09/2014 Delete "translate" forgotten and bug fix discovered by the passage of PyQt to Pyside !
      • +
      • ver 0.6 : 26/08/2014 Delete all "_translate"
      • +
      • ver 0.5 : 25/08/2014 Delete "_translate (" MainWindow "," Stretching X ", None)" that prevented the display of tooltip with PySide (Windows Vista)
      +
      • ver 0.4 : 08/08/2014 PyQt4 PySide
      +
      • ver 0.3 : 28/03/2014 :comment out the line "# self.checkBox_5.setAccessibleName(_fromUtf8(""))"
      +

      that causes an error with the version FreeCAD : Version: 0.14.3343 (Git), Python version: 2.7.6, Qt version: 4.8.5 +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Macro_Texture_Objects.html b/localwiki/Macro_Texture_Objects.html new file mode 100644 index 0000000..9ad61ca --- /dev/null +++ b/localwiki/Macro_Texture_Objects.html @@ -0,0 +1,83 @@ +Macro Texture Objects

      Macro Texture Objects

      + +
      + + + + + + + + + + + + + + + + + + + + + + + + + + +
      +

      Text-x-python.png Texture Objects

      +
      Description +
      This macro allows you to temporarily put a texture image on selected objects. To remove the textures, simply close and reopen the document. +
      Author +
      yorik +
      Links +
      Macros recipes
      How to install macros
      How to customize toolbars +
      Version +
      1.0 +
      Date last modification +
      2011-10-13 +
      +

      Contents

      + +
      + +
      +


      +

      This macro allows you to temporarily put a texture image on selected objects. To remove the textures, simply close and reopen the document. +

      Textured objects.jpg +

      +
      +
      import FreeCADGui
      +from PySide import QtGui
      +from pivy import coin
      +
      +# get a jpg filename
      +jpgfilename = QtGui.QFileDialog.getOpenFileName(QtGui.qApp.activeWindow(),'Open image file','*.jpg')
      +
      +# apply textures
      +for obj in FreeCADGui.Selection.getSelection():
      +    rootnode = obj.ViewObject.RootNode
      +    tex =  coin.SoTexture2()
      +    tex.filename = str(jpgfilename[0])
      +    rootnode.insertChild(tex,1) 
      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Macro_Toggle_Drawstyle.html b/localwiki/Macro_Toggle_Drawstyle.html new file mode 100644 index 0000000..7980dba --- /dev/null +++ b/localwiki/Macro_Toggle_Drawstyle.html @@ -0,0 +1,162 @@ +Macro Toggle Drawstyle

      Macro Toggle Drawstyle

      + +
      + + + + + + + + + + + + + + + + + + + + + + + + + + +
      +

      Macro Toggle Drawstyle.png Macro Toggle Drawstyle

      +
      Description +
      This macro toggles the Drawstyle of the selected object. +
      Author +
      Piffpoof +
      Links +
      Macros recipes
      How to install macros
      How to customize toolbars +
      Version +
      1.0 +
      Date last modification +
      2016-02-25 +
      +

      + +
      +


      +

      +

      Description

      +

      When working with FreeCAD there are times when you want to quickly change the Drawstyle of the object you are working with. This is available through the Drawstyle pull-down menu where any Drawstyle may be selected. This macro makes 2 of the Drawstyles available as a clickable button on a toolbar which the user may click to toggle back and forth between the two Drawstyles. The user can modify the macro code to select which 2 Drawstyles they wish to toggle between. This does not add functionality missing in the Drawstyles pull-down menu, but rather an increased convenience level. +

      +

      Installation

      +

      Installation is comprised of copying the two code to the appropriate Macro directory and invoking it from the Macro menu. It is much preferable to add it both to a toolbar so as to be more easily available. +

      + +

      PS: You must adapt the macro to your language: +

      example with German language, replace the code (lines 41, 42) +

      +
      drawstyleA = "As is"
      +drawstyleB = "Wireframe" 
      +

      to: +

      +
      drawstyleA = "Original"
      +drawstyleB = "Drahtgitter" 
      +

      Macro Toggle Drawstyle 00 .png +

      +
      +


      +

      +

      Usage

      +

      Select an object, then click on the associated toolbar button, or invoke from the Macro menu. The Drawstyle of the slected object will toggle beteen the two drawstyles specified in the macro code (see code listing below). +Note: The specification for each Drawstyle is listed in the code, by modifying the code (which is documented in the macro code) the user may select which 2 Drawstyles are toggled between. +

      +

      User Interface

      +

      The selected object will be redrawn in the other drawstyle specified in the macro. +

      Script optimized for all languages and to object selected or all objects Keyboard shortcut, View toolbar - Wireframe (Sun Nov 27, 2016 6:49 pm) +

      +

      Scripts

      +
      # -*- coding: utf-8 -*-
      +#
      +#
      +#Macro: Toggle Draw Style
      +#
      +# This macros allows the user to switch between different Drawstyles by clicking on
      +# the button of a Macro in a toolbar.
      +#
      +# initial code:triplus
      +# macro-isation:piffpoof
      +#
      +# This macro switches (or toggles) between 2 selected styles from the Drawstyle menu.
      +# As written the macro toggles between "WireFrame" and "As is".
      +# Immediately below this text is a list of the legal values for the Drawstyle menu.
      +# The first 2 lines of executable code are of the form "DrawstyleA = " followed by
      +# the 2nd line which is of the form "DrawstyleB = ".
      +# These 2 lines specify which of the Drawstyle values the macro will toggle between.
      +# Drawstyle "As is" is the system default and so is specified as the first drawstyle.
      +# The second line specifies which drawstyle will be toggled to and from.
      +# Any of the legal values may be used, so if, for example, it is desired to toggle between
      +# the Shaded and Points drawstyles, then the 2 lines of code would be modified to be:
      +#
      +# drawstyleA = "Shaded"
      +# drawstyleB = "Points"
      +#
      +# but remember that the hash signs ('#') are not to be present on the executable lines.
      +#
      +###Legal Values for Drawstyle###
      +#
      +#"As is"
      +#"FlatLines"
      +#"Shaded
      +#"Wireframe"
      +#"Points"
      +#
      +################################
      +
      +from PySide import QtGui
      +
      +# Constant definitions
      +drawstyleA = "As is"
      +drawstyleB = "Wireframe"
      +
      +# code ***********************************************************************************
      +
      +mw = FreeCADGui.getMainWindow()
      +
      +for i in mw.findChildren(QtGui.QAction):
      +    if i.text() == drawstyleA.decode("UTF-8"):
      +        actionA = i
      +    elif i.text() == drawstyleB.decode("UTF-8"):
      +        actionB = i
      +    else:
      +        pass
      +
      +if actionA.isChecked():
      +    actionB.activate(QtGui.QAction.Trigger)
      +else:
      +    actionA.activate(QtGui.QAction.Trigger) 
      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Macro_Toggle_Drawstyle_00_.png b/localwiki/Macro_Toggle_Drawstyle_00_.png new file mode 100644 index 0000000..3cecb30 Binary files /dev/null and b/localwiki/Macro_Toggle_Drawstyle_00_.png differ diff --git a/localwiki/Macro_Toggle_Panels_Visibility.html b/localwiki/Macro_Toggle_Panels_Visibility.html new file mode 100644 index 0000000..e0dd4ce --- /dev/null +++ b/localwiki/Macro_Toggle_Panels_Visibility.html @@ -0,0 +1,107 @@ +Macro Toggle Panels Visibility

      Macro Toggle Panels Visibility

      + +
      + + + + + + + + + + + + + + + + + + + + + + + + + + +
      +

      Macro Toggle Views Visibility.png Macro Toggle Panels Visibility

      +
      Description +
      This macro toggles the visibility of various supporting views in FreeCAD, allowing the main window to be viewed with all available screen space. +
      Author +
      Piffpoof +
      Links +
      Macros recipes
      How to install macros
      How to customize toolbars +
      Version +
      1.0 +
      Date last modification +
      2015-01-17 +
      +

      + +
      +


      +

      +

      Description

      +

      When working with FreeCAD there are times when you need many supporting windows open, such as Combo View, Report View, etc. There are other times when you want all the clutter of the supporting windows to disappear so that all the screen space available can be used to view the model being worked with. This macro lets you hide all the supporting windows (or make them visible again) with one click on the toolbar. +

      +

      Installation

      +

      Save the provided code to the appropriate Macro directory and execute it from the Macro menu. It is preferable to add it to a toolbar for ease of access. +

      + +

      Usage

      +

      Click on the associated toolbar button, or invoke from the Macro menu. The supporting windows Python console, Report view, Combo view will either all become visible or all become hidden. +

      +

      User Interface

      +

      There is immediate confirmation of the user action as the supporting windows either appear or disappear. +

      +

      Scripts

      +
      # macro to toggle visibility of Report view, Python console, Combo view
      +from PySide import QtCore, QtGui
      +mainWindow = FreeCADGui.getMainWindow()
      +dockWidgets = mainWindow.findChildren(QtGui.QDockWidget)
      +for dw in dockWidgets:
      +if dw.objectName() == "Python console":
      +pcWidget = dw
      +   if dw.objectName() == "Combo View":
      +   cvWidget = dw
      +   if dw.objectName() == "Report view":
      + rvWidget = dw
      +     
      +if pcWidget.isVisible():
      +   pcWidget.hide()
      +   cvWidget.hide()
      +   rvWidget.hide()
      +else:
      +   pcWidget.show()
      +   cvWidget.show()
      +   rvWidget.show() 
      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Macro_Toggle_Visibility.html b/localwiki/Macro_Toggle_Visibility.html new file mode 100644 index 0000000..e83007e --- /dev/null +++ b/localwiki/Macro_Toggle_Visibility.html @@ -0,0 +1,186 @@ +Macro Toggle Visibility

      Macro Toggle Visibility

      + +
      + + + + + + + + + + + + + + + + + + + + + + + + + + +
      +

      Macro SelectVisible.png Toggle Visibility

      +
      Description +
      Hidden all objects not selected. +
      Author +
      Mario52 +
      Links +
      Macros recipes
      How to install macros
      How to customize toolbars +
      Version +
      00.02 +
      Date last modification +
      2015-11-12 +
      +

      + +
      +


      +

      +

      Description

      +

      This is a set of four related macros for managing the visibility of objects in the Object Model: +

      +
      1. objects that are selected in a document are made visible while objects that are not selected are made invisible +
        • if no objects are selected then all objects are hidden;
        • +
        • if all objects are selected then all objects are made visible
      2. +
      3. make all objects visible
      4. +
      5. make all objects invisible
      6. +
      7. the object(s) selected then stay , all objects not selected are deleted
      +

      How To Use

      +

      Copy the macros and the icons in your folder macros and run (see How to install macros) +

      +

      ToggleVisibility

      +

      Using the selection of objects in the one of the FreeCAD views, this macro makes all selected objects visible and hides all objects which are not selected. +

      If no object(s) are selected then all objects are hidden +

      If all objects are hidden and there is no selection in ComboView then all object are made visible +

      This version new version (00.02) include the tree macro in one +

      The code Macro_ToggleSelectedObjectVisibility.FCMacro the icon Macro SelectVisible.png +

      +
      import FreeCAD
      +# Macro_ToggleSelectedObjectVisibility
      +__title__="Macro_ToggleSelectedObjectVisibility"
      +__author__ = "Mario52"
      +__url__     = "http://www.freecadweb.org/index-fr.html"
      +__version__ = "00.02"
      +__date__    = "12/11/2015"
      +
      +try:
      +    compt = 0
      +    for ShapeNameObj in FreeCAD.ActiveDocument.Objects:                                   # list alls objet for test if alls hidden
      +        if (FreeCADGui.ActiveDocument.getObject(ShapeNameObj.Name).Visibility == False) and (Gui.Selection.isSelected(ShapeNameObj) == False):
      +            compt += 1                                                                    # if hidden : compt += 1
      +            #print "False : ",ShapeNameObj.Name
      +    if compt == len(FreeCAD.ActiveDocument.Objects):                                      # if (compt = Alls objects hidden) then Visibility = True
      +        for ShapeNameObj in FreeCAD.ActiveDocument.Objects:
      +            FreeCADGui.ActiveDocument.getObject(ShapeNameObj.Name).Visibility = True      # Visibility = True
      +            #print "True  : ",ShapeNameObj.Name
      +        compt = 0
      +    else :
      +        for ShapeNameObj in FreeCAD.ActiveDocument.Objects:                               # hidde objects not selecteds
      +            if Gui.Selection.isSelected(ShapeNameObj) == False:
      +                FreeCADGui.ActiveDocument.getObject(ShapeNameObj.Name).Visibility = False # if objects is not selected then Visibility = False (Hidden)
      +                #print "False : ",ShapeNameObj.Name
      +            else:
      +                FreeCADGui.ActiveDocument.getObject(ShapeNameObj.Name).Visibility = True  # if objects are hidden and selected then Visibility = True and hidden alls objects visibles
      +                #print "True  : ",ShapeNameObj.Name
      +except Exception:
      +    None 
      +

      DisplayAll

      +

      This macro makes all objects visible. +

      The code Macro_DisplayAllObjects the icon Macro VisibleAlls.png +

      +
      import FreeCAD
      +#Macro_VisibleAlls
      +__title__="Macro_DisplayAllObjects"
      +__author__ = "Mario52"
      +__url__     = "http://www.freecadweb.org/index-fr.html"
      +__version__ = "00.00"
      +__date__    = "11/11/2015"
      +
      +try:
      +    for ShapeNameObj in FreeCAD.ActiveDocument.Objects:   # displyed alls objects
      +        #print ShapeNameObj.Name
      +        FreeCADGui.ActiveDocument.getObject(ShapeNameObj.Name).Visibility = True
      +except Exception:
      +    None 
      +

      HideAll

      +

      This macro hides all objects. +

      The code Macro_HideAllObjects the icon Macro HiddenAlls.png +

      +
      import FreeCAD
      +#Macro_HideAllObjects
      +__title__="Macro_HideAllObjects"
      +__author__ = "Mario52"
      +__url__     = "http://www.freecadweb.org/index-fr.html"
      +__version__ = "00.00"
      +__date__    = "11/11/2015"
      +
      +try:
      +    for ShapeNameObj in FreeCAD.ActiveDocument.Objects:   # hidden alls objects
      +        #print ShapeNameObj.Name
      +        FreeCADGui.ActiveDocument.getObject(ShapeNameObj.Name).Visibility = False
      +except Exception:
      +    None 
      +

      SelectedStay

      +

      This macro delete alls object not selected +

      The icon for the tool bar Macro If Selected Stay If Not Then Delete.png +

      +
      import FreeCAD
      +# Macro_If_Selected_Stay_If_Not_Then_Delete
      +__title__="Macro_If_Selected_Stay_If_Not_Then_Delete"
      +__author__ = "Mario52"
      +__url__     = "http://www.freecadweb.org/index-fr.html"
      +__version__ = "00.00"
      +__date__    = "16/06/2016"
      +
      +App = FreeCAD
      +try:
      +    for ShapeNameObj in FreeCAD.ActiveDocument.Objects:
      +        if Gui.Selection.isSelected(ShapeNameObj) == True:
      +            None
      +        else:
      +            App.ActiveDocument.removeObject(ShapeNameObj.Name)        # remove objects not selecteds
      +except Exception:
      +    None 
      +

      Link

      +

      The discussion on the forum Proposal: select one or more pieces, hide the others. +

      +

      Version

      +

      ver 00.02 12/11/2015 macro Macro_SelectVisible : hidden the objects not selected, if not object selected displayed all objects, hidden all objects. This version include the tree macro in one +


      +

      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Macro_Toggle_Visibility2.html b/localwiki/Macro_Toggle_Visibility2.html new file mode 100644 index 0000000..0b8e339 --- /dev/null +++ b/localwiki/Macro_Toggle_Visibility2.html @@ -0,0 +1,141 @@ +Macro Toggle Visibility2

      Macro Toggle Visibility2

      + +
      + + + + + + + + + + + + + + + + + + + + + + + + + + +
      +

      Macro SelectVisible2.png Toggle Visibility

      +
      Description +
      Hidden all objects not selected. +
      Author +
      openfablab +
      Links +
      Macros recipes
      How to install macros
      How to customize toolbars +
      Version +
      00.02b +
      Date last modification +
      2017-07-27 +
      +

      + +
      +


      +

      +

      Description

      +

      This is a set of four related macros for managing the visibility of objects in the Object Model: +

      +
      1. objects that are selected in a document are made visible while objects that are not selected are made invisible +
        • if no objects are selected then all objects are hidden;
        • +
        • if all objects are selected then all objects are made visible
      2. +
      3. make all objects visible
      +

      How To Use

      +

      Copy the macros and the icons in your folder macros and run (see How to install macros) +

      +

      ToggleVisibility

      +

      Using the selection of objects in the one of the FreeCAD views, this macro makes all selected objects visible and hides all objects which are not selected. +

      If no object(s) are selected then all objects are hidden +

      If all objects are hidden and there is no selection in ComboView then all object are made visible +

      The code Macro_ToggleSelectedObjectVisibility2.FCMacro the icon Macro SelectVisible2.png +

      +
      import FreeCAD
      +# Macro_ToggleSelectedObjectVisibility2
      +__title__="Macro_ToggleSelectedObjectVisibility2"
      +__author__ = "openfablab"
      +__url__     = "http://www.freecadweb.org/index-fr.html"
      +__version__ = "00.02b"
      +__date__    = "27/07/2017"
      +FreeCAD.actual=[]
      +try: 
      +    compt = 0
      +    for ShapeNameObj in FreeCAD.ActiveDocument.Objects:                                   # list alls objet for test if alls hidden
      +        if (FreeCADGui.ActiveDocument.getObject(ShapeNameObj.Name).Visibility == False) and (Gui.Selection.isSelected(ShapeNameObj) == False):
      +            compt += 1                                                                    # if hidden : compt += 1
      +            #print "False : ",ShapeNameObj.Name
      +        elif Gui.Selection.isSelected(ShapeNameObj) == False:
      +            FreeCAD.actual.append(ShapeNameObj.Name)
      +            #print "Actual : ",ShapeNameObj.Name
      +    if compt == len(FreeCAD.ActiveDocument.Objects):                                      # if (compt = Alls objects hidden) then Visibility = True
      +        for ShapeNameObj in FreeCAD.ActiveDocument.Objects:
      +            FreeCADGui.ActiveDocument.getObject(ShapeNameObj.Name).Visibility = True      # Visibility = True
      +            #print "True  : ",ShapeNameObj.Name
      +        compt = 0
      +    else :
      +        for ShapeNameObj in FreeCAD.ActiveDocument.Objects:                               # hidde objects not selecteds
      +            if Gui.Selection.isSelected(ShapeNameObj) == False:
      +                FreeCADGui.ActiveDocument.getObject(ShapeNameObj.Name).Visibility = False # if objects is not selected then Visibility = False (Hidden)
      +                #print "False : ",ShapeNameObj.Name
      +            else:
      +                FreeCADGui.ActiveDocument.getObject(ShapeNameObj.Name).Visibility = True  # if objects are hidden and selected then Visibility = True and hidden alls objects visibles
      +                #print "True  : ",ShapeNameObj.Name
      +except Exception:
      +    None 
      +

      DisplayAll

      +

      This macro makes all objects visible respecting the original visible and hidden objects after use the Macro_ToggleSelectedObjectVisibility macro. +

      The code Macro_DisplayAllObjects2 the icon Macro VisibleAlls2.png +

      +
      import FreeCAD
      +#Macro_VisibleAlls
      +__title__="Macro_DisplayAllObjects2"
      +__author__ = "openfablab"
      +__url__     = "http://www.freecadweb.org/index-fr.html"
      +__version__ = "00.00b"
      +__date__    = "27/07/2017"
      +
      +try:
      +    for ShapeNameObj in FreeCAD.actual:   # displyed alls objects
      +        #print ShapeNameObj
      +        FreeCADGui.ActiveDocument.getObject(ShapeNameObj).Visibility = True
      +except Exception:
      +    None 
      +

      Link

      +

      The discussion on the forum Re: Proposal: select one or more pieces, hide the others. +

      Original idea Macro_Toggle_Visibility +

      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Macro_Triangle_AH.html b/localwiki/Macro_Triangle_AH.html new file mode 100644 index 0000000..3713b06 --- /dev/null +++ b/localwiki/Macro_Triangle_AH.html @@ -0,0 +1,133 @@ +Macro Triangle AH

      Macro Triangle AH

      + +
      + + + + + + + + + + + + + + + + + + + + + + + + + + +
      +

      Text-x-python.png Macro Triangle AH

      +
      Description +
      This macro create one triangle creates a triangle by giving the head angle and the height of the triangle. +
      Author +
      mario52 +
      Links +
      Macros recipes
      How to install macros
      How to customize toolbars +
      Version +
      00.02 +
      Date last modification +
      2015-05-03 +
      +

      + +
      +


      +

      +

      Description

      +

      This macro create one isosceles triangle by giving the head angle and the height of the triangle (the triangle of the head is positioned to the xyz coordinates 0.0.0) +

      +

      Use

      +

      Copy the macro Triangle AH complete in the Python console FreeCAD and type: +

      +
      triangleAH(angle=90, height=10)
      +# or
      +triangleAH(90, 10)
      +# or
      +triangleAH(45, hypo=10)
      +# or
      +triangleAH(90, base=10) 
      +

      Script

      +

      Macro_triangleAH.FCMacro +

      +
      __title__   = "triangleAH"
      +__author__  = "Mario52"
      +__version__ = "00.02"
      +__date__    = "03/05/2015"
      +# Give angle and on choice : height or base or hypo
      +from math import cos, sin, tan, degrees, radians, sqrt
      +import Draft, Part
      +def triangleAH(angle, height=0.0, base=0.0, hypo=0.0):
      +    def line_length(x1 = 0.0, y1 = 0.0, z1 = 0.0, length = 10.0, angle2 = 0.0):  # search coordinates
      +        x2 = x1 + (length * cos(radians(angle2)))
      +        y2 = y1 + (length * sin(radians(angle2)))
      +        z2 = z1 #+ ()
      +        return x2,y2,z2                                                          # return coordinates (xyz) to point
      + 
      +    x0 = y0 = z0 = 0.0
      +    angle = float(angle)
      +    height = float(height)
      +    base = float(base)
      +
      +    if base != 0:
      +        height = ( (base/2) / (tan(radians(angle/2))) )                          # imposing base and calculate height
      +    if hypo != 0:
      +        height = hypo * (cos(radians(angle/2)))                                  # imposing hypo and calculate height 
      +    else:
      +        hypo = height / cos(radians(angle/2))                                    # calculate hypotenuse
      +    if base==0:                                                                  # base of triangle
      +        base = (tan(radians(angle/2) ) * height) * 2                             # calculate base
      +
      +    a0 = line_length(x1=x0,y1=y0,z1=z0,length=height,angle2=0 )                  # coord height of triangle
      +    a0 = line_length(x1=x0,y1=y0,z1=z0,length=0, angle2 = angle )                # point 0 (begin vertex)
      +    a  = line_length(x1=a0[0],y1=a0[1],z1=a0[2],length= hypo, angle2=-(angle/2)) #
      +    b  = line_length(a[0],a[1],a[2],length= (abs(a[1])*2), angle2=90.0)          # base of triangle = (abs(a[1])*2)
      +
      +    print "angle theet : ", angle
      +    print "angles base : (", (180-angle)/2,"),(",(180-angle)/2,")"
      +    print "height      : ", height
      +    print "base        : ", base
      +    print "hypotenuse  : ", hypo
      +    print "surface     : ", (base * height) / 2
      +    print "_________________________"
      +    return Draft.makeWire([FreeCAD.Vector(a0),FreeCAD.Vector(a),FreeCAD.Vector(b)],closed=True,face=True,support=None) # create triangle 
      +

      Version

      +

      ver 00.02 03/05/2015 : adding "base=0.0", "hypo=0.0" and print data of triangle +

      ver 00.01 20/03/2015 : +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Macro_TruncateSpring_01.png b/localwiki/Macro_TruncateSpring_01.png new file mode 100644 index 0000000..b94084a Binary files /dev/null and b/localwiki/Macro_TruncateSpring_01.png differ diff --git a/localwiki/Macro_Unbind_Numpad_Shortcuts.html b/localwiki/Macro_Unbind_Numpad_Shortcuts.html new file mode 100644 index 0000000..071ada5 --- /dev/null +++ b/localwiki/Macro_Unbind_Numpad_Shortcuts.html @@ -0,0 +1,85 @@ +Macro Unbind Numpad Shortcuts

      Macro Unbind Numpad Shortcuts

      + +
      + + + + + + + + + + + + + + + + + + + + + + + + + + +
      +

      Text-x-python.png Macro Unbind Numpad Shortcuts

      +
      Description +
      rebinds standard view commands from digit keys to Ctrl+digit, so that they don't spin the view by accident when entering numbers. +
      Author +
      DeepSOIC +
      Links +
      Macros recipes
      How to install macros
      How to customize toolbars +
      Version +
      1.0 +
      Date last modification +
      2018-04-22 +
      +

      + +
      +


      +

      When entering numbers, and the number input box is not properly focused, FreeCAD will react to digits by switching standard views. This macro is a quick way to re-bind the shortcuts to Ctrl+number. Doesn't help very much with entering numbers, but at least the view won't spin like crazy. +

      See forum thread How to turn off (disable) Numpad navigation? +

      +

      How to use:

      +

      1. Copy-paste macro code to Py console of FreeCAD. +

      2. Press enter twice (to make sure everything is executed). +

      3. Restart FreeCAD for the changes to take effect. +

      +
      preset = [
      +    ("Std_ViewAxo"   , "Ctrl+0"),
      +    ("Std_ViewFront" , "Ctrl+1"),
      +    ("Std_ViewTop"   , "Ctrl+2"),
      +    ("Std_ViewRight" , "Ctrl+3"),
      +    ("Std_ViewRear"  , "Ctrl+4"),
      +    ("Std_ViewBottom", "Ctrl+5"),
      +    ("Std_ViewLeft"  , "Ctrl+6"),
      +]
      +for (cmd, shortcut) in preset:
      +    App.ParamGet("User parameter:BaseApp/Preferences/Shortcut").SetString(cmd, shortcut) 
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Macro_Unfold_Box.html b/localwiki/Macro_Unfold_Box.html new file mode 100644 index 0000000..d00e7b4 --- /dev/null +++ b/localwiki/Macro_Unfold_Box.html @@ -0,0 +1,739 @@ +Macro Unfold Box

      Macro Unfold Box

      + +
      + + + + + + + + + + + + + + + + + + + + + + + + + + +
      +

      Text-x-python.png Macro Unfold Box

      +
      Description +
      The macro allows to unfold the surfaces of a box of any shape and to draw them on a page. +
      Author +
      Hervé B. +
      Links +
      Macros recipes
      How to install macros
      How to customize toolbars +
      Version +
      1.0 +
      Date last modification +
      2013-09-20 +
      +

      + +
      +


      +

      The macro allows to unfold the surfaces of a box of any shape and to draw them on a page. +


      +Macro_unfoldBox +

      +

      Installation

      +

      Copy the code file of the macro in the directory : +

      +
      • Linux & Mac  : $home/.Freecad/Mod/unfoldBox.
      • +
      • Windows : C:\Program Files\FreeCAD0.13
      +

      Add templates : A3_Landscape_Empty.svg A3_Landscape.svg A4_Landscape_Empty.svg A4_Landscape.svg
      +Cf Macro for unfolding box surfaces +

      +

      Options

      +
      1. Scale manual or automatic
      2. +
      3. Page format: a3/a4, cartridge (cf FreeCAD templates)
      4. +
      5. Group drawings in the same page as possible.
      6. +
      7. Sew or not the edges of the pieces.
      +

      Instruction for use

      +
      1. Select a box made with Part::Loft tool for example.
      2. +
      3. Explode it (cf Draft menu) into plan pieces
      4. +
      5. Select the surfaces
      6. +
      7. Execute the macro
      +

      Python Code

      +

      Macro_unfoldBox +


      +

      +
      #***************************************************************************
      +#*                                                                         *
      +#*   Copyright (c) 2013 - DoNovae/Herve BAILLY <hbl13@donovae.com>         *
      +#*                                                                         *
      +#*   This program is free software; you can redistribute it and/or modify  *
      +#*   it under the terms of the GNU Lesser General Public License (LGPL)    *
      +#*   as published by the Free Software Foundation; either version 2 of     *
      +#*   the License, or (at your option) any later version.                   *
      +#*   for detail see the LICENCE text file.                                 *
      +#*                                                                         *
      +#*   This program is distributed in the hope that it will be useful,       *
      +#*   but WITHOUT ANY WARRANTY; without even the implied warranty of        *
      +#*   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the         *
      +#*   GNU Library General Public License for more details.                  *
      +#*                                                                         *
      +#*   You should have received a copy of the GNU Library General Public     *
      +#*   License along with this program; if not, write to the Free Software   *
      +#*   Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  *
      +#*   USA                                                                   *
      +#*                                                                         *
      +#***************************************************************************
      +
      +#####################################
      +# Macro unfoldBox
      +#     Unroll of a ruled surface
      +#####################################
      +import FreeCAD , FreeCADGui , Part, Draft, math, Drawing , PySide, os
      +from PySide import QtGui,QtCore
      +from FreeCAD import Base
      +fields_l = [] 
      +unroll_l = [] 
      +
      +#####################################
      +#####################################
      +# Functions 
      +#####################################
      +#####################################
      +
      +#####################################
      +# Function errorDialog 
      +#####################################
      +def errorDialog(msg):
      +    diag = QtGui.QMessageBox(QtGui.QMessageBox.Critical,u"Error Message",msg )
      +    diag.setWindowFlags(PySide.QtCore.Qt.WindowStaysOnTopHint)
      +    diag.exec_()
      +
      +
      +#####################################
      +# Function proceed 
      +#####################################
      +def proceed():
      +   QtGui.qApp.setOverrideCursor(QtCore.Qt.WaitCursor)
      +
      +   FreeCAD.Console.PrintMessage("===========================================\n")
      +   FreeCAD.Console.PrintMessage("unfoldBox: start.\n")
      +   try:
      +      file_name  = fields_l[0].text()
      +      scale    = float(fields_l[1].text())
      +      scale_auto = scale_check.isChecked()
      +      a3 = a3_check.isChecked()
      +      cartridge = cartridge_check.isChecked()
      +      onedrawing = onedrawing_check.isChecked()
      +      sewed = sewed_check.isChecked()
      +      FreeCAD.Console.PrintMessage("unfoldBox.file_name: "+file_name+"\n")
      +      FreeCAD.Console.PrintMessage("unfoldBox.scale: "+str(scale)+"\n")
      +      FreeCAD.Console.PrintMessage("unfoldBox.scale_check: "+str(scale_auto)+"\n")
      +      FreeCAD.Console.PrintMessage("unfoldBox.a3_check: "+str(a3)+"\n")
      +      FreeCAD.Console.PrintMessage("unfoldBox.cartridge: "+str(cartridge)+"\n")
      +      FreeCAD.Console.PrintMessage("unfoldBox.onedrawing: "+str(onedrawing)+"\n")
      +      FreeCAD.Console.PrintMessage("unfoldBox.sewed: "+str(sewed)+"\n")
      +   except:
      +      msg="unfoldBox: wrong inputs...\n"
      +      FreeCAD.Console.PrintError(msg)
      +      errorDialog(msg)
      +
      +   QtGui.qApp.restoreOverrideCursor()
      +   DialogBox.hide()
      +   #
      +   # Get selection
      +   #
      +   sel=FreeCADGui.Selection.getSelection()
      +   faceid=0
      +   objnames_l=[]
      +   tree_l=[]
      +   grp=FreeCAD.activeDocument().addObject("App::DocumentObjectGroup", str(file_name)) 
      +   for objid in range( sel.__len__() ):
      +     obj=Draft.clone(sel[objid])
      +     grp.addObject(obj)
      +     objnames_l.append( [ obj , sel[objid].Name ] )
      +
      +   unfold=unfoldBox()
      +   if sewed : 
      +       objnames_l=unfold.done(objnames_l)
      +       grp.addObject(objnames_l[0][0])
      +   else:
      +       for objid in range( objnames_l.__len__() ):
      +         unfold.moveXY(objnames_l[objid][0])
      +
      +   id=0
      +   while objnames_l.__len__() > 0:
      +       draw=Drawing2d( scale, scale_auto , a3 , cartridge , onedrawing , FreeCAD.activeDocument().Name , "Page"+str(id) ) 
      +       objnames_l=draw.all( objnames_l )
      +       id=id+1
      +       FreeCAD.Console.PrintMessage("unfoldBox: obj_l= "+str(objnames_l.__len__())+"\n")
      +
      +   FreeCAD.Console.PrintMessage("unfoldBox: end.\n")
      +   FreeCAD.Console.PrintMessage("===========================================\n")
      +
      +
      +#####################################
      +# Function close 
      +#####################################
      +def close():
      +   DialogBox.hide()
      +
      +#####################################
      +# Class unfoldBox 
      +#####################################
      +class unfoldBox:
      +  #####################################
      +  # Function __init__ 
      +  #####################################
      +  def __init__(self):
      +     FreeCAD.Console.PrintMessage("unfoldBox.unfoldBox\n")
      +     self.LIMIT=0.0001
      +
      +
      +  #####################################
      +  # Function done 
      +  #####################################
      +  def done(self,objnames_l):
      +       tree_l=self.makeTree(objnames_l)
      +       for id in range( objnames_l.__len__() ): 
      +         face=objnames_l[id]
      +         self.moveXY(face[0])
      +       self.sew( objnames_l , tree_l )
      +       return self.fusion(objnames_l)
      +
      +    
      +  #####################################
      +  # Function makeTree 
      +  #####################################
      +  def makeTree(self,objnames_l):
      +     #
      +     # Initialisation of tree_l
      +     #
      +     tree_l=[]
      +     for k in range( objnames_l.__len__() ):
      +        facek=objnames_l[k][0]
      +facek_l=[]
      +for i in range( facek.Shape.Edges.__len__() ):
      +   if False and type(facek.Shape.Edges[i].Curve).__name__ != 'GeomLineSegment':
      +             facek_l.append([-1,-1])
      +   else:
      +     #
      +     # Search face link to the ith edge
      +     #
      +     vki0=facek.Shape.Edges[i].Curve.StartPoint
      +     vki1=facek.Shape.Edges[i].Curve.EndPoint
      +     found=False
      +     for l in range( k+1 , objnames_l.__len__() ):
      +               facel=objnames_l[l][0]
      +       for j in range( facel.Shape.Edges.__len__() ):
      +            vlj0=facel.Shape.Edges[j].Curve.StartPoint
      +            vlj1=facel.Shape.Edges[j].Curve.EndPoint
      +            if vki0.__eq__(vlj0) and vki1.__eq__(vlj1): 
      +                arelinked=False
      +                isfacek=False
      +                isfacel=False
      +                for kk in range( k-1 ):
      +                   for ii in range( tree_l[kk].__len__() ):
      +              if tree_l[kk][ii][0]==k: isfacek=True
      +              if tree_l[kk][ii][0]==l: isfacel=True
      +           if isfacek and isfacel: 
      +              arelinked=True 
      +              break
      +if not arelinked:
      +                          facek_l.append([l,j])
      +  found=True
      +  break
      +            if found: break
      +   if not found: facek_l.append([-1,-1])
      +        tree_l.append(facek_l) 
      +     return tree_l
      +
      +
      +  #####################################
      +  # Function sew 
      +  #####################################
      +  def sew( self,objnames_l , tree_l ):
      +    placed_l=[]
      +    for k in range( tree_l.__len__() ):
      +      iskplaced=False
      +      for p in range( placed_l.__len__() ):
      +         if placed_l[p] == k:
      +            iskplaced=True 
      +      if not iskplaced:placed_l.append(k)
      +      facek=tree_l[k]
      +      objk=objnames_l[k][0]
      +      for i in range( facek.__len__() ):
      +        edgeki=facek[i]
      +        l=edgeki[0]
      +        j=edgeki[1]
      +islplaced=False
      +for p in range( placed_l.__len__() ):
      +     if placed_l[p] == l: 
      +        islplaced=True 
      +break
      +if not islplaced: placed_l.append(l)
      +        if l >= 0 and not ( islplaced and iskplaced ):
      +  iskplaced=True
      +          #
      +    # Move facel.edgelj to facek.edgeki
      +    #
      +          objl=objnames_l[l][0]
      +          vki0=objk.Shape.Edges[i].Curve.StartPoint
      +          vki1=objk.Shape.Edges[i].Curve.EndPoint
      +  vlj0=objl.Shape.Edges[j].Curve.StartPoint
      +  vlj1=objl.Shape.Edges[j].Curve.EndPoint
      +  vk=vki1.sub(vki0)
      +  vl=vlj1.sub(vlj0)
      +  alpk=vk.getAngle(vl)*180/math.pi
      +  alpl=vl.getAngle(vk)*180/math.pi
      +          self.isPlanZ(objk)
      +  if islplaced:
      +            Draft.move( objk , vlj0.sub(vki0) )
      +  else:
      +            Draft.move( objl , vki0.sub(vlj0) )
      +          self.isPlanZ(objk)
      +
      +  if math.fabs( vk.dot(FreeCAD.Base.Vector(-vl.y,vl.x,0))) > self.LIMIT:
      +     if islplaced:
      +               Draft.rotate( objk , -alpl , vlj0 , self.vecto( vl , vk ))
      +     else:
      +               Draft.rotate( objl , -alpk , vki0 , self.vecto( vk , vl ))
      +  elif vk.dot(vl)<0:
      +     if islplaced:
      +               Draft.rotate( objk , 180 , vlj0 , self.vecto( vl , FreeCAD.Base.Vector(-vl.y,vl.x,0) ))
      +     else:
      +               Draft.rotate( objl , 180 , vki0 , self.vecto( vk , FreeCAD.Base.Vector(-vk.y,vk.x,0)))
      +          #
      +  # Verifications
      +  #
      +          vki0=objk.Shape.Edges[i].Curve.StartPoint
      +          vki1=objk.Shape.Edges[i].Curve.EndPoint
      +  vlj0=objl.Shape.Edges[j].Curve.StartPoint
      +  vlj1=objl.Shape.Edges[j].Curve.EndPoint
      +  vk=vki1.sub(vki0)
      +  vl=vlj1.sub(vlj0)
      +          self.isPlanZ(objk)
      +
      +  #
      +  # Flip or not
      +  #
      +          L=max(objl.Shape.BoundBox.XMax,objk.Shape.BoundBox.XMax) - min( objl.Shape.BoundBox.XMin,objk.Shape.BoundBox.XMin) 
      +          W=max(objl.Shape.BoundBox.YMax,objk.Shape.BoundBox.YMax) - min( objl.Shape.BoundBox.YMin,objk.Shape.BoundBox.YMin) 
      +  S1=L*W
      +  if islplaced:
      +    dum=0
      +            Draft.rotate( objk , 180 , vlj0 ,vl)
      +  else:
      +    dum=0
      +            Draft.rotate( objl , 180 , vki0 ,vk)
      +          L=max(objl.Shape.BoundBox.XMax,objk.Shape.BoundBox.XMax) - min( objl.Shape.BoundBox.XMin,objk.Shape.BoundBox.XMin) 
      +          W=max(objl.Shape.BoundBox.YMax,objk.Shape.BoundBox.YMax) - min( objl.Shape.BoundBox.YMin,objk.Shape.BoundBox.YMin) 
      +  S2=L*W
      +  if (S2<=S1):
      +     if islplaced:
      +        dum=0
      +                Draft.rotate( objk , 180 , vlj0 ,vl)
      +     else:
      +        dum=0
      +                Draft.rotate( objl , 180 , vki0 ,vk)
      +          self.isPlanZ(objk)
      +
      +  #####################################
      +  # Function isPlanZ 
      +  #####################################
      +  def isPlanZ(self,obj):
      +     L=obj.Shape.BoundBox.XMax - obj.Shape.BoundBox.XMin
      +     W=obj.Shape.BoundBox.YMax - obj.Shape.BoundBox.YMin
      +     H=obj.Shape.BoundBox.ZMax - obj.Shape.BoundBox.ZMin
      +     if H < self.LIMIT:
      +       return True
      +     else:
      +       return False
      +
      +
      +  #####################################
      +  # Function fusion 
      +  #####################################
      +  def fusion(self,objnames_l):
      +     #
      +     # Init
      +     #
      +     obj_l=[]
      +     objna_l=[]
      +     obj0=objnames_l[0][0];name=objnames_l[0][1]
      +     objfuse=FreeCAD.activeDocument().addObject("Part::MultiFuse","Unfolding")
      +     for k in range( objnames_l.__len__() ):
      +       objk=objnames_l[k][0]
      +       obj_l.append(objk)
      +     objfuse.Shapes=obj_l
      +     FreeCAD.activeDocument().recompute()
      +     objna_l.append([objfuse,name])
      +     return objna_l 
      +
      +  #####################################
      +  # Function get2Vectors 
      +  #####################################
      +  def get2Vectors(self,shape):
      +    v0=FreeCAD.Base.Vector(0,0,0) 
      +    v1=FreeCAD.Base.Vector(0,0,0) 
      +
      +    edges= shape.Edges
      +    for id in range( edges.__len__()-1):
      +       va=edges[id].Curve.EndPoint.sub(edges[id].Curve.StartPoint)
      +       vb=edges[id+1].Curve.EndPoint.sub(edges[id+1].Curve.StartPoint)
      +       if vb.sub(va).Length > v1.sub(v0).Length:
      +         v0=self.vect_copy(va);v1=self.vect_copy(vb)
      +    #FreeCAD.Console.PrintMessage("unfoldBox.get2Vectors: v0= {:s}, v1= {:s}\n".format(str(v0),str(v1)))
      +    return [ v0 , v1 ]
      +
      +  #####################################
      +  # Function vecto 
      +  #   - vect1,2:  
      +  #   - return abs(sin) angle between 
      +  #     2 vectors 
      +  #####################################
      +  def vecto( self,vect1, vect2 ):
      +     v= FreeCAD.Base.Vector(0,0,0)
      +     v.x=vect1.y*vect2.z-vect1.z*vect2.y
      +     v.y=vect1.z*vect2.x-vect1.x*vect2.z
      +     v.z=vect1.x*vect2.y-vect1.y*vect2.x
      +     return v 
      +
      +
      +  #####################################
      +  # Function vect_copy 
      +  #   - vect:  
      +  #   - return copy of vector
      +  #####################################
      +  def vect_copy( self,vect):
      +     v= vect.add( FreeCAD.Base.Vector(0,0,0) )
      +     return v 
      +
      +
      +  #####################################
      +  # Function movexy 
      +  #####################################
      +  def moveXY( self,obj ):
      +     #
      +     # Move to origin
      +     #
      +     Draft.move( obj , FreeCAD.Base.Vector( -obj.Shape.BoundBox.XMin , -obj.Shape.BoundBox.YMin , -obj.Shape.BoundBox.ZMin ))
      +     #
      +     # Find 2 vectors defining the plan of surface
      +     #
      +     tab=self.get2Vectors( obj.Shape )
      +     v0=tab[0];v1=tab[1]
      +     norm=self.vecto(v0,v1)
      +     norm.normalize()
      +     #FreeCAD.Console.PrintMessage("unfoldBox.moveXY: norm= {:s}\n".format(str(norm)))
      +
      +     #
      +     # Rotate
      +     #
      +     if math.fabs(norm.x) < self.LIMIT and math.fabs(norm.y) < self.LIMIT:
      +        dum=0
      +     elif math.fabs(norm.x) < self.LIMIT and math.fabs(norm.z) < self.LIMIT:
      +        Draft.rotate( obj , 90 , FreeCAD.Base.Vector(0,0,0) , FreeCAD.Base.Vector(1,0,0) )
      +     elif math.fabs(norm.y) < self.LIMIT and math.fabs(norm.z) < self.LIMIT:
      +        Draft.rotate( obj , 90 , FreeCAD.Base.Vector(0,0,0) , FreeCAD.Base.Vector(0,1,0) )
      +     else:
      +#
      +# Rotate following the angle to the normal direction of the plan
      +#
      +        oz= FreeCAD.Base.Vector(0,0,1)
      +alp=oz.getAngle(norm)*180/math.pi
      +        #FreeCAD.Console.PrintMessage("unfoldBox.moveXY: alp= "+str(alp)+"\n")
      +        #FreeCAD.Console.PrintMessage("unfoldBox.moveXY: vecto= {:s}\n".format(str(self.vecto(oz,norm))))
      +        Draft.rotate( obj , -alp , FreeCAD.Base.Vector(0,0,0) , self.vecto( oz, norm ))
      +     #
      +     # Move to z=0
      +     #
      +     Draft.move( obj , FreeCAD.Base.Vector( 0 , 0 , -obj.Shape.BoundBox.ZMin ))
      +     L=obj.Shape.BoundBox.XMax - obj.Shape.BoundBox.XMin
      +     W=obj.Shape.BoundBox.YMax - obj.Shape.BoundBox.YMin
      +     H=obj.Shape.BoundBox.ZMax - obj.Shape.BoundBox.ZMin
      +
      +
      +#####################################
      +# Class Drawing2d 
      +#####################################
      +class Drawing2d:
      +  #####################################
      +  # Function __init__ 
      +  #     - Scale
      +  #     - scale_auto
      +  #     - a3
      +  #     - cartridge
      +  #     - onedrawing
      +  #####################################
      +  def __init__( self,  scale , scale_auto , a3 , cartridge , onedrawing , drawing_name , page_name ):
      +    self.TopX_H=0
      +    self.TopY_H=0
      +    self.TopX_V=0
      +    self.TopY_V=0
      +    self.TopX_Hmax=0
      +    self.TopY_Hmax=0
      +    self.TopX_Vmax=0
      +    self.TopY_Vmax=0
      +    self.a3=a3
      +    self.pts_nbr=100
      +    self.scale=scale
      +    self.scale_auto=scale_auto
      +    self.cartridge=cartridge
      +    self.onedrawing=onedrawing
      +    if self.a3:
      +      self.L=420
      +      self.H=297
      +      self.marge=6
      +    else:
      +      self.L=297
      +      self.H=210
      +      self.marge=6
      +    self.page_name=page_name
      +    self.drawing_name=drawing_name
      +
      +  #####################################
      +  # Function newPage 
      +  #####################################
      +  def newPage( self ):
      +    freecad_dir=os.getenv('HOME')+"/.FreeCAD/Mod/unfoldBox"
      +    page = FreeCAD.activeDocument().addObject('Drawing::FeaturePage', self.page_name )
      +    if self.a3:
      +        if self.cartridge:
      +           page.Template = freecad_dir+'/A3_Landscape.svg'   
      +        else:
      +           page.Template = freecad_dir+'/A3_Landscape_Empty.svg'   
      +    else:
      +        if self.cartridge:
      +           page.Template = freecad_dir+'/A4_Landscape.svg'   
      +        else:
      +           page.Template = freecad_dir+'/A4_Landscape_Empty.svg'   
      +    return page
      +
      +  #####################################
      +  # Function all 
      +  #####################################
      +  def all( self, objnames_l ):
      +      obj_l=[]
      +      for objid in range( objnames_l.__len__() ):
      +        if objid == 0 or not self.onedrawing:
      +          page = self.newPage()
      +        obj_l.extend( self.done( objid , objnames_l[objid] ))
      +      return obj_l 
      +
      +
      +
      +
      +  #####################################
      +  # Function done 
      +  #####################################
      +  def done( self, id , objname ):
      +    #
      +    # Init
      +    #
      +    obj_l=[]
      +    obj=objname[0]
      +    objname=objname[1]
      +    xmax=obj.Shape.BoundBox.XMax-obj.Shape.BoundBox.XMin
      +    ymax=obj.Shape.BoundBox.YMax-obj.Shape.BoundBox.YMin
      +    if ymax > xmax :
      +      Draft.rotate( obj , 90 )
      +    Draft.move( obj , FreeCAD.Base.Vector( -obj.Shape.BoundBox.XMin , -obj.Shape.BoundBox.YMin , 0))
      +    xmax=obj.Shape.BoundBox.XMax-obj.Shape.BoundBox.XMin
      +    ymax=obj.Shape.BoundBox.YMax-obj.Shape.BoundBox.YMin
      +
      +    scale=min((self.L-4*self.marge)/xmax,(self.H-4*self.marge)/ymax)
      +
      +    if ( not self.scale_auto ) or ( self.onedrawing ) :
      +       scale=self.scale
      +
      +
      +    if id == 0 or not self.onedrawing:
      +      #
      +      # Init
      +      #
      +      FreeCAD.Console.PrintMessage("Dawing2d: init\n")
      +      self.TopX_H=self.marge*2
      +      self.TopY_H=self.marge*2
      +      TopX=self.TopX_H
      +      TopY=self.TopY_H
      +      self.TopX_H=self.TopX_H + xmax * scale + self.marge
      +      self.TopY_H=self.TopY_H 
      +      self.TopX_Hmax=max( self.TopX_Hmax , self.TopX_H )
      +      self.TopY_Hmax=max( self.TopY_Hmax , self.TopY_H + ymax*scale+self.marge )
      +      self.TopX_Vmax=max( self.TopX_Vmax , self.TopX_Hmax )
      +      self.TopX_V=max(self.TopX_Vmax,self.TopX_V)
      +      self.TopY_V=self.marge*2
      +    elif self.onedrawing:
      +      if self.TopX_H + xmax * scale < self.L :
      +        if self.TopY_H + ymax * scale + self.marge*2 < self.H :
      +   #
      +   # H Add at right on same horizontal line
      +   #
      +           FreeCAD.Console.PrintMessage("Dawing2d: horizontal\n")
      +           TopX=self.TopX_H
      +           TopY=self.TopY_H
      +           self.TopX_H=self.TopX_H + xmax * scale + self.marge
      +   self.TopX_Hmax=max( self.TopX_Hmax , self.TopX_H )
      +   self.TopY_Hmax=max( self.TopY_Hmax , self.TopY_H + ymax*scale+self.marge )
      +   self.TopX_Vmax=max( self.TopX_Hmax , self.TopX_Vmax )
      +           self.TopX_Vmax=max( self.TopX_Vmax , self.TopX_Hmax  )
      +           self.TopX_V=max(self.TopX_Vmax,self.TopX_V)
      +else:
      +   #
      +   # V Add at right on same horizontal line
      +   #
      +           FreeCAD.Console.PrintMessage("Dawing2d: vertival\n")
      +           if self.TopX_V + ymax * scale +2* self.marge < self.L and self.TopY_V + xmax * scale + 2*self.marge < self.H :
      +             Draft.rotate( obj , 90 )
      +     Draft.move( obj , FreeCAD.Base.Vector( -obj.BoundBox.XMin , -obj.BoundBox.YMin , 0))
      +             self.TopX_V=max(self.TopX_Vmax, self.TopX_V)
      +             TopX=self.TopX_V
      +             TopY=self.TopY_V
      +     self.TopX_V = self.TopX_V + ymax * scale + self.marge
      +     self.TopY_Vmax=max( self.TopY_Vmax , self.TopY_V + xmax * scale + self.marge )
      +   else:
      +     obj_l.append( [ obj , name ] )
      +     return obj_l
      +
      +      else:
      +#
      +# H Carriage return 
      +#
      +        if ( self.TopY_Hmax + ymax * scale + self.marge*2 < self.H ):   
      +           FreeCAD.Console.PrintMessage("Dawing2d: carriage return: "+str(self.TopY_H + ymax * scale )+" > "+str(self.H)+"\n")
      +           TopX=self.marge*2
      +           TopY=self.TopY_Hmax
      +           self.TopX_H=TopX + xmax * scale + self.marge
      +           self.TopY_H=TopY 
      +   self.TopX_Hmax=max( self.TopX_Hmax , self.TopX_H )
      +   self.TopY_Hmax=self.TopY_Hmax + ymax*scale+self.marge
      +           self.TopX_Vmax=max( self.TopX_Vmax , self.TopX_Hmax )
      +           self.TopX_V=max(self.TopX_Vmax,self.TopX_V)
      +else:
      +   #
      +   # V Add at right on same horizontal line
      +   #
      +           FreeCAD.Console.PrintMessage("Dawing2d: vertival: "+str(self.TopX_V)+" , "+str(self.TopX_Vmax)+"\n")
      +           if self.TopX_V + ymax * scale + 2*self.marge < self.L and self.TopY_V + xmax * scale + 2*self.marge < self.H :
      +             Draft.rotate( obj , 90 )
      +     Draft.move( obj , FreeCAD.Base.Vector( -obj.BoundBox.XMin , -obj.BoundBox.YMin , 0))
      +             TopX=self.TopX_V
      +             TopY=self.TopY_V
      +     self.TopX_V = self.TopX_V + ymax * scale + self.marge
      +     self.TopY_Vmax=max( self.TopY_Vmax , self.TopY_V + xmax * scale + self.marge )
      +   else:
      +     obj_l.append( [ obj , name ] )
      +     return obj_l
      +
      +    page=FreeCAD.activeDocument().getObject(self.page_name )
      +
      +    Text=FreeCAD.activeDocument().addObject('Drawing::FeatureViewAnnotation', objname+"_txt")
      +    Text.Text=objname
      +    Text.X=TopX+xmax/2*scale
      +    Text.Y=TopY+ymax/2*scale
      +    Text.Scale=1
      +
      +    TopView = FreeCAD.activeDocument().addObject('Drawing::FeatureViewPart','TopView')
      +    TopView.Source = obj
      +    TopView.Direction = (0.0,0.0,1)
      +    TopView.Rotation = 0 
      +    TopView.X = TopX 
      +    TopView.Y = TopY 
      +    TopView.ShowHiddenLines = True
      +    TopView.Scale = scale 
      +    page.addObject(TopView)
      +    page.addObject(Text)
      +    FreeCAD.activeDocument().recompute()
      +    return obj_l
      +
      +
      +
      +
      +#####################################
      +#####################################
      +# Dialog Box 
      +#####################################
      +#####################################
      +fields = [[ "Group Name" , "Unfolding" ]]
      +fields.append(["Scale","1" ])
      +
      +DialogBox = QtGui.QDialog()
      +DialogBox.resize(250,250)
      +DialogBox.setWindowTitle("unfoldBox")
      +la = QtGui.QVBoxLayout(DialogBox)
      +
      +#
      +# Input fields
      +#
      +for id in range(len( fields )):
      +  la.addWidget(QtGui.QLabel( fields[ id ][ 0 ] ))
      +  fields_l.append( QtGui.QLineEdit( fields[ id ][ 1 ] ))
      +  la.addWidget( fields_l[ id ] )
      +
      +scale_check = QtGui.QCheckBox( DialogBox )
      +scale_check.setObjectName("checkBox")
      +scale_check.setChecked(True)
      +la.addWidget(QtGui.QLabel("Scale auto"))
      +la.addWidget(scale_check)
      +
      +a3_check = QtGui.QCheckBox( DialogBox )
      +a3_check.setObjectName("checkBox")
      +la.addWidget(QtGui.QLabel("A3 Format"))
      +a3_check.setChecked(False)
      +la.addWidget(a3_check)
      +
      +cartridge_check = QtGui.QCheckBox( DialogBox )
      +cartridge_check.setObjectName("checkBox")
      +la.addWidget(QtGui.QLabel("Cartridge"))
      +cartridge_check.setChecked(False)
      +la.addWidget(cartridge_check)
      +
      +onedrawing_check = QtGui.QCheckBox( DialogBox )
      +onedrawing_check.setObjectName("checkBox")
      +la.addWidget(QtGui.QLabel("Group drawings in page"))
      +onedrawing_check.setChecked(True)
      +la.addWidget(onedrawing_check)
      +
      +sewed_check = QtGui.QCheckBox( DialogBox )
      +sewed_check.setObjectName("checkBox")
      +la.addWidget(QtGui.QLabel("Sewed surfaces"))
      +sewed_check.setChecked(True)
      +la.addWidget(sewed_check)
      +
      +box = QtGui.QDialogButtonBox(DialogBox)
      +
      +box = QtGui.QDialogButtonBox(DialogBox)
      +box.setOrientation(QtCore.Qt.Horizontal)
      +box.setStandardButtons(QtGui.QDialogButtonBox.Cancel 
      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Macro_Unroll_Ruled_Surface.html b/localwiki/Macro_Unroll_Ruled_Surface.html new file mode 100644 index 0000000..6a673e9 --- /dev/null +++ b/localwiki/Macro_Unroll_Ruled_Surface.html @@ -0,0 +1,782 @@ +Macro Unroll Ruled Surface

      Macro Unroll Ruled Surface

      + +
      + + + + + + + + + + + + + + + + + + + + + + + + + + +
      +

      Text-x-python.png Macro Unroll Ruled Surface

      +
      Description +
      The macro allows to unroll ruled surfaces and to draw them on a page. +
      Author +
      Hervé B. +
      Links +
      Macros recipes
      How to install macros
      How to customize toolbars +
      Version +
      1.0 +
      Date last modification +
      2013-09-14 +
      +

      + +
      +


      +

      The macro allows to unroll ruled surfaces and to draw them on a page. +


      +Macro_unrollRuledSurface +

      +

      Installation

      +

      Copy the code file of the macro in the directory : +

      +
      • Linux & Mac  : $home/.Freecad/Mod/UnrollRuledSurface.
      • +
      • Windows : C:\Program Files\FreeCAD0.13
      +

      Add templates : A3_Landscape_Empty.svg A3_Landscape.svg A4_Landscape_Empty.svg A4_Landscape.svg
      +Cf Macro for unrolling ruled surfaces +

      +

      Options

      +
      • Number of generatrix
      • +
      • Scale manual or automatic
      • +
      • Page format: a3/a4, cartridge (cf FreeCAD templates)
      • +
      • Group drawings in the same page as possible.
      +

      Macro_unrollRuledSurface +

      +

      Instruction for use

      +
      1. Select ruled surfaces
      2. +
      3. Explode them (cf Draft menu)
      4. +
      5. Select the surfaces
      6. +
      7. Execute the macro
      +

      Python Code

      +

      Macro_unrollRuledSurface.py +


      +

      +
      #***************************************************************************
      +#*                                                                         *
      +#*   Copyright (c) 2013 - DoNovae/Herve BAILLY <hbl13@donovae.com>           *
      +#*                                                                         *
      +#*   This program is free software; you can redistribute it and/or modify  *
      +#*   it under the terms of the GNU Lesser General Public License (LGPL)    *
      +#*   as published by the Free Software Foundation; either version 2 of     *
      +#*   the License, or (at your option) any later version.                   *
      +#*   for detail see the LICENCE text file.                                 *
      +#*                                                                         *
      +#*   This program is distributed in the hope that it will be useful,       *
      +#*   but WITHOUT ANY WARRANTY; without even the implied warranty of        *
      +#*   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the         *
      +#*   GNU Library General Public License for more details.                  *
      +#*                                                                         *
      +#*   You should have received a copy of the GNU Library General Public     *
      +#*   License along with this program; if not, write to the Free Software   *
      +#*   Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  *
      +#*   USA                                                                   *
      +#*                                                                         *
      +#***************************************************************************
      +
      +#####################################
      +# Macro UnrollRuledSurface
      +#     Unroll of a ruled surface
      +#####################################
      +import FreeCAD , FreeCADGui , Part, Draft, math, Drawing , PySide, os
      +from PySide import QtGui,QtCore
      +from FreeCAD import Base
      +#from unrollRuledSurface.unfoldBox import unfoldBoxClass # commented 06/08/2015 give error "No module named unrollRuledSurface.unfoldBox"
      +fields_l = [] 
      +unroll_l = [] 
      +
      +
      +#####################################
      +#####################################
      +# Functions 
      +#####################################
      +#####################################
      +
      +#####################################
      +# Function errorDialog 
      +#####################################
      +def errorDialog(msg):
      +    diag = QtGui.QMessageBox(QtGui.QMessageBox.Critical,u"Error Message",msg )
      +    diag.setWindowFlags(PySide.QtCore.Qt.WindowStaysOnTopHint)
      +    diag.exec_()
      +
      +
      +#####################################
      +# Function proceed 
      +#####################################
      +def proceed():
      +   QtGui.qApp.setOverrideCursor(QtCore.Qt.WaitCursor)
      +
      +   FreeCAD.Console.PrintMessage("===========================================\n")
      +   FreeCAD.Console.PrintMessage("UnrollRuledSurface: start.\n")
      +   try:
      +      file_name  = fields_l[0].text()
      +      pts_nbr    = float(fields_l[1].text())
      +      scale    = float(fields_l[2].text())
      +      scale_auto = scale_check.isChecked()
      +      edge0 = edge0_check.isChecked()
      +      a3 = a3_check.isChecked()
      +      cartridge = cartridge_check.isChecked()
      +      onedrawing = onedrawing_check.isChecked()
      +      FreeCAD.Console.PrintMessage("UnrollRuledSurface.file_name: "+file_name+"\n")
      +      FreeCAD.Console.PrintMessage("UnrollRuledSurface.pts_nbr: "+str(pts_nbr)+"\n")
      +      FreeCAD.Console.PrintMessage("UnrollRuledSurface.scale: "+str(scale)+"\n")
      +      FreeCAD.Console.PrintMessage("UnrollRuledSurface.scale_check: "+str(scale_auto)+"\n")
      +      FreeCAD.Console.PrintMessage("UnrollRuledSurface.edge0_check: "+str(edge0)+"")
      +      FreeCAD.Console.PrintMessage("UnrollRuledSurface.a3_check: "+str(a3)+"\n")
      +      FreeCAD.Console.PrintMessage("UnrollRuledSurface.cartridge: "+str(cartridge)+"\n")
      +      FreeCAD.Console.PrintMessage("UnrollRuledSurface.onedrawing: "+str(onedrawing)+"\n")
      +   except:
      +      msg="UnrollRuledSurface: wrong inputs...\n"
      +      FreeCAD.Console.PrintError(msg)
      +      errorDialog(msg)
      +
      +   QtGui.qApp.restoreOverrideCursor()
      +   DialogBox.hide()
      +   unrollRS=unrollRuledSurface( file_name , pts_nbr , edge0 )
      +   #
      +   # Get selection
      +   #
      +   sel=FreeCADGui.Selection.getSelection()
      +   faceid=0
      +   objnames_l=[]
      +   objnames0_l=[]
      +   grp=FreeCAD.activeDocument().addObject("App::DocumentObjectGroup", str(file_name)+"_objs") 
      +   for objid in range( sel.__len__() ):
      +     shape=sel[objid].Shape
      +     faces=shape.Faces
      +     for id in range( faces.__len__() ):
      +        FreeCAD.Console.PrintMessage("UnrollRuledSurface.proceed: ObjId= "+str(objid)+" , faceId= "+str( faceid )+"\n")
      +if faces.__len__() > 1:
      +  name=sel[objid].Name+".faces "+str(id)
      +else:
      +  name=sel[objid].Name
      +        obj=unrollRS.unroll(faces[id],name) 
      +        obj.ViewObject.Visibility=False
      +        grp.addObject(obj)
      +objnames_l.append( [ obj , name ] )
      +objnames0_l.append( [ sel[objid] , name ] )
      +        faceid=faceid+1
      +   id=0
      +   while objnames_l.__len__() > 0:
      +     draw=Drawing2d( scale, scale_auto , a3 , cartridge , onedrawing,str(file_name)+"_page"+str(id) ) 
      +     objnames_l=draw.all( objnames_l )
      +     id=id+1
      +     FreeCAD.Console.PrintMessage("UnrollRuledSurface: obj_l= "+str(objnames_l.__len__())+"\n")
      +
      +   FreeCAD.Console.PrintMessage("UnrollRuledSurface: end.\n")
      +   FreeCAD.Console.PrintMessage("===========================================\n")
      +
      +#####################################
      +# Function close 
      +#####################################
      +def close():
      +   DialogBox.hide()
      +
      +#####################################
      +# Class unrollRuledSurface 
      +#     - file_name : ouput file 
      +#     - pts_nbr : nbr point of 
      +#       discretization
      +#####################################
      +class unrollRuledSurface:
      +  def __init__( self, file_name, pts_nbr , edge0 ):
      +    self.doc = FreeCAD.activeDocument()
      +    self.file_name = file_name
      +    self.pts_nbr = int(pts_nbr)
      +    self.edge0 = edge0
      +    FreeCAD.Console.PrintMessage("UnrollRuledSurface.unroll - file_name: "+self.file_name+" , pts_nbr: "+str(self.pts_nbr)+"\n")
      +
      +
      +  #####################################
      +  # Function discretize 
      +  #####################################
      +  def discretize(self,curve):
      +         if type(curve).__name__=='GeomLineSegment':
      +            sd=curve.discretize( self.pts_nbr )
      +         elif type(curve).__name__=='GeomBSplineCurve':
      +            nodes=curve.getPoles()
      +            spline=Part.BSplineCurve()
      +            spline.buildFromPoles( nodes )
      +            sd=spline.discretize( self.pts_nbr )
      +         elif type(curve).__name__=='GeomCircle':
      +            sd=curve.discretize( self.pts_nbr )
      + else:
      +            sd=curve.discretize( self.pts_nbr )
      +         return sd 
      +
      +  #####################################
      +  # Function nbpoles 
      +  #####################################
      +  def nbpoles(self,curve):
      +       if type(curve).__name__=='GeomLineSegment':
      +         nbpol=1
      +       elif type(curve).__name__=='GeomBSplineCurve':
      +         nbpol=curve.NbPoles
      +       elif type(curve).__name__=='GeomCircle':
      +         nbpol=2
      +       elif type(curve).__name__=='GeomBezierCurve':
      +         nbpol=4
      +       else:
      +         nbpol=0
      +       FreeCAD.Console.PrintMessage("UnrollRulrdSurface.nbpole {:s} = {:d}\n".format(type(curve).__name__,nbpol))
      +       return nbpol
      +
      +  #####################################
      +  # Function unroll 
      +  #####################################
      +  # Unroll of a face 
      +  # composed of 2 or 4 edges
      +  #####################################
      +  def unroll(self,face,name):
      +    FreeCAD.Console.PrintMessage("UnrollRuledSurface.unroll: Ege Nbr= "+str( face.Edges.__len__())+"\n")
      +    if face.Edges.__len__() == 2: 
      +       e1=face.Edges[0]
      +       e2=face.Edges[1]
      +       sd1=e1.Curve.discretize( self.pts_nbr )
      +       sd2=e2.Curve.discretize( self.pts_nbr )
      +    elif face.Edges.__len__() == 3:
      +       e1=face.Edges[0]
      +       e2=face.Edges[2]
      +       sd1=e1.Curve.discretize( self.pts_nbr )
      +       sd2=e2.Curve.discretize( self.pts_nbr )
      +    else:
      +       E0=face.Edges[0]
      +       E1=face.Edges[1]
      +       E2=face.Edges[2]
      +       E3=face.Edges[3]
      +       #
      +       # Choose more complexe curve as edge
      +       #
      +       nbpol0=self.nbpoles(E0.Curve)
      +       nbpol1=self.nbpoles(E1.Curve)
      +       nbpol2=self.nbpoles(E2.Curve)
      +       nbpol3=self.nbpoles(E3.Curve)
      +       FreeCAD.Console.PrintMessage("UnrollRuledSurface.unroll: nbpol0= {:d}, nbpol1= {:d}, nbpol2= {:d}, nbpol3= {:d}\n".format(nbpol0,nbpol1,nbpol2,nbpol3))
      +
      +       if self.edge0:
      +         e1=E0
      +         e2=E2
      +         v=self.discretize( E1 )
      + v0=v[0]
      + v1=v[self.pts_nbr-1]
      +       else:
      +         e1=E1
      +         e2=E3
      +         v=self.discretize( E2 )
      + v0=v[0]
      + v1=v[self.pts_nbr-1]
      +
      +       sd1=self.discretize( e1 )
      +       sd2=self.discretize( e2 )
      +       #
      +       # Reverse if curves cross over
      +       #
      +       if not ( sd2[0].__eq__( v0 ) or not sd2[0].__eq__( v1 ) ):
      +          sd2.reverse()
      +
      +    #
      +    # Create a polygon object and set its nodes 
      +    #
      +    devlxy_l=self.devlxyz( sd1 , sd2 )
      +    FreeCAD.Console.PrintMessage("UnrollRuledSurface.unroll: size devlxy_l: "+str( devlxy_l.__len__())+"\n")
      +    p=self.doc.addObject("Part::Polygon",name) 
      +    p.Nodes=devlxy_l
      +    self.doc.recompute()
      +    FreeCADGui.SendMsgToActiveView("ViewFit")
      +    return p
      +
      +  #####################################
      +  # Function vect_copy 
      +  #   - vect:  
      +  #   - return copy of vector
      +  #####################################
      +  def vect_copy( self, vect):
      +     v= vect.add( FreeCAD.Base.Vector(0,0,0) )
      +     return v 
      +
      +  #####################################
      +  # Function vect_cos 
      +  #   - vect1,2:  
      +  #   - return cos angle between 
      +  #     2 vectors 
      +  #####################################
      +  def vect_cos( self , vect1, vect2 ):
      +     cosalp=vect1.dot(vect2)/vect1.Length/vect2.Length
      +     return cosalp
      +  
      +  #####################################
      +  # Function vect_sin 
      +  #   - vect1,2:  
      +  #   - return abs(sin) angle between 
      +  #     2 vectors 
      +  #####################################
      +  def vect_sin( self , vect1, vect2 ):
      +     v= FreeCAD.Base.Vector(0,0,0)
      +     v.x=vect1.y*vect2.z-vect1.z*vect2.y
      +     v.y=vect1.z*vect2.x-vect1.x*vect2.z
      +     v.z=vect1.x*vect2.y-vect1.y*vect2.x
      +     sinalp=v.Length/vect1.Length/vect2.Length
      +     return sinalp
      +
      +  
      +  #####################################
      +  # Function devlxyz 
      +  #    - vect1,2: 2 edges of the shape
      +  #    - return dvlxy_l
      +  #####################################
      +  # unroll of a face 
      +  # composed of 4 edges
      +  #####################################
      +  def devlxyz( self , vect1 , vect2 ):
      +    #
      +    # Init
      +    #
      +    if ( vect1.__len__() != vect2.__len__()) or  ( vect1.__len__() != self.pts_nbr ) or ( vect2.__len__() != self.pts_nbr ):
      +        msg="UnrollRuledSurface.devlxyz: incompatility of sizes vect1 , vect2, pts_nbr- "+str( vect1.__len__())+" , "+str( vect2.__len__())+" , "+str( self.pts_nbr )+"\n"
      +        FreeCAD.Console.PrintError(msg)
      +        errorDialog(msg)
      +
      +    devlxy_l=[]
      +    devl1xy_l=[]
      +    devl2xy_l=[]
      +    errormax=0.0
      +    #
      +    # Init unroll
      +    # AB
      +    #
      +    a1b1=vect2[0].sub(vect1[0])
      +    oa1=FreeCAD.Vector(0,0,0)
      +    devl1xy_l.append( oa1 ) #A1
      +    ob1=FreeCAD.Vector(a1b1.Length,0,0)
      +    devl2xy_l.append( ob1 ) #B1
      +    #self.draw_line( devl1xy_l[0] , devl2xy_l[0] )
      +    #self.draw_line( vect1[0] , vect2[0] )
      +    for j in range( 1 , self.pts_nbr ) : 
      +      #
      +      # AB
      +      #
      +      ab=vect2[j-1].sub(vect1[j-1])
      +      #self.draw_line( vect1[j-1] , vect2[j-1] )
      +      #
      +      # AC
      +      #
      +      ac=vect1[j].sub(vect1[j-1])
      +      #
      +      # BD
      +      #
      +      bd=vect2[j].sub(vect2[j-1])
      +      #
      +      # CD 
      +      #
      +      cd=vect2[j].sub(vect1[j])
      +      #
      +      # A1B1 in unroll plan
      +      #
      +      a1b1=devl2xy_l[j-1].sub(devl1xy_l[j-1])
      +      a1b1n=self.vect_copy(a1b1)
      +      a1b1n.normalize()
      +      a1b1on=FreeCAD.Vector(-a1b1n.y,a1b1n.x,0)
      +      #
      +      # A1C1
      +      #
      +      cosalp=self.vect_cos( ab , ac )
      +      sinalp=self.vect_sin( ab , ac )
      +      a1c1=self.vect_copy(a1b1n)
      +      a1c1.multiply(cosalp*ac.Length)
      +      v=self.vect_copy(a1b1on)
      +      v.multiply(sinalp*ac.Length)
      +      a1c1=a1c1.add(v)
      +      #FreeCAD.Console.PrintMessage("UnrollRuledSurface.alp a1b1: "+str(a1b1n.getAngle(a1b1on))+"\n")
      +      #FreeCAD.Console.PrintMessage("UnrollRuledSurface.alp oc1: "+str(a1b1n.getAngle(a1c1)-alp)+"\n")
      +      #FreeCAD.Console.PrintMessage("UnrollRuledSurface.length oc1: "+str(a1c1.Length-ac.Length)+"\n")
      +      oa1=self.vect_copy(devl1xy_l[j-1])
      +      oc1=oa1.add(a1c1)
      +      devl1xy_l.append(oc1)
      +      #
      +      # B1D1
      +      #
      +      cosalp=self.vect_cos( ab , bd )
      +      sinalp=self.vect_sin( ab , bd )
      +      b1d1=self.vect_copy(a1b1n)
      +      b1d1.multiply(cosalp*bd.Length)
      +      v=self.vect_copy(a1b1on)
      +      v.multiply(sinalp*bd.Length)
      +      b1d1=b1d1.add(v)
      +      #FreeCAD.Console.PrintMessage("UnrollRuledSurface.alp od1: "+str(b1a1n.getAngle(b1d1)-alp)+"\n")
      +      #FreeCAD.Console.PrintMessage("UnrollRuledSurface.length od1: "+str(b1d1.Length-bd.Length)+"\n")
      +      ob1=self.vect_copy(devl2xy_l[j-1])
      +      od1=ob1.add(b1d1)
      +      devl2xy_l.append(od1)
      +      #
      +      # Draw generatrice
      +      #
      +      #self.draw_line( devl1xy_l[j] , devl2xy_l[j] )
      +      c1d1=devl2xy_l[j].sub( devl1xy_l[j] )
      +      if ab.Length <> 0 :
      +         errormax=max(errormax,math.fabs(ab.Length-c1d1.Length)/ab.Length)
      +    #
      +    # The end
      +    #
      +    FreeCAD.Console.PrintMessage("UnrollRuledSurface Error cd,c1d1: {:.1f} %\n".format(errormax*100))
      +
      +    #
      +    # Close polygone
      +    #
      +    devlxy_l = devl1xy_l
      +    devl2xy_l.reverse()
      +    devlxy_l.extend( devl2xy_l )
      +    v=FreeCAD.Vector(0,0,0)
      +    devlxy_l.append( v )
      +
      +    return devlxy_l
      +
      +    
      +
      +  #####################################
      +  # Function draw_line 
      +  #   - vect0,1: two points 
      +  #####################################
      +  def draw_line( self , vect0 , vect1 ):
      +     l=Part.Line()
      +     l.StartPoint=vect0
      +     l.EndPoint=vect1
      +     self.doc.addObject("Part::Feature","Line").Shape=l.toShape()
      +
      +
      +#####################################
      +# Class Drawing2d 
      +#   -obj_l: listes of object
      +#   -topxh1
      +#   -topyh1
      +#   -topxv1
      +#   -topyv1
      +#   -topxvmax1
      +#   -topyvmax1
      +#   -topxvmax1
      +#   -topyvmax1
      +#####################################
      +class Drawing2d:
      +  #####################################
      +  # Function __init__ 
      +  #     - Scale
      +  #     - scale_auto
      +  #     - a3
      +  #     - cartridge
      +  #     - onedrawing
      +  #####################################
      +  def __init__( self,  scale , scale_auto , a3 , cartridge , onedrawing , page_str ):
      +    self.TopX_H=0
      +    self.TopY_H=0
      +    self.TopX_V=0
      +    self.TopY_V=0
      +    self.TopX_Hmax=0
      +    self.TopY_Hmax=0
      +    self.TopX_Vmax=0
      +    self.TopY_Vmax=0
      +    self.a3=a3
      +    self.scale=scale
      +    self.scale_auto=scale_auto
      +    self.cartridge=cartridge
      +    self.onedrawing=onedrawing
      +    if self.a3:
      +      self.L=420
      +      self.H=297
      +      self.marge=6
      +    else:
      +      self.L=297
      +      self.H=210
      +      self.marge=6
      +    self.name=page_str
      +
      +  #####################################
      +  # Function newPage 
      +  #####################################
      +  def newPage( self ):
      +    freecad_dir=os.getenv('HOME')+"/.FreeCAD/Mod/unrollRuledSurface"
      +    page = FreeCAD.activeDocument().addObject('Drawing::FeaturePage', self.name )
      +    if self.a3:
      +        if self.cartridge:
      +           page.Template = freecad_dir+'/A3_Landscape.svg'   
      +        else:
      +           page.Template = freecad_dir+'/A3_Landscape_Empty.svg'   
      +    else:
      +        if self.cartridge:
      +           page.Template = freecad_dir+'/A4_Landscape.svg'   
      +        else:
      +           page.Template = freecad_dir+'/A4_Landscape_Empty.svg'   
      +    return page
      +
      +
      +  #####################################
      +  # Function all 
      +  #####################################
      +  def all( self, objname_l ):
      +      obj1_l=[]
      +      for objid in range( objname_l.__len__() ):
      +        if objid == 0 or not self.onedrawing:
      +          page = self.newPage()
      +        obj1_l.extend( self.done( objid , objname_l[objid] ))
      +      return obj1_l 
      +
      +  #####################################
      +  # Function all 
      +  #####################################
      +  def done( self, id , objname ):
      +    #
      +    # Init
      +    #
      +    obj_l=[]
      +    obj=objname[0]
      +    objname=objname[1]
      +    xmax=obj.Shape.BoundBox.XMax-obj.Shape.BoundBox.XMin
      +    ymax=obj.Shape.BoundBox.YMax-obj.Shape.BoundBox.YMin
      +    if ymax > xmax :
      +      Draft.rotate( obj , 90 )
      +    Draft.move( obj , FreeCAD.Base.Vector( -obj.Shape.BoundBox.XMin , -obj.Shape.BoundBox.YMin , 0))
      +    xmax=obj.Shape.BoundBox.XMax-obj.Shape.BoundBox.XMin
      +    ymax=obj.Shape.BoundBox.YMax-obj.Shape.BoundBox.YMin
      +
      +    scale=min((self.L-4*self.marge)/xmax,(self.H-4*self.marge)/ymax)
      +
      +    if ( not self.scale_auto ) or ( self.onedrawing ) :
      +       scale=self.scale
      +
      +    FreeCAD.Console.PrintMessage("UnrollRuledSurface.drawing: scale= {:.2f}\n".format(scale))
      +     
      +
      +    if id == 0 or not self.onedrawing:
      +      #
      +      # Init
      +      #
      +      FreeCAD.Console.PrintMessage("Dawing2d: init\n")
      +      self.TopX_H=self.marge*2
      +      self.TopY_H=self.marge*2
      +      TopX=self.TopX_H
      +      TopY=self.TopY_H
      +      self.TopX_H=self.TopX_H + xmax * scale + self.marge
      +      self.TopY_H=self.TopY_H 
      +      self.TopX_Hmax=max( self.TopX_Hmax , self.TopX_H )
      +      self.TopY_Hmax=max( self.TopY_Hmax , self.TopY_H + ymax*scale+self.marge )
      +      self.TopX_Vmax=max( self.TopX_Vmax , self.TopX_Hmax )
      +      self.TopX_V=max(self.TopX_Vmax,self.TopX_V)
      +      self.TopY_V=self.marge*2
      +    elif self.onedrawing:
      +      if self.TopX_H + xmax * scale < self.L :
      +        if self.TopY_H + ymax * scale + self.marge*2 < self.H :
      +   #
      +   # H Add at right on same horizontal line
      +   #
      +           FreeCAD.Console.PrintMessage("Dawing2d: horizontal\n")
      +           TopX=self.TopX_H
      +           TopY=self.TopY_H
      +           self.TopX_H=self.TopX_H + xmax * scale + self.marge
      +   self.TopX_Hmax=max( self.TopX_Hmax , self.TopX_H )
      +   self.TopY_Hmax=max( self.TopY_Hmax , self.TopY_H + ymax*scale+self.marge )
      +   self.TopX_Vmax=max( self.TopX_Hmax , self.TopX_Vmax )
      +           self.TopX_Vmax=max( self.TopX_Vmax , self.TopX_Hmax  )
      +           self.TopX_V=max(self.TopX_Vmax,self.TopX_V)
      +else:
      +   #
      +   # V Add at right on same horizontal line
      +   #
      +           FreeCAD.Console.PrintMessage("Dawing2d: vertival\n")
      +           if self.TopX_V + ymax * scale +2* self.marge < self.L and self.TopY_V + xmax * scale + 2*self.marge < self.H :
      +             Draft.rotate( obj , 90 )
      +     Draft.move( obj , FreeCAD.Base.Vector( -obj.Shape.BoundBox.XMin , -obj.Shape.BoundBox.YMin , 0))
      +     x0=xmax;xmax=ymax,ymax=x0
      +             self.TopX_V=max(self.TopX_Vmax, self.TopX_V)
      +             TopX=self.TopX_V
      +             TopY=self.TopY_V
      +     self.TopX_V = self.TopX_V + xmax * scale + self.marge
      +     self.TopY_Vmax=max( self.TopY_Vmax , self.TopY_V + ymax * scale + self.marge )
      +   else:
      +     obj_l.append( [ obj , name ] )
      +     return obj_l
      +
      +      else:
      +#
      +# H Carriage return 
      +#
      +        if ( self.TopY_Hmax + ymax * scale + self.marge*2 < self.H ):   
      +           FreeCAD.Console.PrintMessage("Dawing2d: carriage return: "+str(self.TopY_H + ymax * scale )+" > "+str(self.H)+"\n")
      +           TopX=self.marge*2
      +           TopY=self.TopY_Hmax
      +           self.TopX_H=TopX + xmax * scale + self.marge
      +           self.TopY_H=TopY 
      +   self.TopX_Hmax=max( self.TopX_Hmax , self.TopX_H )
      +   self.TopY_Hmax=self.TopY_Hmax + ymax*scale+self.marge
      +           self.TopX_Vmax=max( self.TopX_Vmax , self.TopX_Hmax )
      +           self.TopX_V=max(self.TopX_Vmax,self.TopX_V)
      +else:
      +   #
      +   # V Add at right on same horizontal line
      +   #
      +           FreeCAD.Console.PrintMessage("Dawing2d: vertival: "+str(self.TopX_V)+" , "+str(self.TopX_Vmax)+"\n")
      +           if self.TopX_V + ymax * scale + 2*self.marge < self.L and self.TopY_V + xmax * scale + 2*self.marge < self.H :
      +             Draft.rotate( obj , 90 )
      +     Draft.move( obj , FreeCAD.Base.Vector( -obj.Shape.BoundBox.XMin , -obj.Shape.BoundBox.YMin , 0))
      +     x0=xmax;xmax=ymax,ymax=x0
      +             TopX=self.TopX_V
      +             TopY=self.TopY_V
      +     self.TopX_V = self.TopX_V + xmax * scale + self.marge
      +     self.TopY_Vmax=max( self.TopY_Vmax , self.TopY_V + ymax * scale + self.marge )
      +   else:
      +     obj_l.append( [ obj , objname ] )
      +     return obj_l
      +
      +    page=FreeCAD.activeDocument().getObject(self.name )
      +
      +    Text=FreeCAD.activeDocument().addObject('Drawing::FeatureViewAnnotation', objname+"_txt")
      +    Text.Text=objname
      +    Text.X=TopX+xmax*scale/2
      +    Text.Y=TopY+ymax*scale/2
      +    Text.Scale=2
      +
      +    TopView = FreeCAD.activeDocument().addObject('Drawing::FeatureViewPart',objname)
      +    TopView.Source = obj
      +    TopView.Direction = (0.0,0.0,1)
      +    TopView.Rotation = 0 
      +    TopView.X = TopX 
      +    TopView.Y = TopY 
      +    TopView.ShowHiddenLines = False
      +    TopView.Scale = scale 
      +    page.addObject(TopView)
      +    page.addObject(Text)
      +    FreeCAD.activeDocument().recompute()
      +    return obj_l
      +
      +
      +
      +
      +#####################################
      +#####################################
      +# Dialog Box 
      +#####################################
      +#####################################
      +fields = [[ "File Name" , "UnrollSurface" ]]
      +fields.append(["Dicretization Points Nbr","100" ])
      +fields.append(["Scale","1" ])
      +
      +DialogBox = QtGui.QDialog()
      +DialogBox.resize(250,250)
      +DialogBox.setWindowTitle("UnrollRuledSurface")
      +la = QtGui.QVBoxLayout(DialogBox)
      +buttonGrp1 = QtGui.QButtonGroup(DialogBox)
      +buttonGrp2 = QtGui.QButtonGroup(DialogBox)
      +
      +#
      +# Input fields
      +#
      +for id in range(len( fields )):
      +  la.addWidget(QtGui.QLabel( fields[ id ][ 0 ] ))
      +  fields_l.append( QtGui.QLineEdit( fields[ id ][ 1 ] ))
      +  la.addWidget( fields_l[ id ] )
      +
      +scale_check = QtGui.QCheckBox( DialogBox )
      +scale_check.setObjectName("checkBox")
      +scale_check.setChecked(True)
      +la.addWidget(QtGui.QLabel("Scale auto"))
      +la.addWidget(scale_check)
      +
      +line3 = QtGui.QFrame(DialogBox)
      +line3.setFrameShape(QtGui.QFrame.HLine)
      +line3.setFrameShadow(QtGui.QFrame.Sunken)
      +la.addWidget(line3)
      +
      +edge0_check = QtGui.QRadioButton( DialogBox )
      +la.addWidget(QtGui.QLabel("Generatrices from edge 1 to 4" ))
      +edge0_check.setChecked(False)
      +la.addWidget(edge0_check)
      +edge1_check = QtGui.QRadioButton( DialogBox )
      +la.addWidget(QtGui.QLabel("Generatrices from edge 0 to 3" ))
      +edge1_check.setChecked(True)
      +buttonGrp1.addButton(edge0_check)
      +buttonGrp1.addButton(edge1_check)
      +la.addWidget(edge1_check)
      +
      +line4 = QtGui.QFrame(DialogBox)
      +line4.setFrameShape(QtGui.QFrame.HLine)
      +line4.setFrameShadow(QtGui.QFrame.Sunken)
      +la.addWidget(line4)
      +
      +a3_check = QtGui.QRadioButton( DialogBox )
      +la.addWidget(QtGui.QLabel("A3" ))
      +a3_check.setChecked(False)
      +la.addWidget(a3_check)
      +a4_check = QtGui.QRadioButton( DialogBox )
      +la.addWidget(QtGui.QLabel("A4"))
      +a4_check.setChecked(True)
      +buttonGrp2.addButton(a3_check)
      +buttonGrp2.addButton(a4_check)
      +la.addWidget(a4_check)
      +
      +cartridge_check = QtGui.QCheckBox( DialogBox )
      +cartridge_check.setObjectName("checkBox")
      +la.addWidget(QtGui.QLabel("Cartridge"))
      +cartridge_check.setChecked(False)
      +la.addWidget(cartridge_check)
      +
      +line6 = QtGui.QFrame(DialogBox)
      +line6.setFrameShape(QtGui.QFrame.HLine)
      +line6.setFrameShadow(QtGui.QFrame.Sunken)
      +la.addWidget(line6)
      +
      +onedrawing_check = QtGui.QCheckBox( DialogBox )
      +onedrawing_check.setObjectName("checkBox")
      +la.addWidget(QtGui.QLabel("Group drawings in page"))
      +onedrawing_check.setChecked(True)
      +la.addWidget(onedrawing_check)
      +
      +line7 = QtGui.QFrame(DialogBox)
      +line7.setFrameShape(QtGui.QFrame.HLine)
      +line7.setFrameShadow(QtGui.QFrame.Sunken)
      +la.addWidget(line7)
      +
      +box = QtGui.QDialogButtonBox(DialogBox)
      +box.setOrientation(QtCore.Qt.Horizontal)
      +box.setStandardButtons(QtGui.QDialogButtonBox.Cancel 
      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Macro_View_Rotation.html b/localwiki/Macro_View_Rotation.html new file mode 100644 index 0000000..1796318 --- /dev/null +++ b/localwiki/Macro_View_Rotation.html @@ -0,0 +1,285 @@ +Macro View Rotation

      Macro View Rotation

      + +
      + + + + + + + + + + + + + + + + + + + + + + + + + + +
      +

      Text-x-python.png View Rotation

      +
      Description +
      Macro provides a GUI to permit precise rotation of the objects in the view. +
      Author +
      Joe Dowsett +
      Links +
      Macros recipes
      How to install macros
      How to customize toolbars +
      Version +
      1.0 +
      Date last modification +
      2012-01-04 +
      +

      + +
      +


      +

      This GUI allows the view to be rotated with more precision than when using the mouse. Rotation is according to axes fixed with respect to the user and not the objects, though the aim is that the objects rotate about their approximate shared centre rather than the view centre.
      +The GUI defaults to the top right of the screen, this behaviour can be changed by editing +


      +

      +
      Rotate view
      +
      +
      a = QtGui.QDesktopWidget()
      + right = a.availableGeometry().width()
      +  
      + self.setGeometry(right-300, 0, 300, 150) 
      +


      +at the end of the function 'initUI'. The first two arguments (right-300, 0) provide the position for the top left corner of the window - my experience is that the behaviour was as intended on Ubuntu but Vista positioned the window too high and the 0 needed to be changed to ~30.
      +Three icons are referred to to symbolise the rotation directions. A zip file containing these icons can be found here, the images should be placed in the folder containing your macros. Please feel free to contribute better ones! +


      +

      +
      import PySide
      +from PySide import QtGui, QtCore
      +from pivy import coin
      +from math import pi
      +
      +
      +def find_centre():
      +xmax = xmin = ymax = ymin = zmax = zmin = 0
      +for obj in App.ActiveDocument.Objects:
      +if obj.TypeId[:4] == "Mesh":
      +box = obj.Mesh.BoundBox
      +elif obj.TypeId[:6] == "Points":
      +box = obj.Points.BoundBox
      +elif obj.TypeId[:4] == "Part":
      +box = obj.Shape.BoundBox
      +else:
      +continue
      +xmax = max(xmax, box.XMax)
      +xmin = min(xmin, box.XMin)
      +ymax = max(ymax, box.YMax)
      +ymin = min(ymin, box.YMin)
      +zmax = max(zmax, box.ZMax)
      +zmin = min(zmin, box.ZMin)
      +
      +centre = FreeCAD.Vector((xmax+xmin)/2.0, (ymax+ymin)/2.0, (zmax+zmin)/2.0)
      +return centre
      +
      +
      +
      +class rotate_gui(QtGui.QWidget):  
      +def __init__(self):
      +super(rotate_gui, self).__init__()
      +self.initUI()
      +self.initRotate()
      +
      +
      +def initUI(self):
      +self.sld = [0,1,2]
      +self.tbox = [0,1,2]
      +path = FreeCAD.ConfigGet("UserAppData")
      +icon = [0,1,2]
      +icons = ('right.png', 'up.png', 'out.png')
      +
      +for i in range(3): 
      +self.sld[i] = QtGui.QSlider(QtCore.Qt.Horizontal, self)
      +self.sld[i].setFocusPolicy(QtCore.Qt.NoFocus)
      +self.sld[i].setSingleStep(5)
      +self.sld[i].setPageStep(15)
      +self.sld[i].setValue(0)
      +self.sld[i].setMaximum(180)
      +self.sld[i].setMinimum(-180)
      +self.tbox[i] = QtGui.QLineEdit(self)
      +self.tbox[i].setText("0")
      +self.tbox[i].setAlignment(QtCore.Qt.AlignRight)
      +icon[i] = QtGui.QLabel(self)
      +icon[i].setPixmap(QtGui.QPixmap(path + icons[i]))
      +self.sld[i].valueChanged[int].connect(self.valueChange)
      +self.tbox[i].returnPressed.connect(self.valueEntered)
      +
      +resetButton = QtGui.QPushButton("Reset")
      +resetButton.clicked.connect(self.reset)
      +
      +okButton = QtGui.QPushButton("OK")
      +okButton.clicked.connect(self.close)
      +
      +cancelButton = QtGui.QPushButton("Cancel")
      +cancelButton.clicked.connect(self.cancel)
      +
      +hbox = [0,1,2,3]
      +vbox = QtGui.QVBoxLayout()
      +
      +for i in range(3):
      +hbox[i] = QtGui.QHBoxLayout()
      +hbox[i].addWidget(icon[i],1, QtCore.Qt.AlignCenter)
      +hbox[i].addWidget(self.sld[i],4)
      +hbox[i].addWidget(self.tbox[i],1)
      +vbox.addLayout(hbox[i])
      +
      +hbox[3] = QtGui.QHBoxLayout()
      +hbox[3].addWidget(resetButton,1)
      +hbox[3].addWidget(okButton,1)
      +hbox[3].addWidget(cancelButton,1)
      +vbox.addStretch(1)
      +vbox.addLayout(hbox[3])
      +
      +self.setLayout(vbox)
      +
      +a = QtGui.QDesktopWidget()
      +right = a.availableGeometry().width()
      +
      +self.setGeometry(right-300, 0, 300, 150)
      +self.setWindowTitle('Rotate view...')
      +self.show()
      +
      +
      +def initRotate(self):
      +self.internal = False
      +self.current = 0
      +
      +self.cam = Gui.ActiveDocument.ActiveView.getCameraNode()
      +self.centre = coin.SbVec3f(find_centre())
      +self.view = self.cam.orientation.getValue()
      +self.pos = self.cam.position.getValue()
      +
      +#store a copy of the original view to be restored in the case of user selecting Reset or Cancel
      +self.original_view = coin.SbRotation(self.view.getValue())
      +self.original_pos = coin.SbVec3f(self.pos.getValue())
      +
      +self.config_direction(0)
      +
      +
      +def reset(self):
      +#reset the view to the original one
      +self.cam.orientation = self.original_view
      +self.cam.position = self.original_pos
      +self.internal = True
      +for sld in self.sld:
      +sld.setValue(0)
      +self.internal = False
      +for tbox in self.tbox:
      +tbox.setText("0")
      +self.config_direction(0)
      +
      +
      +def cancel(self):
      +self.reset()
      +self.close()
      +
      +
      +def config_direction(self, i):
      +#evaluate the vectors corresponding to the three directions for the current view, and assign the i-th one to self.direction
      +self.view = self.cam.orientation.getValue()
      +self.view = coin.SbRotation(self.view.getValue())
      +self.pos = self.cam.position.getValue()
      +self.pos = coin.SbVec3f(self.pos.getValue())
      +
      +up = coin.SbVec3f(0,1,0)
      +self.up = self.view.multVec(up)
      +out = coin.SbVec3f(0,0,1)
      +self.out = self.view.multVec(out)
      +u = self.up.getValue()
      +o = self.out.getValue()
      +r = (u[1]*o[2]-u[2]*o[1], u[2]*o[0]-u[0]*o[2], u[0]*o[1]-u[1]*o[0])
      +self.right = coin.SbVec3f(r)
      +
      +self.direction = [self.right, self.up, self.out][i]
      +
      + def check(self, i):
      +#check if the direction of rotation has changed, if so then set previous slider & textbox to zero, and setup the new direction
      +if i <> self.current:
      +self.internal = True
      +self.sld[self.current].setValue(0)
      +self.tbox[self.current].setText("0")
      +self.internal = False
      +self.current = i
      +self.config_direction(i)
      +
      +
      +def rotate(self, value):
      +#carry out the desired rotation about self.direction
      +val = value*pi/180.0
      +rot = coin.SbRotation(self.direction, -val)
      +nrot = self.view*rot
      +prot = rot.multVec(self.pos - self.centre) + self.centre
      +self.cam.orientation = nrot
      +self.cam.position = prot
      +
      +
      +def valueChange(self, value):
      +#respond to the change in value of a slider, update the corresponding text box, check for a direction change then rotate
      +#if the value was changed internally, ignore event.
      +if self.internal:
      +return
      +
      +sender = self.sender()
      +for i in range(3):
      +if sender == self.sld[i]:
      +break
      +self.tbox[i].setText(str(value))
      +self.check(i)
      +self.rotate(value)
      +
      +
      +def valueEntered(self):
      +#respond to a value being entered in a text box, updating the corresponding slider, check for direction change then rotate
      +sender = self.sender()
      +for i in range(3):
      +if sender == self.tbox[i]:
      +break
      +value = int(self.tbox[i].text())
      +self.internal = True
      +self.sld[i].setValue(value)
      +self.internal = False
      +self.check(i)
      +self.rotate(value)
      + 
      +
      +rotate = rotate_gui() 
      +
      +


      +

      +

      Discussion page

      +

      View+Rotation +

      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Macro_WireXYZ.html b/localwiki/Macro_WireXYZ.html new file mode 100644 index 0000000..04eeaaf --- /dev/null +++ b/localwiki/Macro_WireXYZ.html @@ -0,0 +1,131 @@ +Macro WireXYZ

      Macro WireXYZ

      + +
      + + + + + + + + + + + + + + + + + + + + + + + + + + +
      +

      Text-x-python.png WireXYZ

      +
      Description +
      Creates a wire with coordinate x y z. +
      Author +
      Mario52 +
      Links +
      Macros recipes
      How to install macros
      How to customize toolbars +
      Version +
      0.1 +
      Date last modification +
      2016-09-06 +
      +

      + +
      +


      +

      +

      Description

      +

      This macro creates a wire (or points) with the coordinates extracted from a file. The coordinates X Y Z are separated by a space. +

      +

      Use

      +

      The file must have three coordinates X Y Z in ascii format without header +

      Ex: +

      +0 240.42686 0 +

      20 243.83054 0 +

      40 247.33677 0 +

      60 250.94702 0 +

      80 254.66283 0 +

      100 258.48575 0 +

      ... + +

      Modify your path and name of file, save and load the macro and run. +

      +
      fichier = "C:\yourPath\cloud.asc"                          # path and name of file.txt
      +

      If you want a close wire modify this line (closed=False): +

      +
      Draft.makeWire(wire,closed=False,face=False,support=None)   # create the wire open
      +

      and replace with (closed=True): +

      +
      Draft.makeWire(wire,closed=True,face=False,support=None)   # create the wire closed
      +

      same for the face, False or True (face=True). +

      +

      Script

      +

      Macro_WireXYZ.FCMacro +

      +
      # -*- coding: utf-8 -*-
      +# created a wire with coordinate x y z separated (in the file)
      +#EX:
      +#0 0 0
      +#10 10 10
      +#15 20 25
      +#. . . .
      +
      +from __future__ import unicode_literals
      +from FreeCAD import Base
      +import Draft, Part
      +
      +fichier = "C:\yourPath\cloud.asc"                          # path and name of file.txt
      +
      +file = open(fichier, "r")                                  # open the file read
      +wire = []
      +X=Y=Z = 0.0
      +
      +for ligne in file:
      +    coordinates = ligne.split()
      +    X,Y,Z = coordinates                                     # separate the coordinates
      +#    Draft.makePoint(float(X),float(Y),float(Z))            # create points (uncomment for use)
      +    print X," ",Y," ",Z
      +    wire.append(FreeCAD.Vector(float(X),float(Y),float(Z))) # append the coordinates
      +
      +file.close()
      +Draft.makeWire(wire,closed=False,face=False,support=None)   # create the wire open
      +#Draft.makeWire(wire,closed=True,face=False,support=None)   # create the wire closed (uncomment for use)
      +

      Links

      +

      The discussion How do I transform a point cloud to a line? +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Macro_WorkFeatures.html b/localwiki/Macro_WorkFeatures.html new file mode 100644 index 0000000..fdb3278 --- /dev/null +++ b/localwiki/Macro_WorkFeatures.html @@ -0,0 +1,444 @@ +Macro WorkFeatures

      Macro WorkFeatures

      + +
      + + + + + + + + + + + + + + + + + + + + + + + + + + +
      +

      WF wf.png Macro WorkFeatures

      +
      Description +
      Tool utility to create Points, Axis, Planes...and other usefull functions. +
      Author +
      rentlau_64 +
      Links +
      Macros recipes
      How to install macros
      How to customize toolbars +
      Version +
      00.52 +
      Date last modification +
      2018-01-31 +
      +

      + +
      +


      +

      +

      Description

      +

      Tool utility to create Points (mid points, center of circle, center of object(s)...), +Axes (from 2 points, Normal of a plane...), +Planes (from 3 points, from one axis and a point...) +and many other useful features to facilitate the creation of your project. This utility is up next in the combo view with "Work Features" label. +


      +WorkFeatures +

      +
      +


      +

      +

      Uses

      +

      Work Features +

      +
      + +
      +


      +Origin Tab +

      + + + +
      Macro WorkFeatures 02.png
      +
      +
      • Origin Tab
      • +
      • Origin : Create at origin: a point and X,Y and Z axis and XZ,XY and YZ planes. The Axis, Point and Planes origin are directly keyed to hidden.
      +
      +

      Points Tab +

      + + + +
      Macro WorkFeatures 03.png
      +
      +
      • Points Tab
      • +
      • Object(s) Center : Create a Point at center location of all selected Object(s).
      • +
      • Lines(s) Center : Create a Point at mid point location of each selected Line(s).
      • +
      • Line(s) Extrema : Create Points at start and end location of each selected Line(s).
      • +
      • Circle(s) Center : Create a Point at center location of each selected Circle(s) or Arc(s).
      • +
      • Point along Line : Create a Point on a line at some distance of the extremity point selected.
      • +
      • SpinBox : enter the displacement value
      • +
      • Face(s) Center : Create a Point at center location of each selected Face(s).
      • +
      • Point (Line,Face) : Create a point at the intersection of the Line and Plane selected.
      • +
      • Point (Line,Point) : Create a projection Point of a Point onto a Line and symetric point.
      • +
      • Point (Point,Face) : Create a projection Point of a Point onto a Face.
      • +
      • Object(s) Base Point : Create Base Point of all selected Object(s).
      +
      +


      +Axis Tab +

      + + + +
      Macro WorkFeatures 04.png
      +
      +
      • Axis Tab
      • +
      • Object(s) X, Y, Z Axes : Create 3 Axes at center location of all selected Object(s).
      • +
      • Two Points Axis : Create an Axis crossing 2 Points.
      • +
      • SpinBox : enter the displacement value
      • +
      • Cylinder(s) Axis : Create the Axis of a Cylinder.
      • +
      • Axis (Line,Line) : Create an Axis between 2 Axes.
      • +
      • Plane(s) Axes : Create 2 Perpendicular Axes at center location of a Plane.
      • +
      • Axis (Point,Axis) : Create an Axis parallel to an Axis and crossing a Point.
      • +
      • Axis (Axis,Point) : Create an Axis perpendicular to an Axis and crossing a Point.
      • +
      • SpinBox : enter the displacement value
      • +
      • Axis (Plane,Axis) : Create an Axis on a Plane by projection from another Axis.
      • +
      • Axis (Plane,Plane) : Create an Axis by intersect of 2 Planes.
      • +
      • Object(s) Base Axis : Create 3 Axes at Base location of all selected Object(s).
      +
      +

      Plane Tab +

      + + + +
      Macro WorkFeatures 05.png
      +
      +
      • Plane Tab
      • +
      • Three Points Plane : Create a Plane crossing 3 Points.
      • +
      • Plane (Point, Axis) : Create a plane crossing a Line and a Point. The point MUST not belongs to the Line !
      • +
      • Plane (Point, _Axis) : Create a plane perpendicular to a Line and crossing a Point.
      • +
      • Plane (Point, Plane) : Create a plane crossing a Point and parallel to a Plane.
      • +
      • SpinBox : enter the displacement value
      • +
      • Plane (Plane, Axis) : Create a Plane crossing a Line and perpendicular to a Plane.
      • +
      • SpinBox : enter the displacement value
      • +
      • Object(s) Center Planes : Create 3 Planes (XY, XZ and YZ) at center location of all selected Object(s).
      +
      +

      Objects Tab +

      + + + +
      Macro WorkFeatures 06.png
      +
      +
      • Objects Tab
      • +
      • Bounding Box(es) : Create bounding boxes around each of selected object(s).
      • +
      • Bounding Box : Create one bounding box around all of selected object(s).
      • +
      • Cylinder : First select an Axis and a Point. Define Diameter and Length if needed. Then Click the button... It will create a Cylinder aligned on the selected axis. with one of the extremities at point selected.
      • +
      • Cube : First select an Axis and a Point. Define Dimensions if needed. Then Click the button... It will create a Cube aligned on the selected axis. with one of the extremities at point selected.
      +
      +

      Views Tab +

      + + + +
      Macro WorkFeatures 09.png
      +
      +
      • Views Tab
      • +
      • Align to ... : Set the current view perpendicular to the selected Face, or aligned to the selected Axis, or aligned on 2 Points. ReClick with same selection, will reverse the direction.
      +
      +

      Modif. Tab +

      + + + +
      Macro WorkFeatures 10.png
      +
      +
      • Modif. Cutting Tab
      • +
      • Select Object : After selected your object and, First, one Object to cut and click 'Select Object' button, +
        • The name of the object selected are displayed
      • +
      • Select Cut Line : Second, one cutting Line and click 'Select Cut Line' button, +
        • The name of the line selected are displayed
      • +
      • Select Ref. Plane : Last, a reference Plane and click 'Select Ref. Plane' button! +
        • The name of the plane selected are displayed
      • +
      • Angle : Angle for cut (Defaut : 0.0)
      • +
      • Thichness : Thichness the cut (Defaut : 0.0)
      • +
      • Reset : Reset the values
      • +
      • Apply : Apply the values
      +
      +

      Check. Tab +

      + + + +
      Macro WorkFeatures 11.png
      +
      +
      • Check. Tab
      • +
      • are Parallel ? : Check if two faces or two Edges are Parallel: +
        • Select the 2 faces/planes or 2 Edges/Lines and Click this button
      • +
      • are Perpendicular ? : Check if two faces or two Edges are Perpendicular: +
        • Select the 2 faces/planes or 2 Edges/Lines and Click this button
      • +
      • are Coplanar ? : Check if two faces or two Edges are Coplanar: +
        • Select the 2 faces/planes or 2 Edges/Lines and Click this button
      • +
      • Distance Clearance ? : Check for two Objects Clearance distance: +
        • Quick measurements between parallel faces and similarly placed objects Select the 2 Objects and Click this button
      • +
      • Angle ? : Calculate angle from 2 objects: +
        • Angle measurement between two Edges or two Planes
        • +
        • Select the 2 Edges and Click this button
        • +
        • or : Select the 2 Planes and Click this button
        • +
        • or : Select one Edge and one Plane and Click this button
      • +
      • Distance ? : Check for two Points distance: +
        • Distances measurement and Delta values (on main Axes) between two Points
        • +
        • Select the 2 Points and Click this button
      • +
      • Length ? : Check for Line Length: +
        • Length measurement and Delta values (on main Axes) for a Line
        • +
        • Select the Line and Click this button
      • +
      • Area ? : Check for surface Area: +
        • Area measurement for a Plane or a set of Planes.
        • +
        • Select One or several Planes and Click this button
      • +
      • View : Detect the position of the camera. The returned value is the value provided by the function getCameraOrientation().
      +
      +

      Script

      +

      After downloading the file compressed here +Download the latest version on GitHub , +you must unzip the zip and copy all the files in your macro directory. +

      PS:This macro is still in development please visit this page for commonly be sure to have the latest version. +


      +

      +
      Download in GitHub click the Download ZIP button
      +
      +


      +Install the macro addons_installer for install easily WorkFeatures and other interesting macros +

      Here for How to install macros detailed +

      +

      Examples

      +

      Cutting tools

      +

      Setting of the Cutting tools: Select an object to cut, a cutting line and a reference Plane. +Angle is an angle between the cutting Plane and the Ref. Plane. +Thickness is the wide of the of the cutting Plane. +

      +
      + +
      +
      +
      +

      Example the practice +

      + +
      +
      +
      + +
      +
      +
      + +
      +
      +
      + +
      +
      +


      +

      +
      + +
      +
      +


      +

      +

      Concentric constraint between two non cylindrical parts

      +
      + +
      +
      +


      +

      +

      Rotation Object

      +
      + +
      +
      +


      +

      +

      Links

      +

      The forum discussion MACRO:Work Feature 2014_12 +

      +

      Latest version

      +

      Icons : +

      WF wf.png +

      WF centerObjectsPlanes.png +

      Sources : +

      08/03:2105 : WF_2015_03_08 +- Circle cut added +- Are Parallel, Are Perpendicular, Are Coplanar added +

      17/02/2015 : WF_2015_02_17 +- Circle and Ellipse Tab added +- Cutting tab added +

      25/01/2015 : WF_2015_01_25.zip add Object Cylinder Cube +

      18/01/2015 : WF_2015_01_18.tar.gz add plane and face to view +

      28/12/2014 : WorkFeatures_2014_12_28.zip +

      27/12/2014 : WF_2014_12_27.zip +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Macro_circle.html b/localwiki/Macro_circle.html new file mode 100644 index 0000000..6535449 --- /dev/null +++ b/localwiki/Macro_circle.html @@ -0,0 +1,192 @@ +Macro circle

      Macro circle

      (Redirected from Macro circle)
      + +
      + + + + + + + + + + + + + + + + + + + + + + + + + + +
      +

      Text-x-python.png Macro Circle

      +
      Description +
      Creates a circle or arc with parameters. +
      Author +
      mario52 +
      Links +
      Macros recipes
      How to install macros
      How to customize toolbars +
      Version +
      0.3 +
      Date last modification +
      2018-06-10 +
      +

      + +
      +


      +

      +

      Description

      +

      This small macro create a circle or arc giving radius, diameter, circumference, area, startangle, endangle, arc, anglecenter, cord, arrow, center (point), placemObject on choice. +

      The circle is still facing the screen (with getCameraOrientation) (or give the placement) +

      +

      Use

      +

      Copy the code and paste it in the console Python the FreeCAD the command is used all the time to the disposal FreeCAD open +give the parameter on choice : +

      +
      • x y z : coordinates of circle if not coordinates the circle is created on point 0,0,0
      • +
      • radius : radius of cicle
      • +
      • diameter : diameter of circle
      • +
      • circumference : circumference of circle
      • +
      • area : area of circle
      • +
      • startangle : start angle for arc
      • +
      • endangle : end angle for arc
      • +
      • arc and anglecenter : arc in combination with anglecenter +
        • arc = length of arc
        • +
        • anglecenter = angle of center circle to extremities of arc
      • +
      • cord and arrow : cord in combination with arrow of circle +
        • cord : length of cord of circle
        • +
        • arrow : length of arrow of circle
      • +
      • center : if center as different 0 one point is created on center of circle
      • +
      • placemObject +
        • example :
        • +
        • pl=FreeCAD.Placement()
        • +
        • pl.Rotation.Q=(0.0,-0.0,-0.0,1.0)
        • +
        • pl.Base=FreeCAD.Vector(-1.89847898483,-0.490152746439,0.0)
        • +
        • give placemObject = pl
      +

      if there is no parameter "circle()" a list of functions is displayed in the report view +

      +Example entrance : +

      +
      circle(arc=50,anglecenter=20,center=1)
      +circle(cord = 100,arrow = 20,center=1)
      +circle(circumference = 100,center=1) 
      +

      Script

      +

      Macro_circle.FCMacro +

      +
      # -*- coding: utf-8 -*-
      +# creer un cercle ou un arc entierement parametrabel en utilisant :
      +# create a circle or arc fully parametrabel using:
      +# x x x coordinates
      +#with radius
      +#with diameter
      +#with circumference
      +#with area
      +#with startangle
      +#with endangle
      +#with [arc and anglecenter]      in combination (angle in degrees)
      +#with [cord and arrow]           in combination
      +#with center (if center as different 0 one point is created on center of circle)
      +#give placemObject  
      +# ex :pl=FreeCAD.Placement()
      +#     pl.Rotation.Q=(0.0,-0.0,-0.0,1.0)
      +#     pl.Base=FreeCAD.Vector(-1.89847898483,-0.490152746439,0.0)
      +#     placemObject = pl
      +# s'il n'y a pas de parametre "circle()" une liste des fonctions s'affiche dans la Vue rapport
      +# if there is no parameter "circle()" a list of functions is displayed in the report view
      +
      +__title__   = "circle"
      +__author__  = "Mario52"
      +__date__    = "10/06/2018"
      +
      +import Draft #, Part
      +def circle(x=0.0,y=0.0,z=0.0,radius=0.0,diameter=0.0,circumference=0.0,area=0.0,startangle=0.0,endangle=0.0,arc=0.0,anglecenter=0.0,cord=0.0,arrow=0.0,center=0,placemObject=""):
      +    from math import sqrt, pi
      +    if placemObject == "":
      +        pl = FreeCAD.Placement()
      +        pl.Rotation = FreeCADGui.ActiveDocument.ActiveView.getCameraOrientation()   
      +        pl.Base = FreeCAD.Vector(x,y,z)
      +    else:
      +        pl = placemObject                                  # placement imposted
      +
      +    if diameter != 0:                                      # with diameter
      +        radius = diameter / 2.0
      +    elif circumference != 0:                               # with circumference
      +        radius = (circumference / pi) / 2.0
      +    elif area != 0:                                        # with area
      +        radius =  sqrt((area / pi))
      +    elif (cord != 0) and (arrow != 0):                     # with cord and arrow
      +        radius = ((arrow**2) + (cord**2) / 4.0) / (arrow*2) 
      +    elif (arc != 0) and (anglecenter != 0):                # with arc and anglecenter central in degrees
      +        radius = ((360/anglecenter)*arc) / pi/2.0
      +        if endangle != 0:
      +            startangle  = endangle - anglecenter
      +        endangle   = anglecenter + startangle
      +        startangle  = endangle - anglecenter
      +
      +    if radius != 0:
      +        try:
      +            Draft.makeCircle(radius,placement=pl,face=False,startangle=startangle,endangle=endangle,support=None)
      +            if center != 0:
      +                Draft.makePoint(x,y,z)
      +        except Exception:
      +            App.Console.PrintError("Unexpected keyword argument" + "\n")
      +    else:
      +        App.Console.PrintMessage("Unexpected keyword argument" + "\n")
      +        App.Console.PrintMessage("circle(x,y,z,radius,diameter,circumference,area,startangle,endangle,[arc,anglecenter],[cord,arrow],center,placemObject)" + "\n")
      +
      +#example
      +#circle(arc=50,anglecenter=20,center=1) 
      +

      Memo of circle

      +

      Examples codes +

      +
      circle(radius=10)    # example 1
      +circle(x=15,diameter=20)    # example 2
      +circle(y=45,circumference=100)    # example 3 
      +
      examples 1, 2, 3
      +
      +


      +

      +
      circle(y=-15,area=100)    # example 4
      +circle(y=-15,x=15,startangle=60,endangle=-20,center=1)    # example 5
      +circle(y=-15,x=45,cord=9,arrow=3,center=1)    # example 6 left
      +circle(x=65,y=-15,arc=3.5,anglecenter=40,startangle=20,center=1)    # example 6 rigth 
      +
      examples
      +
      +

      Version

      +

      ver 0.3 10/06/2018 : replace /2 to /2.0 (float) +

      ver 0.2 24/02/2015 : adding function "placemObject" +

      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Macro_crank_simul.html b/localwiki/Macro_crank_simul.html new file mode 100644 index 0000000..ae78dbc --- /dev/null +++ b/localwiki/Macro_crank_simul.html @@ -0,0 +1,126 @@ +Macro crank simul

      Macro crank simul

      + +
      + + + + + + + + + + + + + + + + + + + + + + + + + + +
      +

      Text-x-python.png Crank Simul

      +
      Description +
      Crank simulation. +
      Author +
      kwahoo +
      Links +
      Macros recipes
      How to install macros
      How to customize toolbars +
      Version +
      1.0 +
      Date last modification +
      2014-06-13 +
      +

      + +
      +


      +

      My simple animation uses sketch and sketcher solver to determine piston position and conrod position/rotation. +


      +

      +
      Crank 00.gif
      +


      +

      +

      Use

      +

      To test the animation: +

      Download the files and copy the code in the Python console FreeCAD. +

      1. Open the attached file +

      To stop animation type : +

      +
      animation.stop() 
      +

      The File

      +

      crank_simul.fcstd +

      +

      Script

      +

      crank_simul.FCMacro +

      +
      import FreeCAD as App, FreeCADGui as Gui, Part, time, sys, math, Draft, DraftGeomUtils
      +from PySide import QtGui,QtCore
      +
      +class Animation(object):
      +    def __init__(self):
      +        App.Console.PrintMessage('init')
      +
      +        App.ActiveDocument.recompute()
      +
      +        self.timer = QtCore.QTimer()
      +        QtCore.QObject.connect(self.timer, QtCore.SIGNAL("timeout()"), self.my_update)
      +        self.timer.start(50)
      +
      +        self.an = 0.1
      +
      +    def my_update(self):
      +        string = '{0}'.format(self.an)
      +        self.an = self.an + 0.01 if self.an < (2 * math.pi) else 0.0
      +
      +        angle = math.degrees(self.an)
      +        App.ActiveDocument.Sketch.setDatum(5,App.Units.Quantity(str(angle)+' deg'))
      +        App.ActiveDocument.recompute()
      +        p1 = App.ActiveDocument.Sketch.Shape.Vertexes[0].Point
      +        p2 = App.ActiveDocument.Sketch.Shape.Vertexes[1].Point
      +        conrodangle = math.degrees(Draft.DraftVecUtils.angle(App.Vector(1,0,0),(p1-p2))) - 90
      +        App.ActiveDocument.getObject("Cylinder").Placement = App.Placement(p1,App.Rotation(App.Vector(1,0,0),-90))
      +        App.ActiveDocument.getObject("Sketch001").Placement = App.Placement(p1,App.Rotation(App.Vector(0,0,1),conrodangle))
      +
      +    def stop(self):
      +        self.timer.stop()
      +         
      +
      +animation = Animation() 
      +

      Links

      +

      The forum discussion Inline-four engine animation +

      The blog freecad-tutorial.blogspot +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Macro_cross_section.html b/localwiki/Macro_cross_section.html new file mode 100644 index 0000000..ed365ef --- /dev/null +++ b/localwiki/Macro_cross_section.html @@ -0,0 +1,694 @@ +Macro cross section

      Macro cross section

      + +
      + + + + + + + + + + + + + + + + + + + + + + + + + + +
      +

      Text-x-python.png Cross_section

      +
      Description +
      Dynamically slidable cross-section +
      Author +
      aleph0 +
      Links +
      Macros recipes
      How to install macros
      How to customize toolbars +
      Version +
      0.07 +
      Date last modification +
      2017-09-17 +
      +

      + +
      +


      +


      +

      +

      Description

      +

      Macro to display a cross-section of the objects in the scene: the cross-section plane can be moved by a slider bar. +

      +
      Cross-section.png
      +
      +


      +

      +
      Macro Cross Section 02.png
      +
      +


      +

      +

      Use

      +
      • To run the macro, first download it from this site and install it in your macros directory,
      • +
      • then use the menu to call up your list of macros and double-click on this one.
      • +
      • It will display a default cross-section and pop up a window to enable you to set the cross-sectioning parameters.
      • +
      • Closing the pop-up window will restore the scene to its previous state before the macro was started.
      +

      LINKS

      +

      Mario52 has created a new version of this macro that allows you to save the sectional view. +See forum +

      +
      Macro Cross Section 01.png
      +

      Look down right: "Keep the sectional view" +

      +

      Script

      +

      Changes by Mario52 include. +

      Changes by Sam include. +

      Changes by Gift include. +


      +Macro cross section.FCMacro +

      +
      # -*- coding: utf-8 -*-
      +"""
      +***************************************************************************
      +*                                                                         *
      +*   This widget makes an interactively moveable cross-section of the      *
      +*   currently visible objects in the currently active document. The       *
      +*   cross-sectioning plane is specified by its normal, and the cross-     *
      +*   section can be moved along that normal using a slider bar. It can     *
      +*   show the cross-section either as an outline or a view of the sliced   *
      +*   objects. To run the macro, first download it from this site and       *
      +*   install it in your macros directory, then use the menu to call up     *
      +*   your list of macros and double-click on this one. It will display     *
      +*   a default cross-section and pop up a window to enable you to set      *
      +*   the cross-sectioning parameters. Closing the pop-up window will       *
      +*   restore the scene to its previous state before the macro was          *
      +*   started.                                                              *
      +*                                                                         *
      +***************************************************************************
      +*   Copyright (c) 2016 Richard P. Parkins, M. A.                          *
      +*                                                                         *
      +*   This file is a supplement to the FreeCAD CAx development system.      *
      +*                                                                         *
      +*   This program is free software; you can redistribute it and/or modify  *
      +*   it under the terms of the GNU Lesser General Public License (LGPL)    *
      +*   as published by the Free Software Foundation; either version 2 of     *
      +*   the License, or (at your option) any later version.                   *
      +*   for detail see the LICENCE text file.                                 *
      +*                                                                         *
      +*   This software is distributed in the hope that it will be useful,      *
      +*   but WITHOUT ANY WARRANTY; without even the implied warranty of        *
      +*   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the         *
      +*   GNU Library General Public License for more details.                  *
      +*                                                                         *
      +*   You should have received a copy of the GNU Library General Public     *
      +*   License along with this macro; if not, write to the Free Software     *
      +*   Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  *
      +*   USA                                                                   *
      +***************************************************************************
      +"""
      +__title__   = "Cross-Section"
      +__author__  = "Aleph0"
      +__version__ = "00.07"
      +__date__    = "17/09/2017"
      +
      +#"29/01/2016" "10/06/2016" "29/09/2016 * 2" "17/08/2017" "06/09/2017" "17/09/2017"
      +
      +# Upgrade:
      +# 17/08/2017 by Sam             #https://forum.freecadweb.org/viewtopic.php?f=28&t=15084&start=10#p187030
      +# 06/09/2017 17/09/2017 by Gift #https://www.forum.freecadweb.org/viewtopic.php?f=13&t=24130
      + 
      +__Comment__ = "Dynamic cross section viewer"
      + 
      +__Wiki__ = "http://www.freecadweb.org/wiki/index.php?title=Macro_cross_section"
      +__Help__ = "see first few lines of macro text"
      +__Status__ = "stable"
      +__Requires__ = "freecad 0.15"
      + 
      +# OS: Ubuntu 14.04.3 LTS
      +# Word size of OS: 64-bit
      +# Word size of FreeCAD: 64-bit
      +# Version: 0.15.4671 (Git)
      +# Branch: releases/FreeCAD-0-15
      +# Hash: 244b3aef360841646cbfe80a1b225c8b39c8380c
      +# Python version: 2.7.6
      +# Qt version: 4.8.6
      +# Coin version: 4.0.0a
      +# OCC version: 6.8.0.oce-0.17
      + 
      +import PySide
      +from PySide import QtCore, QtGui
      +import FreeCADGui
      +import Part
      +import Draft
      +from FreeCAD import Base
      +
      +try:
      +    _fromUtf8 = QtCore.QString.fromUtf8
      +except AttributeError:
      +    def _fromUtf8(s):
      +        return s
      + 
      +try:
      +    _encoding = QtGui.QApplication.UnicodeUTF8
      +    def _translate(context, text, disambig):
      +        return QtGui.QApplication.translate(context, text, disambig, _encoding)
      +except AttributeError:
      +    def _translate(context, text, disambig):
      +        return QtGui.QApplication.translate(context, text, disambig)
      + 
      + 
      +width = 350 # width of our window
      +height = 310 # height of our window
      +global FreeCADRootWindow # main window before we start
      + 
      +# This is the interactive window that the macro creates
      +# Its main function is to have a close box and tidy up when closed
      +class CrossSectionWindow(PySide.QtGui.QMainWindow):
      + 
      +    # automagically called when the window is created
      +    def __init__(self):
      +        super(CrossSectionWindow, self).__init__()
      +        self.setWindowFlags(PySide.QtCore.Qt.WindowStaysOnTopHint)
      +        self.setWindowTitle(_translate(
      +            "MainWindow", "Cross-section", None))
      + 
      +        # Create and set the window's widget, which does all the work
      +        self.child = CrossSection(self)
      +        self.setCentralWidget(self.child)
      +        self.child.initUI(self)
      +        if self.child.startup_failed :
      +            self.destroy()
      +        else:
      +            # Position our window relative to the FreeCAD root
      +            self.setPosition(FreeCADRootWindow)
      +            self.child.show()
      +            self.show()
      + 
      +    # User closed the window, tidy up
      +    def closeEvent(self, event) :
      +        self.child.restoreObjects()
      + 
      +    # Set a sensible default position for the window
      +    # With FreeCAD's default layout, this will be over the docking area
      +    # so it will not obscure the 3D view
      +    def setPosition(self, parent) :
      +        geom = parent.geometry()
      +        xpos = geom.left() + 50
      +        ypos = geom.center().y() - height / 2
      +        self.setGeometry(xpos, ypos, width, height)
      +        self.setFixedSize(width, height)
      + 
      +# This is the widget which does almost all of the work
      +# Widgets don't have close boxes, so closing is dealt with in CrossSectionWindow
      +class CrossSection(PySide.QtGui.QWidget):
      + 
      +    # Lay out the interactive elements
      +    def initUI(self, parent):
      + 
      +        self.parent = parent
      +
      +        font = QtGui.QFont()
      +        font.setFamily("Times New Roman")
      +        font.setPointSize(10)
      +        font.setWeight(10)
      +        font.setBold(True)
      + 
      +        self.hideObjects()
      +
      +        margin = 10
      +        alw = 20 # axis label width
      +        sbp = margin + alw + margin # spin boxes to right of axis labels
      +        slw = width - 2 * margin # width of slider and progress bar
      +        ypos = margin
      + 
      +        self.setObjectName(_fromUtf8("CrossSection"))
      + 
      +        # The cross-section plane is defined by its normal
      +        # The length of the normal is immaterial as long as it is nonzero
      +        self.label_1 = QtGui.QLabel(self)
      +        self.label_1.setGeometry(QtCore.QRect(margin, ypos, slw, 22))
      +        self.label_1.setObjectName(_fromUtf8("label_1"))
      +        self.label_1.setText(_translate(
      +            "MainWindow", "Sliding axis direction", None))
      +        self.label_1.setToolTip(_translate(
      +            "MainWindow",
      +            "Cross-section is taken perpendicular to this axis", None))
      +        ypos = ypos + 30
      + 
      +        self.label_2 = QtGui.QLabel(self)
      +        self.label_2.setGeometry(QtCore.QRect(margin, ypos, alw, 25))
      +        self.label_2.setObjectName(_fromUtf8("label_2"))
      +        self.label_2.setText(_translate("MainWindow", "X", None))
      + 
      +        self.doubleSpinBox_X = QtGui.QDoubleSpinBox(self)
      +        self.doubleSpinBox_X.setGeometry(QtCore.QRect(sbp, ypos, 62, 25))
      +        self.doubleSpinBox_X.setMinimum(-10000.0)
      +        self.doubleSpinBox_X.setMaximum(10000.0)
      +        self.doubleSpinBox_X.setValue(0.0)
      +        self.doubleSpinBox_X.setSingleStep(1)
      +        self.doubleSpinBox_X.setObjectName(_fromUtf8("doubleSpinBox_X"))
      +        self.doubleSpinBox_X.valueChanged.connect(
      +           self.on_doubleSpinBox_X_valueChanged)
      +        self.doubleSpinBox_X.setToolTip(_translate(
      +            "MainWindow", "Sliding axis X", None))
      +        ypos = ypos + 30
      + 
      +        self.label_3 = QtGui.QLabel(self)
      +        self.label_3.setGeometry(QtCore.QRect(margin, ypos, alw, 25))
      +        self.label_3.setObjectName(_fromUtf8("label_3"))
      +        self.label_3.setText(_translate("MainWindow", "Y", None))
      + 
      +        self.doubleSpinBox_Y = QtGui.QDoubleSpinBox(self)
      +        self.doubleSpinBox_Y.setGeometry(QtCore.QRect(sbp, ypos, 62, 25))
      +        self.doubleSpinBox_Y.setMinimum(-10000.0)
      +        self.doubleSpinBox_Y.setMaximum(10000.0)
      +        self.doubleSpinBox_Y.setValue(0.0)
      +        self.doubleSpinBox_Y.setSingleStep(1)
      +        self.doubleSpinBox_Y.setObjectName(_fromUtf8("doubleSpinBox_Y"))
      +        self.doubleSpinBox_Y.valueChanged.connect(
      +           self.on_doubleSpinBox_Y_valueChanged)
      +        self.doubleSpinBox_Y.setToolTip(_translate(
      +            "MainWindow", "Sliding axis Y", None))
      +        ypos = ypos + 30
      + 
      +        self.label_4 = QtGui.QLabel(self)
      +        self.label_4.setGeometry(QtCore.QRect(margin, ypos, alw, 25))
      +        self.label_4.setObjectName(_fromUtf8("label_4"))
      +        self.label_4.setText(_translate("MainWindow", "Z", None))
      + 
      +        self.doubleSpinBox_Z = QtGui.QDoubleSpinBox(self)
      +        self.doubleSpinBox_Z.setGeometry(QtCore.QRect(sbp, ypos, 62, 25))
      +        self.doubleSpinBox_Z.setMinimum(-10000.0)
      +        self.doubleSpinBox_Z.setMaximum(10000.0)
      +        self.doubleSpinBox_Z.setValue(1.0)
      +        self.doubleSpinBox_Z.setSingleStep(1)
      +        self.doubleSpinBox_Z.setObjectName(_fromUtf8("doubleSpinBox_Z"))
      +        self.doubleSpinBox_Z.valueChanged.connect(
      +           self.on_doubleSpinBox_Z_valueChanged)
      +        self.doubleSpinBox_Z.setToolTip(
      +            _translate("MainWindow", "Sliding axis Z", None))
      +        ypos = ypos + 40
      +        # Make the interactive slider control
      +        # As you move this slider with the mouse, the cross-section slides
      +        # through the model
      +        self.label_5 = QtGui.QLabel(self)
      +        self.label_5.setGeometry(QtCore.QRect(margin, ypos, slw, 22))
      +        self.label_5.setObjectName(_fromUtf8("label_5"))
      +        self.label_5.setText(_translate(
      +            "MainWindow", "Position along axis", None))
      +        ypos = ypos + 30
      + 
      +        self.horizontalSlider = QtGui.QSlider(self)
      +        self.horizontalSlider.setGeometry(QtCore.QRect(margin, ypos, slw-50, 20))
      +        self.horizontalSlider.setOrientation(QtCore.Qt.Horizontal)
      +        self.horizontalSlider.setInvertedAppearance(False)
      +        self.horizontalSlider.setObjectName(_fromUtf8("horizontalSlider"))
      +        self.horizontalSlider.setRange(0, 100)
      +        self.horizontalSlider.setValue(int(self.fraction * 100.0))
      +        self.horizontalSlider.setToolTip(_translate(
      +            "MainWindow", "Slide to move cross-section along axis", None))
      + 
      +        # must be called after setValue()
      +        self.horizontalSlider.valueChanged.connect(self.on_horizontal_slider)
      +        ypos = ypos + 30
      + 
      +        self.progressBar_1 = QtGui.QProgressBar(self)
      +        self.progressBar_1.setGeometry(QtCore.QRect(margin, ypos, slw-50, 23))
      +        self.progressBar_1.setValue(int(self.fraction * 100.0))
      +        self.progressBar_1.setOrientation(QtCore.Qt.Horizontal)
      +        self.progressBar_1.setAlignment(QtCore.Qt.AlignCenter)
      +        self.progressBar_1.setObjectName(_fromUtf8("progressBar_1"))
      +        self.progressBar_1.setToolTip(_translate(
      +            "MainWindow", "Percent position of cross-section", None))
      +        ypos = ypos + 40
      + 
      +##################################    add
      +        self.SpinBox_PBar = QtGui.QSpinBox(self)
      +        self.SpinBox_PBar.setGeometry(QtCore.QRect(sbp+255, ypos-40, 45, 23))
      +        self.SpinBox_PBar.setMinimum(0.0)
      +        self.SpinBox_PBar.setMaximum(100.0)
      +        self.SpinBox_PBar.setValue(int(self.fraction * 100.0))
      +        self.SpinBox_PBar.setSingleStep(1)
      +        self.SpinBox_PBar.setObjectName(_fromUtf8("SpinBox_PBar"))
      +        self.SpinBox_PBar.valueChanged.connect(self.on_SpinBox_PBar_valueChanged)
      +        self.SpinBox_PBar.setToolTip(_translate(
      +            "MainWindow", "Sliding percent", None))
      +#################################    add
      +
      +        # Select the display format for the cross-section
      +        # This button shows a wire line in the cross-section plane
      +        self.radioButton_1 = QtGui.QRadioButton(self)
      +        self.radioButton_1.setGeometry(QtCore.QRect(margin, ypos, slw, 20))
      +        self.radioButton_1.setText(_fromUtf8("Outline"))
      +        self.radioButton_1.setChecked(True)
      +        self.radioButton_1.toggled.connect(self.onRadioButton)
      +        self.radioButton_1.setObjectName(_fromUtf8("radioButton_1"))
      +        self.radioButton_1.setToolTip(_translate(
      +            "MainWindow", "Make cross-section as wire outline", None))
      +        ypos = ypos + 30
      + 
      +        # Select the display format for the cross-section
      +        # This button shows a normal 3D display with everything above the
      +        # cross-section plane cut away
      +        self.radioButton_2 = QtGui.QRadioButton(self)
      +        self.radioButton_2.setGeometry(QtCore.QRect(margin, ypos, slw, 20))
      +        self.radioButton_2.setText(_fromUtf8("Cut objects"))
      +        self.radioButton_2.setChecked(False)
      +        self.radioButton_2.toggled.connect(self.onRadioButton)
      +        self.radioButton_2.setObjectName(_fromUtf8("radioButton_2"))
      +        self.radioButton_2.setToolTip(_translate(
      +            "MainWindow", "Make cross-section as cut objects", None))
      +
      +##################################
      +        #Keep the sectional view
      +        self.CB_00 = QtGui.QCheckBox(self)
      +        self.CB_00.setText(_fromUtf8("Keep the sectional view"))
      +        self.CB_00.setGeometry(QtCore.QRect(margin+168, ypos-30, slw, 20))
      +        self.CB_00.setObjectName(_fromUtf8("CB_00"))
      +        self.CB_00.setChecked(False)
      +        self.CB_00.setToolTip(_translate(
      +            "MainWindow", "Keep the sectional view or erase", None))
      +##################################
      +
      +
      +    # Called at macro start up by initUI()
      +    def hideObjects(self):
      +        # Initialise the cross-section state variables
      +        self.startup_failed = False
      +        self.fraction = 0.5
      +        self.axisX = 0.0
      +        self.axisY = 0.0
      +        self.axisZ = 1.0
      +        self.cross_section_type = 1
      + 
      +        # We must have something to do a cross-section on
      +        if App.ActiveDocument is None :
      +            QtGui.QMessageBox.warning(None, _translate("MainWindow",
      +                "Cross-section", None),
      +                _translate("MainWindow", "There is no Active Document\n" +
      +                    "Create one and run this macro again.", None),
      +                QtGui.QMessageBox.Cancel,
      +                QtGui.QMessageBox.Cancel)
      +            self.startup_failed = True
      +            self.parent.destroy() # This will close the window
      +        else :
      + 
      +            # Make a list of the user's objects
      +            # WARNING!!
      +            # This list is persistent. We'll get confused if the user deletes or
      +            # adds objects while the macro is active
      +            self.oblist = App.ActiveDocument.Objects
      + 
      +            # Create the cross-section object
      +            self.cs = FreeCAD.ActiveDocument.addObject("Part::Feature",
      +                "Generated__cross-section")
      +            self.OriginalVisibilities = list()
      +            self.xmin = 1000.0
      +            self.xmax = -1000.0
      +            self.ymin = 1000.0
      +            self.ymax = -1000.0
      +            self.zmin = 1000.0
      +            self.zmax = -1000.0
      +#            n = 0
      +#            for p in self.oblist: # stupid Python list has no length function
      +#                n = n + 1
      +############################# Skip the <group object> ########################         # add
      +            b0 = []
      +            for x0 in self.oblist:
      +                if str(x0) !=  "<group object>":
      +                    b0.append(x0)
      +            self.oblist = b0
      +            n = len(self.oblist)
      +###############################################################################
      +            # Make a list of the visible objects and make them invisible while
      +            # the macro is active
      +            # Also we compute the bounding box of the model
      +            for i in range(n):
      +                vis = self.oblist[i].ViewObject.Visibility
      +                self.OriginalVisibilities.append(vis)
      +                if vis :
      +                    if self.oblist[i].TypeId != str("Drawing::FeatureViewPython") :    # add
      +                        self.oblist[i].ViewObject.Visibility=False
      +                        b = self.oblist[i].Shape.BoundBox
      +                        if b.XMin < self.xmin :
      +                            self.xmin = b.XMin
      +                        if b.XMax > self.xmax :
      +                            self.xmax = b.XMax
      +                        if b.YMin < self.ymin :
      +                            self.ymin = b.YMin
      +                        if b.YMax > self.ymax :
      +                            self.ymax = b.YMax
      +                        if b.ZMin < self.zmin :
      +                            self.zmin = b.ZMin
      +                        if b.ZMax > self.zmax :
      +                            self.zmax = b.ZMax
      +            # Moan and give up if there is nothing to cross-section
      +            if self.xmax <= self.xmin \
      +            or self.ymax <= self.ymin \
      +            or self.zmax <= self.zmin :
      +                QtGui.QMessageBox.warning(None, _translate("MainWindow",
      +                    "Cross-section", None),
      +                    _translate("MainWindow",
      +                    "There are no visible solid objects\n" +
      +                    "Create some and run this macro again.", None),
      +                    QtGui.QMessageBox.Cancel,
      +                    QtGui.QMessageBox.Cancel)
      +                self.restoreObjects()
      +                self.startup_failed = True
      +                App.ActiveDocument.removeObject("Generated__cross_section")
      +                self.parent.destroy() # This will close the window
      +            else :
      +                # Trigger initial display
      +                self.updateAxis()
      + 
      +    # Called when macro is closed
      +    # Restore the original visibility of the user's objects
      +    # and destroy our cross-section object
      +    def restoreObjects(self):
      +
      +        n = 0
      +        for p in self.oblist: # stupid Python list has no length function
      +            n = n + 1
      +        for i in range(n):
      +            self.oblist[i].ViewObject.Visibility = self.OriginalVisibilities[i]
      +        try:
      +            if self.CB_00.isChecked() == False:
      +                App.ActiveDocument.removeObject("Generated__cross_section")
      +        except Exception:
      +            None
      +    # Something has changed, recalculate the cross-section
      +    def updateGui(self):
      + 
      +        # default to no visible cross-ection
      +        self.cs.ViewObject.Visibility = False
      + 
      +        # check if the sliding axis is invalid
      +        if self.xdir == 0.0 and self.ydir == 0.0 and self.zdir == 0.0 :
      +            QtGui.QMessageBox.warning(None, _translate("MainWindow",
      +                "Cross-section", None),
      +                _translate("MainWindow", "The sliding axis has zero length\n" +
      +                    "Please set a valid axis.", None),
      +                QtGui.QMessageBox.Ok,
      +                QtGui.QMessageBox.Ok)
      +        else :
      + 
      +            # First we compute the 0% and 100% positions on the sliding axis
      +            if self.xdir < 0.0 :
      +                x = self.xmax + self.fraction * self.xdir
      +            else :
      +                x = self.xmin + self.fraction * self.xdir
      +            if self.ydir < 0.0 :
      +                y = self.ymax + self.fraction * self.ydir
      +            else :
      +                y = self.ymin + self.fraction * self.ydir
      +            if self.zdir < 0.0 :
      +                z = self.zmax + self.fraction * self.zdir
      +            else :
      +                z = self.zmin + self.fraction * self.zdir
      +
      +            r = 2 * max(self.xmax - self.xmin, self.ymax - self.ymin,
      +                        self.zmax - self.xmin)
      +
      +            # Display the dimensions
      +            dimDep = "X "+str(x)+" mm , Y "+str(y)+" mm , Z "+str(z)+" mm"
      +            App.Console.PrintMessage(dimDep + "\n")
      +
      +
      +            # Create a big enough disc in the cross-section plane
      +            c = Part.makeCircle(r, Base.Vector(x, y, z),
      +                 Base.Vector(self.xdir,  self.ydir,  self.zdir))
      +            f = Part.Face(Part.Wire(c))
      +            l = list() # list for cross-section parts
      +            n = 0
      +            for p in self.oblist: # stupid Python list has no length function
      +                n = n + 1
      +            something = 0
      +            if self.cross_section_type == 1 :
      +                # wire line cross-section
      +                for i in range(n):
      +                    if self.oblist[i].TypeId != str("Drawing::FeatureViewPython") :    # add
      +                        if self.OriginalVisibilities[i] :
      +ob = self.oblist[i].Shape.section(f)
      +                            # check for valid section part
      +if ob.BoundBox.XMin <= ob.BoundBox.XMax :
      +l.append(ob)
      +something = 1
      +            else :
      +                # cut shape cross-section
      +                # extrude our cross-ection disc into a cylinder
      +                cyl = f.extrude(Base.Vector(self.xdir,  self.ydir,  self.zdir))
      +                doc = FreeCAD.ActiveDocument
      +                for i in range(n):
      +                    if self.oblist[i].TypeId != str("Drawing::FeatureViewPython") :    # add
      +                        if self.OriginalVisibilities[i] :
      +if (self.oblist[i].Shape.Volume <= 0.0):
      +continue
      +acut  = doc.addObject("Part::Cut","Cut")
      +abase = Draft.clone(self.oblist[i]) 
      +abase.ViewObject.DiffuseColor = self.oblist[i].ViewObject.DiffuseColor
      +abase.ViewObject.Transparency = self.oblist[i].ViewObject.Transparency
      +doc.recompute()
      +atool = doc.addObject("Part::Feature")
      +atool.Shape = cyl
      +atool.ViewObject.ShapeColor= self.oblist[i].ViewObject.ShapeColor  #(0.25,0.57,0.35)
      +atool.ViewObject.Transparency = self.oblist[i].ViewObject.Transparency
      +doc.recompute()
      +acut.Base = abase
      +acut.Tool = atool
      +acut.ViewObject.DiffuseColor = abase.ViewObject.DiffuseColor
      +doc.recompute()
      +if acut.Shape.isValid() and acut.Shape.Volume > 0.0 :
      +ob = doc.addObject("Part::Feature")
      +ob.Shape = acut.Shape
      +ob.ViewObject.DiffuseColor = acut.ViewObject.DiffuseColor 
      +doc.recompute()
      +l.append(ob)
      +something = 2
      +doc.removeObject(acut.Name)
      +doc.recompute()
      +doc.removeObject(abase.Name)
      +doc.recompute()
      +doc.removeObject(atool.Name)
      +doc.recompute()
      +
      +            if something == 1 :
      +                s = Part.makeCompound(l)
      +                if s.isValid() :
      +                    self.cs.Shape = s
      +                    self.cs.ViewObject.Visibility = True 
      +            if something == 2 :
      +feature = FreeCAD.ActiveDocument.addObject("Part::Compound","Compound")
      +feature.Links = l
      +FreeCAD.ActiveDocument.recompute()
      +if feature.Shape.isValid() :
      +self.cs.Shape = feature.Shape.copy()
      +self.cs.ViewObject.DiffuseColor = feature.ViewObject.DiffuseColor
      +self.cs.ViewObject.Visibility = True
      +FreeCAD.ActiveDocument.recompute()
      +for od in l:
      +FreeCAD.ActiveDocument.removeObject(od.Name)
      +FreeCAD.ActiveDocument.recompute()
      +FreeCAD.ActiveDocument.removeObject(feature.Name)
      +            FreeCADGui.updateGui()
      + 
      +    # User changed axis vector
      +    # Compute a new axis vector whose length just covers the model
      +    def updateAxis(self):
      +        ldir = 0.0
      +        if self.axisX != 0.0 :
      +            ldir = (self.xmax - self.xmin) / abs(self.axisX)
      +        if self.axisY != 0.0 :
      +            ldir = max(ldir, (self.ymax - self.ymin) / abs(self.axisY))
      +        if self.axisZ != 0.0 :
      +            ldir = max(ldir, (self.zmax - self.zmin) / abs(self.axisZ))
      +        self.xdir = self.axisX * ldir
      +        self.ydir = self.axisY * ldir
      +        self.zdir = self.axisZ * ldir
      +        self.updateGui() # recalculate the cross-section
      + 
      +    def on_horizontal_slider(self, val):
      +        self.fraction = val / 100.0
      +        self.progressBar_1.setValue(val)
      +        self.SpinBox_PBar.setValue(val)
      +        self.updateGui()
      + 
      +    def on_doubleSpinBox_X_valueChanged(self, val):
      +        self.axisX = val
      +        self.updateAxis()
      + 
      +    def on_doubleSpinBox_Y_valueChanged(self, val):
      +        self.axisY = val
      +        self.updateAxis()
      + 
      +    def on_doubleSpinBox_Z_valueChanged(self, val):
      +        self.axisZ = val
      +        self.updateAxis()
      +
      +    def on_SpinBox_PBar_valueChanged(self, val):
      +        self.progressBar_1.setValue(val)
      +        self.horizontalSlider.setValue(int(val))
      +        self.updateGui()
      +       
      +
      +    def onRadioButton(self, wasChecked) :
      +        if self.radioButton_1.isChecked() :
      +            self.cross_section_type = 1
      +        else :
      +            self.cross_section_type = 2
      +        self.updateGui()
      + 
      +#######################################
      + 
      +# Find FreeCAD's root window
      +FreeCADRootWindow = Gui.getMainWindow()
      + 
      +# Create the window and start it
      +myWidget = CrossSectionWindow()
      + 
      +# The CrossSectionWindow will do all the work 
      +
      +

      Example

      +
      Macro Cross Section 03.gif
      +

      Links

      +

      The forum discussion Posting a new macro +

      +

      Version

      +

      ver 00.07 17/09/2017 : upgrade multiple objects with different colors by Gift +

      ver 00.06 06/09/2017 : upgrade by Gift see Optischer Schnitt durch Baugruppe, z.B. für Ventilgehäuse accept the multiple objects with different colors +

      ver 00.05 17/08/2017 : upgrade for 0.17 FreeCAD version by Sam see Sezione Dinamica +

      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Macro_cutCircle.html b/localwiki/Macro_cutCircle.html new file mode 100644 index 0000000..015f00d --- /dev/null +++ b/localwiki/Macro_cutCircle.html @@ -0,0 +1,153 @@ +Macro cutCircle

      Macro cutCircle

      (Redirected from Macro cutCircle)
      + +
      + + + + + + + + + + + + + + + + + + + + + + + + + + +
      +

      Text-x-python.png Macro Cut Circle

      +
      Description +
      Cut a circle or arc in x arcs. +
      Author +
      mario52 +
      Links +
      Macros recipes
      How to install macros
      How to customize toolbars +
      Version +
      00.02 +
      Date last modification +
      2015-03-09 +
      +

      + +
      +


      +

      +

      Description

      +

      This macro cut a circle(s) or arc(s) in multiple arcs, the arcs can be coloured alternately to distinguish. +


      +CutCircle +

      +
      +

      Use

      +

      Copy the macro cutCirle complete in the Python console FreeCAD select the circle(s) and (or) arc(s) type in the console: +

      +
      cutCircle(5, 1)  # here with 5 arcs and coloured
      +cutCircle(4)     # 
      +

      to see the circles and arcs cut here in the example 5 contiguous arcs. +

      The original object is not deleted. +

      +

      Script

      +

      Macro_Cut_Circle.FCMacro +

      +
      __title__= "cutCircle"
      +__author__= "Mario52"
      +__date__= "09/03/2015"
      +__version__= "00.02"
      +
      +# selection circle(s) (circles and arcs)
      +# give number of cut, biColor 0/1
      +# cut the circle to x arcs
      +# if biColor is <> 0 the arcs are colored alternately Red White Red White ....
      +# 
      +
      +import Draft
      +global biscolor ; biscolor = 0
      +def cutCircle(number = 2, biColor = 0):
      +    global biscolor
      +    def defbiColor(objet):
      +        global biscolor
      +        if biscolor == 0:
      +            FreeCADGui.ActiveDocument.getObject(objet.Name).LineColor = (1.0,0.0,0.0) # 255 = 1 (10 = (1/255 * 10 ))
      +            biscolor = 1
      +        else:
      +            FreeCADGui.ActiveDocument.getObject(objet.Name).LineColor = (1.0,1.0,1.0) # 255 = 1 (10 = (1/255 * 10 ))
      +            biscolor = 0
      +    selection = FreeCADGui.Selection.getSelection()
      +    for piece in selection:
      +        nom = piece.Name
      +        if (nom[:6] == "Circle") or (nom[:8] == "Cylinder"):
      +            circonference = piece.Shape.Length
      +            rayon = piece.Radius
      +            placem = piece.Placement
      + 
      +            if (nom[:8] == "Cylinder"):
      +                pivot0 = float(piece.Angle/number)
      +                FreeCAD.Console.PrintMessage("Cylinder"+"\n")
      +            else:
      +                pivot0 = float(360/number)
      +                FreeCAD.Console.PrintMessage("Circle"+"\n")
      +            pivot1 = 0.0
      +            for i in range(number):
      +                cercle = Draft.makeCircle(radius=rayon,placement=placem,face=False,startangle=(pivot1),endangle=(pivot0+pivot1),support=None)
      +                if biColor != 0:
      +                    defbiColor(cercle)
      +                pivot1 += pivot0
      +        elif nom[:3] == "Arc":
      +            FreeCAD.Console.PrintMessage("Arc"+"\n")
      +            circonference = piece.Shape.Length
      +            rayon = piece.Radius
      +            placem = piece.Placement
      +            First = float(piece.FirstAngle)
      +            Last  = float(piece.LastAngle)
      +            pivot0 = abs((First - Last) / number)
      +            pivot1 = 0.0
      +            for i in range(number):
      +                cercle = Draft.makeCircle(radius=rayon,placement=placem,face=False,startangle=(pivot1+First),endangle=(pivot0+pivot1+First),support=None)
      +                if biColor != 0:
      +                    defbiColor(cercle)
      +                pivot1 += pivot0 
      +

      Project

      +

      Cut circle to cylinder +

      +

      Version

      +

      ver 00.02 09/03/2015 : adding create arcs coloured altenat alternately Red White Red White .... or not +

      ver 00.01 24/02/2015 : +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Macro_cutLine.html b/localwiki/Macro_cutLine.html new file mode 100644 index 0000000..95215bf --- /dev/null +++ b/localwiki/Macro_cutLine.html @@ -0,0 +1,160 @@ +Macro cutLine

      Macro cutLine

      (Redirected from Macro cutLine)
      + +
      + + + + + + + + + + + + + + + + + + + + + + + + + + +
      +

      Text-x-python.png Macro Cut Line

      +
      Description +
      Cut a line giving as an argument number cut, create line, bicolor, create point. +
      Author +
      mario52 +
      Links +
      Macros recipes
      How to install macros
      How to customize toolbars +
      Version +
      1.0 +
      Date last modification +
      2015-03-08 +
      +

      + +
      +


      +

      +

      Description

      +

      This small macro cut a line and create a points , lines , two colours of line. +

      +
      cutLine
      +
      +

      Use

      +

      Can be used from the Freecad macro editor. +

      If the macro is copied in the Python console, you can you can use it by: +

      +
      cutLine(4, createLine = 1, biColor = 1, createPoint = 0) 
      +
      • 4 : number cuts
      • +
      • createPoint : create points or not (0) (Defaut 1)
      • +
      • createLine : create line (>0) or not (0) (Defaut 0)
      • +
      • biColor : create line biColor (>0) or not (0) (Defaut 0)
      +


      +you can change the default values in the macro. +

      With bisColor the lines on the original line is created by a white line red line white line .... the colors are modifiable in the code, line 19 and 22. +

      +

      Script

      +

      Macro_cutLine.FCMacro +

      +
      #################################################################
      +# http://forum.freecadweb.org/viewtopic.php?f=3&t=4217&hilit=discretize
      +
      +__title__   = "cutLine"
      +__author__  = "Mario52"
      +__version__ = "00.01"
      +__date__    = "08/03/2015"
      +
      +import Draft, Part
      +def cutLine(numberOfPoints = 2, createPoint = 1, createLine = 0, biColor = 0):           # create a points of forme
      +
      +    def createLines(numberOfPoints, points, biColor):                                        # create line
      +        biscolor = 0
      +        for lin in range(numberOfPoints-1):
      +            creaLine = [FreeCAD.Vector(points[lin]),FreeCAD.Vector(points[lin+1])]
      +            wire = Draft.makeWire(creaLine,closed=False,face=False,support=None)
      +            if biColor != 0:                                                                 # biColor 
      +                if biscolor == 0:
      +                    FreeCADGui.ActiveDocument.getObject(wire.Name).LineColor = (1.0,0.0,0.0) # 255 = 1 (10 = (1/255 * 10 ))
      +                    biscolor = 1
      +                else:
      +                    FreeCADGui.ActiveDocument.getObject(wire.Name).LineColor = (1.0,1.0,1.0) # 255 = 1 (10 = (1/255 * 10 ))
      +                    biscolor = 0
      +    try:
      +        points = []
      +        points[:] = []
      +        selectionObjects = FreeCADGui.Selection.getSelectionEx()         # getSelectionEx
      +        numberOfPoints += 1
      +        for selection in selectionObjects:
      +            compteur = pas = 0
      +            for selectedEdge in selection.SubObjects:
      +#                    FreeCAD.Console.PrintMessage(selectionObjects[0].SubElementNames[compteur] + "\n")                   
      +                    print selectionObjects[0].SubElementNames[compteur]  # getSelectionEx
      +                    compteur += 1                                              
      +                    points = selectedEdge.discretize(numberOfPoints)   
      +                    if createLine != 0:
      +                        createLines(numberOfPoints, points, biColor)
      +                    for p in points:
      +                        if createPoint != 0:
      +                            Draft.makePoint( p.x, p.y, p.z)
      +#                        FreeCAD.Console.PrintMessage(str(compteur)+" X"+ str(p.x)+" Y"+ str(p.y)+ " Z"+ str(p.z) + "\n")
      +                        print compteur," X", p.x, " Y", p.y, " Z", p.z
      +                    pas = 1                                              #
      +
      +            if pas == 0:                                                 # the not SubObjects
      +                selectionObjects = FreeCADGui.Selection.getSelection()   # select all elements
      +#                FreeCAD.Console.PrintMessage(selectionObjects[0].Name + "\n")
      +                print selectionObjects[0].Name                           # getSelection()
      +                compteur = 0
      +                for ii in enumerate(selectionObjects[0].Shape.Edges): 
      +                    compteur += 1
      +                    points = ii[1].discretize(numberOfPoints)            # discretize the element
      +                    for p in points:
      +                        if createPoint != 0:
      +                            Draft.makePoint( p.x, p.y, p.z)              # create points
      +#                        FreeCAD.Console.PrintMessage(str(compteur)+" X"+ str(p.x)+" Y"+ str(p.y)+ " Z"+ str(p.z) + "\n")
      +                        print compteur, " X", p.x, " Y", p.y, " Z", p.z  # list and display the coordinates
      +                    if createLine != 0:
      +                        createLines(numberOfPoints, points, biColor)
      +    except:
      +#        FreeCAD.Console.PrintError("Error" + "\n" + "Give : cutLine(numberOfPoints = 2, createPoint = 1, createLine = 0, biColor = 0)"+"\n")
      +        print "Error : Give cutLine(numberOfPoints = 2, createPoint = 1, createLine = 0, biColor = 0)"
      +
      +
      +#cutLine(2, createLine = 1, biColor = 1, createPoint = 0) 
      +

      Links

      +

      this function use the function discretize the original code +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Macro_hinge.html b/localwiki/Macro_hinge.html new file mode 100644 index 0000000..e510055 --- /dev/null +++ b/localwiki/Macro_hinge.html @@ -0,0 +1,110 @@ +Macro hinge

      Macro hinge

      + +
      + + + + + + + + + + + + + + + + + + + + + + + + + + +
      +

      Text-x-python.png Hinge Simul

      +
      Description +
      Hinge simulation. +
      Author +
      Mario52 +
      Links +
      Macros recipes
      How to install macros
      How to customize toolbars +
      Version +
      1.0 +
      Date last modification +
      2014-09-09 +
      +

      + +
      +


      +

      Simulates hinge movement +

      +
      Hing 00.gif
      +


      +

      +

      Uses

      +

      Open the 2 files (20140908b_Hinge-1.FCMacro and 20140908b_Hinge-1.FCStd) in FreeCAD with 2 screens (Menu: Windows > Tile) and click in the window and the macro and click F6 (debug macro) to run the macro or run the macro with Macro-execute.svg +

      +
      Hing 01.png
      +


      +

      +

      The File

      +

      20140908b_Hinge-1.fcstd +

      +

      Script

      +

      20140908b_Hinge-1.FCMacro +

      +
      import FreeCAD, FreeCADGui, Draft, Part
      +from FreeCAD import Base
      +import time
      +
      +ii = 0
      +pas = 0
      +for ii2 in range(180):
      +    if pas == 0:
      +        if ii > 90:
      +            pas = 1
      +        ii += 5
      +    else:
      +        if ii < 1:
      +            pas = 0
      +        ii -= 5
      +   
      +    App.getDocument("_0140908b_Hinge_1").Fusion.Placement=App.Placement(App.Vector(0,0,0), App.Rotation(App.Vector(0,0,1),ii), App.Vector(44.4,6.9,0))
      +    App.Console.PrintMessage(str(ii2)+"  " + str(ii)+"  " + str(pas) +"\n")
      +    Gui.updateGui()
      +    time.sleep(0) #modify the time here 
      +

      Link

      +

      The discussion page Struggling with LinearPattern (again) +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Macro_installer_01.jpg b/localwiki/Macro_installer_01.jpg new file mode 100644 index 0000000..dafe9af Binary files /dev/null and b/localwiki/Macro_installer_01.jpg differ diff --git a/localwiki/Macro_installer_02.jpg b/localwiki/Macro_installer_02.jpg new file mode 100644 index 0000000..bead0ac Binary files /dev/null and b/localwiki/Macro_installer_02.jpg differ diff --git a/localwiki/Macro_makeCube.png b/localwiki/Macro_makeCube.png new file mode 100644 index 0000000..62b0398 Binary files /dev/null and b/localwiki/Macro_makeCube.png differ diff --git a/localwiki/Macro_merge_duplicate_materials.html b/localwiki/Macro_merge_duplicate_materials.html new file mode 100644 index 0000000..09933cd --- /dev/null +++ b/localwiki/Macro_merge_duplicate_materials.html @@ -0,0 +1,101 @@ +Macro merge duplicate materials

      Macro merge duplicate materials

      + +
      + + + + + + + + + + + + + + + + + + + + + + + + + + +
      +

      Text-x-python.png Macro merge duplicate materials

      +
      Description +
      Merges materials that have the same base name +
      Author +
      yorik +
      Links +
      Macros recipes
      How to install macros
      How to customize toolbars +
      Version +
      1.0 +
      Date last modification +
      2017-04-16 +
      +

      + +
      +


      +

      +

      Description

      +

      Merges materials that have the same base name (with different numeral endings like 001, 002,...) into one. Only the first one will be kept, and all the objects that link to the duplicates will be linking to the first one instead. So before using this macro, make sure your first material (either the one without numerical ending or the lowest number found) is the right one. +

      +

      Script

      +

      Merge duplicate materials.FCMacro +

      +
      import FreeCAD,FreeCADGui
      +mats = [o for o in FreeCAD.ActiveDocument.Objects if o.isDerivedFrom("App::MaterialObject")]
      +todelete = []
      +for mat in mats:
      +    if mat.Label[-1].isdigit() and mat.Label[-2].isdigit() and mat.Label[-3].isdigit():
      +        orig = None
      +        for om in mats:
      +            if om.Label == mat.Label[:-3].strip():
      +                orig = om
      +                break
      +        if orig:
      +            for par in mat.InList:
      +                for prop in par.PropertiesList:
      +                    if getattr(par,prop) == mat:
      +                        print "Changed property '"+prop+"' of object "+par.Label+" from "+mat.Label+" to "+orig.Label
      +                        setattr(par,prop,orig)
      +            todelete.append(mat)
      +for tod in todelete:
      +    if not tod.InList:
      +        print "Deleting material "+tod.Label
      +        FreeCAD.ActiveDocument.removeObject(tod.Name)
      +    elif (len(tod.InList) == 1) and (tod.InList[0].isDerivedFrom("App::DocumentObjectGroup")):
      +        print "Deleting material "+tod.Label
      +        FreeCAD.ActiveDocument.removeObject(tod.Name)
      +    else:
      +        print "Unable to delete material "+tod.Label+": InList not empty" 
      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Macro_screw_maker1_2.html b/localwiki/Macro_screw_maker1_2.html new file mode 100644 index 0000000..9908395 --- /dev/null +++ b/localwiki/Macro_screw_maker1_2.html @@ -0,0 +1,5329 @@ +Macro screw maker1 2

      Macro screw maker1 2

      + +
      + + + + + + + + + + + + + + + + + + + + + + + + + + +
      +

      Text-x-python.png Macro_screw_maker1_2

      +
      Description +
      Creates a screw, bolt... with or without thread +
      Author +
      Ulrich Brammer +
      Links +
      Macros recipes
      How to install macros
      How to customize toolbars +
      Version +
      02.00 +
      Date last modification +
      2015-07-26 +
      +

      + +
      +


      +

      This macro creates a screw with or without thread, according to ISO standards. +


      +screw_maker +

      +
      +


      +

      +

      Usage

      +

      Select the characteristics of the screw and click on the create button.
      +If you select a circle on a hole, or alternatively the inner surface of a circular hole and the circle at top of that hole at the same time, the screw will be placed into the hole with the create button. +There is a message text, that will inform you, when the selected combination of properties is not available. +

      +
      + +
      +

      The creation of the thread takes some time. Be patient and have a look at the CPU-usage. +The latest version of Screw maker is 2.0. The wiki does not allow to upload a zip-File and copying the text from this page is not convenient. So here is a link to a forum post with the latest version: http://forum.freecadweb.org/viewtopic.php?f=22&t=6558&start=30#p95929 +

      The text below is still the old version 1.4. It has lesser screws than the actual one. It still needs the former used library PyQt, which is not available in actual FreeCAD-Versions. Please use the version from the link above. +

      +

      Script

      +
      #!/usr/bin/env python
      +# -*- coding: utf-8 -*-
      +#
      +#  screw_maker2_0.py
      +#  
      +
      +
      +"""
      +Macro to generate screws with FreeCAD.
      +Version 1.4 from 1st of September 2013
      +Version 1.5 from 23rd of December 2013
      +Corrected hex-heads above M12 not done.
      +Version 1.6 from 15th of March 2014
      +Added PySide support
      +
      +Version 1.7 from April 2014
      +fixed bool type error. (int is not anymore accepted at linux)
      +fixed starting point of real thread at some screw types.
      +
      +Version 1.8 from July 2014
      +first approch for a faster real thread
      +
      +Version 1.9 / 2.0 July 2015
      +new calculation of starting point of thread
      +shell-based approach for screw generation
      +added:
      +ISO 14582 Hexalobular socket countersunk head screws, high head
      +ISO 14584 Hexalobular socket raised countersunk head screws
      +ISO 7380-2 Hexagon socket button head screws with collar
      +DIN 967 Cross recessed pan head screws with collar
      +ISO 4032 Hexagon nuts, Style 1
      +ISO 4033 Hexagon nuts, Style 2
      +ISO 4035 Hexagon thin nuts, chamfered
      +EN 1661 Hexagon nuts with flange
      +ISO 7094 definitions  Plain washers - Extra large series
      +ISO 7092 definitions  Plain washers - Small series
      +ISO 7093-1 Plain washer - Large series
      +Screw-tap to drill inner threads in parts with user defined length
      +
      +ScrewMaker can now also used as a python module.
      +The following shows how to generate a screw from a python script:
      +  import screw_maker2_0
      +
      +  threadDef = 'M3.5'
      +  o = screw_maker2_0.Screw()
      +  t = screw_maker2_0.Screw.setThreadType(o,'real')
      +  # Creates a Document-Object with label describing the screw
      +  d = screw_maker2_0.Screw.createScrew(o, 'ISO1207', threadDef, '20', 'real')
      +
      +  # creates a shape in memory
      +  t = screw_maker2_0.Screw.setThreadType(o,'real')
      +  s = screw_maker1_9d.Screw.makeIso7046(o, 'ISO14582', threadDef, 40.0)
      +  Part.show(s)
      +
      +
      +
      +to do: check ISO7380 usage of rs and rt, actual only rs is used 
      +check chamfer angle on hexogon heads and nuts
      +***************************************************************************
      +*   Copyright (c) 2013, 2014, 2015                                        *
      +*   Ulrich Brammer <ulrich1a[at]users.sourceforge.net>                    *
      +*                                                                         *
      +*   This file is a supplement to the FreeCAD CAx development system.      *
      +*                                                                         *
      +*   This program is free software; you can redistribute it and/or modify  *
      +*   it under the terms of the GNU Lesser General Public License (LGPL)    *
      +*   as published by the Free Software Foundation; either version 2 of     *
      +*   the License, or (at your option) any later version.                   *
      +*   for detail see the LICENCE text file.                                 *
      +*                                                                         *
      +*   This software is distributed in the hope that it will be useful,      *
      +*   but WITHOUT ANY WARRANTY; without even the implied warranty of        *
      +*   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the         *
      +*   GNU Library General Public License for more details.                  *
      +*                                                                         *
      +*   You should have received a copy of the GNU Library General Public     *
      +*   License along with this macro; if not, write to the Free Software     *
      +*   Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  *
      +*   USA                                                                   *
      +*                                                                         *
      +***************************************************************************
      +"""
      +
      +__author__ = "Ulrich Brammer <ulrich1a@users.sourceforge.net>"
      +
      +
      +
      +import FreeCAD, FreeCADGui, Part, math
      +from FreeCAD import Base
      +import DraftVecUtils
      +
      +try:
      +  from PySide import QtCore, QtGui
      +  #FreeCAD.Console.PrintMessage("PySide is used" + "\n")
      +except:
      +  #FreeCAD.Console.PrintMessage("PyQt4 is needed" + "\n")
      +  from PyQt4 import QtCore, QtGui
      +
      +
      +DEBUG = False # set to True to show debug messages; does not work, still todo.
      +
      +
      +# Diameters included in this library/macro
      +# some ISO-standards may include more diameters!
      +# Dictionary used for user messages
      +standard_diameters = {
      +  'ISO4017': ('M1.6', 'M64'), # ISO 4017 Hex-head-screw
      +  'ISO4014': ('M1.6', 'M64'), # ISO 4014 Hex-head-bolt
      +  'EN1662':  ('M5',   'M16'), # EN 1662 Hexagon bolts with flange, small series
      +  'EN1665':  ('M5',   'M20'), # EN 1665 Hexagon bolts with flange, heavy series
      +  'ISO4762': ('M1.6', 'M64'), # ISO 4762 Hexagon socket head cap screws
      +  'ISO2009': ('M1.6', 'M10'), # ISO 2009 Slotted countersunk flat head screws
      +  'ISO2010': ('M1.6', 'M10'), # ISO 2010 Slotted raised countersunk head screws
      +  'ISO1580': ('M1.6', 'M10'), # ISO 1580 Slotted pan head screws
      +  'ISO7045': ('M1.6', 'M10'), # ISO 7045 Pan head screws type H cross recess
      +  'ISO7046': ('M1.6', 'M10'),
      +  'ISO7047': ('M1.6', 'M10'),
      +  'ISO1207': ('M3',   'M10'), # ISO 1207 Slotted cheese head screws
      +  'ISO7048': ('M2.5', 'M8'),  # ISO 7048 Cross-recessed cheese head screws with type H cross recess
      +  'ISO7380-1':('M3',  'M16'), # ISO 7380 Hexagon socket button head screws
      +  'ISO7380-2':('M3',  'M16'), # ISO 7380 Hexagon socket button head screws with collar
      +  'DIN967'  :('M3',   'M8'),  # DIN 967 Cross recessed pan head screws with collar
      +  'ISO10642':('M3',   'M20'), # ISO 10642 Hexagon socket countersunk head screws
      +  'ISO14579':('M2',   'M20'), # ISO 14579 Hexalobular socket head cap screws
      +  'ISO14580':('M2',   'M10'), # ISO 14580 Hexalobular socket cheese head screws
      +  'ISO14581':('M2',   'M10'), # ISO 14581 Hexalobular socket countersunk flat head screws (to do!!)
      +  'ISO14582':('M3',   'M10'), # ISO 14582 Hexalobular socket countersunk head screws, high head
      +  'ISO14583':('M2',   'M10'), # ISO 14583 Hexalobular socket pan head screws
      +  'ISO14584':('M2',   'M10'), # ISO 14584 Hexalobular socket raised countersunk head screws
      +  'ISO7089': ('M1.6', 'M64'), # Washer
      +  'ISO7090': ('M5',   'M64'), # ISO 7090 definitions Plain washers, chamfered - Normal series
      +  'ISO7091': ('M1.6', 'M64'), # ISO 7091 definitions  Plain washer - Normal series Product Grade C
      +  'ISO7092': ('M1.6', 'M36'), # ISO 7092 definitions  Plain washers - Small series
      +  'ISO7093-1': ('M3', 'M36'), # ISO 7093-1 Plain washer - Large series
      +  'ISO7094': ('M5',   'M36'), # ISO 7094 definitions  Plain washers - Extra large series
      +  'ISO4032': ('M1.6', 'M64'), # ISO 4032 Hexagon nuts, Style 1
      +  'ISO4033': ('M5',   'M36'), # ISO 4033 Hexagon nuts, Style 2
      +  'ISO4035': ('M1.6', 'M64'), # ISO 4035 Hexagon thin nuts, chamfered
      +  'ISO4036': ('M1.6', 'M10'), # ISO 4035 Hexagon thin nuts, unchamfered, todo no function coded
      +  'EN1661':  ('M5',   'M20')} # EN 1661 Hexagon nuts with flange
      +
      +# ISO 4017 Hex-head-screw
      +#           P,    c,  dw,    e,     k,   r,   s
      +iso4017head={
      +  'M1.6':  (0.35, 0.2, 2.9,  3.4,   1.1, 0.1,  3.2),
      +  'M2':    (0.40, 0.2, 3.7,  4.4,   1.4, 0.1,  4.0),
      +  'M2.5':  (0.45, 0.2, 4.6,  5.5,   1.7, 0.1,  5.0),
      +  'M3':    (0.5,  0.2, 5.2,  6.1,   2.0, 0.1,  5.5),
      +  '(M3.5)':(0.6,  0.2, 5.2,  6.6,   2.4, 0.1,  5.5),
      +  'M4':    (0.7,  0.2, 6.6,  7.7,   2.8, 0.2,  7.0), 
      +  'M5':    (0.8,  0.2, 7.5,  8.9,   3.5, 0.2,  8.0),
      +  'M6':    (1.0,  0.2, 9.5,  11.05, 4.0, 0.25, 10.0),
      +  'M8':    (1.25, 0.3, 11.7, 14.5,  5.3, 0.25, 13.0),
      +  'M10':   (1.50, 0.3, 14.7, 17.9,  6.4, 0.4,  16.0),
      +  'M12':   (1.75, 0.3, 16.7, 20.1,  7.5, 0.6,  18.0),
      +  '(M14)': (2.00, 0.3, 20.5, 24.5,  8.8, 0.6,  22.0),
      +  'M16':   (2.00, 0.4, 22.4, 26.9, 10.0, 0.6,  24.0),
      +  '(M18)': (2.50, 0.4, 25.4, 30.2, 11.5, 0.6,  27.0),
      +  'M20':   (2.50, 0.4, 28.2, 33.7, 12.5, 0.8,  30.0),
      +  '(M22)': (2.50, 0.4, 31.8, 37.7, 14.0, 0.8,  34.0),
      +  'M24':   (3.00, 0.4, 33.7, 40.1, 15.0, 0.8,  36.0),
      +  '(M27)': (3.00, 0.4, 38.0, 45.2, 17.0, 1.0,  41.0),
      +  'M30':   (3.50, 0.4, 42.8, 50.9, 18.7, 1.0,  46.0), #dw not in class A, e not in class A
      +  '(M33)': (3.50, 0.4, 46.6, 55.4, 21.0, 1.0,  50.0), 
      +  'M36':   (4.00, 0.4, 51.2, 61.0, 22.5, 1.0,  55.0), #dw not in class A, e not in class A
      +  '(M39)': (4.00, 0.5, 55.9, 66.5, 25.0, 1.0,  60.0),
      +  'M42':   (4.50, 0.7, 60.0, 71.3, 26.0, 1.2,  65.0),
      +  '(M45)': (4.50, 0.7, 64.7, 77.0, 28.0, 1.2,  70.0),
      +  'M48':   (5.00, 0.7, 69.5, 82.6, 30.0, 1.6,  75.0),
      +  '(M52)': (5.00, 0.7, 74.5, 88.3, 33.0, 1.6,  80.0),
      +  'M56':   (5.50, 0.7, 78.7, 93.6, 35.0, 2.0,  85.0),
      +  '(M60)': (5.50, 0.7, 82.7, 99.2, 38.0, 2.0,  90.0),
      +  'M64':   (6.00, 0.7, 88.2,104.9, 40.0, 2.0,  95.0)
      +  } 
      +
      +
      +
      +iso4017length = {
      +  '2': ( 1.8,  2.2),
      +  '3': ( 2.8,  3.2),
      +  '4': ( 3.76, 4.24),
      +  '5': ( 4.76, 5.24),
      +  '6': ( 5.76, 6.24),
      +  '8': ( 7.71, 8.29),
      +  '10':( 9.71, 10.29),
      +  '12':(11.65, 12.35),
      +  '14':(13.65, 14.35),
      +  '16':(15.65, 16.35),
      +  '20':(19.58, 20.42),
      +  '25':(24.58, 25.42),
      +  '30':(29.58, 30.42),
      +  '35':(34.5,  35.5),
      +  '40':(39.5,  40.5),
      +  '45':(44.5,  45.5),
      +  '50':(49.5,  50.5),
      +  '55':(54.4, 55.6),
      +  '60':(59.4, 60.6),
      +  '65':(64.4, 65.6),
      +  '70':(69.4, 70.6),
      +  '80':(79.4, 80.6),
      +  '100':(99.3, 100.7),
      +  '110':(109.3, 110.7),
      +  '120':(119.3, 120.7),
      +  '130':(129.2, 130.8),
      +  '140':(139.2, 130.8),
      +  '150':(149.2, 150.8),
      +  '160':(159.2, 160.8),
      +  '180':(179.2, 180.8),
      +  '200':(199.1, 200.9)
      +  }
      +
      +# range of typical srew lengths
      +#    min_length,  max_length
      +iso4017range = {
      +  'M1.6':  ('2', '16'),
      +  'M2':    ('4', '20'),
      +  'M2.5':  ('5', '25'),
      +  'M3':    ('5', '30'),
      +  '(M3.5)':('8', '35'),
      +  'M4':    ('6', '40'),
      +  'M5':    ('8', '50'),
      +  'M6':   ('12', '60'),
      +  'M8':   ('16', '80'),
      +  'M10':  ('20','100'),
      +  'M12':  ('25','120'),
      +  '(M14)':('25','140'),
      +  'M16':  ('30','150'),
      +  '(M18)':('35','200'),
      +  'M20':  ('40','160'),
      +  '(M22)':('45','200'),
      +  'M24':  ('50','180'),
      +  '(M27)':('50','100'),
      +  'M30':  ('60','200'), 
      +  '(M33)':('65','200'),
      +  'M36':  ('70','200'),
      +  '(M39)':('80','200'),
      +  'M42':  ('70','200'),
      +  '(M45)':('90','200'),
      +  'M48': ('100','200'),
      +  '(M52)':('100','200'),
      +  'M56':  ('110','200'),
      +  '(M60)':('120','200'),
      +  'M64':  ('120','200')
      +  } 
      +
      +
      +# ISO 4014 Hex-head-bolt
      +#          P,      b1,    b2,    b3,  c,   dw,    e,    k,   r,   s
      +iso4014head={
      +  'M1.6':  (0.35,   9.0,  15.0,  28.0, 0.2,  2.3,  3.4,  1.1, 0.1,  3.2),
      +  'M2':    (0.40,  10.0,  16.0,  29.0, 0.2,  3.0,  4.4,  1.4, 0.1,  4.0),
      +  'M2.5':  (0.45,  11.0,  17.0,  30.0, 0.2,  4.0,  5.5,  1.7, 0.1,  5.0),
      +  'M3':    (0.50,  12.0,  18.0,  31.0, 0.2,  4.6,  6.1,  2.0, 0.1,  5.5),
      +  '(M3.5)':(0.60,  13.0,  19.0,  32.0, 0.2,  5.1,  6.6,  2.4, 0.1,  6.0),
      +  'M4':    (0.70,  14.0,  20.0,  33.0, 0.2,  5.9,  7.7,  2.8, 0.2,  7.0),
      +  'M5':    (0.80,  16.0,  22.0,  35.0, 0.2,  6.9,  8.9,  3.5, 0.2,  8.0), 
      +  'M6':    (1.00,  18.0,  24.0,  37.0, 0.2,  8.9, 11.05, 4.0, 0.25,10.0),
      +  'M8':    (1.25,  22.0,  28.0,  41.0, 0.3, 11.7, 14.5,  5.3, 0.4, 13.0),
      +  'M10':   (1.50,  26.0,  32.0,  45.0, 0.3, 14.7, 17.9,  6.4, 0.4, 16.0),
      +  'M12':   (1.75,  30.0,  36.0,  49.0, 0.3, 16.7, 20.1,  7.5, 0.6, 18.0),
      +  '(M14)': (2.00,  34.0,  40.0,  53.0, 0.3, 20.5, 24.5,  8.8, 0.6, 22.0),
      +  'M16':   (2.00,  38.0,  44.0,  57.0, 0.4, 22.4, 26.9, 10.0, 0.6, 24.0),
      +  '(M18)': (2.50,  42.0,  48.0,  61.0, 0.4, 25.4, 30.2, 11.5, 0.6, 27.0),
      +  'M20':   (2.50,  46.0,  52.0,  65.0, 0.4, 28.2, 33.7, 12.5, 0.8, 30.0),
      +  '(M22)': (2.50,  50.0,  56.0,  69.0, 0.4, 31.8, 37.7, 14.0, 0.8, 34.0),
      +  'M24':   (3.00,  54.0,  60.0,  73.0, 0.4, 33.7, 40.1, 15.0, 0.8, 36.0),
      +  '(M27)': (3.00,  60.0,  66.0,  79.0, 0.4, 38.0, 45.2, 17.0, 1.0, 41.0),
      +  'M30':   (3.50,  66.0,  72.0,  85.0, 0.4, 42.8, 50.9, 18.7, 1.0, 46.0), #dw not in class A, e not in class A
      +  '(M33)': (3.50,  78.0,  78.0,  91.0, 0.4, 46.6, 55.4, 21.0, 1.0, 50.0), 
      +  'M36':   (4.00,  84.0,  84.0,  97.0, 0.4, 51.2, 60.8, 22.5, 1.0, 55.0),
      +  '(M39)': (4.00,  90.0,  90.0, 103.0, 0.5, 55.9, 66.5, 25.0, 1.0, 60.0),
      +  'M42':   (4.50,  96.0,  96.0, 109.0, 0.6, 60.0, 71.3, 26.0, 1.2, 65.0),
      +  '(M45)': (4.50, 102.0, 102.0, 115.0, 0.7, 64.7, 77.0, 28.0, 1.2, 70.0),
      +  'M48':   (5.00, 108.0, 108.0, 121.0, 0.6, 69.5, 82.6, 30.0, 1.6, 75.0),
      +  '(M52)': (5.00, 116.0, 116.0, 129.0, 0.7, 74.5, 88.3, 33.0, 1.6, 80.0),
      +  'M56':   (5.50, 137.0, 137.0, 137.0, 0.6, 78.7, 93.6, 35.0, 2.0, 85.0),
      +  '(M60)': (5.50, 145.0, 145.0, 145.0, 0.7, 82.7, 99.2, 38.0, 2.0, 90.0),
      +  'M64':   (6.00, 153.0, 153.0, 153.0, 0.6, 88.2,104.9, 40.0, 2.0, 55.0)
      +  }
      +
      +
      +iso4014length = {
      +  '12':(11.65, 12.35),
      +  '16':(15.65, 16.35),
      +  '20':(19.58, 20.42),
      +  '25':(24.58, 25.42),
      +  '30':(29.58, 30.42),
      +  '35':(34.5,  35.5),
      +  '40':(39.5,  40.5),
      +  '45':(44.5,  45.5),
      +  '50':(49.5,  50.5),
      +  '55':(54.4, 55.6),
      +  '60':(59.4, 60.6),
      +  '65':(64.4, 65.6),
      +  '70':(69.4, 70.6),
      +  '80':(79.4, 80.6),
      +  '100':(99.3, 100.7),
      +  '110':(109.3, 110.7),
      +  '120':(119.3, 120.7),
      +  '130':(129.2, 130.8),
      +  '140':(139.2, 130.8),
      +  '150':(149.2, 150.8),
      +  '160':(159.2, 160.8),
      +  '180':(179.2, 180.8),
      +  '200':(199.1, 200.9),
      +  '220':(219.1, 220.9),   
      +  '240':(237.7, 242.3),
      +  '260':(219.1, 220.9),
      +  '280':(219.1, 220.9),
      +  '300':(219.1, 220.9),
      +  '320':(219.1, 220.9),
      +  '340':(219.1, 220.9),
      +  '360':(219.1, 220.9),
      +  '380':(219.1, 220.9),
      +  '400':(219.1, 220.9),
      +  '420':(219.1, 220.9),
      +  '440':(219.1, 220.9),
      +  '460':(219.1, 220.9),
      +  '480':(219.1, 220.9),
      +  '500':(496.85, 503.15)   
      +  }
      +
      +# range of typical srew lengths
      +#    min_length,  max_length
      +iso4014range = {
      +  'M1.6':('12', '16'),
      +  'M2':  ('16', '20'),
      +  'M2.5':('16', '25'),
      +  'M3':  ('20', '30'),
      +  '(M3.5)':('20', '35'),
      +  'M4':  ('25', '50'),
      +  'M5':  ('25', '50'),
      +  'M6':  ('30', '130'),
      +  'M8':  ('30', '180'),
      +  'M10': ('35', '150'),
      +  'M12': ('50', '150'),
      +  '(M14)': ('50', '160'),
      +  'M16': ('55', '200'),
      +  '(M18)':('70','180'),
      +  'M20': ('60', '300'),
      +  '(M22)':('70','220'),
      +  'M24': ('80', '220'),
      +  '(M27)':('90', '220'),
      +  'M30': ('110','300'),
      +  '(M33)':('130','320'),
      +  'M36': ('140','360'),
      +  '(M39)':('150','380'),
      +  'M42': ('160','440'),
      +  '(M45)':('180','440'),
      +  'M48': ('180','480'),
      +  '(M52)':('200','480'),
      +  'M56': ('220','500'),
      +  '(M60)':('220','500'),
      +  'M64': ('260','500')
      +  }
      +
      +
      +# EN 1662 Hexagon bolts with flange, small series
      +#          P,   b0,    b1,   b2,   b3,   c,  dc,    dw,    e,     k,   kw,  lf,  r1,   s
      +en1662def={
      +  'M5': (0.80, 25.0, 16.0,  0.0,  0.0, 1.0, 11.4,  9.4,  7.59,  5.6, 2.3, 1.4, 0.2, 7.0), 
      +  'M6': (1.00, 30.0, 18.0,  0.0,  0.0, 1.1, 13.6, 11.6,  8.71,  6.9, 2.9, 1.6, 0.25, 8.0),
      +  'M8': (1.25, 35.0, 22.0, 28.0,  0.0, 1.2, 17.0, 14.9, 10.95,  8.5, 3.8, 2.1, 0.4, 10.0),
      +  'M10':(1.50, 40.0, 26.0, 32.0,  0.0, 1.5, 20.8, 18.7, 14.26,  9.7, 4.3, 2.1, 0.4, 13.0),
      +  'M12':(1.75, 45.0, 30.0, 36.0,  0.0, 1.8, 24.7, 22.5, 17.62, 12.1, 5.4, 2.1, 0.6, 16.0),
      +  '(M14)':(2.00, 50.0, 34.0, 40.0,  0.0, 2.1, 28.6, 26.4, 19.86, 12.9, 5.6, 2.1, 0.6, 18.0),
      +  'M16':(2.00, 55.0, 38.0, 44.0, 57.0, 2.4, 32.8, 30.6, 23.15, 15.2, 6.8, 3.2, 0.6, 21.0)}
      +
      +
      +# range of typical srew lengths
      +#    min_length,  max_length
      +en1662range = {
      +  'M5': ('10', '50'),
      +  'M6': ('12', '60'),
      +  'M8': ('16', '80'),
      +  'M10':('20','100'),
      +  'M12':('25','120'),
      +  '(M14)':('30','140'), 
      +  'M16':('35','160')
      +  } 
      +
      +en1662length = {
      +  '10':( 9.71, 10.29),
      +  '12':(11.65, 12.35),
      +  '16':(15.65, 16.35),
      +  '20':(19.58, 20.42),
      +  '25':(24.58, 25.42),
      +  '30':(29.58, 30.42),
      +  '35':(34.5,  35.5),
      +  '40':(39.5,  40.5),
      +  '45':(44.5,  45.5),
      +  '50':(49.5,  50.5),
      +  '55':(54.4, 55.6),
      +  '60':(59.4, 60.6),
      +  '65':(64.4, 65.6),
      +  '70':(69.4, 70.6),
      +  '80':(79.4, 80.6),
      +  '90':(89.3, 90.7),
      +  '100':(99.3, 100.7),
      +  '110':(109.3, 110.7),
      +  '120':(119.3, 120.7),
      +  '130':(129.2, 130.8),
      +  '140':(139.2, 130.8),
      +  '150':(149.2, 150.8),
      +  '160':(159.2, 160.8)
      +  }
      +
      +
      +# EN 1665 Hexagon bolts with flange, heavy series
      +#          P,    b0,  b1,   b2,   b3,   c,  dc,    dw,    e,     k,   kw,  lf,  r1,   s
      +en1665def={
      +  'M5': (0.80, 25.0, 16.0,  0.0,  0.0, 1.0, 11.8,  9.8,  8.71,  5.8, 2.6, 1.4, 0.2,  8.0), 
      +  'M6': (1.00, 30.0, 18.0,  0.0,  0.0, 1.1, 14.2, 12.2, 10.95,  6.6, 3.0, 1.6, 0.25,10.0),
      +  'M8': (1.25, 35.0, 22.0, 28.0,  0.0, 1.2, 18.0, 15.8, 14.26,  8.1, 3.9, 2.1, 0.4, 13.0),
      +  'M10':(1.50, 40.0, 26.0, 32.0,  0.0, 1.5, 22.3, 19.6, 17.62, 10.4, 4.1, 2.1, 0.4, 16.0),
      +  'M12':(1.75, 45.0, 30.0, 36.0,  0.0, 1.8, 26.6, 23.8, 19.86, 11.8, 5.6, 2.1, 0.6, 18.0),
      +  '(M14)':(2.00, 50.0, 34.0, 40.0,  0.0, 2.1, 30.5, 27.6, 23.15, 13.7, 6.5, 2.1, 0.6, 21.0),
      +  'M16':(2.00, 55.0, 38.0, 44.0, 57.0, 2.4, 35.0, 31.9, 26.51, 15.4, 7.3, 3.2, 0.6, 24.0),
      +  'M20':(2.50, 65.0, 46.0, 52.0, 65.0, 3.0, 43.0, 39.9, 33.23, 18.9, 8.9, 4.2, 0.8, 30.0)}
      +
      +
      +# range of typical srew lengths
      +#    min_length,  max_length
      +en1665range = {
      +  'M5': ('10', '50'),
      +  'M6': ('12', '60'),
      +  'M8': ('16', '80'),
      +  'M10':('20','100'),
      +  'M12':('25','120'),
      +  '(M14)':('30','140'), 
      +  'M16':('35','160'),
      +  'M20':('65','200')
      +  } 
      +
      +en1665length = {
      +  '10':( 9.71, 10.29),
      +  '12':(11.65, 12.35),
      +  '16':(15.65, 16.35),
      +  '20':(19.58, 20.42),
      +  '25':(24.58, 25.42),
      +  '30':(29.58, 30.42),
      +  '35':(34.5,  35.5),
      +  '40':(39.5,  40.5),
      +  '45':(44.5,  45.5),
      +  '50':(49.5,  50.5),
      +  '55':(54.4, 55.6),
      +  '60':(59.4, 60.6),
      +  '65':(64.4, 65.6),
      +  '70':(69.4, 70.6),
      +  '80':(79.4, 80.6),
      +  '90':(89.3, 90.7),
      +  '100':(99.3, 100.7),
      +  '110':(109.3, 110.7),
      +  '120':(119.3, 120.7),
      +  '130':(129.2, 130.8),
      +  '140':(139.2, 130.8),
      +  '150':(149.2, 150.8),
      +  '160':(159.2, 160.8),
      +  '180':(179.2, 180.8),
      +  '200':(199.1, 200.9)
      +  }
      +
      +
      +
      +# ISO 1207 definitions Class A, Slotted cheese head screws
      +#          P,     a,   b,   dk,  dk_mean, da,  k,  n_min, r, t_min, x
      +iso1207def={
      +  'M1.6':(0.35, 0.7, 25.0,  3.0,  2.9,  2.0, 1.1, 0.46, 0.1, 0.45, 0.9),
      +  'M2':  (0.40, 0.8, 25.0,  3.8,  3.7,  2.6, 1.4, 0.56, 0.1, 0.6, 1.0),
      +  'M2.5':(0.45, 0.9, 25.0,  4.5,  4.4,  3.1, 1.8, 0.66, 0.1, 0.7, 1.1),
      +  'M3':  (0.50, 1.0, 25.0,  5.5,  5.4,  3.6, 2.0, 0.86, 0.1, 0.85, 1.25),
      +  '(M3.5)':(0.60, 1.2, 38.0,  6.0,  5.9,  4.1, 2.4, 1.06, 0.1, 1.0, 1.5),
      +  'M4':  (0.70, 1.4, 38.0,  7.0,  6.9,  4.7, 2.6, 1.26, 0.2, 1.1, 1.75),
      +  'M5':  (0.80, 1.6, 38.0,  8.5,  8.4,  5.7, 3.3, 1.26, 0.2, 1.3, 2.0),
      +  'M6':  (1.00, 2.0, 38.0, 10.0,  9.9,  6.8, 3.9, 1.66, 0.25,1.6, 2.5),
      +  'M8':  (1.25, 2.5, 38.0, 13.0, 12.85, 9.2, 5.0, 2.06, 0.4, 2.0, 3.2),
      +  'M10': (1.50, 3.0, 38.0, 16.0, 15.85, 11.2,6.0, 2.56, 0.4, 2.4, 3.8)}
      +
      +# range of typical srew lengths
      +#    min_length,  max_length
      +iso1207range = {
      +  'M1.6':('2', '16'),
      +  'M2':  ('3', '20'),
      +  'M2.5':('3', '25'),
      +  'M3':  ('4', '30'),
      +  '(M3.5)':('5', '35'),
      +  'M4':  ('5', '40'),
      +  'M5':  ('6', '50'),
      +  'M6':  ('8', '60'),
      +  'M8': ('10', '80'),
      +  'M10':('12', '80')}
      +
      +# slotted cheese head screws
      +# nom length: l_min, l_max       
      +iso1207length = {
      +  '2': (1.8,  2.2),
      +  '3': ( 2.8,  3.2),
      +  '4': ( 3.76, 4.24),
      +  '5': ( 4.76, 5.24),
      +  '6': ( 5.76, 6.24),
      +  '8': ( 7.71, 8.29),
      +  '10':( 9.71, 10.29),
      +  '12':(11.65, 12.35),
      +  '14':(13.65, 14.35),
      +  '16':(15.65, 16.35),
      +  '20':(19.58, 20.42),
      +  '25':(24.58, 25.42),
      +  '30':(29.58, 30.42),
      +  '35':(34.5,  35.5),
      +  '40':(39.5,  40.5),
      +  '45':(44.5,  45.5),
      +  '50':(49.5,  50.5),
      +  '55':(54.05, 55.95),
      +  '60':(59.05, 60.95),
      +  '65':(64.05, 65.95),
      +  '70':(69.05, 70.95),
      +  '75':(74.05, 75.95),
      +  '80':(79.05, 80.95)
      +  }
      +
      +
      +# ISO 14580 definitions , Hexalobular socket cheese head screws
      +#          P,     a,   b,   dk,  dk_mean, da,  k,  n_min, r, t_min, x
      +#           tt,    k,    A,  t_mean
      +iso14580def={
      +  'M2':  ('T6',  1.55, 1.75, 0.8),
      +  'M2.5':('T8',  1.85, 2.40, 0.9),
      +  'M3':  ('T10', 2.40, 2.80, 1.2),
      +  '(M3.5)':('T15', 2.60, 3.35, 1.3),
      +  'M4':  ('T20', 3.10, 3.95, 1.5),
      +  'M5':  ('T25', 3.65, 4.50, 1.7),
      +  'M6':  ('T30', 4.40, 5.60, 2.1),
      +  'M8':  ('T45', 5.80, 7.95, 2.9),
      +  'M10': ('T50', 6.90, 8.95, 3.3)}
      +  
      +# range of typical srew lengths
      +#    min_length,  max_length
      +# iso14580range = iso1207range
      +
      +# nom length: l_min, l_max       
      +iso14580length = {
      +  '3': ( 2.8,  3.2),
      +  '4': ( 3.76, 4.24),
      +  '5': ( 4.76, 5.24),
      +  '6': ( 5.76, 6.24),
      +  '8': ( 7.71, 8.29),
      +  '10':( 9.71, 10.29),
      +  '12':(11.65, 12.35),
      +  '14':(13.65, 14.35),
      +  '16':(15.65, 16.35),
      +  '20':(19.58, 20.42),
      +  '25':(24.58, 25.42),
      +  '30':(29.58, 30.42),
      +  '35':(34.5,  35.5),
      +  '40':(39.5,  40.5),
      +  '45':(44.5,  45.5),
      +  '50':(49.5,  50.5),
      +  '55':(54.05, 55.95),
      +  '60':(59.05, 60.95),
      +  '65':(64.05, 65.95),
      +  '70':(69.05, 70.95),
      +  '75':(74.05, 75.95),
      +  '80':(79.05, 80.95)
      +  }
      +
      +
      +
      +# ISO 7048 definitions Class A, 
      +# Cross-recessed cheese head screws with type H or Z cross recess
      +#          P,     a,   b,   dk,  dk_mean, da,  k,   r,   x, cT,   mH,   mZ 
      +iso7048def={
      +  'M2.5':(0.45, 0.9, 25.0,  4.5,  4.4,  3.1, 1.8, 0.1, 1.1, '1', 2.7, 2.4),
      +  'M3':  (0.50, 1.0, 25.0,  5.5,  5.4,  3.6, 2.0, 0.1, 1.25,'2', 3.5, 3.5),
      +  '(M3.5)':(0.60, 1.2, 38.0,  6.0,  5.9,  4.1, 2.4, 0.1, 1.5, '2', 3.8, 3.7),
      +  'M4':  (0.70, 1.4, 38.0,  7.0,  6.9,  4.7, 2.6, 0.2, 1.75,'2', 4.1, 4.0),
      +  'M5':  (0.80, 1.6, 38.0,  8.5,  8.4,  5.7, 3.3, 0.2, 2.0, '2', 4.8, 4.6),
      +  'M6':  (1.00, 2.0, 38.0, 10.0,  9.9,  6.8, 3.9, 0.25,2.5, '3', 6.2, 6.1),
      +  'M8':  (1.25, 2.5, 38.0, 13.0, 12.85, 9.2, 5.0, 0.4, 3.2, '3', 7.7, 7.5)
      +  }
      +
      +# range of typical srew lengths
      +#    min_length,  max_length
      +iso7048range = {
      +  'M2.5':('3', '25'),
      +  'M3':  ('4', '30'),
      +  '(M3.5)':('5', '35'),
      +  'M4':  ('5', '40'),
      +  'M5':  ('6', '50'),
      +  'M6':  ('8', '60'),
      +  'M8': ('10', '80')}
      +
      +# nom length: l_min, l_max       
      +iso7048length = {
      +  '3': ( 2.8,  3.2),
      +  '4': ( 3.76, 4.24),
      +  '5': ( 4.76, 5.24),
      +  '6': ( 5.76, 6.24),
      +  '8': ( 7.71, 8.29),
      +  '10':( 9.71, 10.29),
      +  '12':(11.65, 12.35),
      +  '16':(15.65, 16.35),
      +  '20':(19.58, 20.42),
      +  '25':(24.58, 25.42),
      +  '30':(29.58, 30.42),
      +  '35':(34.5,  35.5),
      +  '40':(39.5,  40.5),
      +  '45':(44.5,  45.5),
      +  '50':(49.5,  50.5),
      +  '60':(59.05, 60.95),
      +  '70':(69.05, 70.95),
      +  '80':(79.05, 80.95)
      +  }
      +
      +
      +# Button Head Screw
      +# nom length: l_min, l_max       
      +iso7380length = {
      +  #'2.5':(2.3,  2.7),
      +  #'3': ( 2.8,  3.2),
      +  '4': ( 3.76, 4.24),
      +  '5': ( 4.76, 5.24),
      +  '6': ( 5.76, 6.24),
      +  '8': ( 7.71, 8.29),
      +  '10':( 9.71, 10.29),
      +  '12':(11.65, 12.35),
      +  '14':(13.65, 14.35),
      +  '16':(15.65, 16.35),
      +  '20':(19.58, 20.42),
      +  '25':(24.58, 25.42),
      +  '30':(29.58, 30.42),
      +  '35':(34.5,  35.5),
      +  '40':(39.5,  40.5),
      +  '45':(44.5,  45.5),
      +  '50':(49.5,  50.5),
      +  '55':(54.05, 55.95),
      +  '60':(59.05, 60.95),
      +  '65':(64.4, 65.6),
      +  '70':(69.4, 70.6),
      +  '80':(79.4, 80.6),
      +  '90':(89.3, 90.7)
      +  }
      +
      +# ISO 7380-1 definitions Class A 
      +# http://www.agrati.com/it/unificati/it/gamma/unificati/home02.htm
      +#          P,   b,     a,   da, dk,  dk_mean,s_mean,t_min, r, k,   e,    w,  
      +iso7380def={
      +  'M3':  (0.50, 18.0, 1.0,  3.6,  5.7,  5.5, 2.03, 1.04, 0.1, 1.65, 2.3,  0.2),
      +  'M4':  (0.70, 20.0, 1.4,  4.7,  7.6,  7.4, 2.54, 1.30, 0.2, 2.20, 2.87, 0.3),
      +  'M5':  (0.80, 22.0, 1.6,  5.7,  9.5,  9.3, 3.05, 1.56, 0.2, 2.75, 3.44, 0.38),
      +  'M6':  (1.00, 24.0, 2.0,  6.8, 10.5, 10.3, 4.05, 2.08, 0.25,3.3,  4.58, 0.74),
      +  'M8':  (1.25, 28.0, 2.5,  9.2, 14.0, 13.8, 5.05, 2.60, 0.4, 4.4,  5.72, 1.05),
      +  'M10': (1.50, 32.0, 3.0, 11.2, 17.5, 17.3, 6.05, 3.12, 0.4, 5.5,  6.86, 1.45),
      +  'M12': (1.75, 36.0, 3.5, 13.7, 21.0, 20.7, 8.06, 4.16, 0.6, 6.6,  9.15, 1.63),
      +  'M16': (2.00, 44.0, 3.5, 17.7, 28.0, 27.8, 10.06,5.20, 0.6, 8.8, 11.43, 2.25)
      +  }
      +
      +# range of typical srew lengths
      +#    min_length,  max_length
      +iso7380range = {
      +  'M3':  ('6', '30'),
      +  'M4':  ('6', '40'),
      +  'M5':  ('8', '50'),
      +  'M6':  ('10', '60'),
      +  'M8': ('12', '80'),
      +  'M10':('16', '90'),
      +  'M12':('20', '90'),
      +  'M16':('25', '90')}
      +
      +# ISO 7380-2 definitions 
      +#          P,   b,     c,   da, dk,    dk_c,s_mean,t_min, r,  k,   e,    w,  
      +iso7380_2def={
      +  'M3':  (0.50, 18.0, 0.7,  3.6,  5.2,  6.9, 2.03, 1.04, 0.1, 1.65, 2.3,  0.2),
      +  'M4':  (0.70, 20.0, 0.8,  4.7,  7.2,  9.4, 2.54, 1.30, 0.2, 2.20, 2.87, 0.3),
      +  'M5':  (0.80, 22.0, 1.0,  5.7,  8.8, 11.8, 3.05, 1.56, 0.2, 2.75, 3.44, 0.38),
      +  'M6':  (1.00, 24.0, 1.2,  6.8, 10.0, 13.6, 4.05, 2.08, 0.25,3.3,  4.58, 0.74),
      +  'M8':  (1.25, 28.0, 1.5,  9.2, 13.2, 17.8, 5.05, 2.60, 0.4, 4.4,  5.72, 1.05),
      +  'M10': (1.50, 32.0, 2.0, 11.2, 16.5, 21.9, 6.05, 3.12, 0.4, 5.5,  6.86, 1.45),
      +  'M12': (1.75, 36.0, 2.4, 13.7, 19.4, 26.0, 8.06, 4.16, 0.6, 6.6,  9.15, 1.63),
      +  'M16': (2.00, 44.0, 2.8, 17.7, 26.0, 34.0, 10.06,5.20, 0.6, 8.8, 11.43, 2.25)
      +  }
      +
      +
      +# DIN 967 definitions: Cross recessed pan head screw with collar
      +#          P,   b,     c,   da,   dk,   r,  k,    rf,  x,    cT,  mH,   mZ 
      +din967def={
      +  'M3':  (0.50, 25.0, 0.7,  3.6,  7.5, 0.1, 2.35,  3.8, 1.25, '1', 3.0, 2.9),
      +  '(M3.5)':(0.60, 38.0, 0.8,  4.1,  9.0, 0.1, 2.60,  4.6, 1.5,  '2', 4.2, 3.9),
      +  'M4':  (0.70, 38.0, 1.0,  4.7, 10.0, 0.2, 3.05,  5.8, 1.75, '2', 4.6, 4.3),
      +  'M5':  (0.80, 38.0, 1.2,  5.7, 11.5, 0.2, 3.55,  6.6, 2.0,  '2', 5.0, 4.7),
      +  'M6':  (1.00, 38.0, 1.6,  6.8, 14.5, 0.25,4.55,  8.2, 2.5,  '3', 7.1, 6.7),
      +  'M8':  (1.25, 38.0, 2.0,  9.2, 19.0, 0.4, 5.90, 11.0, 3.2,  '4', 9.0, 8.8)
      +  }
      +
      +# range of typical srew lengths
      +#    min_length,  max_length
      +din967range = {
      +  'M3':  ('4', '30'),
      +  '(M3.5)':  ('5', '35'),
      +  'M4':  ('5', '40'),
      +  'M5':  ('6', '45'),
      +  'M6':  ('8', '60'),
      +  'M8': ('10', '60')
      +}
      +# Button Head Screw
      +# nom length: l_min, l_max       
      +din967length = {
      +  '4': ( 3.76, 4.24),
      +  '5': ( 4.76, 5.24),
      +  '6': ( 5.76, 6.24),
      +  '8': ( 7.71, 8.29),
      +  '10':( 9.71, 10.29),
      +  '12':(11.65, 12.35),
      +  '14':(13.65, 14.35),
      +  '16':(15.65, 16.35),
      +  '20':(19.58, 20.42),
      +  '25':(24.58, 25.42),
      +  '30':(29.58, 30.42),
      +  '35':(34.5,  35.5),
      +  '40':(39.5,  40.5),
      +  '45':(44.5,  45.5),
      +  '50':(49.5,  50.5),
      +  '55':(54.05, 55.95),
      +  '60':(59.05, 60.95)
      +  }
      +
      +
      +L_iso2009length =['2.5','3','4','5','6','8','10','12','14','16','20', \
      +   '25','30','35','40','45','50','55','60','65','70','75','80'] 
      +# nom length: l_min, l_max       
      +iso2009length = {
      +  '2.5':(2.3,  2.7),
      +  '3': ( 2.8,  3.2),
      +  '4': ( 3.76, 4.24),
      +  '5': ( 4.76, 5.24),
      +  '6': ( 5.76, 6.24),
      +  '8': ( 7.71, 8.29),
      +  '10':( 9.71, 10.29),
      +  '12':(11.65, 12.35),
      +  '14':(13.65, 14.35),
      +  '16':(15.65, 16.35),
      +  '20':(19.58, 20.42),
      +  '25':(24.58, 25.42),
      +  '30':(29.58, 30.42),
      +  '35':(34.5,  35.5),
      +  '40':(39.5,  40.5),
      +  '45':(44.5,  45.5),
      +  '50':(49.5,  50.5),
      +  '55':(54.05, 55.95),
      +  '60':(59.05, 60.95),
      +  '65':(64.05, 65.95),
      +  '70':(69.05, 70.95),
      +  '75':(74.05, 75.95),
      +  '80':(79.05, 80.95)
      +  }
      +
      +
      +# ISO 2009 definitions Class A
      +#          P, a, b, dk_theo, dk_mean, k, n_min, r, t_mean, x
      +iso2009def={
      +   'M1.6':(0.35, 0.7, 25, 3.6, 2.8,  1.0,  0.46, 0.2, 0.4, 0.9),
      +   'M2':  (0.40, 0.8, 25, 4.4, 3.6,  1.2,  0.56, 0.3, 0.5, 1.0),
      +   'M2.5':(0.45, 0.9, 25, 5.5, 4.5,  1.5,  0.66, 0.3, 0.6, 1.1),
      +   'M3':  (0.50, 1.0, 25, 6.3, 5.3,  1.65, 0.86, 0.4, 0.7, 1.25),
      +   '(M3.5)':(0.60, 1.2, 38, 8.2, 7.1,  2.35, 1.06, 0.4, 1.0, 1.5),
      +   'M4':  (0.70, 1.4, 38, 9.4, 8.2,  2.7,  1.26, 0.5, 1.1, 1.75),
      +   'M5':  (0.80, 1.6, 38,10.4, 9.2,  2.7,  1.26, 0.6, 1.2, 2.0),
      +   'M6':  (1.00, 2.0, 38,12.6, 11.2, 3.3,  1.66, 0.7, 1.4, 2.5),
      +   'M8':  (1.25, 2.5, 38,17.3, 15.6, 4.65, 2.06, 1.0, 2.0, 3.2),
      +   'M10': (1.50, 3.0, 38,20.0, 18.1, 5.0,  2.56, 1.2, 2.3, 3.8)}
      +   
      +# range of typical srew lengths
      +#    min_length,  max_length
      +iso2009range = {
      +  'M1.6':('2.5', '16'),
      +  'M2':  ('3', '20'),
      +  'M2.5':('4', '25'),
      +  'M3':  ('5', '30'),
      +  '(M3.5)':('6', '35'),
      +  'M4':  ('6', '40'),
      +  'M5':  ('8', '50'),
      +  'M6':  ('8', '60'),
      +  'M8': ('10', '80'),
      +  'M10':('12', '80')}
      +
      +
      +# ISO 7046 definitions Class A
      +# ISO 7046 Countersunk flat head srews (common head style)
      +# with type H or type Z cross recess
      +# Parameters P, a, b, dk_theo, dk_mean, k, r, x to be read from iso2009def
      +# Length = iso7045length
      +#          cT,   mH,   mZ 
      +iso7046def={
      +  'M1.6':('0', 1.6, 1.6),
      +  'M2':  ('0', 1.9, 1.9),
      +  'M2.5':('1', 2.9, 2.8),
      +  'M3':  ('1', 3.2, 3.0),
      +  '(M3.5)':('2', 4.4, 4.1),
      +  'M4':  ('2', 4.6, 4.4),
      +  'M5':  ('2', 5.2, 4.0),
      +  'M6':  ('3', 6.8, 6.6),
      +  'M8':  ('4', 8.9, 8.8),
      +  'M10': ('4', 10.0,9.8)}
      +
      +# range of typical srew lengths
      +#    min_length,  max_length
      +iso7046range = {
      +  'M1.6':('3', '16'),
      +  'M2':  ('3', '20'),
      +  'M2.5':('3', '25'),
      +  'M3':  ('4', '30'),
      +  '(M3.5)':('5', '35'),
      +  'M4':  ('5', '40'),
      +  'M5':  ('6', '50'),
      +  'M6':  ('8', '60'),
      +  'M8': ('10', '60'),
      +  'M10':('12', '60')}
      +
      +# ISO 2010, ISO 7047 definitions Class A: Raised Countersunk head srews
      +# ISO 2010 slotted screws (common head style)   range = iso2009range
      +# ISO 7047  with type H or type Z cross recess  range = iso7046range
      +# Parameters P, a, b, dk_theo, dk_mean, k, r, x to be read from iso2009def
      +# Length = iso7045length
      +#          rf, t_mean, cT,   mH,   mZ 
      +Raised_countersunk_def={
      +  'M1.6':(3.0,  0.7, '0', 1.9,  1.9),
      +  'M2':  (4.0,  0.9, '0', 2.0,  2.2),
      +  'M2.5':(5.0,  1.1, '1', 3.0,  2.8),
      +  'M3':  (6.0,  1.3, '1', 3.4,  3.1),
      +  '(M3.5)':(8.5,  1.5, '2', 4.8,  4.6),
      +  'M4':  (9.5,  1.8, '2', 5.2,  5.0),
      +  'M5':  (9.5,  2.2, '2', 5.4,  5.3),
      +  'M6':  (12.0, 2.6, '3', 7.3,  7.1),
      +  'M8':  (16.5, 3.5, '4', 9.6,  9.5),
      +  'M10': (19.5, 4.1, '4', 10.4,10.3)}
      +
      +
      +
      +# ISO 14582 definitions 
      +#          P,    a,    b, dk_theo, dk_mean,k,   r,  tt, A, t_mean
      +iso14582def={
      +  'M3':  (0.50, 1.0, 18.0,  7.40,  6.5, 2.20, 0.10, 'T10', 2.80, 1.1),
      +  'M4':  (0.70, 1.4, 20.0, 10.02,  9.0, 3.01, 0.20, 'T20', 3.95, 1.6),
      +  'M5':  (0.80, 1.6, 22.0, 12.00, 10.8, 3.50, 0.20, 'T25', 4.50, 1.8),
      +  'M6':  (1.00, 2.0, 24.0, 14.44, 13.1, 4.22, 0.25, 'T30', 5.60, 2.2),
      +  'M8':  (1.25, 2.5, 28.0, 19.38, 17.8, 5.69, 0.40, 'T45', 7.93, 2.8),
      +  'M10': (1.50, 3.0, 32.0, 23.00, 21.1, 6.50, 0.40, 'T50', 8.95, 3.3)}
      +
      +# range of typical srew lengths
      +#    min_length,  max_length
      +iso14582range = {
      +  'M3':  ('8', '30'),
      +  'M4':  ('8', '40'),
      +  'M5':  ('8', '50'),
      +  'M6':  ('8', '60'),
      +  'M8': ('10', '80'),
      +  'M10':('12', '100')}
      +
      +# nom length: l_min, l_max       
      +iso14582length = {
      +  '8': ( 7.71, 8.29),
      +  '10':( 9.71, 10.29),
      +  '12':(11.65, 12.35),
      +  '14':(13.65, 14.35),
      +  '16':(15.65, 16.35),
      +  '20':(19.58, 20.42),
      +  '25':(24.58, 25.42),
      +  '30':(29.58, 30.42),
      +  '35':(34.5,  35.5),
      +  '40':(39.5,  40.5),
      +  '45':(44.5,  45.5),
      +  '50':(49.5,  50.5),
      +  '55':(54.4, 55.6),
      +  '60':(59.4, 60.6),
      +  '65':(64.4, 65.6),
      +  '70':(69.4, 70.6),
      +  '80':(79.4, 80.6),
      +  '90':(89.3, 90.7),
      +  '100':(99.3, 100.7)
      +  }
      +
      +
      +
      +# ISO 1580 definitions Class A, Slotted pan head screws
      +#           P,    a,   b, dk_max,da,  k, n_min,  r,  rf, t_mean, x
      +iso1580def={
      +  'M1.6':(0.35, 0.7, 25,  3.2, 2.0, 1.0, 0.46, 0.1, 0.5, 0.4, 0.9),
      +  'M2':  (0.4,  0.8, 25,  4.0, 2.6, 1.3, 0.56, 0.1, 0.6, 0.5, 1.0),
      +  'M2.5':(0.45, 0.9, 25,  5.0, 3.1, 1.5, 0.66, 0.1, 0.8, 0.6, 1.1),
      +  'M3':  (0.5,  1.0, 25,  5.6, 3.6, 1.8, 0.86, 0.1, 0.9, 0.7, 1.25),
      +  '(M3.5)':(0.6,  1.2, 38,  7.0, 4.1, 2.1, 1.06, 0.1, 1.0, 0.8, 1.5),
      +  'M4':  (0.7,  1.4, 38,  8.0, 4.7, 2.4, 1.26, 0.2, 1.2, 1.0, 1.75),
      +  'M5':  (0.8,  1.6, 38,  9.5, 5.7, 3.0, 1.26, 0.2, 1.5, 1.2, 2.0),
      +  'M6':  (1.0,  2.0, 38, 12.0, 6.8, 3.6, 1.66, 0.25,1.8, 1.4, 2.5),
      +  'M8':  (1.25, 2.5, 38, 16.0, 9.2, 4.8, 2.06, 0.4, 2.4, 1.9, 3.2),
      +  'M10': (1.50, 3.0, 38, 20.0,11.2, 6.0, 2.56, 0.4, 3.0, 2.4, 3.8)}
      +
      +
      +
      +# ISO 7045 definitions Class A, Pan head screws with type H or type Z
      +# partly used also for ISO 14583 Hexalobular socket pan head screws
      +#   cross recess;    cT = size of cross recess
      +#           P,    a,   b, dk_max,da,  k,   r,   rf,  x,  cT,   mH,   mZ 
      +iso7045def={
      +  'M1.6':(0.35, 0.7, 25,  3.2, 2.0, 1.3, 0.1, 2.5, 0.9, '0', 1.7, 1.6),
      +  'M2':  (0.4,  0.8, 25,  4.0, 2.6, 1.6, 0.1, 3.2, 1.0, '0', 1.9, 2.1),
      +  'M2.5':(0.45, 0.9, 25,  5.0, 3.1, 2.1, 0.1, 4.0, 1.1, '1', 2.7, 2.6),
      +  'M3':  (0.5,  1.0, 25,  5.6, 3.6, 2.4, 0.1, 5.0, 1.25,'1', 3.0, 2.8),
      +  '(M3.5)':(0.6,  1.2, 38,  7.0, 4.1, 2.6, 0.1, 6.0, 1.5, '2', 3.9, 3.9),
      +  'M4':  (0.7,  1.4, 38,  8.0, 4.7, 3.1, 0.2, 6.5, 1.75,'2', 4.4, 4.3),
      +  'M5':  (0.8,  1.6, 38,  9.5, 5.7, 3.7, 0.2, 8.0, 2.0, '2', 4.9, 4.7),
      +  'M6':  (1.0,  2.0, 38, 12.0, 6.8, 4.6, 0.25,10., 2.5, '3', 6.9, 6.7),
      +  'M8':  (1.25, 2.5, 38, 16.0, 9.2, 6.0, 0.4, 13., 3.2, '4', 9.0, 8.8),
      +  'M10': (1.50, 3.0, 38, 20.0,11.2, 7.5, 0.4, 16., 3.8, '4', 10.1,9.9)}
      +
      +# nom length: l_min, l_max       
      +iso7045length = {
      +  '3': ( 2.8,  3.2),
      +  '4': ( 3.76, 4.24),
      +  '5': ( 4.76, 5.24),
      +  '6': ( 5.76, 6.24),
      +  '8': ( 7.71, 8.29),
      +  '10':( 9.71, 10.29),
      +  '12':(11.65, 12.35),
      +  '14':(13.65, 14.35),
      +  '16':(15.65, 16.35),
      +  '20':(19.58, 20.42),
      +  '25':(24.58, 25.42),
      +  '30':(29.58, 30.42),
      +  '35':(34.5,  35.5),
      +  '40':(39.5,  40.5),
      +  '45':(44.5,  45.5),
      +  '50':(49.5,  50.5),
      +  '55':(54.05, 55.95),
      +  '60':(59.05, 60.95)
      +  }
      +
      +# range of typical srew lengths
      +#    min_length,  max_length
      +iso7045range = {
      +  'M1.6':('3', '16'),
      +  'M2':  ('3', '20'),
      +  'M2.5':('3', '25'),
      +  'M3':  ('4', '30'),
      +  '(M3.5)':('5', '35'),
      +  'M4':  ('5', '40'),
      +  'M5':  ('6', '45'),
      +  'M6':  ('8', '60'),
      +  'M8': ('10', '60'),
      +  'M10':('12', '60')}
      +
      +
      +# ISO 14583 Hexalobular socket pan head screws
      +#   hexalobular recess;    tt = size of hexalobular recess
      +
      +#           tt,    A,  t_mean
      +iso14583def={
      +  'M2':  ('T6',  1.75, 0.7),
      +  'M2.5':('T8',  2.40, 1.0),
      +  'M3':  ('T10', 2.80, 1.2),
      +  '(M3.5)':('T15', 3.35, 1.3),
      +  'M4':  ('T20', 3.95, 1.5),
      +  'M5':  ('T25', 4.50, 1.7),
      +  'M6':  ('T30', 5.60, 2.2),
      +  'M8':  ('T45', 7.95, 3.0),
      +  'M10': ('T50', 8.95, 3.8)}
      +
      +
      +#iso14583range = iso7046range
      +#iso14583length = iso7045length
      +
      +# ISO 14584 Hexalobular socket raised countersunk head screws
      +#           P,   b, dk_theo, dk_mean, f,  k,   r,   rf,    x,    tt,    A,  t_mean
      +iso14584def={
      +  'M2':  (0.40, 25.0,  4.4,  3.8,  0.5, 1.20, 0.2,  4.0, 1.00, 'T6',  1.75, 0.7),
      +  'M2.5':(0.45, 25.0,  5.5,  4.7,  0.6, 1.50, 0.3,  5.0, 1.10, 'T8',  2.40, 1.0),
      +  'M3':  (0.50, 25.0,  6.3,  5.5,  0.7, 1.65, 0.4,  6.0, 1.25, 'T10', 2.80, 1.2),
      +  '(M3.5)':(0.60, 38.0,  8.2,  7.3,  0.8, 2.35, 0.4,  8.5, 1.50, 'T15', 3.35, 1.3),
      +  'M4':  (0.70, 38.0,  9.4,  8.4,  1.0, 2.70, 0.5,  9.5, 1.75, 'T20', 3.95, 1.5),
      +  'M5':  (0.80, 38.0, 10.4,  9.3,  1.2, 2.70, 0.6,  9.5, 2.00, 'T25', 4.50, 1.7),
      +  'M6':  (1.00, 38.0, 12.6, 11.3,  1.4, 3.30, 0.7, 12.0, 2.50, 'T30', 5.60, 2.2),
      +  'M8':  (1.25, 38.0, 17.3, 15.8,  2.0, 4.65, 1.0, 16.5, 3.20, 'T45', 7.95, 3.0),
      +  'M10': (1.50, 38.0, 20.0, 18.3,  2.3, 5.00, 1.2, 19.5, 3.80, 'T50', 8.95, 3.8)}
      +
      +
      +# range of typical srew lengths
      +#    min_length,  max_length
      +iso14584range = {
      +  'M2':  ('3', '20'),
      +  'M2.5':('3', '25'),
      +  'M3':  ('4', '30'),
      +  '(M3.5)':('5', '35'),
      +  'M4':  ('5', '40'),
      +  'M5':  ('6', '50'),
      +  'M6':  ('8', '60'),
      +  'M8': ('10', '60'),
      +  'M10':('12', '60')}
      +
      +#iso14584length = iso7045length
      +
      +
      +# ISO 4762 Hexagon socket head cap screws ( Allan screw)
      +# ISO 4762 definitions
      +#           P,   b,  dk_max,  da,  ds_min,   e,    lf,   k,   r,   s_mean, t,    v,   dw,   w
      +iso4762def={
      +  'M1.6':(0.35,  15.0,  3.0,  2.0,  1.46,  1.73, 0.34,  1.6, 0.1,  1.56,  0.7, 0.16, 2.72, 0.55),
      +  'M2':  (0.40,  16.0,  3.8,  2.6,  1.86,  1.73, 0.51,  2.0, 0.1,  1.56,  1.0, 0.2,  3.48, 0.55),
      +  'M2.5':(0.45,  17.0,  4.5,  3.1,  2.36,  2.30, 0.51,  2.5, 0.1,  2.06,  1.1, 0.25, 4.18, 0.85),
      +  'M3':  (0.50,  18.0,  5.5,  3.6,  2.86,  2.87, 0.51,  3.0, 0.1,  2.56,  1.3, 0.3,  5.07, 1.15),
      +  'M4':  (0.70,  20.0,  7.0,  4.7,  3.82,  3.44, 0.60,  4.0, 0.2,  3.06,  2.0, 0.4,  6.53, 1.40),
      +  'M5':  (0.80,  22.0,  8.5,  5.7,  4.82,  4.58, 0.60,  5.0, 0.2,  4.06,  2.5, 0.5,  8.03, 1.9),
      +  'M6':  (1.00,  24.0, 10.0,  6.8,  5.82,  5.72, 0.68,  6.0, 0.25, 5.06,  3.0, 0.6,  9.38, 2.3),
      +  'M8':  (1.25,  28.0, 13.0,  9.2,  7.78,  6.86, 1.02,  8.0, 0.4,  6.06,  4.0, 0.8, 12.33, 3.3),
      +  'M10': (1.50,  32.0, 16.0, 11.2,  9.78,  9.15, 1.02, 10.0, 0.4,  8.07,  5.0, 1.0, 15.33, 4.0),
      +  'M12': (1.75,  36.0, 18.0, 13.7, 11.73, 11.43, 1.45, 12.0, 0.6, 10.07,  6.0, 1.2, 17.23, 4.8),
      +  '(M14)':(2.00,  40.0, 21.0, 15.7, 13.73, 13.72, 1.45, 14.0, 0.6, 12.07,  7.0, 1.4, 20.17, 5.8),
      +  'M16': (2.00,  44.0, 24.0, 17.7, 15.73, 16.00, 1.45, 16.0, 0.6, 14.08,  8.0, 1.6, 23.17, 6.8),
      +  'M20': (2.50,  52.0, 30.0, 22.4, 19.67, 19.44, 2.04, 20.0, 0.8, 17.10, 10.0, 2.0, 28.87, 8.6),
      +  'M24': (3.00,  60.0, 36.0, 26.4, 23.67, 21.73, 2.04, 24.0, 0.8, 19.15, 12.0, 2.0, 34.81, 10.4),
      +  'M30': (3.50,  72.0, 45.0, 33.4, 29.67, 25.15, 2.89, 30.0, 1.0, 22.15, 15.5, 2.4, 43.61, 13.1),
      +  'M36': (4.00,  84.0, 54.0, 39.4, 35.61, 30.85, 2.89, 36.0, 1.0, 27.15, 19.0, 3.0, 52.54, 15.3),
      +  'M42': (4.50,  96.0, 63.0, 45.6, 41.61, 36.58, 3.06, 42.0, 1.2, 32.15, 24.0, 4.2, 61.34, 16.3),
      +  'M48': (5.00, 108.0, 72.0, 52.6, 47.61, 41.14, 3.91, 48.0, 1.6, 36.15, 28.0, 4.8, 70.34, 17.5),
      +  'M56': (5.50, 124.0, 84.0, 63.0, 55.54, 46.84, 5.95, 56.0, 2.0, 41.15, 34.0, 5.6, 82.26, 19.0),
      +  'M64': (6.00, 140.0, 96.0, 71.0, 63.54, 52.54, 5.95, 64.0, 2.0, 46.15, 38.0, 6.4, 94.26, 22.0)
      +  }
      +
      +# nom length: l_min, l_max       
      +iso4762length = {
      +  '2.5':(2.3,  2.7),
      +  '3': ( 2.8,  3.2),
      +  '4': ( 3.76, 4.24),
      +  '5': ( 4.76, 5.24),
      +  '6': ( 5.76, 6.24),
      +  '8': ( 7.71, 8.29),
      +  '10':( 9.71, 10.29),
      +  '12':(11.65, 12.35),
      +  '14':(13.65, 14.35),
      +  '16':(15.65, 16.35),
      +  '20':(19.58, 20.42),
      +  '25':(24.58, 25.42),
      +  '30':(29.58, 30.42),
      +  '35':(34.5,  35.5),
      +  '40':(39.5,  40.5),
      +  '45':(44.5,  45.5),
      +  '50':(49.5,  50.5),
      +  '55':(54.4, 55.6),
      +  '60':(59.4, 60.6),
      +  '65':(64.4, 65.6),
      +  '70':(69.4, 70.6),
      +  '75':(74.4, 75.6),
      +  '80':(79.4, 80.6),
      +  '100':(99.3, 100.7),
      +  '110':(109.3, 110.7),
      +  '120':(119.3, 120.7),
      +  '130':(129.2, 130.8),
      +  '140':(139.2, 130.8),
      +  '150':(149.2, 150.8),
      +  '160':(159.2, 160.8),
      +  '180':(179.2, 180.8),
      +  '200':(199.1, 200.9),
      +  '220':(219.1, 220.9),   
      +  '240':(237.7, 242.3),
      +  '260':(219.1, 220.9),
      +  '280':(219.1, 220.9),
      +  '300':(219.1, 220.9)
      +  }
      +
      +# range of typical srew lengths
      +#    min_length,  max_length
      +iso4762range = {
      +  'M1.6':('2.5', '16'),
      +  'M2':  ('3', '20'),
      +  'M2.5':('4', '25'),
      +  'M3':  ('5', '30'),
      +  '(M3.5)':('6', '35'),
      +  'M4':  ('6', '40'),
      +  'M5':  ('8', '50'),
      +  'M6':  ('8', '60'),
      +  'M8': ('10', '80'),
      +  'M10':('16', '100'),
      +  'M12':('20', '120'),
      +  '(M14)':('25', '140'),
      +  'M16':('25', '160'),
      +  'M20':('16', '100'),
      +  'M24':('40', '200'),
      +  'M30':('45', '200'),
      +  'M36':('55', '200'),   
      +  'M42':('60', '300'),
      +  'M48':('100','300'),
      +  'M56':('110','300'),
      +  'M64':('120','300')
      +  }
      +
      +
      +# ISO 14579 Hexalobular socket head cap screws
      +#   hexalobular recess;    tt = size of hexalobular recess
      +
      +#           tt,    A,  t_mean
      +iso14579def={
      +  'M2':  ( 'T6',  1.75, 0.8),
      +  'M2.5':( 'T8',  2.40, 1.0),
      +  'M3':  ('T10',  2.80, 1.2),
      +  'M4':  ('T20',  3.95, 1.7),
      +  'M5':  ('T25',  4.50, 1.9),
      +  'M6':  ('T30',  5.60, 2.3),
      +  'M8':  ('T45',  7.95, 3.2),
      +  'M10': ('T50',  8.95, 3.8),
      +  'M12': ('T55', 11.35, 5.0),
      +  '(M14)': ('T60', 13.45, 5.8),
      +  'M16': ('T70', 15.70, 6.8),
      +  '(M18)': ('T80', 17.75, 7.8),
      +  'M20': ('T90', 20.20, 9.0),
      +  }
      +
      +# range of typical srew lengths
      +#    min_length,  max_length
      +iso14579range = {
      +  'M2':  ('3', '20'),
      +  'M2.5':('4', '25'),
      +  'M3':  ('5', '30'),
      +  'M4':  ('6', '40'),
      +  'M5':  ('8', '50'),
      +  'M6': ('10', '60'),
      +  'M8': ('12', '80'),
      +  'M10':('16','100'),
      +  'M12':('20','120'),
      +  '(M14)':('25','140'), 
      +  'M16':('25','160'),
      +  '(M18)':('30','180'),
      +  'M20':('30','200'),
      +  } 
      +
      +iso14579length = {
      +  '3': ( 2.8,  3.2),
      +  '4': ( 3.76, 4.24),
      +  '5': ( 4.76, 5.24),
      +  '6': ( 5.76, 6.24),
      +  '8': ( 7.71, 8.29),
      +  '10':( 9.71, 10.29),
      +  '12':(11.65, 12.35),
      +  '16':(15.65, 16.35),
      +  '20':(19.58, 20.42),
      +  '25':(24.58, 25.42),
      +  '30':(29.58, 30.42),
      +  '35':(34.5,  35.5),
      +  '40':(39.5,  40.5),
      +  '45':(44.5,  45.5),
      +  '50':(49.5,  50.5),
      +  '55':(54.4, 55.6),
      +  '60':(59.4, 60.6),
      +  '65':(64.4, 65.6),
      +  '70':(69.4, 70.6),
      +  '80':(79.4, 80.6),
      +  '90':(89.3, 90.7),
      +  '100':(99.3, 100.7),
      +  '110':(109.3, 110.7),
      +  '120':(119.3, 120.7),
      +  '130':(129.2, 130.8),
      +  '140':(139.2, 130.8),
      +  '150':(149.2, 150.8),
      +  '160':(159.2, 160.8),
      +  '180':(179.2, 180.8),
      +  '200':(199.1, 200.9)
      +  }
      +
      +
      +# ISO 10642 Hexagon socket countersunk head screws ( Allan screw)
      +# ISO 10642 definitions
      +#           P,   b,  dk_theo, dk_mean,da,  ds_min,   e,  k,   r,   s_mean, t,    w
      +iso10642def={
      +  'M3':  (0.50, 18.0,  6.72,  6.0,  3.3,  2.86,  2.31, 1.86, 0.1,  2.06,  1.1, 0.25),
      +  'M4':  (0.70, 20.0,  8.96,  8.0,  4.4,  3.82,  2.88, 2.48, 0.2,  2.56,  1.5, 0.45),
      +  'M5':  (0.80, 22.0, 11.20, 10.0,  5.5,  4.82,  3.45, 3.10, 0.2,  3.06,  1.9, 0.66),
      +  'M6':  (1.00, 24.0, 13.44, 12.0,  6.6,  5.82,  4.59, 3.72, 0.25, 4.06,  2.2, 0.70),
      +  'M8':  (1.25, 28.0, 17.92, 16.0,  8.54, 7.78,  5.73, 4.96, 0.4,  5.06,  3.0, 1.16),
      +  'M10': (1.50, 32.0, 22.40, 20.5, 10.62, 9.78,  6.87, 6.20, 0.4,  6.06,  3.6, 1.62),
      +  'M12': (1.75, 36.0, 26.88, 25.0, 13.5, 11.73,  9.15, 7.44, 0.6,  8.07,  4.3, 1.80),
      +  '(M14)': (2.00, 40.0, 30.80, 28.4, 15.5, 13.73, 11.43, 8.40, 0.6, 10.07,  4.5, 1.62),
      +  'M16': (2.00, 44.0, 33.60, 31.0, 17.5, 15.73, 11.43, 8.80, 0.6, 10.07,  4.8, 2.20),
      +  'M20': (2.50, 52.0, 40.32, 38.0, 22.0, 19.67, 13.72, 10.16, 0.8, 12.10,  5.6, 2.20)}
      +
      +# range of typical srew lengths
      +#    min_length,  max_length
      +iso10642range = {
      +  'M3':  ('8', '30'),
      +  'M4':  ('8', '40'),
      +  'M5':  ('8', '50'),
      +  'M6':  ('8', '60'),
      +  'M8': ('10', '80'),
      +  'M10':('12','100'),
      +  'M12':('20','100'),
      +  '(M14)':('25','100'), 
      +  'M16':('30','100'),
      +  'M20':('35','100'),
      +  } 
      +
      +iso10642length = {
      +  '8': ( 7.71, 8.29),
      +  '10':( 9.71, 10.29),
      +  '12':(11.65, 12.35),
      +  '16':(15.65, 16.35),
      +  '20':(19.58, 20.42),
      +  '25':(24.58, 25.42),
      +  '30':(29.58, 30.42),
      +  '35':(34.5,  35.5),
      +  '40':(39.5,  40.5),
      +  '45':(44.5,  45.5),
      +  '50':(49.5,  50.5),
      +  '55':(54.4, 55.6),
      +  '60':(59.4, 60.6),
      +  '65':(64.4, 65.6),
      +  '70':(69.4, 70.6),
      +  '80':(79.4, 80.6),
      +  '90':(89.3, 90.7),
      +  '100':(99.3, 100.7),
      +  }
      +
      +
      +# ISO 7089 definitions  Washer
      +#           d1_min, d2_max, h, h_max
      +iso7089def={
      +  'M1.6':( 1.7,  4.0, 0.3, 0.35),
      +  'M2':  ( 2.2,  5.0, 0.3, 0.35),
      +  'M2.5':( 2.7,  6.0, 0.5, 0.55),
      +  'M3':  ( 3.2,  7.0, 0.5, 0.55),
      +  'M4':  ( 4.3,  9.0, 0.8, 0.90),
      +  'M5':  ( 5.3, 10.0, 1.0, 1.10),
      +  'M6':  ( 6.4, 12.0, 1.6, 1.80),
      +  'M8':  ( 8.4, 16.0, 1.6, 1.80),
      +  'M10': (10.5, 20.0, 2.0, 2.20),
      +  'M12': (13.0, 24.0, 2.5, 2.70),
      +  'M16': (17.0, 30.0, 3.0, 3.30),
      +  'M20': (21.0, 37.0, 3.0, 3.30),
      +  'M24': (25.0, 44.0, 4.0, 4.30),
      +  'M30': (31.0, 56.0, 4.0, 4.30),
      +  'M36': (37.0, 66.0, 5.0, 5.60),
      +  'M42': (45.0, 78.0, 8.0, 9.0),
      +  'M48': (52.0, 92.0, 8.0, 9.0),
      +  'M56': (62.0,105.0,10.0, 11.0),
      +  'M64': (70.0,115.0,10.0, 11.0)
      +  }       
      +
      +
      +# ISO 7090 definitions Plain washers, chamfered - Normal series
      +# chamfer angle 30° / 45°
      +# chamfer      h/4 / h/2
      +#           d1_min, d2_max, h, h_max
      +iso7090def={
      +  'M5':  ( 5.3, 10.0, 1.0, 1.10),
      +  'M6':  ( 6.4, 12.0, 1.6, 1.80),
      +  'M8':  ( 8.4, 16.0, 1.6, 1.80),
      +  'M10': (10.5, 20.0, 2.0, 2.20),
      +  'M12': (13.0, 24.0, 2.5, 2.70),
      +  'M16': (17.0, 30.0, 3.0, 3.30),
      +  'M20': (21.0, 37.0, 3.0, 3.30),
      +  'M24': (25.0, 44.0, 4.0, 4.30),
      +  'M30': (31.0, 56.0, 4.0, 4.30),
      +  'M36': (37.0, 66.0, 5.0, 5.60),
      +  'M42': (45.0, 78.0, 8.0, 9.0),
      +  'M48': (52.0, 92.0, 8.0, 9.0),
      +  'M56': (62.0,105.0,10.0, 11.0),
      +  'M64': (70.0,115.0,10.0, 11.0)
      +  }       
      +
      +
      +# ISO 7091 definitions  Plain washer - Normal series Product Grade C
      +#           d1_min, d2_max, h, h_max
      +iso7091def={
      +  'M1.6':( 1.8,  4.0, 0.3, 0.35),
      +  'M2':  ( 2.4,  5.0, 0.3, 0.35),
      +  'M2.5':( 2.9,  6.0, 0.5, 0.55),
      +  'M3':  ( 3.4,  7.0, 0.5, 0.55),
      +  'M4':  ( 4.5,  9.0, 0.8, 0.90),
      +  'M5':  ( 5.5, 10.0, 1.0, 1.10),
      +  'M6':  ( 6.6, 12.0, 1.6, 1.80),
      +  'M8':  ( 9.0, 16.0, 1.6, 1.80),
      +  'M10': (11.0, 20.0, 2.0, 2.20),
      +  'M12': (13.5, 24.0, 2.5, 2.70),
      +  'M16': (17.5, 30.0, 3.0, 3.30),
      +  'M20': (22.0, 37.0, 3.0, 3.30),
      +  'M24': (26.0, 44.0, 4.0, 4.30),
      +  'M30': (33.0, 56.0, 4.0, 4.30),
      +  'M36': (39.0, 66.0, 5.0, 5.60),
      +  'M42': (45.0, 78.0, 8.0, 9.0),
      +  'M48': (52.0, 92.0, 8.0, 9.0),
      +  'M56': (62.0,105.0,10.0, 11.0),
      +  'M64': (70.0,115.0,10.0, 11.0)
      +  }       
      +
      +
      +# ISO 7092 definitions  Plain washers - Small series
      +#           d1_min, d2_max, h, h_max
      +iso7092def={
      +  'M1.6':( 1.7,  3.5, 0.3, 0.35),
      +  'M2':  ( 2.2,  4.5, 0.3, 0.35),
      +  'M2.5':( 2.7,  5.0, 0.5, 0.55),
      +  'M3':  ( 3.2,  6.0, 0.5, 0.55),
      +  'M4':  ( 4.3,  8.0, 0.5, 0.55),
      +  'M5':  ( 5.3,  9.0, 1.0, 1.10),
      +  'M6':  ( 6.4, 11.0, 1.6, 1.80),
      +  'M8':  ( 8.4, 15.0, 1.6, 1.80),
      +  'M10': (10.5, 18.0, 1.6, 1.80),
      +  'M12': (13.0, 20.0, 2.0, 2.20),
      +  'M16': (17.0, 28.0, 2.5, 2.70),
      +  'M20': (21.0, 34.0, 3.0, 3.30),
      +  'M24': (25.0, 39.0, 4.0, 4.30),
      +  'M30': (31.0, 50.0, 4.0, 4.30),
      +  'M36': (37.0, 60.0, 5.0, 5.60)
      +  }       
      +
      +
      +
      +# ISO 7093-1 definitions  Plain washers - Large series
      +#           d1_min, d2_max, h, h_max
      +iso7093def={
      +  'M3':    ( 3.2,  9.0, 0.8, 0.90),
      +  '(M3.5)':( 3.7, 11.0, 0.8, 0.90),
      +  'M4':    ( 4.3, 12.0, 1.0, 1.10),
      +  'M5':    ( 5.3, 15.0, 1.0, 1.10),
      +  'M6':    ( 6.4, 18.0, 1.6, 1.80),
      +  'M8':    ( 8.4, 24.0, 2.0, 2.20),
      +  'M10':   (10.5, 30.0, 2.5, 2.70),
      +  'M12':   (13.0, 37.0, 3.0, 3.30),
      +  '(M14)': (15.0, 44.0, 3.0, 3.30),
      +  'M16':   (17.0, 50.0, 3.0, 3.30),
      +  '(M18)': (19.0, 56.0, 4.0, 4.30),
      +  'M20':   (21.0, 60.0, 4.0, 4.30),
      +  '(M22)': (23.0, 66.0, 5.0, 5.60),
      +  'M24':   (25.0, 72.0, 5.0, 5.60),
      +  '(M27)': (30.0, 85.0, 6.0, 6.60),
      +  'M30':   (33.0, 92.0, 6.0, 6.60),
      +  '(M33)': (36.0,105.0, 6.0, 6.60),
      +  'M36':   (39.0,110.0, 8.0, 9.00)
      +  }       
      +
      +
      +# ISO 7094 definitions  Plain washers - Extra large series
      +#           d1_min, d2_max, h, h_max
      +iso7094def={
      +  'M5':    ( 5.5, 18.0, 2.0, 2.3),
      +  'M6':    ( 6.6, 22.0, 2.0, 2.3),
      +  'M8':    ( 9.0, 28.0, 3.0, 3.6),
      +  'M10':   (11.0, 34.0, 3.0, 3.6),
      +  'M12':   (13.5, 44.0, 4.0, 4.6),
      +  '(M14)': (15.5, 50.0, 4.0, 4.6),
      +  'M16':   (17.5, 56.0, 5.0, 6.0),
      +  '(M18)': (20.0, 60.0, 5.0, 6.0),
      +  'M20':   (22.0, 72.0, 6.0, 7.0),
      +  '(M22)': (24.0, 80.0, 6.0, 7.0),
      +  'M24':   (26.0, 85.0, 6.0, 7.0),
      +  '(M27)': (30.0, 98.0, 6.0, 7.0),
      +  'M30':   (33.0,105.0, 6.0, 7.0),
      +  '(M33)': (36.0,115.0, 8.0, 9.2),
      +  'M36':   (39.0,125.0, 8.0, 9.2)
      +  }       
      +
      +
      +
      +
      +# ISO 4757:1983 Definition of cross recess type H
      +#          b, e_min, g, f_mean, r, t1, alpha, beta
      +iso4757def = {
      +  '0': (0.61, 0.26, 0.81, 0.34, 0.3, 0.22, 138.0, 7.0 ),
      +  '1': (0.97, 0.41, 1.27, 0.54, 0.5, 0.34, 138.0, 7.0 ),
      +  '2': (1.47, 0.79, 2.29, 0.70, 0.6, 0.61, 140.0, 5.75),
      +  '3': (2.41, 1.98, 3.81, 0.83, 0.8, 1.01, 146.0, 5.75),
      +  '4': (3.48, 2.39, 5.08, 1.23, 1.0, 1.35, 153.0, 7.0 )
      +  }
      +
      +# ISO 10664 Hexalobular internal driving feature for bolts and screws
      +#           A,     B,   Re
      +iso10664def = {
      +  'T6': ( 1.75,  1.205, 0.14),
      +  'T8': ( 2.40,  1.67, 0.20),
      +  'T10':( 2.80,  1.98, 0.24),
      +  'T15':( 3.35,  2.35, 0.28),
      +  'T20':( 3.95,  2.75, 0.32),
      +  'T25':( 4.50,  3.16, 0.39),
      +  'T30':( 5.60,  3.95, 0.46),
      +  'T40':( 6.75,  4.76, 0.56),
      +  'T45':( 7.93,  5.55, 0.59),
      +  'T50':( 8.95,  6.36, 0.78),
      +  'T55':(11.35,  7.92, 0.77),
      +  'T60':(13.45,  9.48, 1.07),
      +  'T70':(15.70, 11.08, 1.20),
      +  'T80':(17.75, 12.64, 1.53),
      +  'T90':(20.20, 14.22, 1.54),
      +  'T100':(22.40,15.81, 1.73)
      +  } 
      +
      +
      +
      +# ISO 4032 Hex-head-nut
      +#           P,   c,  damax, dw,    e,     m,  mw,  s_nom
      +iso4032def={
      +  'M1.6':  (0.35, 0.2, 1.84, 2.9,  3.4,   1.3, 0.8,  3.2),
      +  'M2':    (0.40, 0.2, 2.3,  3.7,  4.4,   1.6, 1.1,  4.0),
      +  'M2.5':  (0.45, 0.2, 2.9,  4.6,  5.5,   2.0, 1.4,  5.0),
      +  'M3':    (0.5,  0.2, 3.45, 5.2,  6.1,   2.4, 1.7,  5.5),
      +  '(M3.5)':(0.6,  0.2, 4.00, 5.7,  6.6,   2.8, 2.0,  6.0),
      +  'M4':    (0.7,  0.2, 4.6,  6.6,  7.7,   3.2, 2.3,  7.0), 
      +  'M5':    (0.8,  0.2, 5.75, 7.5,  8.9,   3.5, 3.5,  8.0),
      +  'M6':    (1.0,  0.2, 6.75, 9.5,  11.05, 4.7, 3.9, 10.0),
      +  'M8':    (1.25, 0.3, 8.75, 11.7, 14.5,  6.8, 5.2, 13.0),
      +  'M10':   (1.50, 0.3, 10.8, 14.7, 17.9,  8.4, 6.4,  16.0),
      +  'M12':   (1.75, 0.3, 13.0, 16.7, 20.1, 10.8, 8.3,  18.0),
      +  '(M14)': (2.00, 0.3, 15.1, 20.5, 24.5, 12.8, 9.7,  22.0),
      +  'M16':   (2.00, 0.4, 17.3, 22.4, 26.9, 14.8, 11.3,  24.0),
      +  '(M18)': (2.50, 0.4, 19.5, 24.9, 29.6, 15.8, 12.3,  27.0),
      +  'M20':   (2.50, 0.4, 21.6, 28.2, 33.7, 18.0, 13.5,  30.0),
      +  '(M22)': (2.50, 0.4, 23.7, 31.4, 37.3, 19.4, 15.0,  34.0),
      +  'M24':   (3.00, 0.4, 25.9, 33.7, 40.1, 21.5, 16.2,  36.0),
      +  '(M27)': (3.00, 0.4, 29.1, 38.0, 45.2, 23.8, 18.0,  41.0),
      +  'M30':   (3.50, 0.4, 32.4, 42.8, 50.9, 25.6, 19.4,  46.0), 
      +  '(M33)': (3.50, 0.4, 35.6, 46.6, 55.4, 28.7, 21.4,  50.0), 
      +  'M36':   (4.00, 0.4, 38.9, 51.2, 61.0, 31.0, 23.5,  55.0),
      +  '(M39)': (4.00, 0.5, 42.1, 55.9, 66.5, 33.4, 24.5,  60.0),
      +  'M42':   (4.50, 0.7, 45.4, 60.0, 71.3, 34.0, 25.9,  65.0),
      +  '(M45)': (4.50, 0.7, 48.6, 64.7, 77.0, 36.0, 27.9,  70.0),
      +  'M48':   (5.00, 0.7, 51.8, 69.5, 82.6, 38.0, 29.1,  75.0),
      +  '(M52)': (5.00, 0.7, 56.2, 74.5, 88.3, 42.0, 32.1,  80.0),
      +  'M56':   (5.50, 0.7, 60.5, 78.7, 93.6, 45.0, 34.7,  85.0),
      +  '(M60)': (5.50, 0.7, 64.8, 82.7, 99.2, 48.0, 38.7,  90.0),
      +  'M64':   (6.00, 0.7, 69.1, 88.2,104.9, 51.0, 39.3,  95.0)
      +  } 
      +
      +
      +
      +# ISO 4033 Hexagon nuts style 2
      +#           P,   c,  damax, dw,    e,     m,  mw,  s_nom
      +iso4033def={
      +  'M5':    (0.8,  0.2, 5.75, 7.5,  8.9,   5.1, 3.5,  8.0),
      +  'M6':    (1.0,  0.2, 6.75, 9.5,  11.05, 5.7, 3.9, 10.0),
      +  'M8':    (1.25, 0.3, 8.75, 11.7, 14.5,  7.5, 5.2, 13.0),
      +  'M10':   (1.50, 0.3, 10.8, 14.7, 17.9,  9.3, 6.4,  16.0),
      +  'M12':   (1.75, 0.3, 13.0, 16.7, 20.1, 12.0, 8.3,  18.0),
      +  '(M14)': (2.00, 0.3, 15.1, 20.5, 24.5, 14.1, 9.7,  22.0),
      +  'M16':   (2.00, 0.4, 17.3, 22.4, 26.9, 16.4, 11.3,  24.0),
      +  'M20':   (2.50, 0.4, 21.6, 28.2, 33.7, 20.3, 13.5,  30.0),
      +  'M24':   (3.00, 0.4, 25.9, 33.7, 40.1, 23.9, 16.2,  36.0),
      +  'M30':   (3.50, 0.4, 32.4, 42.8, 50.9, 28.6, 19.4,  46.0), 
      +  'M36':   (4.00, 0.4, 38.9, 51.2, 61.0, 33.1, 23.5,  55.0)
      +  }
      +
      +
      +
      +
      +
      +
      +# ISO 4035 Hexagon thin nuts, chamfered
      +#           P,   c,  damax, dw,    e,     m,  mw,  s_nom
      +iso4035def={
      +  'M1.6':  (0.35, 0.2, 1.84, 2.9,  3.4,   1.0,  0.8,  3.2),
      +  'M2':    (0.40, 0.2, 2.3,  3.7,  4.4,   1.2,  1.1,  4.0),
      +  'M2.5':  (0.45, 0.2, 2.9,  4.6,  5.5,   1.6,  1.4,  5.0),
      +  'M3':    (0.5,  0.2, 3.45, 5.2,  6.1,   1.8,  1.7,  5.5),
      +  '(M3.5)':(0.6,  0.2, 4.00, 5.7,  6.6,   2.0,  2.0,  6.0),
      +  'M4':    (0.7,  0.2, 4.6,  6.6,  7.7,   2.2,  2.3,  7.0), 
      +  'M5':    (0.8,  0.2, 5.75, 7.5,  8.9,   2.7,  3.5,  8.0),
      +  'M6':    (1.0,  0.2, 6.75, 9.5,  11.05, 3.2,  3.9, 10.0),
      +  'M8':    (1.25, 0.3, 8.75, 11.7, 14.5,  4.0,  5.2, 13.0),
      +  'M10':   (1.50, 0.3, 10.8, 14.7, 17.9,  5.0,  6.4, 16.0),
      +  'M12':   (1.75, 0.3, 13.0, 16.7, 20.1,  6.0,  8.3, 18.0),
      +  '(M14)': (2.00, 0.3, 15.1, 20.5, 24.5,  7.0,  9.7, 22.0),
      +  'M16':   (2.00, 0.4, 17.3, 22.4, 26.9,  8.0, 11.3, 24.0),
      +  '(M18)': (2.50, 0.4, 19.5, 24.9, 29.6,  9.0, 12.3, 27.0),
      +  'M20':   (2.50, 0.4, 21.6, 28.2, 33.7, 10.0, 13.5, 30.0),
      +  '(M22)': (2.50, 0.4, 23.7, 31.4, 37.3, 11.0, 15.0, 34.0),
      +  'M24':   (3.00, 0.4, 25.9, 33.7, 40.1, 12.0, 16.2, 36.0),
      +  '(M27)': (3.00, 0.4, 29.1, 38.0, 45.2, 13.5, 18.0, 41.0),
      +  'M30':   (3.50, 0.4, 32.4, 42.8, 50.9, 15.0, 19.4, 46.0), 
      +  '(M33)': (3.50, 0.4, 35.6, 46.6, 55.4, 16.5, 21.4, 50.0), 
      +  'M36':   (4.00, 0.4, 38.9, 51.2, 61.0, 18.0, 23.5, 55.0),
      +  '(M39)': (4.00, 0.5, 42.1, 55.9, 66.5, 19.5, 24.5, 60.0),
      +  'M42':   (4.50, 0.7, 45.4, 60.0, 71.3, 21.0, 25.9, 65.0),
      +  '(M45)': (4.50, 0.7, 48.6, 64.7, 77.0, 22.5, 27.9, 70.0),
      +  'M48':   (5.00, 0.7, 51.8, 69.5, 82.6, 24.0, 29.1, 75.0),
      +  '(M52)': (5.00, 0.7, 56.2, 74.5, 88.3, 26.0, 32.1, 80.0),
      +  'M56':   (5.50, 0.7, 60.5, 78.7, 93.6, 28.0, 34.7, 85.0),
      +  '(M60)': (5.50, 0.7, 64.8, 82.7, 99.2, 30.0, 38.7, 90.0),
      +  'M64':   (6.00, 0.7, 69.1, 88.2,104.9, 32.0, 39.3, 95.0)
      +  }
      +
      +
      +
      +
      +
      +
      +# ISO 4036 Hexagon thin nuts, unchamfered
      +#           P,      e,   m,  s_nom
      +iso4036def={
      +  'M1.6':  (0.35,  3.4, 1.0,  3.2),
      +  'M2':    (0.40,  4.4, 1.2,  4.0),
      +  'M2.5':  (0.45,  5.5, 1.6,  5.0),
      +  'M3':    (0.5,   6.1, 1.8,  5.5),
      +  '(M3.5)':(0.6,   6.6, 2.0,  6.0),
      +  'M4':    (0.7,   7.7, 2.2,  7.0), 
      +  'M5':    (0.8,   8.9, 2.7,  8.0),
      +  'M6':    (1.0,  10.9, 3.2, 10.0),
      +  'M8':    (1.25, 14.5, 4.0, 13.0),
      +  'M10':   (1.50, 17.9, 5.0, 16.0)}
      +
      +
      +
      +# EN 1661 Hexagon nuts with flange
      +#          P,    damax,  c,  dc,    dw,    e,     m,   mw,   r,   s
      +en1661def={
      +  'M5'   :(0.80,  5.75, 1.0, 11.8,  9.8,  8.79,  5.0, 2.5,  0.30,  8.0), 
      +  'M6'   :(1.00,  6.75, 1.1, 14.2, 12.2, 11.05,  6.0, 3.1,  0.36, 10.0),
      +  'M8'   :(1.25,  8.75, 1.2, 17.9, 15.8, 14.38,  8.0, 4.6,  0.48, 13.0),
      +  'M10'  :(1.50, 10.80, 1.5, 21.8, 19.6, 17.77, 10.0, 5.9,  0.60, 16.0),
      +  'M12'  :(1.75, 13.00, 1.8, 26.0, 23.8, 20.03, 12.0, 6.8,  0.72, 18.0),
      +  '(M14)':(2.00, 15.10, 2.1, 29.9, 27.6, 23.36, 14.0, 7.7,  0.88, 21.0),
      +  'M16'  :(2.00, 17.30, 2.4, 34.5, 31.9, 26.75, 16.0, 8.9,  0.96, 24.0),
      +  'M20'  :(2.50, 21.60, 3.0, 42.8, 39.9, 33.23, 20.0,10.7,  1.20, 30.0)}
      +
      +
      +# Tuning table to get valid shapes
      +#         P, tunIn, tunEx   
      +tuningTable={
      +  'M1.6':(0.35, 516, 516),
      +  'M2':  (0.40, 515, 516),
      +  'M2.5':(0.45, 515, 515),
      +  'M3':  (0.5,  480, 502),
      +  '(M3.5)':(0.6,  480, 502),
      +  'M4':  (0.7,  510, 519), #last value needed for ISO7380
      +  'M5':  (0.8,  510, 510),
      +  'M6':  (1.0,  515, 515),
      +  'M8':  (1.25, 516, 516),
      +  'M10': (1.50, 515, 515),
      +  'M12': (1.75, 513, 513),
      +  '(M14)': (2.00, 513, 513),
      +  'M16': (2.00, 513, 513),
      +  'M20': (2.50, 513, 513),
      +  'M24': (3.00, 513, 513),
      +  '(M27)': (3.00, 513, 513),
      +  'M30': (3.50, 513, 513),
      +  '(M33)': (3.50, 513, 513),
      +  'M36': (4.00, 513, 513),
      +  'M42': (4.50, 515, 515),
      +  '(M45)': (4.50, 515, 515),
      +  'M48': (5.00, 515, 505), # ISO4014: 505, 502 or 488; ISO4017: above 505
      +  '(M52)': (5.00, 508, 508),
      +  'M56': (5.50, 508, 508),
      +  '(M60)': (5.50, 508, 508),
      +  'M64': (6.00, 489, 489) # Nut ISO4032: 489
      +  } 
      +
      +
      +
      +
      +try:
      +  _fromUtf8 = QtCore.QString.fromUtf8
      +except AttributeError:
      +  _fromUtf8 = lambda s: s
      +
      +class Ui_ScrewMaker(object):
      +  def setupUi(self, ScrewMaker):
      +    FCUi = FreeCADGui.UiLoader()
      +
      +    ScrewMaker.setObjectName(_fromUtf8("ScrewMaker"))
      +    ScrewMaker.resize(450, 362)
      +    ScrewMaker.setLocale(QtCore.QLocale(QtCore.QLocale.English, QtCore.QLocale.UnitedKingdom))
      +    self.layoutWidget = QtGui.QWidget(ScrewMaker)
      +    self.layoutWidget.setGeometry(QtCore.QRect(348, 35, 102, 161))
      +    self.layoutWidget.setObjectName(_fromUtf8("layoutWidget"))
      +    self.verticalLayout_2 = QtGui.QVBoxLayout(self.layoutWidget)
      +    #self.verticalLayout_2.setMargin(0)
      +    self.verticalLayout_2.setObjectName(_fromUtf8("verticalLayout_2"))
      +    self.ScrewTypeLabel = QtGui.QLabel(self.layoutWidget)
      +    self.ScrewTypeLabel.setObjectName(_fromUtf8("ScrewTypeLabel"))
      +    self.verticalLayout_2.addWidget(self.ScrewTypeLabel)
      +    self.NomDiaLabel = QtGui.QLabel(self.layoutWidget)
      +    self.NomDiaLabel.setObjectName(_fromUtf8("NomDiaLabel"))
      +    self.verticalLayout_2.addWidget(self.NomDiaLabel)
      +    self.NomLenLabel = QtGui.QLabel(self.layoutWidget)
      +    self.NomLenLabel.setObjectName(_fromUtf8("NomLenLabel"))
      +    self.verticalLayout_2.addWidget(self.NomLenLabel)
      +    self.UserLenLabel = QtGui.QLabel(self.layoutWidget)
      +    self.UserLenLabel.setObjectName(_fromUtf8("UserLenLabel"))
      +    self.verticalLayout_2.addWidget(self.UserLenLabel)
      +
      +    self.layoutWidget1 = QtGui.QWidget(ScrewMaker)
      +    self.layoutWidget1.setGeometry(QtCore.QRect(3, 35, 350, 166))
      +    #self.layoutWidget1.setGeometry(QtCore.QRect(10, 5, 315, 200))
      +    self.layoutWidget1.setObjectName(_fromUtf8("layoutWidget1"))
      +    self.verticalLayout = QtGui.QVBoxLayout(self.layoutWidget1)
      +    #self.verticalLayout.setMargin(0)
      +    self.verticalLayout.setObjectName(_fromUtf8("verticalLayout"))
      +    self.ScrewType = QtGui.QComboBox(self.layoutWidget1)
      +    self.ScrewType.setObjectName(_fromUtf8("ScrewType"))
      +    for i in range(32):
      +      self.ScrewType.addItem(_fromUtf8(""))  # 0
      +
      +    self.verticalLayout.addWidget(self.ScrewType)
      +    self.NominalDiameter = QtGui.QComboBox(self.layoutWidget1)
      +    self.NominalDiameter.setObjectName(_fromUtf8("NominalDiameter"))
      +    for i in range(28):
      +      self.NominalDiameter.addItem(_fromUtf8("")) # 0
      +
      +    self.verticalLayout.addWidget(self.NominalDiameter)
      +    self.NominalLength = QtGui.QComboBox(self.layoutWidget1)
      +    self.NominalLength.setObjectName(_fromUtf8("NominalLength"))
      +    for i in range(48):
      +      self.NominalLength.addItem(_fromUtf8("")) #0
      +
      +    self.verticalLayout.addWidget(self.NominalLength)
      +    #self.UserLen = QtGui.QComboBox(self.layoutWidget1)
      +    self.UserLen = FCUi.createWidget("Gui::InputField")
      +    self.UserLen.setObjectName(_fromUtf8("UserLen"))
      +    #self.UserLen.addItem(_fromUtf8(""))
      +    self.UserLen.setProperty("text", "0 mm")
      +    self.verticalLayout.addWidget(self.UserLen)
      +
      +    #self.CommentLabel = QtGui.QLabel(self.layoutWidget)
      +    self.CommentLabel = QtGui.QLabel(ScrewMaker)
      +    self.CommentLabel.setObjectName(_fromUtf8("CommentLabel"))
      +    self.CommentLabel.setGeometry(QtCore.QRect(10, 184, 411, 21))
      +    #self.verticalLayout.addWidget(self.CommentLabel)
      +
      +
      +
      +
      +
      +    self.layoutWidget2 = QtGui.QWidget(ScrewMaker)
      +    #self.layoutWidget2.setGeometry(QtCore.QRect(10, 200, 321, 83))
      +    self.layoutWidget2.setGeometry(QtCore.QRect(3, 200, 321, 120))
      +    self.layoutWidget2.setObjectName(_fromUtf8("layoutWidget2"))
      +    self.verticalLayout_3 = QtGui.QVBoxLayout(self.layoutWidget2)
      +    #self.verticalLayout_3.setMargin(0)
      +    self.verticalLayout_3.setObjectName(_fromUtf8("verticalLayout_3"))
      +    self.SimpleScrew = QtGui.QRadioButton(self.layoutWidget2)
      +    self.SimpleScrew.setChecked(True)
      +    self.SimpleScrew.setObjectName(_fromUtf8("SimpleScrew"))
      +    self.verticalLayout_3.addWidget(self.SimpleScrew)
      +    self.SymbolThread = QtGui.QRadioButton(self.layoutWidget2)
      +    self.SymbolThread.setObjectName(_fromUtf8("SymbolThread"))
      +    self.verticalLayout_3.addWidget(self.SymbolThread)
      +    self.RealThread = QtGui.QRadioButton(self.layoutWidget2)
      +    self.RealThread.setObjectName(_fromUtf8("RealThread"))
      +    self.verticalLayout_3.addWidget(self.RealThread)
      +    self.MessageLabel = QtGui.QLabel(ScrewMaker)
      +    self.MessageLabel.setGeometry(QtCore.QRect(10, 10, 411, 21))
      +    self.MessageLabel.setProperty("Empty_text", _fromUtf8(""))
      +    self.MessageLabel.setObjectName(_fromUtf8("MessageLabel"))
      +    self.CreateButton = QtGui.QToolButton(ScrewMaker)
      +    self.CreateButton.setGeometry(QtCore.QRect(180, 320, 111, 26))
      +    self.CreateButton.setObjectName(_fromUtf8("CreateButton"))
      +    self.ScrewAvailable = True
      +    
      +    self.simpThread = self.SimpleScrew.isChecked()
      +    self.symThread = self.SymbolThread.isChecked()
      +    self.rThread = self.RealThread.isChecked()
      +    
      +    self.theScrew = Screw()
      +
      +
      +    self.retranslateUi(ScrewMaker)
      +    self.NominalDiameter.setCurrentIndex(5)
      +    self.NominalLength.setCurrentIndex(9)
      +    QtCore.QObject.connect(self.ScrewType, QtCore.SIGNAL(_fromUtf8("currentIndexChanged(int)")), self.guiCheck_Data)
      +    QtCore.QObject.connect(self.CreateButton, QtCore.SIGNAL(_fromUtf8("pressed()")), self.guiCreateScrew)
      +    QtCore.QObject.connect(self.NominalDiameter, QtCore.SIGNAL(_fromUtf8("currentIndexChanged(int)")), self.guiCheck_Data)
      +    QtCore.QObject.connect(self.NominalLength, QtCore.SIGNAL(_fromUtf8("currentIndexChanged(int)")), self.guiCheck_Data)
      +    QtCore.QMetaObject.connectSlotsByName(ScrewMaker)
      +
      +  def retranslateUi(self, ScrewMaker):
      +    ScrewMaker.setWindowTitle(QtGui.QApplication.translate("ScrewMaker", "Screw-Maker 2.0", None, QtGui.QApplication.UnicodeUTF8))
      +    self.ScrewTypeLabel.setText(QtGui.QApplication.translate("ScrewMaker", "Type of Screw", None, QtGui.QApplication.UnicodeUTF8))
      +    self.NomDiaLabel.setText(QtGui.QApplication.translate("ScrewMaker", "Nomimal\nDiameter", None, QtGui.QApplication.UnicodeUTF8))
      +    self.NomLenLabel.setText(QtGui.QApplication.translate("ScrewMaker", "Nominal\nLength", None, QtGui.QApplication.UnicodeUTF8))
      +    self.UserLenLabel.setText(QtGui.QApplication.translate("ScrewMaker", "User length \nfor screw-tap", None, QtGui.QApplication.UnicodeUTF8))
      +    self.CommentLabel.setText(QtGui.QApplication.translate("ScrewMaker", "Values in brackets are not recommended!", None, QtGui.QApplication.UnicodeUTF8))
      +    self.ScrewType.setItemText(0, QtGui.QApplication.translate("ScrewMaker", "ISO4017: Hexagon head screws", None, QtGui.QApplication.UnicodeUTF8))
      +    self.ScrewType.setItemText(1, QtGui.QApplication.translate("ScrewMaker", "ISO4014: Hexagon head bolts", None, QtGui.QApplication.UnicodeUTF8))
      +    self.ScrewType.setItemText(2, QtGui.QApplication.translate("ScrewMaker", "EN1662: Hexagon bolts with flange, small\n   series", None, QtGui.QApplication.UnicodeUTF8))
      +    self.ScrewType.setItemText(3, QtGui.QApplication.translate("ScrewMaker", "EN1665: Hexagon bolts with flange, heavy\n   series", None, QtGui.QApplication.UnicodeUTF8))
      +    self.ScrewType.setItemText(4, QtGui.QApplication.translate("ScrewMaker", "ISO4762: Hexagon socket head cap screws", None, QtGui.QApplication.UnicodeUTF8))
      +    self.ScrewType.setItemText(5, QtGui.QApplication.translate("ScrewMaker", "ISO7380-1: Hexagon socket button head\n    screws", None, QtGui.QApplication.UnicodeUTF8))
      +    self.ScrewType.setItemText(6, QtGui.QApplication.translate("ScrewMaker", "ISO7380-2: Hexagon socket button head\n    screws with collar", None, QtGui.QApplication.UnicodeUTF8))
      +    self.ScrewType.setItemText(7, QtGui.QApplication.translate("ScrewMaker", "DIN967: Cross recessed pan head screws\n    with collar", None, QtGui.QApplication.UnicodeUTF8))
      +    self.ScrewType.setItemText(8, QtGui.QApplication.translate("ScrewMaker", "ISO10642: Hexagon socket countersunk \n    head screws", None, QtGui.QApplication.UnicodeUTF8))
      +    self.ScrewType.setItemText(9, QtGui.QApplication.translate("ScrewMaker", "ISO2009: Slotted countersunk flat head\n    screws", None, QtGui.QApplication.UnicodeUTF8))
      +    self.ScrewType.setItemText(10, QtGui.QApplication.translate("ScrewMaker", "ISO2010: Slotted raised countersunk head\n   screws", None, QtGui.QApplication.UnicodeUTF8))
      +    self.ScrewType.setItemText(11, QtGui.QApplication.translate("ScrewMaker", "ISO1207: Slotted cheese head screws", None, QtGui.QApplication.UnicodeUTF8))
      +    self.ScrewType.setItemText(12, QtGui.QApplication.translate("ScrewMaker", "ISO1580: Slotted pan head screws", None, QtGui.QApplication.UnicodeUTF8))
      +    self.ScrewType.setItemText(13, QtGui.QApplication.translate("ScrewMaker", "ISO7045: Pan head screws, type H cross recess", None, QtGui.QApplication.UnicodeUTF8))
      +    self.ScrewType.setItemText(14, QtGui.QApplication.translate("ScrewMaker", "ISO7046: Countersunk flat head screws\n    H cross recess", None, QtGui.QApplication.UnicodeUTF8))
      +    self.ScrewType.setItemText(15, QtGui.QApplication.translate("ScrewMaker", "ISO7047: Raised countersunk head screws\n    H cross recess", None, QtGui.QApplication.UnicodeUTF8))
      +    self.ScrewType.setItemText(16, QtGui.QApplication.translate("ScrewMaker", "ISO7048: Cheese head screws type H cross recess", None, QtGui.QApplication.UnicodeUTF8))
      +    self.ScrewType.setItemText(17, QtGui.QApplication.translate("ScrewMaker", "ISO14579: Hexalobular socket head cap screws", None, QtGui.QApplication.UnicodeUTF8))
      +    self.ScrewType.setItemText(18, QtGui.QApplication.translate("ScrewMaker", "ISO14580: Hexalobular socket cheese head\n   screws", None, QtGui.QApplication.UnicodeUTF8))
      +    self.ScrewType.setItemText(19, QtGui.QApplication.translate("ScrewMaker", "ISO14583: Hexalobular socket pan head screws", None, QtGui.QApplication.UnicodeUTF8))
      +    self.ScrewType.setItemText(20, QtGui.QApplication.translate("ScrewMaker", "ISO14582: Hexalobular socket countersunk\n    head screws, high head", None, QtGui.QApplication.UnicodeUTF8))
      +    self.ScrewType.setItemText(21, QtGui.QApplication.translate("ScrewMaker", "ISO14584: Hexalobular socket raised\n    countersunk head screws", None, QtGui.QApplication.UnicodeUTF8))
      +    self.ScrewType.setItemText(22, QtGui.QApplication.translate("ScrewMaker", "ISO7089: Plain washers - Normal series", None, QtGui.QApplication.UnicodeUTF8))
      +    self.ScrewType.setItemText(23, QtGui.QApplication.translate("ScrewMaker", "ISO7090: Plain washers, chamfered - Normal series", None, QtGui.QApplication.UnicodeUTF8))
      +    self.ScrewType.setItemText(24, QtGui.QApplication.translate("ScrewMaker", "ISO7092: Plain washers - Small series", None, QtGui.QApplication.UnicodeUTF8))
      +    self.ScrewType.setItemText(25, QtGui.QApplication.translate("ScrewMaker", "ISO7093-1: Plain washer - Large series", None, QtGui.QApplication.UnicodeUTF8))
      +    self.ScrewType.setItemText(26, QtGui.QApplication.translate("ScrewMaker", "ISO7094: Plain washers - Extra large series", None, QtGui.QApplication.UnicodeUTF8))
      +    self.ScrewType.setItemText(27, QtGui.QApplication.translate("ScrewMaker", "ISO4032: Hexagon nuts, Style 1", None, QtGui.QApplication.UnicodeUTF8))
      +    self.ScrewType.setItemText(28, QtGui.QApplication.translate("ScrewMaker", "ISO4033: Hexagon nuts, Style 2", None, QtGui.QApplication.UnicodeUTF8))
      +    self.ScrewType.setItemText(29, QtGui.QApplication.translate("ScrewMaker", "ISO4035: Hexagon thin nuts, chamfered", None, QtGui.QApplication.UnicodeUTF8))
      +    self.ScrewType.setItemText(30, QtGui.QApplication.translate("ScrewMaker", "EN1661: Hexagon nuts with flange", None, QtGui.QApplication.UnicodeUTF8))
      +    self.ScrewType.setItemText(31, QtGui.QApplication.translate("ScrewMaker", "ScrewTap: ISO Screw-Tap", None, QtGui.QApplication.UnicodeUTF8))
      +    
      +    self.NominalDiameter.setItemText(0, QtGui.QApplication.translate("ScrewMaker", "M1.6", None, QtGui.QApplication.UnicodeUTF8))
      +    self.NominalDiameter.setItemText(1, QtGui.QApplication.translate("ScrewMaker", "M2", None, QtGui.QApplication.UnicodeUTF8))
      +    self.NominalDiameter.setItemText(2, QtGui.QApplication.translate("ScrewMaker", "M2.5", None, QtGui.QApplication.UnicodeUTF8))
      +    self.NominalDiameter.setItemText(3, QtGui.QApplication.translate("ScrewMaker", "M3", None, QtGui.QApplication.UnicodeUTF8))
      +    self.NominalDiameter.setItemText(4, QtGui.QApplication.translate("ScrewMaker", "(M3.5)", None, QtGui.QApplication.UnicodeUTF8))
      +    self.NominalDiameter.setItemText(5, QtGui.QApplication.translate("ScrewMaker", "M4", None, QtGui.QApplication.UnicodeUTF8))
      +    self.NominalDiameter.setItemText(6, QtGui.QApplication.translate("ScrewMaker", "M5", None, QtGui.QApplication.UnicodeUTF8))
      +    self.NominalDiameter.setItemText(7, QtGui.QApplication.translate("ScrewMaker", "M6", None, QtGui.QApplication.UnicodeUTF8))
      +    self.NominalDiameter.setItemText(8, QtGui.QApplication.translate("ScrewMaker", "M8", None, QtGui.QApplication.UnicodeUTF8))
      +    self.NominalDiameter.setItemText(9, QtGui.QApplication.translate("ScrewMaker", "M10", None, QtGui.QApplication.UnicodeUTF8))
      +    self.NominalDiameter.setItemText(10, QtGui.QApplication.translate("ScrewMaker", "M12", None, QtGui.QApplication.UnicodeUTF8))
      +    self.NominalDiameter.setItemText(11, QtGui.QApplication.translate("ScrewMaker", "(M14)", None, QtGui.QApplication.UnicodeUTF8))
      +    self.NominalDiameter.setItemText(12, QtGui.QApplication.translate("ScrewMaker", "M16", None, QtGui.QApplication.UnicodeUTF8))
      +    self.NominalDiameter.setItemText(13, QtGui.QApplication.translate("ScrewMaker", "(M18)", None, QtGui.QApplication.UnicodeUTF8))
      +    self.NominalDiameter.setItemText(14, QtGui.QApplication.translate("ScrewMaker", "M20", None, QtGui.QApplication.UnicodeUTF8))
      +    self.NominalDiameter.setItemText(15, QtGui.QApplication.translate("ScrewMaker", "(M22)", None, QtGui.QApplication.UnicodeUTF8))
      +    self.NominalDiameter.setItemText(16, QtGui.QApplication.translate("ScrewMaker", "M24", None, QtGui.QApplication.UnicodeUTF8))
      +    self.NominalDiameter.setItemText(17, QtGui.QApplication.translate("ScrewMaker", "(M27)", None, QtGui.QApplication.UnicodeUTF8))
      +    self.NominalDiameter.setItemText(18, QtGui.QApplication.translate("ScrewMaker", "M30", None, QtGui.QApplication.UnicodeUTF8))
      +    self.NominalDiameter.setItemText(19, QtGui.QApplication.translate("ScrewMaker", "M36", None, QtGui.QApplication.UnicodeUTF8))
      +    self.NominalDiameter.setItemText(20, QtGui.QApplication.translate("ScrewMaker", "(M33)", None, QtGui.QApplication.UnicodeUTF8))
      +    self.NominalDiameter.setItemText(21, QtGui.QApplication.translate("ScrewMaker", "M42", None, QtGui.QApplication.UnicodeUTF8))
      +    self.NominalDiameter.setItemText(22, QtGui.QApplication.translate("ScrewMaker", "(M45)", None, QtGui.QApplication.UnicodeUTF8))
      +    self.NominalDiameter.setItemText(23, QtGui.QApplication.translate("ScrewMaker", "M48", None, QtGui.QApplication.UnicodeUTF8))
      +    self.NominalDiameter.setItemText(24, QtGui.QApplication.translate("ScrewMaker", "(M52)", None, QtGui.QApplication.UnicodeUTF8))
      +    self.NominalDiameter.setItemText(25, QtGui.QApplication.translate("ScrewMaker", "M54", None, QtGui.QApplication.UnicodeUTF8))
      +    self.NominalDiameter.setItemText(26, QtGui.QApplication.translate("ScrewMaker", "(M60)", None, QtGui.QApplication.UnicodeUTF8))
      +    self.NominalDiameter.setItemText(27, QtGui.QApplication.translate("ScrewMaker", "M64", None, QtGui.QApplication.UnicodeUTF8))
      +
      +    self.NominalLength.setItemText(0, QtGui.QApplication.translate("ScrewMaker", "2", None, QtGui.QApplication.UnicodeUTF8))
      +    self.NominalLength.setItemText(1, QtGui.QApplication.translate("ScrewMaker", "2.5", None, QtGui.QApplication.UnicodeUTF8))
      +    self.NominalLength.setItemText(2, QtGui.QApplication.translate("ScrewMaker", "3", None, QtGui.QApplication.UnicodeUTF8))
      +    self.NominalLength.setItemText(3, QtGui.QApplication.translate("ScrewMaker", "4", None, QtGui.QApplication.UnicodeUTF8))
      +    self.NominalLength.setItemText(4, QtGui.QApplication.translate("ScrewMaker", "5", None, QtGui.QApplication.UnicodeUTF8))
      +    self.NominalLength.setItemText(5, QtGui.QApplication.translate("ScrewMaker", "6", None, QtGui.QApplication.UnicodeUTF8))
      +    self.NominalLength.setItemText(6, QtGui.QApplication.translate("ScrewMaker", "8", None, QtGui.QApplication.UnicodeUTF8))
      +    self.NominalLength.setItemText(7, QtGui.QApplication.translate("ScrewMaker", "10", None, QtGui.QApplication.UnicodeUTF8))
      +    self.NominalLength.setItemText(8, QtGui.QApplication.translate("ScrewMaker", "12", None, QtGui.QApplication.UnicodeUTF8))
      +    self.NominalLength.setItemText(9, QtGui.QApplication.translate("ScrewMaker", "16", None, QtGui.QApplication.UnicodeUTF8))
      +    self.NominalLength.setItemText(10, QtGui.QApplication.translate("ScrewMaker", "20", None, QtGui.QApplication.UnicodeUTF8))
      +    self.NominalLength.setItemText(11, QtGui.QApplication.translate("ScrewMaker", "25", None, QtGui.QApplication.UnicodeUTF8))
      +    self.NominalLength.setItemText(12, QtGui.QApplication.translate("ScrewMaker", "30", None, QtGui.QApplication.UnicodeUTF8))
      +    self.NominalLength.setItemText(13, QtGui.QApplication.translate("ScrewMaker", "35", None, QtGui.QApplication.UnicodeUTF8))
      +    self.NominalLength.setItemText(14, QtGui.QApplication.translate("ScrewMaker", "40", None, QtGui.QApplication.UnicodeUTF8))
      +    self.NominalLength.setItemText(15, QtGui.QApplication.translate("ScrewMaker", "45", None, QtGui.QApplication.UnicodeUTF8))
      +    self.NominalLength.setItemText(16, QtGui.QApplication.translate("ScrewMaker", "50", None, QtGui.QApplication.UnicodeUTF8))
      +    self.NominalLength.setItemText(17, QtGui.QApplication.translate("ScrewMaker", "55", None, QtGui.QApplication.UnicodeUTF8))
      +    self.NominalLength.setItemText(18, QtGui.QApplication.translate("ScrewMaker", "60", None, QtGui.QApplication.UnicodeUTF8))
      +    self.NominalLength.setItemText(19, QtGui.QApplication.translate("ScrewMaker", "65", None, QtGui.QApplication.UnicodeUTF8))
      +    self.NominalLength.setItemText(20, QtGui.QApplication.translate("ScrewMaker", "70", None, QtGui.QApplication.UnicodeUTF8))
      +    self.NominalLength.setItemText(21, QtGui.QApplication.translate("ScrewMaker", "80", None, QtGui.QApplication.UnicodeUTF8))
      +    self.NominalLength.setItemText(22, QtGui.QApplication.translate("ScrewMaker", "90", None, QtGui.QApplication.UnicodeUTF8))
      +    self.NominalLength.setItemText(23, QtGui.QApplication.translate("ScrewMaker", "100", None, QtGui.QApplication.UnicodeUTF8))
      +    self.NominalLength.setItemText(24, QtGui.QApplication.translate("ScrewMaker", "110", None, QtGui.QApplication.UnicodeUTF8))
      +    self.NominalLength.setItemText(25, QtGui.QApplication.translate("ScrewMaker", "120", None, QtGui.QApplication.UnicodeUTF8))
      +    self.NominalLength.setItemText(26, QtGui.QApplication.translate("ScrewMaker", "130", None, QtGui.QApplication.UnicodeUTF8))
      +    self.NominalLength.setItemText(27, QtGui.QApplication.translate("ScrewMaker", "140", None, QtGui.QApplication.UnicodeUTF8))
      +    self.NominalLength.setItemText(28, QtGui.QApplication.translate("ScrewMaker", "150", None, QtGui.QApplication.UnicodeUTF8))
      +    self.NominalLength.setItemText(29, QtGui.QApplication.translate("ScrewMaker", "160", None, QtGui.QApplication.UnicodeUTF8))
      +    self.NominalLength.setItemText(30, QtGui.QApplication.translate("ScrewMaker", "180", None, QtGui.QApplication.UnicodeUTF8))
      +    self.NominalLength.setItemText(31, QtGui.QApplication.translate("ScrewMaker", "200", None, QtGui.QApplication.UnicodeUTF8))
      +    self.NominalLength.setItemText(32, QtGui.QApplication.translate("ScrewMaker", "220", None, QtGui.QApplication.UnicodeUTF8))
      +    self.NominalLength.setItemText(33, QtGui.QApplication.translate("ScrewMaker", "240", None, QtGui.QApplication.UnicodeUTF8))
      +    self.NominalLength.setItemText(34, QtGui.QApplication.translate("ScrewMaker", "260", None, QtGui.QApplication.UnicodeUTF8))
      +    self.NominalLength.setItemText(35, QtGui.QApplication.translate("ScrewMaker", "280", None, QtGui.QApplication.UnicodeUTF8))
      +    self.NominalLength.setItemText(36, QtGui.QApplication.translate("ScrewMaker", "300", None, QtGui.QApplication.UnicodeUTF8))
      +    self.NominalLength.setItemText(37, QtGui.QApplication.translate("ScrewMaker", "320", None, QtGui.QApplication.UnicodeUTF8))
      +    self.NominalLength.setItemText(38, QtGui.QApplication.translate("ScrewMaker", "340", None, QtGui.QApplication.UnicodeUTF8))
      +    self.NominalLength.setItemText(39, QtGui.QApplication.translate("ScrewMaker", "360", None, QtGui.QApplication.UnicodeUTF8))
      +    self.NominalLength.setItemText(40, QtGui.QApplication.translate("ScrewMaker", "380", None, QtGui.QApplication.UnicodeUTF8))
      +    self.NominalLength.setItemText(41, QtGui.QApplication.translate("ScrewMaker", "400", None, QtGui.QApplication.UnicodeUTF8))
      +    self.NominalLength.setItemText(42, QtGui.QApplication.translate("ScrewMaker", "420", None, QtGui.QApplication.UnicodeUTF8))
      +    self.NominalLength.setItemText(43, QtGui.QApplication.translate("ScrewMaker", "440", None, QtGui.QApplication.UnicodeUTF8))
      +    self.NominalLength.setItemText(44, QtGui.QApplication.translate("ScrewMaker", "460", None, QtGui.QApplication.UnicodeUTF8))
      +    self.NominalLength.setItemText(45, QtGui.QApplication.translate("ScrewMaker", "480", None, QtGui.QApplication.UnicodeUTF8))
      +    self.NominalLength.setItemText(46, QtGui.QApplication.translate("ScrewMaker", "500", None, QtGui.QApplication.UnicodeUTF8))
      +    self.NominalLength.setItemText(47, QtGui.QApplication.translate("ScrewMaker", "User", None, QtGui.QApplication.UnicodeUTF8))
      +    #self.UserLen.setItemText(0, QtGui.QApplication.translate("ScrewMaker", "regular pitch", None, QtGui.QApplication.UnicodeUTF8))
      +    self.SimpleScrew.setText(QtGui.QApplication.translate("ScrewMaker", "Simple Screw (no thread at all!)", None, QtGui.QApplication.UnicodeUTF8))
      +    self.SymbolThread.setText(QtGui.QApplication.translate("ScrewMaker", "Symbol Thread (not implemented yet)", None, QtGui.QApplication.UnicodeUTF8))
      +    self.RealThread.setText(QtGui.QApplication.translate("ScrewMaker", "Real Thread (takes time, memory intensive)\nMay not work for all screws!", None, QtGui.QApplication.UnicodeUTF8))
      +    self.MessageLabel.setText(QtGui.QApplication.translate("ScrewMaker", "Select your screw type", None, QtGui.QApplication.UnicodeUTF8))
      +    self.MessageLabel.setProperty("Errortext", QtGui.QApplication.translate("ScrewMaker", "Combination not implemented", None, QtGui.QApplication.UnicodeUTF8))
      +    self.MessageLabel.setProperty("OK_text", QtGui.QApplication.translate("ScrewMaker", "Screw is made", None, QtGui.QApplication.UnicodeUTF8))
      +    self.CreateButton.setText(QtGui.QApplication.translate("ScrewMaker", "create", None, QtGui.QApplication.UnicodeUTF8))
      +
      +
      +
      +  def guiCheck_Data(self):
      +    ST_text = str(self.ScrewType.currentText())
      +    ST_text = ST_text.split(':')[0]
      +    ND_text = str(self.NominalDiameter.currentText())
      +    NL_text = str(self.NominalLength.currentText())
      +    M_text, self.ScrewAvailable  = self.theScrew.check_Data(ST_text, ND_text, NL_text)
      +    self.MessageLabel.setText(QtGui.QApplication.translate("ScrewMaker", M_text, None, QtGui.QApplication.UnicodeUTF8))
      +
      +
      +  def guiCreateScrew(self):
      +    #self.simpThread = self.SimpleScrew.isChecked()
      +    #self.symThread = self.SymbolThread.isChecked()
      +    #self.rThread = self.RealThread.isChecked()
      +    if self.SimpleScrew.isChecked():
      +      threadType = 'simple'
      +    if self.SymbolThread.isChecked():
      +      threadType = 'symbol'
      +    if self.RealThread.isChecked():
      +      threadType = 'real'
      +      
      +    ND_text = str(self.NominalDiameter.currentText())
      +    NL_text = str(self.NominalLength.currentText())
      +    ST_text = str(self.ScrewType.currentText())
      +    ST_text = ST_text.split(':')[0]
      +    
      +    if ST_text == 'ScrewTap':
      +      if NL_text == 'User':
      +        textValue = self.UserLen.property("text")
      +        stLength = FreeCAD.Units.parseQuantity(textValue).Value
      +        NL_text = str(stLength)
      +
      +    myObj = self.theScrew.createScrew(ST_text, ND_text, NL_text, threadType)
      +
      +
      +
      +
      +
      +
      +
      +class Screw(object):
      +  def __init__(self):
      +    self.objAvailable = True
      +    self.Tuner = 510
      +  
      +  def check_Data(self, ST_text, ND_text, NL_text):
      +    #FreeCAD.Console.PrintMessage("Data checking" + NL_text + "\n")
      +    #set screw not ok
      +    self.objAvailable = False
      +    M_text = "Select your screw type"
      +    Type_text = ''
      +    if ST_text == 'ISO4017':
      +      table = iso4017head
      +      tab_len = iso4017length
      +      tab_range = iso4017range
      +      Type_text = 'Screw'
      +
      +    if ST_text == 'EN1662':
      +      table = en1662def
      +      tab_len = en1662length
      +      tab_range = en1662range
      +      Type_text = 'Screw'
      +      
      +    if ST_text == 'EN1665':
      +      table = en1665def
      +      tab_len = en1665length
      +      tab_range = en1665range
      +      Type_text = 'Screw'
      +              
      +    if ST_text == 'ISO2009':
      +      table = iso2009def
      +      tab_len = iso2009length
      +      tab_range = iso2009range
      +      Type_text = 'Screw'
      +    if ST_text == 'ISO2010':
      +      table = iso2009def
      +      tab_len = iso2009length
      +      tab_range = iso2009range
      +      Type_text = 'Screw'
      +    if ST_text == 'ISO4762':
      +      table = iso4762def
      +      tab_len = iso4762length
      +      tab_range = iso4762range
      +      Type_text = 'Screw'
      +
      +    if ST_text == 'ISO10642':
      +      table = iso10642def
      +      tab_len = iso10642length
      +      tab_range = iso10642range
      +      Type_text = 'Screw'
      +
      +    if ST_text == 'ISO4014':
      +      table = iso4014head
      +      tab_len = iso4014length
      +      tab_range = iso4014range
      +      Type_text = 'Screw'
      +      
      +    if ST_text == 'ISO1207':
      +      table = iso1207def
      +      tab_len = iso1207length
      +      tab_range = iso1207range
      +      Type_text = 'Screw'
      +    if ST_text == 'ISO1580':
      +      table = iso1580def
      +      tab_len = iso2009length
      +      tab_range = iso2009range
      +      Type_text = 'Screw'
      +
      +    if ST_text == 'ISO7045':
      +      table = iso7045def
      +      tab_len = iso7045length
      +      tab_range = iso7045range
      +      Type_text = 'Screw'
      +
      +    if ST_text == 'ISO7046':
      +      table = iso7046def  # contains only cross recess data
      +      tab_len = iso7045length
      +      tab_range = iso7046range
      +      Type_text = 'Screw'
      +
      +    if ST_text == 'ISO7047':
      +      table = iso2009def  
      +      tab_len = iso7045length
      +      tab_range = iso7046range
      +      Type_text = 'Screw'
      +
      +    if ST_text == 'ISO7048':
      +      table = iso7048def
      +      tab_len = iso7048length
      +      tab_range = iso7048range
      +      Type_text = 'Screw'
      +
      +    if ST_text == 'ISO7380-1':
      +      table = iso7380def
      +      tab_len = iso7380length
      +      tab_range = iso7380range
      +      Type_text = 'Screw'
      +
      +    if ST_text == 'ISO7380-2':
      +      table = iso7380_2def
      +      tab_len = iso7380length
      +      tab_range = iso7380range
      +      Type_text = 'Screw'
      +
      +    if ST_text == 'DIN967':
      +      table = din967def
      +      tab_len = din967length
      +      tab_range = din967range
      +      Type_text = 'Screw'
      +
      +    if ST_text == 'ISO14579':
      +      table = iso14579def
      +      tab_len = iso14579length
      +      tab_range = iso14579range
      +      Type_text = 'Screw'
      +
      +    if ST_text == 'ISO14580':
      +      table = iso14580def
      +      tab_len = iso14580length
      +      tab_range = iso1207range
      +      Type_text = 'Screw'
      +
      +    if ST_text == 'ISO14583':
      +      table = iso14583def
      +      tab_len = iso7045length
      +      tab_range = iso7046range
      +      Type_text = 'Screw'
      +
      +    if ST_text == 'ISO14584':
      +      table = iso14584def
      +      tab_len = iso7045length
      +      tab_range = iso14584range
      +      Type_text = 'Screw'
      +
      +    if ST_text == 'ISO14582':
      +      table = iso14582def
      +      tab_len = iso14582length
      +      tab_range = iso14582range
      +      Type_text = 'Screw'
      +
      +    if ST_text == 'ISO7089':
      +      table = iso7089def
      +      Type_text = 'Washer'
      +
      +    if ST_text == 'ISO7090':
      +      table = iso7090def
      +      Type_text = 'Washer'
      +
      +    if ST_text == 'ISO7091':
      +      table = iso7091def
      +      Type_text = 'Washer'
      +
      +    if ST_text == 'ISO7092':
      +      table = iso7092def
      +      Type_text = 'Washer'
      +
      +    if ST_text == 'ISO7093-1':
      +      table = iso7093def
      +      Type_text = 'Washer'
      +      
      +    if ST_text == 'ISO7094':
      +      table = iso7094def
      +      Type_text = 'Washer'
      +
      +    if ST_text == 'ISO4032':
      +      table = iso4032def
      +      Type_text = 'Nut'
      +
      +    if ST_text == 'ISO4033':
      +      table = iso4033def
      +      Type_text = 'Nut'
      +
      +    if ST_text == 'ISO4035':
      +      table = iso4035def
      +      Type_text = 'Nut'
      +
      +    if ST_text == 'ISO4036':
      +      table = iso4036def
      +      Type_text = 'Nut'
      +
      +    if ST_text == 'EN1661':
      +      table = en1661def
      +      Type_text = 'Nut'
      +
      +    if ST_text == 'ScrewTap':
      +      table = tuningTable
      +      Type_text = 'Screw-Tap'
      +
      +    if ND_text not in table:
      +       ND_min, ND_max = standard_diameters[ST_text]
      +       M_text = ST_text+' has diameters from '+ ND_min +' to ' + ND_max + ' and not ' + ND_text +'!'
      +       self.objAvailable = False
      +       # set scew not ok
      +    else:
      +      if Type_text == 'Screw':
      +        #NL_text = str(self.NominalLength.currentText())
      +        NL_min, NL_max = tab_range[ND_text]
      +        NL_min_float = float(NL_min)
      +        NL_max_float = float(NL_max)
      +        if NL_text == 'User':
      +          M_text = 'User length is only available for the screw-tab!'
      +          self.objAvailable = False
      +        else:
      +          NL_text_float = float(NL_text)
      +          if (NL_text_float<NL_min_float)or(NL_text_float>NL_max_float)or(NL_text not in tab_len):            
      +            if '(' in ND_text:
      +              ND_text = ND_text.lstrip('(').rstrip(')')
      +            M_text = ST_text+'-'+ ND_text +' has lengths from '+ NL_min +' to ' + NL_max + ' and not ' + NL_text +'!'
      +            self.objAvailable = False
      +            # set screw not ok
      +          else:
      +            if '(' in ND_text:
      +              ND_text = ND_text.lstrip('(').rstrip(')')
      +            M_text = ST_text+'-'+ ND_text +'x'+ NL_text +' is in library available! '
      +            self.objAvailable = True
      +            #set screw ok
      +      else: # Washers and Nuts
      +        if not (Type_text == 'Screw-Tap'):
      +          if '(' in ND_text:
      +            ND_text = ND_text.lstrip('(').rstrip(')')
      +          M_text = ST_text+'-'+ ND_text +' is in library available! '
      +          self.objAvailable = True
      +          #set washer/nut ok
      +        else:
      +          if NL_text == 'User':
      +            M_text = 'Screw-tab with user length is ok!'
      +            self.objAvailable = True
      +          else:
      +            #NL_text = str(self.NominalLength.currentText())
      +            if '(' in ND_text:
      +              ND_text = ND_text.lstrip('(').rstrip(')')
      +            M_text = ST_text+'-'+ ND_text +' with '+ NL_text +'mm length is in library available! '
      +            self.objAvailable = True
      +            #set screwTap ok
      +    
      +    #print "Data checking: ", self.NominalLength.currentText(), "\n"
      +    #FreeCAD.Console.PrintMessage("Set Check_result into text " + str(self.objAvailable) + M_text + "\n")
      +    return M_text, self.objAvailable
      +
      +
      +  def createScrew(self, ST_text, ND_text, NL_text, threadType):
      +    #self.simpThread = self.SimpleScrew.isChecked()
      +    #self.symThread = self.SymbolThread.isChecked()
      +    #self.rThread = self.RealThread.isChecked()
      +    if threadType == 'real':
      +      self.rThread = True
      +    else:
      +      self.rThread = False
      +    
      +    if self.objAvailable:
      +      try:
      +        # first we check if valid numbers have been entered
      +        #FreeCAD.Console.PrintMessage("NominalLength: " + self.NominalLength.currentText() + "\n")
      +        #FreeCAD.Console.PrintMessage("NominalDiameter: " + self.NominalDiameter.currentText() + "\n")
      +        #FreeCAD.Console.PrintMessage("SimpleThread: " + str(self.SimpleScrew.isChecked()) + "\n")
      +        #FreeCAD.Console.PrintMessage("SymbolThread: " + str(self.SymbolThread.isChecked()) + "\n")
      +        #FreeCAD.Console.PrintMessage("RealThread: " + str(self.RealThread.isChecked()) + "\n")
      +                   
      +        #ND_text = str(self.NominalDiameter.currentText())
      +        #NL_text = str(self.NominalLength.currentText())
      +        #ST_text = str(self.ScrewType.currentText())
      +        #ST_text = ST_text.split(':')[0]
      +        #dia = float(ND_text.lstrip('M'))
      +        l = float(NL_text)
      +        if ST_text == 'ISO4017':
      +           table = iso4017head
      +        if ST_text == 'ISO4014':
      +           table = iso4014head
      +        if ST_text == 'EN1662':
      +           table = en1662def
      +        if ST_text == 'EN1665':
      +           table = en1665def
      +        if ST_text == 'ISO2009':
      +           table = iso2009def
      +        if ST_text == 'ISO2010':
      +           table = iso2009def
      +        if ST_text == 'ISO4762':
      +           table = iso4762def
      +        if ST_text == 'ISO10642':
      +           table = iso10642def
      +        if ST_text == 'ISO1207':
      +           table = iso1207def
      +        if ST_text == 'ISO1580':
      +           table = iso1580def
      +        if ST_text == 'ISO7045':
      +           table = iso7045def
      +        if ST_text == 'ISO7046':
      +           table = iso7045def
      +        if ST_text == 'ISO7047':
      +           table = iso7045def
      +        if ST_text == 'ISO7048':
      +           table = iso7048def
      +        if ST_text == 'ISO7380-1':
      +           table = iso7380def
      +        if ST_text == 'ISO7380-2':
      +           table = iso7380_2def
      +        if ST_text == 'DIN967':
      +           table = din967def
      +        if ST_text == 'ISO14579':
      +           table = iso14579def
      +        if ST_text == 'ISO14580':
      +           table = iso14580def
      +        if ST_text == 'ISO14582':
      +           table = iso14582def
      +        if ST_text == 'ISO14583':
      +           table = iso14583def
      +        if ST_text == 'ISO14584':
      +           table = iso14584def
      +        if ST_text == 'ISO7089':
      +           table = iso7089def
      +        if ST_text == 'ISO7090':
      +           table = iso7090def
      +        if ST_text == 'ISO7091':
      +           table = iso7091def
      +        if ST_text == 'ISO7092':
      +           table = iso7092def
      +        if ST_text == 'ISO7093-1':
      +           table = iso7093def
      +        if ST_text == 'ISO7094':
      +           table = iso7094def
      +        if ST_text == 'ISO4032':
      +           table = iso4032def
      +        if ST_text == 'ISO4033':
      +           table = iso4033def
      +        if ST_text == 'ISO4035':
      +           table = iso4035def
      +        if ST_text == 'ISO4036':
      +           table = iso4036def
      +        if ST_text == 'EN1661':
      +           table = en1661def
      +        if ST_text == 'ScrewTap':
      +           table = tuningTable
      +        if ND_text not in table:
      +           FreeCAD.Console.PrintMessage("Combination of type "+ST_text \
      +              + " and diameter " + ND_text +" not available!" + "\n")
      +        #self.MessageLabel.setText(QtGui.QApplication.translate("ScrewMaker", "not implemented", None, QtGui.QApplication.UnicodeUTF8))
      +            
      +      except ValueError:
      +        #print "Error! nom_dia and length values must be valid numbers!"
      +        FreeCAD.Console.PrintMessage("Error! nom_dia and length values must be valid numbers!\n")
      +      else:
      +        doc=FreeCAD.activeDocument()
      +        done = False
      +        if (ST_text == 'ISO4014') or (ST_text == 'ISO4017'):
      +          screw = self.makeIso4017_2(ST_text, ND_text,l)
      +          Type_text = 'Screw'
      +          done = True
      +        if (ST_text == 'EN1662') or (ST_text == 'EN1665'):
      +          screw = self.makeEN1662_2(ST_text, ND_text,l)
      +          Type_text = 'Screw'
      +          done = True
      +        if (ST_text == 'ISO2009') or (ST_text == 'ISO2010') or (ST_text == 'ISO1580'):
      +          screw = self.makeSlottedScrew(ST_text, ND_text,l)
      +          Type_text = 'Screw'
      +          done = True
      +        if (ST_text == 'ISO4762') or (ST_text == 'ISO14579'):
      +          screw = self.makeIso4762(ST_text, ND_text,l)
      +          Type_text = 'Screw'
      +          done = True
      +        if (ST_text == 'ISO1207') or (ST_text == 'ISO14580') or (ST_text == 'ISO7048'):
      +          screw = self.makeIso1207(ST_text, ND_text,l)
      +          Type_text = 'Screw'
      +          done = True
      +        if (ST_text == 'ISO7045') or (ST_text == 'ISO14583'):
      +          screw = self.makeIso7045(ST_text, ND_text,l)
      +          Type_text = 'Screw'
      +          done = True
      +        if (ST_text == 'ISO7046') or (ST_text == 'ISO7047') or \
      +          (ST_text == 'ISO14582') or (ST_text == 'ISO14584') or (ST_text == 'ISO10642'):
      +          screw = self.makeIso7046(ST_text, ND_text,l)
      +          Type_text = 'Screw'
      +          done = True
      +        if (ST_text == 'ISO7380-1') or (ST_text == 'ISO7380-2') or (ST_text == 'DIN967'):
      +          screw = self.makeIso7380(ST_text, ND_text,l)
      +          Type_text = 'Screw'
      +          done = True
      +        if (ST_text == 'ISO7089') or (ST_text == 'ISO7090') or (ST_text == 'ISO7093-1') or \
      +          (ST_text == 'ISO7091') or (ST_text == 'ISO7092') or (ST_text == 'ISO7094'):
      +          screw = self.makeIso7089(ST_text, ND_text)
      +          Type_text = 'Washer'
      +          done = True
      +        if (ST_text == 'ISO4032') or (ST_text == 'ISO4033') or (ST_text == 'ISO4035'):
      +          screw = self.makeIso4032(ST_text, ND_text)
      +          Type_text = 'Nut'
      +          done = True
      +        if ST_text == 'EN1661':
      +          screw = self.makeEN1661(ND_text)
      +          Type_text = 'Nut'
      +          done = True
      +        if ST_text == 'ScrewTap':
      +          screw = self.makeScrewTap(ND_text,l)
      +          Type_text = 'Screw-Tap'
      +          done = True
      +        if not done:
      +          FreeCAD.Console.PrintMessage("No valid Screw Type!" +  "\n")
      +        if '(' in ND_text:
      +          ND_text = ND_text.lstrip('(').rstrip(')')
      + 
      +        if Type_text == 'Screw':
      +          label = ST_text + "-" + ND_text +"x"+ NL_text +"_"
      +        else:
      +          if (Type_text == 'Nut'):
      +            label = ST_text + '-' + ND_text +'_'
      +          else:
      +            if Type_text == 'Screw-Tap':
      +              label = ST_text + '-' + ND_text +'x'+ NL_text +'_'
      +            else: # washer
      +              label = ST_text + '-' + ND_text.lstrip('M') +'_'
      +        ScrewObj = doc.addObject("Part::Feature")
      +        ScrewObj.Label=label
      +        ScrewObj.Shape=screw
      +        #FreeCAD.Console.PrintMessage("Placement: "+ str(ScrewObj.Placement) +"\n")
      +        #FreeCAD.Console.PrintMessage("The label: "+ label +"\n")
      +        self.moveScrew(ScrewObj)
      +        #ScrewObj.Label = label
      +        doc.recompute()
      +        # Part.show(screw)
      +        return ScrewObj
      +         
      +  def moveScrew(self, ScrewObj_m):
      +    #FreeCAD.Console.PrintMessage("In Move Screw: " + str(ScrewObj_m) + "\n")
      +
      +    mylist = FreeCAD.Gui.Selection.getSelectionEx()
      +    if (mylist.__len__() == 1):
      +       # check selection
      +       #FreeCAD.Console.PrintMessage("Selektionen: " + str(mylist.__len__()) + "\n")
      +       Pnt1 = None
      +       Axis1 = None
      +       Axis2 = None
      +       
      +       for o in Gui.Selection.getSelectionEx():
      +          #for s in o.SubElementNames:
      +             #FreeCAD.Console.PrintMessage( "name: " + str(s) + "\n")
      +          for s in o.SubObjects:
      +             #FreeCAD.Console.PrintMessage( "object: "+ str(s) + "\n")
      +             if hasattr(s,"Curve"):
      +                #FreeCAD.Console.PrintMessage( "The Object is a Curve!\n")
      +                if hasattr(s.Curve,"Center"):
      +                   """
      +                   FreeCAD.Console.PrintMessage( "The object has a Center!\n")
      +                   FreeCAD.Console.PrintMessage( "Curve attribut. "+ str(s.__getattribute__('Curve')) + "\n")
      +                   FreeCAD.Console.PrintMessage( "Center: "+ str(s.Curve.Center) + "\n")
      +                   FreeCAD.Console.PrintMessage( "Axis: "+ str(s.Curve.Axis) + "\n")
      +                   """
      +                   Pnt1 = s.Curve.Center
      +                   Axis1 = s.Curve.Axis
      +             if hasattr(s,'Surface'):
      +                #print 'the object is a face!'
      +                if hasattr(s.Surface,'Axis'):
      +                   Axis1 = s.Surface.Axis
      +       
      +             if hasattr(s,'Point'):
      +                #FreeCAD.Console.PrintMessage( "the object seems to be a vertex! "+ str(s.Point) + "\n")
      +                Pnt1 = s.Point
      +                   
      +       if (Axis1 != None):
      +          #FreeCAD.Console.PrintMessage( "Got Axis1: " + str(Axis1) + "\n")
      +          Axis2 = Base.Vector(0.0,0.0,1.0)
      +          Axis2_minus = Base.Vector(0.0,0.0,-1.0)
      +          
      +          # Calculate angle
      +          if Axis1 == Axis2:
      +             normvec = Base.Vector(1.0,0.0,0.0)
      +             result = 0.0
      +          else:
      +             if Axis1 == Axis2_minus:
      +                normvec = Base.Vector(1.0,0.0,0.0)
      +                result = math.pi
      +             else:
      +                normvec = Axis1.cross(Axis2) # Berechne Achse der Drehung = normvec
      +                normvec.normalize() # Normalisieren fuer Quaternionenrechnung
      +                #normvec_rot = normvec
      +                result = DraftVecUtils.angle(Axis1, Axis2, normvec) # Winkelberechnung
      +          sin_res = math.sin(result/2.0)
      +          cos_res = math.cos(result/2.0)
      +          normvec.multiply(-sin_res) # Berechnung der Quaternionen-Elemente
      +          #FreeCAD.Console.PrintMessage( "Winkel = "+ str(math.degrees(result)) + "\n")
      +          #FreeCAD.Console.PrintMessage("Normalvektor: "+ str(normvec) + "\n")
      +          
      +          pl = FreeCAD.Placement()
      +          pl.Rotation = (normvec.x,normvec.y,normvec.z,cos_res) #Drehungs-Quaternion
      +          
      +          #FreeCAD.Console.PrintMessage("pl mit Rot: "+ str(pl) + "\n")
      +          #neuPlatz = Part2.Object.Placement.multiply(pl)
      +          neuPlatz = ScrewObj_m.Placement
      +          #FreeCAD.Console.PrintMessage("die Position     "+ str(neuPlatz) + "\n")
      +          neuPlatz.Rotation = pl.Rotation.multiply(ScrewObj_m.Placement.Rotation)
      +          neuPlatz.move(Pnt1)
      +          #FreeCAD.Console.PrintMessage("die rot. Position: "+ str(neuPlatz) + "\n")
      +
      +
      +
      +  # make Washer
      +  def makeIso7089(self,SType ='ISO7089', ThreadType ='M6'):
      +    dia = self.getDia(ThreadType)
      +    #FreeCAD.Console.PrintMessage("die Scheibe mit dia: " + str(dia) + "\n")
      +    if SType == 'ISO7089':
      +      d1_min, d2_max, h, h_max = iso7089def[ThreadType]
      +    if SType == 'ISO7090':
      +      d1_min, d2_max, h, h_max = iso7090def[ThreadType]
      +    if SType == 'ISO7091':
      +      d1_min, d2_max, h, h_max = iso7091def[ThreadType]
      +    if SType == 'ISO7092':
      +      d1_min, d2_max, h, h_max = iso7092def[ThreadType]
      +    if SType == 'ISO7093-1':
      +      d1_min, d2_max, h, h_max = iso7093def[ThreadType]
      +    if SType == 'ISO7094':
      +      d1_min, d2_max, h, h_max = iso7094def[ThreadType]
      +      #FreeCAD.Console.PrintMessage("got: " + SType + "\n")
      +
      +    #FreeCAD.Console.PrintMessage("die Scheibe mit d1_min: " + str(d1_min) + "\n")
      +
      +    #Washer Points  
      +    Pnt0 = Base.Vector(d1_min/2.0,0.0,h_max)
      +    Pnt2 = Base.Vector(d2_max/2.0,0.0,h_max)
      +    Pnt3 = Base.Vector(d2_max/2.0,0.0,0.0)      
      +    Pnt4 = Base.Vector(d1_min/2.0,0.0,0.0)
      +    if SType == 'ISO7090':
      +      Pnt1 = Base.Vector(d2_max/2.0-h_max/4.0,0.0,h_max)
      +      Pnt2 = Base.Vector(d2_max/2.0,0.0,h_max*0.75)
      +      edge1 = Part.makeLine(Pnt0,Pnt1)
      +      edgeCham = Part.makeLine(Pnt1,Pnt2)
      +      edge1 = Part.Wire([edge1, edgeCham])
      +    else:
      +      edge1 = Part.makeLine(Pnt0,Pnt2)
      +    
      +    edge2 = Part.makeLine(Pnt2,Pnt3)
      +    edge3 = Part.makeLine(Pnt3,Pnt4)
      +    edge4 = Part.makeLine(Pnt4,Pnt0)
      +    #FreeCAD.Console.PrintMessage("Edges made Pnt2: " + str(Pnt2) + "\n")
      +
      +    aWire=Part.Wire([edge1,edge2,edge3,edge4])
      +    #Part.show(aWire)
      +    aFace =Part.Face(aWire)
      +    head = aFace.revolve(Base.Vector(0.0,0.0,0.0),Base.Vector(0.0,0.0,1.0),360)
      +    #FreeCAD.Console.PrintMessage("Washer revolved: " + str(dia) + "\n")
      +
      +    return head
      +
      +
      +  # make ISO 2009 Slotted countersunk flat head screws
      +  # make ISO 2010 Slotted raised countersunk head screws
      +  # make ISO 1580 Pan head slotted screw (Code is nearly identical to iso1207)
      +  def makeSlottedScrew(self,SType ='ISO1580', ThreadType ='M6',l=25.0):
      +    dia = self.getDia(ThreadType)
      +    if SType == 'ISO1580':
      +      #FreeCAD.Console.PrintMessage("der Kopf mit l: " + str(l) + "\n")
      +      #P, a, b, dk, dk_mean, da, k, n_min, r, t_min, x = iso1580def[ThreadType]
      +      P, a, b, dk_max, da, k, n_min, r, rf, t_min, x = iso1580def[ThreadType]
      +      #FreeCAD.Console.PrintMessage("der Kopf mit iso: " + str(dk_max) + "\n")
      +      ht = k
      +      headEnd = r
      +      
      +      #Length for calculation of head fillet
      +      sqrt2_ = 1.0/math.sqrt(2.0)
      +      r_fil = rf
      +      beta = math.radians(5.0)   # angle of pan head edge
      +      alpha = math.radians(90.0 - (90.0+5.0)/2.0)
      +      tan_beta = math.tan(beta)      
      +      # top head diameter without fillet
      +      rK_top = dk_max/2.0 - k * tan_beta     
      +      fillet_center_x = rK_top - r_fil + r_fil * tan_beta 
      +      fillet_center_z = k - r_fil
      +      fillet_arc_x = fillet_center_x + r_fil * math.sin(alpha)
      +      fillet_arc_z = fillet_center_z + r_fil * math.cos(alpha)
      +      #FreeCAD.Console.PrintMessage("rK_top: " + str(rK_top) + "\n")
      +      if (b > (l - 1.0*P)):
      +        bmax = l- 1.0*P
      +      else:
      +        bmax = b
      +
      +      #Head Points  
      +      Pnt0 = Base.Vector(0.0,0.0,k)
      +      Pnt2 = Base.Vector(fillet_center_x,0.0,k)
      +      Pnt3 = Base.Vector(fillet_arc_x,0.0,fillet_arc_z)      
      +      Pnt4 = Base.Vector(fillet_center_x + r_fil*math.cos(beta),0.0,fillet_center_z+ r_fil * math.sin(beta))
      +      Pnt5 = Base.Vector(dk_max/2.0,0.0,0.0)
      +      Pnt6 = Base.Vector(dia/2.0+r,0.0,0.0)     #start of fillet between head and shank
      +      Pnt7 = Base.Vector(dia/2.0+r-r*sqrt2_,0.0,-r+r*sqrt2_) #arc-point of fillet
      +      #Pnt8 = Base.Vector(dia/2.0,0.0,-r)        # end of fillet
      +      PntR = Base.Vector(dia/2.0,0.0,-r)        # end of fillet
      +      PntT0 = Base.Vector(0.0,0.0,-r)        # helper point for real thread
      +      
      +      edge1 = Part.makeLine(Pnt0,Pnt2)
      +      edge2 = Part.Arc(Pnt2,Pnt3,Pnt4).toShape()
      +      edge3 = Part.makeLine(Pnt4,Pnt5)
      +      edge4 = Part.makeLine(Pnt5,Pnt6)
      +      edge5 = Part.Arc(Pnt6,Pnt7,PntR).toShape()
      +      headWire=Part.Wire([edge1,edge2,edge3,edge4,edge5])
      +      
      +    if (SType == 'ISO2009') or (SType == 'ISO2010'):
      +      P, a, b, dk_theo, dk_mean, k, n_min, r, t_mean, x = iso2009def[ThreadType]
      +      dk_max = dk_theo
      +      t_min = t_mean
      +      ht = 0.0 # Head heigth of flat head
      +      if (SType == 'ISO2010'):
      +        rf, t_mean, cT, mH, mZ = Raised_countersunk_def[ThreadType]
      +        #Lengths and angles for calculation of head rounding
      +        beta = math.asin(dk_mean /2.0 / rf)   # angle of head edge
      +        tan_beta = math.tan(beta)      
      +        alpha = beta/2.0 # half angle
      +        # heigth of raised head top
      +        ht = rf - (dk_mean/2.0) / tan_beta
      +        h_arc_x = rf * math.sin(alpha) 
      +        h_arc_z = ht - rf + rf * math.cos(alpha)
      +
      +      cham = (dk_theo - dk_mean)/2.0
      +      rad225 = math.radians(22.5)
      +      rad45 = math.radians(45.0)
      +      rtan = r*math.tan(rad225)
      +      headEnd = k + rtan
      +
      +      if (b > l - k - rtan/2.0 - 1.0*P):
      +        bmax = l-k-rtan/2.0 - 1.0*P
      +      else:
      +        bmax = b
      +      
      +      #Head Points
      +      Pnt0 = Base.Vector(0.0,0.0,ht)
      +      Pnt1 = Base.Vector(dk_mean/2.0,0.0,0.0)
      +      Pnt2 = Base.Vector(dk_mean/2.0,0.0,-cham)
      +      Pnt3 = Base.Vector(dia/2.0+r-r*math.cos(rad45),0.0,-k-rtan+r*math.sin(rad45))
      +      # Arc-points
      +      Pnt4 = Base.Vector(dia/2.0+r-r*(math.cos(rad225)),0.0,-k-rtan+r*math.sin(rad225))
      +      PntR = Base.Vector(dia/2.0,0.0,-k-rtan)
      +      #PntA = Base.Vector(dia/2.0,0.0,-a_point)
      +      PntT0 = Base.Vector(0.0,0.0,-k-rtan)        # helper point for real thread
      +  
      +      if (SType == 'ISO2010'): # make raised head rounding
      +        Pnt0arc = Base.Vector(h_arc_x,0.0,h_arc_z)
      +        edge1 = Part.Arc(Pnt0,Pnt0arc,Pnt1).toShape()     
      +      else:
      +        edge1 = Part.makeLine(Pnt0,Pnt1)  # make flat head
      +         
      +      edge2 = Part.makeLine(Pnt1,Pnt2)
      +      edge3 = Part.makeLine(Pnt2,Pnt3)
      +      edgeArc = Part.Arc(Pnt3,Pnt4,PntR).toShape()     
      +      headWire=Part.Wire([edge1,edge2,edge3,edgeArc])
      +
      +
      +    ### make the new code with math.modf(l)
      +    residue, turns = math.modf((bmax)/P)
      +    halfturns = 2*int(turns)
      +    if residue < 0.5:
      +      a_point = l - (turns+1.0) * P 
      +      halfturns = halfturns +1
      +    else:
      +      halfturns = halfturns + 2
      +      a_point = l - (turns+2.0) * P
      +    #halfturns = halfturns + 2
      +    offSet = headEnd - a_point
      +    PntA = Base.Vector(dia/2.0,0.0,-a_point)        # Start of thread
      +
      +
      +    if self.rThread:
      +      edgeZ1 = Part.makeLine(PntR,PntT0)
      +      edgeZ0 = Part.makeLine(PntT0,Pnt0)
      +      aWire=Part.Wire([headWire, edgeZ1, edgeZ0])
      +    
      +    else:
      +      # bolt points
      +      PntB1 = Base.Vector(dia/2.0,0.0,-l)
      +      PntB2 = Base.Vector(0.0,0.0,-l)
      +      
      +      edgeB2 = Part.makeLine(PntB1,PntB2)
      +      edgeZ0 = Part.makeLine(PntB2,Pnt0)
      +
      +      if a_point <= r:
      +        edgeB1 = Part.makeLine(PntR,PntB1)
      +        aWire=Part.Wire([headWire, edgeB1, edgeB2, edgeZ0])
      +      else:
      +        edgeRA = Part.makeLine(PntR,PntA)
      +        edgeB1 = Part.makeLine(PntA,PntB1)
      +        aWire=Part.Wire([headWire, edgeRA, edgeB1, edgeB2, edgeZ0])
      +
      +    aFace =Part.Face(aWire)
      +    head = aFace.revolve(Base.Vector(0.0,0.0,0.0),Base.Vector(0.0,0.0,1.0),360)
      +    #FreeCAD.Console.PrintMessage("der Kopf mit revolve: " + str(dia) + "\n")
      +
      +    #Parameter for slot-recess: dk_max, n_min, k, t_min
      +    slot = Part.makePlane(dk_max, n_min, \
      +        Base.Vector(dk_max/2.0,-n_min/2.0,ht+1.0),Base.Vector(0.0,0.0,-1.0))
      +    slot = slot.extrude(Base.Vector(0.0,0.0,-t_min-1.0))
      +    #Part.show(slot)
      +    head = head.cut(slot)
      +    #FreeCAD.Console.PrintMessage("der Kopf geschnitten: " + str(dia) + "\n")
      +    #Part.show(head)
      +    
      +    if self.rThread:
      +      rthread = self.makeShellthread(dia, P, halfturns, False, offSet)
      +      rthread.translate(Base.Vector(0.0, 0.0,-a_point -2.0*P))
      +      #Part.show(rthread)
      +      headFaces = []
      +      if (SType == 'ISO2009'):
      +        for i in range(0,len(head.Faces)-2):
      +          headFaces.append(head.Faces[i])
      +        headFaces.append(head.Faces[len(head.Faces)-1])
      +          
      +      if (SType == 'ISO1580') or (SType == 'ISO2010'):
      +        for i in range(0,len(head.Faces)-1):
      +          headFaces.append(head.Faces[i])
      +
      +      for threadFace in rthread.Faces:
      +        headFaces.append(threadFace)
      +
      +      newHeadShell = Part.Shell(headFaces)
      +      #Part.show(newHeadShell)
      +      head = Part.Solid(newHeadShell)
      +
      +    return head
      +
      +
      +
      +
      +
      +
      +  # ISO 7045 Pan head screws with type H or type Z cross recess
      +  # ISO 14583 Hexalobular socket pan head screws  
      +  def makeIso7045(self, SType ='ISO7045', ThreadType ='M6',l=25.0):
      +    dia = self.getDia(ThreadType)
      +    #FreeCAD.Console.PrintMessage("der Kopf mit l: " + str(l) + "\n")
      +    P, a, b, dk_max,da, k, r, rf, x, cT, mH, mZ  = iso7045def[ThreadType]
      +    #FreeCAD.Console.PrintMessage("der Kopf mit iso: " + str(dk_max) + "\n")
      +
      +    #Lengths and angles for calculation of head rounding
      +    beta = math.asin(dk_max /2.0 / rf)   # angle of head edge
      +    #print 'beta: ', math.degrees(beta)
      +    tan_beta = math.tan(beta)      
      +
      +
      +    if SType == 'ISO14583':
      +       tt, A, t_mean = iso14583def[ThreadType]
      +       beta_A = math.asin(A/2.0 / rf)   # angle of recess edge
      +       tan_beta_A = math.tan(beta_A)
      +
      +       alpha = (beta_A + beta)/2.0 # half angle
      +       #print 'alpha: ', math.degrees(alpha)
      +       # heigth of head edge
      +       he = k - A/2.0/tan_beta_A + (dk_max/2.0) / tan_beta    
      +       #print 'he: ', he
      +       h_arc_x = rf * math.sin(alpha) 
      +       h_arc_z = k - A/2.0/tan_beta_A + rf * math.cos(alpha)
      +       #FreeCAD.Console.PrintMessage("h_arc_z: " + str(h_arc_z) + "\n")
      +    else:
      +       alpha = beta/2.0 # half angle
      +       #print 'alpha: ', math.degrees(alpha)
      +       # heigth of head edge
      +       he = k - rf + (dk_max/2.0) / tan_beta    
      +       #print 'he: ', he
      +       h_arc_x = rf * math.sin(alpha) 
      +       h_arc_z = k - rf + rf * math.cos(alpha)
      +       #FreeCAD.Console.PrintMessage("h_arc_z: " + str(h_arc_z) + "\n")
      +    
      +    if (b > (l - 1.0*P)):
      +       bmax = l- 1.0*P
      +    else:
      +       bmax = b
      +
      +    ### make the new code with math.modf(l)
      +    residue, turns = math.modf((bmax)/P)
      +    halfturns = 2*int(turns)
      +    if residue < 0.5:
      +      a_point = l - (turns+1.0) * P 
      +      halfturns = halfturns +1
      +    else:
      +      halfturns = halfturns + 2
      +      a_point = l - (turns+2.0) * P
      +    #halfturns = halfturns + 2
      +    offSet = r - a_point
      +    #FreeCAD.Console.PrintMessage("The transition at a: " + str(a) + " turns " + str(turns) + "\n")
      +       
      +    sqrt2_ = 1.0/math.sqrt(2.0)
      +    
      +    #Head Points  
      +    Pnt1 = Base.Vector(h_arc_x,0.0,h_arc_z)
      +    Pnt2 = Base.Vector(dk_max/2.0,0.0,he)      
      +    Pnt3 = Base.Vector(dk_max/2.0,0.0,0.0)
      +    Pnt4 = Base.Vector(dia/2.0+r,0.0,0.0)     #start of fillet between head and shank
      +    Pnt5 = Base.Vector(dia/2.0+r-r*sqrt2_,0.0,-r+r*sqrt2_) #arc-point of fillet
      +    Pnt6 = Base.Vector(dia/2.0,0.0,-r)        # end of fillet
      +    Pnt7 = Base.Vector(dia/2.0,0.0,-a_point)        # Start of thread
      +    #FreeCAD.Console.PrintMessage("Points defined a_point: " + str(a_point) + "\n")
      +
      +
      +    if (SType == 'ISO14583'):
      +      #Pnt0 = Base.Vector(0.0,0.0,k-A/4.0)
      +      Pnt0 = Base.Vector(0.0,0.0,k-A/8.0)
      +      PntFlat = Base.Vector(A/8.0,0.0,k-A/8.0)
      +      PntCham = Base.Vector(A/1.99,0.0,k)
      +      edgeCham0 = Part.makeLine(Pnt0,PntFlat)    
      +      edgeCham1 = Part.makeLine(PntFlat,PntCham)    
      +      edgeCham2 = Part.Arc(PntCham,Pnt1,Pnt2).toShape()   
      +      #edge1 = Part.Wire([edgeCham0,edgeCham1,edgeCham2]) 
      +      edge1 = Part.Wire([edgeCham0,edgeCham1])
      +      edge2 = Part.makeLine(Pnt2,Pnt3)
      +      edge2 = Part.Wire([edgeCham2, edge2])
      +      # Part.show(edge2)
      +      
      +      # Here is the next approach to shorten the head building time
      +      # Make two helper points to create a cutting tool for the 
      +      # recess and recess shell.
      +      PntH1 = Base.Vector(A/1.99,0.0, 2.0*k)
      +      PntH2 = Base.Vector(0.0,0.0, 2.0*k)
      +      edgeH1 = Part.makeLine(PntCham,PntH1)
      +      edgeH2 = Part.makeLine(PntH1,PntH2)
      +      edgeH3 = Part.makeLine(PntH2,Pnt0)
      +      
      +    else:
      +      Pnt0 = Base.Vector(0.0,0.0,k)
      +      edge1 = Part.Arc(Pnt0,Pnt1,Pnt2).toShape()  # make round head
      +      edge2 = Part.makeLine(Pnt2,Pnt3)
      +
      +      # Here is the next approach to shorten the head building time
      +      # Make two helper points to create a cutting tool for the 
      +      # recess and recess shell.
      +      PntH1 = Base.Vector(dk_max/2.0,0.0, 2.0*k)
      +      PntH2 = Base.Vector(0.0,0.0, 2.0*k)
      +      edgeH1 = Part.makeLine(Pnt2,PntH1)
      +      edgeH2 = Part.makeLine(PntH1,PntH2)
      +      edgeH3 = Part.makeLine(PntH2,Pnt0)
      +
      +    edge3 = Part.makeLine(Pnt3,Pnt4)
      +    edge4 = Part.Arc(Pnt4,Pnt5,Pnt6).toShape()
      +    #FreeCAD.Console.PrintMessage("Edges made h_arc_z: " + str(h_arc_z) + "\n")
      +
      +    #if self.RealThread.isChecked():
      +    if self.rThread:
      +      aWire=Part.Wire([edge2,edge3,edge4])
      +    else:
      +      # bolt points
      +      PntB1 = Base.Vector(dia/2.0,0.0,-l)
      +      PntB2 = Base.Vector(0.0,0.0,-l)
      +      edgeB2 = Part.makeLine(PntB1,PntB2)
      +      if a_point <= r:
      +        edgeB1 = Part.makeLine(Pnt6,PntB1)
      +        aWire=Part.Wire([edge2, edge3, edge4, edgeB1, edgeB2])
      +      else:
      +        edge5 = Part.makeLine(Pnt6,Pnt7)
      +        edgeB1 = Part.makeLine(Pnt7,PntB1)
      +        aWire=Part.Wire([edge2, edge3, edge4, edge5, edgeB1, edgeB2])
      +
      +
      +    
      +    hWire = Part.Wire([edge1,edgeH1,edgeH2,edgeH3]) # Cutter for recess-Shell
      +    hFace = Part.Face(hWire)
      +    hCut = hFace.revolve(Base.Vector(0.0,0.0,0.0),Base.Vector(0.0,0.0,1.0),360)
      +    #Part.show(hWire)
      +
      +    headShell = aWire.revolve(Base.Vector(0.0,0.0,0.0),Base.Vector(0.0,0.0,1.0),360)
      +    #head = Part.Solid(headShell)
      +    #Part.show(aWire)
      +    #FreeCAD.Console.PrintMessage("der Kopf mit revolve: " + str(dia) + "\n")
      +    headFaces = headShell.Faces
      + 
      +    if (SType == 'ISO14583'):
      +      recess, recessShell = self.makeIso10664_3(tt, t_mean, k)
      +      recessShell = recessShell.cut(hCut)
      +      topFace = hCut.Faces[1]
      +      topFace = topFace.cut(recess)
      +      #Part.show(topFace)
      +      #Part.show(recessShell)
      +      #Part.show(headShell)
      +      headFaces.append(topFace.Faces[0])
      +      #headFaces.append(hCut.Faces[2])
      +      
      +    else:
      +      #Lengths and angles for calculation of recess positioning
      +      beta_cr = math.asin(mH /2.0 / rf)   # angle of recess edge
      +      tan_beta_cr = math.tan(beta_cr)      
      +      # heigth of cross recess cutting
      +      hcr = k - rf + (mH/2.0) / tan_beta_cr
      +      #print 'hcr: ', hcr
      +      
      +      #Parameter for cross-recess type H: cT, mH
      +      recess, recessShell = self.makeCross_H3(cT, mH, hcr)
      +      recessShell = recessShell.cut(hCut)
      +      topFace = hCut.Faces[0]
      +      topFace = topFace.cut(recess)
      +      #Part.show(topFace)
      +      #Part.show(recessShell)
      +      #Part.show(headShell)
      +      headFaces.append(topFace.Faces[0])
      +        
      +    #Part.show(hCut)
      +    headFaces.extend(recessShell.Faces)
      +      
      +
      +    #if self.RealThread.isChecked():
      +    if self.rThread:
      +      #head = self.cutIsoThread(head, dia, P, turns, l)
      +      rthread = self.makeShellthread(dia, P, halfturns, False, offSet)
      +      rthread.translate(Base.Vector(0.0, 0.0,-a_point -2.0*P))
      +      #head = head.fuse(rthread)
      +      #Part.show(rthread)
      +      for threadFace in rthread.Faces:
      +        headFaces.append(threadFace)
      +
      +    newHeadShell = Part.Shell(headFaces)
      +    #Part.show(newHeadShell)
      +    head = Part.Solid(newHeadShell)
      +
      +    return head
      +
      +
      +  # make Cheese head screw
      +  # ISO 1207 slotted screw
      +  # ISO 7048 cross recessed screw
      +  # ISO 14580 Hexalobular socket cheese head screws
      +  def makeIso1207(self,SType ='ISO1207', ThreadType ='M6',l=25.0):
      +    dia = self.getDia(ThreadType)
      +    '''
      +    if '(' in TreadType:
      +      threadString = ThreadType.lstrip('(M')
      +      dia = float(ThreadType.rstrip(')'))
      +    else:
      +      dia=float(ThreadType.lstrip('M'))
      +    '''
      +    #FreeCAD.Console.PrintMessage("der Kopf mit l: " + str(l) + "\n")
      +    if (SType == 'ISO1207') or (SType == 'ISO14580'):
      +       P, a, b, dk, dk_mean, da, k, n_min, r, t_min, x = iso1207def[ThreadType]
      +    if SType == 'ISO7048':
      +       P, a, b, dk, dk_mean, da, k, r, x, cT, mH, mZ  = iso7048def[ThreadType]
      +    if (SType == 'ISO14580'):
      +       tt, k, A, t_min = iso14580def[ThreadType]
      +
      +    #FreeCAD.Console.PrintMessage("der Kopf mit iso: " + str(dk) + "\n")
      +    
      +    #Length for calculation of head fillet
      +    r_fil = r*2.0
      +    beta = math.radians(5.0)   # angle of cheese head edge
      +    alpha = math.radians(90.0 - (90.0+5.0)/2.0)
      +    tan_beta = math.tan(beta)      
      +    # top head diameter without fillet
      +    rK_top = dk/2.0 - k * tan_beta     
      +    fillet_center_x = rK_top - r_fil + r_fil * tan_beta 
      +    fillet_center_z = k - r_fil
      +    fillet_arc_x = fillet_center_x + r_fil * math.sin(alpha)
      +    fillet_arc_z = fillet_center_z + r_fil * math.cos(alpha)
      +    #FreeCAD.Console.PrintMessage("rK_top: " + str(rK_top) + "\n")
      +
      +    if (b > (l - 1.0*P)):
      +       bmax = l- 1.0*P
      +    else:
      +       bmax = b
      +
      +    ### make the new code with math.modf(l)
      +    residue, turns = math.modf((bmax)/P)
      +    halfturns = 2*int(turns)
      +    if residue < 0.5:
      +      a_point = l - (turns+1.0) * P 
      +      halfturns = halfturns +1
      +    else:
      +      halfturns = halfturns + 2
      +      a_point = l - (turns+2.0) * P
      +    #halfturns = halfturns + 2
      +    offSet = r - a_point
      +      
      +    sqrt2_ = 1.0/math.sqrt(2.0)
      +
      +    #Head Points  
      +    Pnt2 = Base.Vector(fillet_center_x,0.0,k)
      +    Pnt3 = Base.Vector(fillet_arc_x,0.0,fillet_arc_z)      
      +    Pnt4 = Base.Vector(fillet_center_x + r_fil*math.cos(beta),0.0,fillet_center_z+ r_fil * math.sin(beta))
      +    Pnt5 = Base.Vector(dk/2.0,0.0,0.0)
      +    Pnt6 = Base.Vector(dia/2.0+r,0.0,0.0)     #start of fillet between head and shank
      +    Pnt7 = Base.Vector(dia/2.0+r-r*sqrt2_,0.0,-r+r*sqrt2_) #arc-point of fillet
      +    Pnt8 = Base.Vector(dia/2.0,0.0,-r)        # end of fillet
      +    Pnt9 = Base.Vector(dia/2.0,0.0,-a_point)        # Start of thread
      +    #FreeCAD.Console.PrintMessage("Points defined fillet_center_x: " + str(fillet_center_x) + "\n")
      +
      +    if (SType == 'ISO14580'):
      +      # Pnt0 = Base.Vector(0.0,0.0,k-A/4.0) #Center Point for countersunk
      +      Pnt0 = Base.Vector(0.0,0.0,k-A/8.0) #Center Point for flat countersunk
      +      PntFlat = Base.Vector(A/8.0,0.0,k-A/8.0) # End of flat part
      +      Pnt1 = Base.Vector(A/1.99,0.0,k)     #countersunk edge at head
      +      edgeCham0 = Part.makeLine(Pnt0,PntFlat)    
      +      edgeCham1 = Part.makeLine(PntFlat,Pnt1)
      +      edgeCham2 = Part.makeLine(Pnt1,Pnt2)
      +      edge1 = Part.Wire([edgeCham1,edgeCham2]) # make head with countersunk
      +      PntH1 = Base.Vector(A/1.99,0.0, 2.0*k)
      +    
      +    else:
      +      Pnt0 = Base.Vector(0.0,0.0,k)
      +      edge1 = Part.makeLine(Pnt0,Pnt2)  # make flat head
      +
      +        
      +    edge2 = Part.Arc(Pnt2,Pnt3,Pnt4).toShape()
      +    edge3 = Part.makeLine(Pnt4,Pnt5)
      +    edge4 = Part.makeLine(Pnt5,Pnt6)
      +    edge5 = Part.Arc(Pnt6,Pnt7,Pnt8).toShape()
      +    #FreeCAD.Console.PrintMessage("Edges made fillet_center_z: " + str(fillet_center_z) + "\n")
      +
      +    if SType == 'ISO1207':
      +      #Parameter for slot-recess: dk, n_min, k, t_min
      +      recess = Part.makePlane(dk, n_min, \
      +        Base.Vector(dk/2.0,-n_min/2.0,k+1.0),Base.Vector(0.0,0.0,-1.0))
      +      recess = recess.extrude(Base.Vector(0.0,0.0,-t_min-1.0))
      +
      +      if self.rThread:
      +        Pnt11 = Base.Vector(0.0,0.0,-r)        # helper point for real thread
      +        edgeZ1 = Part.makeLine(Pnt8,Pnt11)
      +        edgeZ0 = Part.makeLine(Pnt11,Pnt0)
      +        aWire=Part.Wire([edge1,edge2,edge3,edge4,edge5, \
      +            edgeZ1, edgeZ0])
      +      else:
      +        # bolt points
      +        PntB1 = Base.Vector(dia/2.0,0.0,-l)
      +        PntB2 = Base.Vector(0.0,0.0,-l)
      +        
      +        edgeB2 = Part.makeLine(PntB1,PntB2)
      +  
      +        if a_point <= r:
      +          edgeB1 = Part.makeLine(Pnt8,PntB1)
      +          aWire=Part.Wire([edge1,edge2,edge3,edge4,edge5, \
      +              edgeB1, edgeB2])
      +        else:
      +          edge6 = Part.makeLine(Pnt8,Pnt9)
      +          edgeB1 = Part.makeLine(Pnt9,PntB1)
      +          aWire=Part.Wire([edge1,edge2,edge3,edge4,edge5,edge6, \
      +              edgeB1, edgeB2])
      +
      +      aFace =Part.Face(aWire)
      +      head = aFace.revolve(Base.Vector(0.0,0.0,0.0),Base.Vector(0.0,0.0,1.0),360.0)
      +      head = head.cut(recess)
      +      # FreeCAD.Console.PrintMessage("der Kopf geschnitten: " + str(dia) + "\n")
      +      #Part.show(head)
      +      if self.rThread:
      +        screwFaces = []
      +        for i in range(0, len(head.Faces)-1):
      +          screwFaces.append(head.Faces[i])
      +        rthread = self.makeShellthread(dia, P, halfturns, False, offSet)
      +        rthread.translate(Base.Vector(0.0, 0.0,-a_point -2.0*P))
      +        for threadFace in rthread.Faces:
      +          screwFaces.append(threadFace)
      +  
      +        screwShell = Part.Shell(screwFaces)
      +        head = Part.Solid(screwShell)
      +
      +
      +
      +    else:
      +      if self.rThread:
      +        aWire=Part.Wire([edge1,edge2,edge3,edge4,edge5 ])
      +      else:
      +        # bolt points
      +        PntB1 = Base.Vector(dia/2.0,0.0,-l)
      +        PntB2 = Base.Vector(0.0,0.0,-l)
      +        
      +        edgeB2 = Part.makeLine(PntB1,PntB2)
      +  
      +        if a_point <= r:
      +          edgeB1 = Part.makeLine(Pnt8,PntB1)
      +          aWire=Part.Wire([edge1,edge2,edge3,edge4,edge5, \
      +              edgeB1, edgeB2])
      +        else:
      +          edge6 = Part.makeLine(Pnt8,Pnt9)
      +          edgeB1 = Part.makeLine(Pnt9,PntB1)
      +          aWire=Part.Wire([edge1,edge2,edge3,edge4,edge5,edge6, \
      +              edgeB1, edgeB2])
      +  
      +      #aFace =Part.Face(aWire)
      +      headShell = aWire.revolve(Base.Vector(0.0,0.0,0.0),Base.Vector(0.0,0.0,1.0),360.0)
      +      #FreeCAD.Console.PrintMessage("der Kopf mit revolve: " + str(dia) + "\n")
      +      
      +      if SType == 'ISO7048':
      +        # hCut should be just a cylinder
      +        hCut = Part.makeCylinder(fillet_center_x,k,Pnt0)
      +        recess, recessShell = self.makeCross_H3(cT, mH, k)
      +        recessShell = recessShell.cut(hCut)
      +        topFace = headShell.Faces[0].cut(recess)
      +        screwFaces = [topFace.Faces[0]]
      +        screwFaces.extend(recessShell.Faces)
      +      if (SType == 'ISO14580'):
      +        # Ring-cutter for recess shell
      +        PntH2 = Base.Vector(A/8.0,0.0, 2.0*k)
      +        edgeH1 = Part.makeLine(Pnt1,PntH1)
      +        edgeH2 = Part.makeLine(PntH1,PntH2)
      +        edgeH3 = Part.makeLine(PntH2,PntFlat)
      +        hWire = Part.Wire([edgeCham1,edgeH1,edgeH2,edgeH3]) # Cutter for recess-Shell
      +        hFace = Part.Face(hWire)
      +        hCut = hFace.revolve(Base.Vector(0.0,0.0,0.0),Base.Vector(0.0,0.0,1.0),360)
      +        #Part.show(hWire)
      +  
      +        recess, recessShell = self.makeIso10664_3(tt, t_min, k)
      +        recessShell = recessShell.cut(hCut)
      +        topFace = headShell.Faces[0].cut(recess)
      +        screwFaces = [topFace.Faces[0]]
      +        screwFaces.extend(recessShell.Faces)
      +        
      +      for i in range(1, len(headShell.Faces)):
      +        screwFaces.append(headShell.Faces[i])
      +          
      +      if self.rThread:
      +        #head = self.cutIsoThread(head, dia, P, turns, l)
      +        rthread = self.makeShellthread(dia, P, halfturns, False, offSet)
      +        rthread.translate(Base.Vector(0.0, 0.0,-a_point -2.0*P))
      +        #head = head.fuse(rthread)
      +        #Part.show(rthread)
      +        for threadFace in rthread.Faces:
      +          screwFaces.append(threadFace)
      +  
      +      screwShell = Part.Shell(screwFaces)
      +      head = Part.Solid(screwShell)
      +
      +    return head
      +
      +
      +  
      +  # make the ISO 4017 Hex-head-screw
      +  # make the ISO 4014 Hex-head-bolt
      +  def makeIso4017_2(self,SType ='ISO4017', ThreadType ='M6',l=40.0):
      +    dia = self.getDia(ThreadType)
      +    #FreeCAD.Console.PrintMessage("der Kopf mit l: " + str(l) + "\n")
      +    if SType == 'ISO4017':
      +      P, c, dw, e,k,r,s = iso4017head[ThreadType]
      +      
      +      ### make the new code with math.modf(l)
      +      residue, turns = math.modf((l-1*P)/P)
      +      halfturns = 2*int(turns)
      +
      +    if SType == 'ISO4014':
      +      P, b1, b2, b3, c, dw, e, k, r, s = iso4014head[ThreadType]
      +      if l<= 125.0:
      +         b = b1
      +      else:
      +         if l<= 200.0:
      +            b = b2
      +         else:
      +            b = b3
      +  
      +      ### make the new code with math.modf(l)
      +      residue, turns = math.modf((b)/P)
      +      halfturns = 2*int(turns)
      +      
      +    if residue < 0.5:
      +      a = l - (turns+1.0) * P 
      +      halfturns = halfturns +1
      +    else:
      +      halfturns = halfturns + 2
      +      a = l - (turns+2.0) * P
      +    #halfturns = halfturns + 2
      +    offSet = r - a
      +    
      +    sqrt2_ = 1.0/math.sqrt(2.0)
      +    cham = (e-s)*math.sin(math.radians(15)) # needed for chamfer at head top
      +  
      +    #Head Points  Usage of k, s, cham, c, dw, dia, r, a
      +    #FreeCAD.Console.PrintMessage("der Kopf mit halfturns: " + str(halfturns) + "\n")
      +    Pnt0 = Base.Vector(0.0,0.0,k)
      +    Pnt2 = Base.Vector(s/2.0,0.0,k)
      +    Pnt3 = Base.Vector(s/math.sqrt(3.0),0.0,k-cham)
      +    Pnt4 = Base.Vector(s/math.sqrt(3.0),0.0,c)
      +    Pnt5 = Base.Vector(dw/2.0,0.0,c)
      +    Pnt6 = Base.Vector(dw/2.0,0.0,0.0)
      +    Pnt7 = Base.Vector(dia/2.0+r,0.0,0.0)     #start of fillet between head and shank
      +    Pnt8 = Base.Vector(dia/2.0+r-r*sqrt2_,0.0,-r+r*sqrt2_) #arc-point of fillet
      +    Pnt9 = Base.Vector(dia/2.0,0.0,-r)        # end of fillet
      +    Pnt10 = Base.Vector(dia/2.0,0.0,-a)        # Start of thread
      +    
      +    edge1 = Part.makeLine(Pnt0,Pnt2)
      +    edge2 = Part.makeLine(Pnt2,Pnt3)
      +    edge3 = Part.makeLine(Pnt3,Pnt4)
      +    edge4 = Part.makeLine(Pnt4,Pnt5)
      +    edge5 = Part.makeLine(Pnt5,Pnt6)
      +    edge6 = Part.makeLine(Pnt6,Pnt7)
      +    edge7 = Part.Arc(Pnt7,Pnt8,Pnt9).toShape()
      +    
      +    # create cutting tool for hexagon head 
      +    # Parameters s, k, outer circle diameter =  e/2.0+10.0     
      +    extrude = self.makeHextool(s, k, s*2.0)
      +    
      +    #if self.RealThread.isChecked():
      +    if self.rThread:
      +      Pnt11 = Base.Vector(0.0,0.0,-r)        # helper point for real thread
      +      edgeZ1 = Part.makeLine(Pnt9,Pnt11)
      +      edgeZ0 = Part.makeLine(Pnt11,Pnt0)
      +      aWire=Part.Wire([edge1,edge2,edge3,edge4,edge5,edge6,edge7, \
      +          edgeZ1, edgeZ0])
      +
      +      aFace =Part.Face(aWire)
      +      head = aFace.revolve(Base.Vector(0.0,0.0,0.0),Base.Vector(0.0,0.0,1.0),360.0)
      +      #FreeCAD.Console.PrintMessage("der Kopf mit revolve: " + str(dia) + "\n")
      +    
      +      # Part.show(extrude)
      +      head = head.cut(extrude)   
      +      #FreeCAD.Console.PrintMessage("der Kopf geschnitten: " + str(dia) + "\n")
      +      #Part.show(head)
      +      
      +      headFaces = []
      +      for i in range(18):
      +        headFaces.append(head.Faces[i])
      +
      +      if (dia < 3.0) or (dia > 5.0):
      +        rthread = self.makeShellthread(dia, P, halfturns, True, offSet)
      +        rthread.translate(Base.Vector(0.0, 0.0,-a-2.0*P))
      +        #rthread.translate(Base.Vector(0.0, 0.0,-2.0*P))
      +        #Part.show(rthread)
      +        for tFace in rthread.Faces:
      +          headFaces.append(tFace)
      +        headShell = Part.Shell(headFaces)
      +        head = Part.Solid(headShell)
      +      else:
      +        rthread = self.makeShellthread(dia, P, halfturns, False, offSet)
      +        rthread.translate(Base.Vector(0.0, 0.0,-a-2.0*P))
      +        #rthread.translate(Base.Vector(0.0, 0.0,-2.0*P))
      +        #Part.show(rthread)
      +        for tFace in rthread.Faces:
      +          headFaces.append(tFace)
      +        headShell = Part.Shell(headFaces)
      +        head = Part.Solid(headShell)
      +        cyl = self.cutChamfer(dia, P, l)
      +        #FreeCAD.Console.PrintMessage("vor Schnitt Ende: " + str(dia) + "\n")
      +        head = head.cut(cyl)
      +
      +    else:
      +      # bolt points
      +      cham_t = P*math.sqrt(3.0)/2.0*17.0/24.0
      +      
      +      PntB0 = Base.Vector(0.0,0.0,-a)
      +      PntB1 = Base.Vector(dia/2.0,0.0,-l+cham_t)
      +      PntB2 = Base.Vector(dia/2.0-cham_t,0.0,-l)
      +      PntB3 = Base.Vector(0.0,0.0,-l)
      +      
      +      edgeB1 = Part.makeLine(Pnt10,PntB1)
      +      edgeB2 = Part.makeLine(PntB1,PntB2)
      +      edgeB3 = Part.makeLine(PntB2,PntB3)
      +      
      +      edgeZ0 = Part.makeLine(PntB3,Pnt0)
      +      if a <= r:
      +        edgeB1 = Part.makeLine(Pnt9,PntB1)
      +        aWire=Part.Wire([edge1,edge2,edge3,edge4,edge5,edge6,edge7, \
      +            edgeB1, edgeB2, edgeB3, edgeZ0])
      +        
      +      else:
      +        edge8 = Part.makeLine(Pnt9,Pnt10)
      +        edgeB1 = Part.makeLine(Pnt10,PntB1)
      +        aWire=Part.Wire([edge1,edge2,edge3,edge4,edge5,edge6,edge7,edge8, \
      +            edgeB1, edgeB2, edgeB3, edgeZ0])
      +
      +      aFace =Part.Face(aWire)
      +      head = aFace.revolve(Base.Vector(0.0,0.0,0.0),Base.Vector(0.0,0.0,1.0),360.0)
      +      #FreeCAD.Console.PrintMessage("der Kopf mit revolve: " + str(dia) + "\n")
      +    
      +      # Part.show(extrude)
      +      head = head.cut(extrude)   
      +      #FreeCAD.Console.PrintMessage("der Kopf geschnitten: " + str(dia) + "\n")
      +    
      +    return head
      +
      +
      +  # EN 1662 Hex-head-bolt with flange - small series
      +  # EN 1665 Hexagon bolts with flange, heavy series
      +  def makeEN1662_2(self,SType ='EN1662', ThreadType ='M8',l=25.0):
      +    dia = self.getDia(ThreadType)
      +    #FreeCAD.Console.PrintMessage("der Kopf mit l: " + str(l) + "\n")
      +    if SType == 'EN1662':
      +       P, b0, b1, b2, b3, c, dc, dw, e, k, kw,f, r1, s = en1662def[ThreadType]
      +    else:
      +       P, b0, b1, b2, b3, c, dc, dw, e, k, kw,f, r1, s = en1665def[ThreadType]
      +    if l< b0:
      +       b = l - 2*P
      +    else:
      +       if l<= 125.0:
      +          b = b1
      +       else:
      +          if l<= 200.0:
      +             b = b2
      +          else:
      +             b = b3
      +    
      +    #FreeCAD.Console.PrintMessage("der Kopf mit isoEN1662: " + str(c) + "\n")
      +    cham = s*(2.0/math.sqrt(3.0)-1.0)*math.sin(math.radians(25)) # needed for chamfer at head top
      +
      +    ### make the new code with math.modf(l)
      +    residue, turns = math.modf((b)/P)
      +    halfturns = 2*int(turns)
      +    if residue < 0.5:
      +      a_point = l - (turns+1.0) * P 
      +      halfturns = halfturns +1
      +    else:
      +      halfturns = halfturns + 2
      +      a_point = l - (turns+2.0) * P
      +    #halfturns = halfturns + 2
      +    offSet = r1 - a_point
      +
      +    sqrt2_ = 1.0/math.sqrt(2.0)
      + 
      +    # Flange is made with a radius of c
      +    beta = math.radians(25.0)
      +    tan_beta = math.tan(beta)
      +    
      +    # Calculation of Arc points of flange edge using dc and c
      +    arc1_x = dc/2.0 - c/2.0 + (c/2.0)*math.sin(beta)
      +    arc1_z = c/2.0 + (c/2.0)*math.cos(beta)
      +    
      +    hF = arc1_z + (arc1_x -s/2.0) * tan_beta  # height of flange at center
      +    
      +    kmean = arc1_z + (arc1_x - s/math.sqrt(3.0)) * tan_beta + kw * 1.1 + cham
      +    #kmean = k * 0.95
      +    
      +
      +    #Hex-Head Points
      +    #FreeCAD.Console.PrintMessage("der Kopf mit math a: " + str(a_point) + "\n")
      +    PntH0 = Base.Vector(0.0,0.0,kmean*0.9)
      +    PntH1 = Base.Vector(s/2.0*0.8 - r1/2.0,0.0,kmean*0.9)
      +    PntH1a = Base.Vector(s/2.0*0.8-r1/2.0+r1/2.0*sqrt2_,0.0,kmean*0.9 +r1/2.0 -r1/2.0*sqrt2_)
      +    PntH1b = Base.Vector(s/2.0*0.8,0.0,kmean*0.9 +r1/2.0)
      +    PntH2 = Base.Vector(s/2.0*0.8,0.0,kmean -r1)
      +    PntH2a = Base.Vector(s/2.0*0.8+r1-r1*sqrt2_,0.0,kmean -r1 +r1*sqrt2_)
      +    PntH2b = Base.Vector(s/2.0*0.8 + r1 ,0.0,kmean)
      +    PntH3 = Base.Vector(s/2.0,0.0,kmean)
      +    #PntH4 = Base.Vector(s/math.sqrt(3.0),0.0,kmean-cham)   #s/math.sqrt(3.0)
      +    #PntH5 = Base.Vector(s/math.sqrt(3.0),0.0,c)
      +    #PntH6 = Base.Vector(0.0,0.0,c)
      +    
      +    edgeH1 = Part.makeLine(PntH0,PntH1)
      +    edgeH2 = Part.Arc(PntH1,PntH1a,PntH1b).toShape()
      +    edgeH3 = Part.makeLine(PntH1b,PntH2)
      +    edgeH3a = Part.Arc(PntH2,PntH2a,PntH2b).toShape()   
      +    edgeH3b = Part.makeLine(PntH2b,PntH3)
      +
      +    hWire=Part.Wire([edgeH1,edgeH2,edgeH3,edgeH3a,edgeH3b])
      +    topShell = hWire.revolve(Base.Vector(0.0,0.0,0.0),Base.Vector(0.0,0.0,1.0),360)
      +    #Part.show(hWire)
      +    #Part.show(topShell)
      +    
      +    # create a cutter ring to generate the chamfer at the top of the hex
      +    chamHori = s/math.sqrt(3.0) - s/2.0
      +    PntC1 = Base.Vector(s/2.0-chamHori,0.0,kmean+kmean)
      +    PntC2 = Base.Vector(s/math.sqrt(3.0)+chamHori,0.0,kmean+kmean)
      +    PntC3 = Base.Vector(s/2.0-chamHori,0.0,kmean+cham)
      +    PntC4 = Base.Vector(s/math.sqrt(3.0)+chamHori,0.0,kmean-cham-cham)   #s/math.sqrt(3.0)
      +    edgeC1 = Part.makeLine(PntC3, PntC1)
      +    edgeC2 = Part.makeLine(PntC1, PntC2)
      +    edgeC3 = Part.makeLine(PntC2, PntC4)
      +    edgeC4 = Part.makeLine(PntC4, PntC3)
      +    cWire = Part.Wire([edgeC4, edgeC1, edgeC2, edgeC3])
      +    cFace = Part.Face(cWire)
      +    chamCut = cFace.revolve(Base.Vector(0.0,0.0,0.0),Base.Vector(0.0,0.0,1.0),360)
      +    #Part.show(cWire)
      +    #Part.show(chamCut)
      +
      +
      +    # create hexagon
      +    mhex=Base.Matrix()
      +    mhex.rotateZ(math.radians(60.0))
      +    polygon = []
      +    vhex=Base.Vector(s/math.sqrt(3.0),0.0,kmean)
      +    for i in range(6):
      +       polygon.append(vhex)
      +       vhex = mhex.multiply(vhex)
      +    polygon.append(vhex)
      +    hexagon = Part.makePolygon(polygon)
      +    hexFace = Part.Face(hexagon)
      +    solidHex = hexFace.extrude(Base.Vector(0.0,0.0,c-kmean))
      +    #Part.show(solidHex)
      +    hexCham = solidHex.cut(chamCut)
      +    #Part.show(hexCham)
      +    
      +    topFaces = topShell.Faces
      +    
      +    topFaces.append(hexCham.Faces[6])
      +    topFaces.append(hexCham.Faces[12])
      +    topFaces.append(hexCham.Faces[14])
      +    topFaces.append(hexCham.Faces[13])
      +    topFaces.append(hexCham.Faces[8])
      +    topFaces.append(hexCham.Faces[2])
      +    topFaces.append(hexCham.Faces[1])
      +    
      +    hexFaces = [hexCham.Faces[5], hexCham.Faces[11], hexCham.Faces[10]]
      +    hexFaces.extend([hexCham.Faces[9], hexCham.Faces[3], hexCham.Faces[0]])
      +    hexShell = Part.Shell(hexFaces)
      +
      +    # Center of flange:
      +    Pnt0 = Base.Vector(0.0,0.0,hF)
      +    Pnt1 = Base.Vector(s/2.0,0.0,hF)
      +    
      +    # arc edge of flange:
      +    Pnt2 = Base.Vector(arc1_x,0.0,arc1_z)
      +    Pnt3 = Base.Vector(dc/2.0,0.0,c/2.0)
      +    Pnt4 = Base.Vector((dc-c)/2.0,0.0,0.0)
      +    
      +    Pnt5 = Base.Vector(dia/2.0+r1,0.0,0.0)     #start of fillet between head and shank
      +    Pnt6 = Base.Vector(dia/2.0+r1-r1*sqrt2_,0.0,-r1+r1*sqrt2_) #arc-point of fillet
      +    Pnt7 = Base.Vector(dia/2.0,0.0,-r1)        # end of fillet
      +    Pnt8 = Base.Vector(dia/2.0,0.0,-a_point)        # Start of thread
      +    
      +    edge1 = Part.makeLine(Pnt0,Pnt1)
      +    edge2 = Part.makeLine(Pnt1,Pnt2)
      +    edge3 = Part.Arc(Pnt2,Pnt3,Pnt4).toShape()
      +    edge4 = Part.makeLine(Pnt4,Pnt5)
      +    edge5 = Part.Arc(Pnt5,Pnt6,Pnt7).toShape()
      +
      +    # make a cutter for the hexShell
      +    PntHC1 = Base.Vector(0.0,0.0,arc1_z)
      +    PntHC2 = Base.Vector(0.0,0.0,0.0)
      +    
      +    edgeHC1 = Part.makeLine(Pnt2,PntHC1)
      +    edgeHC2 = Part.makeLine(PntHC1,PntHC2)
      +    edgeHC3 = Part.makeLine(PntHC2,Pnt0)
      +
      +    HCWire = Part.Wire([edge2, edgeHC1, edgeHC2, edgeHC3, edge1])
      +    HCFace = Part.Face(HCWire)
      +    hex2Cut = HCFace.revolve(Base.Vector(0.0,0.0,0.0),Base.Vector(0.0,0.0,1.0),360)
      +    
      +    hexShell = hexShell.cut(hex2Cut)
      +    #Part.show(hexShell)
      +    
      +    topFaces.extend(hexShell.Faces)
      +    
      +    # bolt points
      +    cham_t = P*math.sqrt(3.0)/2.0*17.0/24.0
      +    
      +    PntB0 = Base.Vector(0.0,0.0,-a_point)
      +    PntB1 = Base.Vector(dia/2.0,0.0,-l+cham_t)
      +    PntB2 = Base.Vector(dia/2.0-cham_t,0.0,-l)
      +    PntB3 = Base.Vector(0.0,0.0,-l)
      +    
      +    edgeB2 = Part.makeLine(PntB1,PntB2)
      +    edgeB3 = Part.makeLine(PntB2,PntB3)
      +    
      +    #if self.RealThread.isChecked():
      +    if self.rThread:
      +      aWire=Part.Wire([edge2,edge3,edge4,edge5])
      +      boltIndex = 4
      +    
      +    else:
      +      if a_point <=r1:
      +        edgeB1 = Part.makeLine(Pnt7,PntB1)
      +        aWire=Part.Wire([edge2,edge3,edge4,edge5, edgeB1, edgeB2, edgeB3])
      +        boltIndex = 7
      +      else:
      +        edgeB1 = Part.makeLine(Pnt8,PntB1)
      +        edge6 = Part.makeLine(Pnt7,Pnt8)
      +        aWire=Part.Wire([edge2,edge3,edge4,edge5,edge6, \
      +            edgeB1, edgeB2, edgeB3])
      +        boltIndex = 8
      +
      +
      +    #aFace =Part.Face(aWire)
      +    #Part.show(aWire)
      +    headShell = aWire.revolve(Base.Vector(0.0,0.0,0.0),Base.Vector(0.0,0.0,1.0),360)
      +    #FreeCAD.Console.PrintMessage("der Kopf mit revolve: " + str(dia) + "\n")
      +    #Part.show(headShell)
      +    chamFace = headShell.Faces[0].cut(solidHex)
      +    #Part.show(chamFace)
      +    
      +    topFaces.append(chamFace.Faces[0])
      +    for i in range(1,boltIndex):
      +      topFaces.append(headShell.Faces[i])
      +
      +    
      +    if self.rThread:
      +      if (dia < 3.0) or (dia > 5.0):
      +        rthread = self.makeShellthread(dia, P, halfturns, True, offSet)
      +        rthread.translate(Base.Vector(0.0, 0.0,-a_point-2.0*P))
      +        for tFace in rthread.Faces:
      +          topFaces.append(tFace)
      +        headShell = Part.Shell(topFaces)
      +        screw = Part.Solid(headShell)
      +      else:
      +        rthread = self.makeShellthread(dia, P, halfturns, False, offSet)
      +        rthread.translate(Base.Vector(0.0, 0.0,-a_point-2.0*P))
      +        for tFace in rthread.Faces:
      +          topFaces.append(tFace)
      +        headShell = Part.Shell(topFaces)
      +        head = Part.Solid(headShell)
      +        cyl = self.cutChamfer(dia, P, l)
      +        #FreeCAD.Console.PrintMessage("vor Schnitt Ende: " + str(dia) + "\n")
      +        screw = head.cut(cyl)
      +    else:
      +      screwShell = Part.Shell(topFaces)
      +      screw = Part.Solid(screwShell)
      +
      +    return screw
      +
      +
      +  # also used for ISO 7046 countersunk flat head screws with H cross recess
      +  # also used for ISO 7047 raised countersunk head screws with H cross recess
      +  # also used for ISO 10642 Hexagon socket countersunk head screws
      +  # also used for ISO 14582 Hexalobular socket countersunk head screws, high head
      +  # also used for ISO 14584 Hexalobular socket raised countersunk head screws
      +  def makeIso7046(self, SType ='ISO7046', ThreadType ='M6',l=25.0):
      +    dia = self.getDia(ThreadType)
      +    #FreeCAD.Console.PrintMessage("der 2009Kopf mit l: " + str(l) + "\n")
      +    if (SType == 'ISO10642'):
      +      P,b,dk_theo,dk_mean,da, ds_min, e, k, r, s_mean, t, w =iso10642def[ThreadType]
      +      ePrax = s_mean / math.sqrt(3.0) / 0.99
      +      ht = 0.0
      +      a = 2*P
      +      t_mean = t
      +    else: #still need the data from iso2009def, but this screw can not created here
      +      P, a, b, dk_theo, dk_mean, k, n_min, r, t_mean, x = iso2009def[ThreadType]
      +      ht = 0.0 # Head heigth of flat head
      +    if SType == 'ISO7046':
      +      cT, mH, mZ  = iso7046def[ThreadType]
      +    if (SType == 'ISO7047'):
      +      rf, t_mean, cT, mH, mZ = Raised_countersunk_def[ThreadType]
      +      #Lengths and angles for calculation of head rounding
      +      beta = math.asin(dk_mean /2.0 / rf)   # angle of head edge
      +      tan_beta = math.tan(beta)      
      +      alpha = beta/2.0 # half angle
      +      # heigth of raised head top
      +      ht = rf - (dk_mean/2.0) / tan_beta
      +      #print 'he: ', he
      +      h_arc_x = rf * math.sin(alpha) 
      +      h_arc_z = ht - rf + rf * math.cos(alpha)
      +      #FreeCAD.Console.PrintMessage("h_arc_z: " + str(h_arc_z) + "\n")
      +
      +    if (SType == 'ISO14582'):
      +      P, a, b, dk_theo, dk_mean, k, r, tt, A, t_mean = iso14582def[ThreadType]
      +      ePrax = A / 2.0 / 0.99
      +
      +    if (SType == 'ISO14584'):
      +      P, b, dk_theo, dk_mean, f, k, r, rf, x, tt, A, t_mean = iso14584def[ThreadType]
      +      ePrax = A / 2.0 / 0.99
      +      #Lengths and angles for calculation of head rounding
      +      beta = math.asin(dk_mean /2.0 / rf)   # angle of head edge
      +      tan_beta = math.tan(beta)      
      +      ctp = - (dk_mean/2.0) / tan_beta # Center Top Edge = center for rf
      +      betaA = math.asin(ePrax / rf)   # angle of head edge at start of recess
      +      ht = ctp + ePrax / math.tan(betaA)
      +      alpha = betaA + (beta - betaA)/2.0 # half angle of top Arc
      +      h_arc_x = rf * math.sin(alpha) 
      +      h_arc_z = ctp + rf * math.cos(alpha)
      +      
      +           
      +    #FreeCAD.Console.PrintMessage("der Kopf mit iso r: " + str(r) + "\n")
      +    cham = (dk_theo - dk_mean)/2.0
      +    rad225 = math.radians(22.5)
      +    rad45 = math.radians(45.0)
      +    rtan = r*math.tan(rad225)
      +    #FreeCAD.Console.PrintMessage("Checking rtan: " + str(rtan) + "\n")
      +    
      +    if (b > (l - k - rtan/2.0 - 1.0*P)):
      +      bmax = l - k - rtan/2.0 - 1.0*P
      +    else:
      +      bmax = b
      +
      +    ### make the new code with math.modf(l)
      +    residue, turns = math.modf((bmax)/P)
      +    halfturns = 2*int(turns)
      +    if residue < 0.5:
      +      a_point = l - (turns+1.0) * P 
      +      halfturns = halfturns +1
      +    else:
      +      halfturns = halfturns + 2
      +      a_point = l - (turns+2.0) * P
      +    #halfturns = halfturns + 2
      +    offSet = k + rtan - a_point
      +       
      +    #Head Points
      +    Pnt1 = Base.Vector(dk_mean/2.0,0.0,0.0)
      +    Pnt2 = Base.Vector(dk_mean/2.0,0.0,-cham)
      +    Pnt3 = Base.Vector(dia/2.0+r-r*math.cos(rad45),0.0,-k-rtan+r*math.sin(rad45))
      +    
      +    # Arc-points
      +    Pnt4 = Base.Vector(dia/2.0+r-r*(math.cos(rad225)),0.0,-k-rtan+r*math.sin(rad225))
      +    Pnt5 = Base.Vector(dia/2.0,0.0,-k-rtan)
      +    Pnt6 = Base.Vector(dia/2.0,0.0,-a_point)
      +
      +    if (SType == 'ISO10642') or (SType == 'ISO14582'):
      +      if (SType == 'ISO10642'):
      +        recess, recessShell = self.makeAllen2(s_mean, t_mean, 0.0 )
      +        Pnt0 = Base.Vector(ePrax/2.0,0.0,-ePrax/2.0)
      +        PntCham = Base.Vector(ePrax,0.0,0.0)
      +        edge1 = Part.makeLine(Pnt0,PntCham)    
      +        edgeCham2 = Part.makeLine(PntCham,Pnt1)    
      +        edge2 = Part.makeLine(Pnt1,Pnt2)
      +        edge2 = Part.Wire([edgeCham2,edge2])
      +        PntH0 = Base.Vector(ePrax/2.0,0.0, ht + k)
      +        PntH1 = Base.Vector(ePrax,0.0, ht + k)
      +      if (SType == 'ISO14582'):
      +        recess, recessShell = self.makeIso10664_3(tt, t_mean, 0.0) # hexalobular recess
      +        Pnt0 = Base.Vector(0.0,0.0,0.0)
      +        edge1 = Part.makeLine(Pnt0,Pnt1)    
      +        edge2 = Part.makeLine(Pnt1,Pnt2)
      +
      +
      +      # bolt points with bolt chamfer
      +      cham_b = P*math.sqrt(3.0)/2.0*17.0/24.0
      +      
      +      PntB1 = Base.Vector(dia/2.0,0.0,-l+cham_b)
      +      PntB2 = Base.Vector(dia/2.0-cham_b,0.0,-l)
      +      PntB3 = Base.Vector(0.0,0.0,-l)
      +      if a_point <= (k + rtan):
      +        edgeB0 = Part.makeLine(Pnt5,PntB1)
      +      else:
      +        edgeB0 = Part.makeLine(Pnt6,PntB1)
      +      edgeB2 = Part.makeLine(PntB1,PntB2)
      +      edgeB3 = Part.makeLine(PntB2,PntB3)
      +      edgeB1 = Part.Wire([edgeB2,edgeB3])
      +
      +    else:
      +      # bolt points
      +      PntB1 = Base.Vector(dia/2.0,0.0,-l)
      +      PntB2 = Base.Vector(0.0,0.0,-l)
      +      if a_point <= (k + rtan):
      +        edgeB0 = Part.makeLine(Pnt5,PntB1)
      +      else:
      +        edgeB0 = Part.makeLine(Pnt6,PntB1)
      +      edgeB1 = Part.makeLine(PntB1,PntB2)
      +
      +      if (SType == 'ISO7047'): # make raised head rounding
      +        Pnt0 = Base.Vector(0.0,0.0,ht)
      +        Pnt0arc = Base.Vector(h_arc_x,0.0,h_arc_z)
      +        edge1 = Part.Arc(Pnt0,Pnt0arc,Pnt1).toShape()     
      +        edge2 = Part.makeLine(Pnt1,Pnt2)
      +        PntH0 = Base.Vector(0.0,0.0, ht + k)
      +        PntH1 = Base.Vector(dk_mean/2.0,0.0, ht + k)
      +        recess, recessShell = self.makeCross_H3(cT, mH, ht)
      +      if (SType == 'ISO7046'):
      +        # ISO7046
      +        Pnt0 = Base.Vector(0.0,0.0,ht)
      +        edge1 = Part.makeLine(Pnt0,Pnt1)  # make flat head
      +        edge2 = Part.makeLine(Pnt1,Pnt2)
      +        recess, recessShell = self.makeCross_H3(cT, mH, ht)
      +
      +      if (SType == 'ISO14584'): # make raised head rounding with chamfer
      +        Pnt0 = Base.Vector(ePrax/2.0,0.0,ht-ePrax/4.0)
      +        PntCham = Base.Vector(ePrax,0.0,ht)
      +        PntArc = Base.Vector(h_arc_x,0.0,h_arc_z)
      +        edge1 = Part.makeLine(Pnt0,PntCham)    
      +        edgeArc = Part.Arc(PntCham,PntArc,Pnt1).toShape() 
      +        edge2 = Part.makeLine(Pnt1,Pnt2)
      +        edge2 = Part.Wire([edgeArc,edge2])
      +        PntH0 = Base.Vector(ePrax/2.0,0.0, ht + k)
      +        PntH1 = Base.Vector(ePrax,0.0, ht + k)
      +        recess, recessShell = self.makeIso10664_3(tt, t_mean, ht) # hexalobular recess
      +       
      +    edge3 = Part.makeLine(Pnt2,Pnt3)
      +    edgeArc = Part.Arc(Pnt3,Pnt4,Pnt5).toShape()     
      +    edgeArc1 = Part.makeLine(Pnt3,Pnt4)     
      +    edgeArc2 = Part.makeLine(Pnt4,Pnt5)
      +    edge6 = Part.makeLine(Pnt5,Pnt6)
      +    
      +    if self.rThread:
      +      #aWire=Part.Wire([edge1,edge2,edge3,edgeArc])
      +      aWire=Part.Wire([edge2,edge3,edgeArc])
      +    else:
      +      if a_point <= (k + rtan):
      +        aWire=Part.Wire([edge2,edge3,edgeArc, edgeB0, edgeB1])
      +      else:
      +        aWire=Part.Wire([edge2,edge3,edgeArc,edge6, edgeB0, edgeB1])
      +
      +    #Part.show(aWire)
      +    headShell = aWire.revolve(Base.Vector(0.0,0.0,0.0),Base.Vector(0.0,0.0,1.0),360)
      +    headFaces = headShell.Faces
      +    #Part.show(headShell)
      +
      +    if (SType == 'ISO7046') or (SType == 'ISO14582'):
      +      # hCut is just a cylinder for ISO7046
      +      hCut = Part.makeCylinder(dk_mean/2.0,k,Pnt0)
      +      #Part.show(hCut)
      +      topFace = hCut.Faces[2]
      +    else:
      +      edgeH1 = Part.makeLine(Pnt1,PntH1)
      +      edgeH2 = Part.makeLine(PntH1,PntH0)
      +      edgeH3 = Part.makeLine(PntH0,Pnt0)
      +      hWire = Part.Wire([edge1,edgeH1,edgeH2,edgeH3]) # Cutter for recess-Shell
      +      hFace = Part.Face(hWire)
      +      hCut = hFace.revolve(Base.Vector(0.0,0.0,0.0),Base.Vector(0.0,0.0,1.0),360)
      +      #Part.show(hWire)
      +      topFace = hCut.Faces[0]
      +
      +    recessShell = recessShell.cut(hCut)
      +    topFace = topFace.cut(recess)
      +    #Part.show(topFace)
      +    #Part.show(recessShell)
      +    #Part.show(headShell)
      +    headFaces.append(topFace.Faces[0])
      +    headFaces.extend(recessShell.Faces)
      +    
      +
      +    if (SType == 'ISO10642') or (SType == 'ISO14582'):
      +      if self.rThread:
      +        if (dia < 3.0) or (dia > 5.0):
      +          #if True:
      +          rthread = self.makeShellthread(dia, P, halfturns, True, offSet)
      +          rthread.translate(Base.Vector(0.0, 0.0,-a_point -2.0*P))
      +          #head = head.fuse(rthread)
      +          #Part.show(rthread)
      +          for threadFace in rthread.Faces:
      +            headFaces.append(threadFace)
      +
      +          screwShell = Part.Shell(headFaces)
      +          screw = Part.Solid(screwShell)
      +        else:
      +          '''
      +          # head = self.cutIsoThread(head, dia, P, turns, l)
      +          rthread = self.makeShellthread(dia, P, halfturns, False)
      +          rthread.translate(Base.Vector(0.0, 0.0,-a_point-2.0*P))
      +          head = head.fuse(rthread)
      +          head = head.removeSplitter()
      +          cyl = self.cutChamfer(dia, P, l)
      +          #FreeCAD.Console.PrintMessage("vor Schnitt Ende: " + str(dia) + "\n")
      +          head = head.cut(cyl)
      +          '''
      +          
      +          rthread = self.makeShellthread(dia, P, halfturns, False, offSet)
      +          rthread.translate(Base.Vector(0.0, 0.0,-a_point -2.0*P))
      +          #head = head.fuse(rthread)
      +          Part.show(rthread)
      +          for threadFace in rthread.Faces:
      +            headFaces.append(threadFace)
      +
      +          screwShell = Part.Shell(headFaces)
      +          screw = Part.Solid(screwShell)
      +          cyl = self.cutChamfer(dia, P, l)
      +          screw = screw.cut(cyl)
      +      else:
      +        screwShell = Part.Shell(headFaces)
      +        screw = Part.Solid(screwShell)
      +
      +    else:
      +      if self.rThread:
      +        rthread = self.makeShellthread(dia, P, halfturns, False, offSet)
      +        rthread.translate(Base.Vector(0.0, 0.0,-a_point -2.0*P))
      +        #head = head.fuse(rthread)
      +        #Part.show(rthread)
      +        for threadFace in rthread.Faces:
      +          headFaces.append(threadFace)
      +
      +      screwShell = Part.Shell(headFaces)
      +      screw = Part.Solid(screwShell)
      +
      +
      +    
      +    return screw
      +
      +
      +
      +
      +
      +
      +  # make ISO 4762 Allan Screw head
      +  # ISO 14579 Hexalobular socket head cap screws
      +  def makeIso4762(self, SType ='ISO4762', ThreadType ='M6',l=25.0):
      +    dia = self.getDia(ThreadType)
      +    #FreeCAD.Console.PrintMessage("der 4762Kopf mit l: " + str(l) + "\n")
      +    P, b, dk_max, da, ds_mean, e, lf, k, r, s_mean, t, v, dw, w = iso4762def[ThreadType]
      +    #FreeCAD.Console.PrintMessage("der Kopf mit iso r: " + str(r) + "\n")
      +    if SType == 'ISO14579':
      +      tt, A, t = iso14579def[ThreadType]
      +      #Head Points 30° countersunk
      +      # Pnt0 = Base.Vector(0.0,0.0,k-A/4.0) #Center Point for countersunk
      +      Pnt0 = Base.Vector(0.0,0.0,k-A/8.0) #Center Point for flat countersunk
      +      PntFlat = Base.Vector(A/8.0,0.0,k-A/8.0) # End of flat part
      +      Pnt1 = Base.Vector(A/1.99,0.0,k)     #countersunk edge at head
      +      edgeCham0 = Part.makeLine(Pnt0,PntFlat)    
      +      edgeCham1 = Part.makeLine(PntFlat,Pnt1)    
      +      edge1 = Part.Wire([edgeCham0,edgeCham1])
      +      
      +      # Here is the next approach to shorten the head building time
      +      # Make two helper points to create a cutting tool for the 
      +      # recess and recess shell.
      +      PntH1 = Base.Vector(A/1.99,0.0, 2.0*k)
      +
      +    else:
      +      e_cham = 2.0 * s_mean / math.sqrt(3.0)
      +      #Head Points 45° countersunk
      +      Pnt0 = Base.Vector(0.0,0.0,k-e_cham/1.99/2.0) #Center Point for countersunk
      +      PntFlat = Base.Vector(e_cham/1.99/2.0,0.0,k-e_cham/1.99/2.0) # End of flat part
      +      Pnt1 = Base.Vector(e_cham/1.99,0.0,k)     #countersunk edge at head
      +      edgeCham0 = Part.makeLine(Pnt0,PntFlat)    
      +      edgeCham1 = Part.makeLine(PntFlat,Pnt1)    
      +      edge1 = Part.Wire([edgeCham0,edgeCham1])
      +      PntH1 = Base.Vector(e_cham/1.99,0.0, 2.0*k)
      +      
      +    
      +    PntH2 = Base.Vector(0.0,0.0, 2.0*k)
      +    edgeH1 = Part.makeLine(Pnt1,PntH1)
      +    edgeH2 = Part.makeLine(PntH1,PntH2)
      +    edgeH3 = Part.makeLine(PntH2,Pnt0)
      +    hWire = Part.Wire([edge1,edgeH1,edgeH2,edgeH3]) # Cutter for recess-Shell
      +    hFace = Part.Face(hWire)
      +    hCut = hFace.revolve(Base.Vector(0.0,0.0,0.0),Base.Vector(0.0,0.0,1.0),360)
      +    #Part.show(hWire)
      +    '''
      +
      +
      +    PntH2 = Base.Vector(A/8.0,0.0, 2.0*k)
      +    edgeH1 = Part.makeLine(Pnt1,PntH1)
      +    edgeH2 = Part.makeLine(PntH1,PntH2)
      +    edgeH3 = Part.makeLine(PntH2,PntFlat)
      +    hWire = Part.Wire([edgeCham1,edgeH1,edgeH2,edgeH3]) # Cutter for recess-Shell
      +    hFace = Part.Face(hWire)
      +    hCut = hFace.revolve(Base.Vector(0.0,0.0,0.0),Base.Vector(0.0,0.0,1.0),360)
      +    #Part.show(hWire)
      +    '''
      +
      +
      +    sqrt2_ = 1.0/math.sqrt(2.0)
      +    #depth = s_mean / 3.0
      +
      +    '''
      +    if (b > l - 2*P):
      +       bmax = l-2*P
      +    else:
      +       bmax = b
      +    halfturns = round(2.0*(bmax+P)/P) # number of thread turns
      +    if self.RealThread.isChecked():
      +      a_real = l-(halfturns+2)*P/2.0  # point to fuse real thread
      +    else:
      +      a_real = l-halfturns*P/2.0  # starting point of thread
      +    if a_real < r:
      +      a_point = r*1.3
      +    else:
      +      a_point = a_real
      +    '''
      +
      +
      +    if (b > (l - 1.0*P)):
      +       bmax = l- 1.0*P
      +    else:
      +       bmax = b
      +
      +    ### make the new code with math.modf(l)
      +    residue, turns = math.modf((bmax)/P)
      +    halfturns = 2*int(turns)
      +    if residue < 0.5:
      +      a_point = l - (turns+1.0) * P 
      +      halfturns = halfturns +1
      +    else:
      +      halfturns = halfturns + 2
      +      a_point = l - (turns+2.0) * P
      +    #halfturns = halfturns + 2
      +    offSet = r - a_point
      +    #FreeCAD.Console.PrintMessage("The transition at a: " + str(a) + " turns " + str(turns) + "\n")
      +
      +
      +
      +         
      +    #rad30 = math.radians(30.0)
      +    #Head Points
      +    Pnt2 = Base.Vector(dk_max/2.0-v,0.0,k)   #start of fillet
      +    Pnt3 = Base.Vector(dk_max/2.0-v+v*sqrt2_,0.0,k-v+v*sqrt2_) #arc-point of fillet
      +    Pnt4 = Base.Vector(dk_max/2.0,0.0,k-v)   #end of fillet
      +    Pnt5 = Base.Vector(dk_max/2.0,0.0,(dk_max-dw)/2.0) #we have a chamfer here
      +    Pnt6 = Base.Vector(dw/2.0,0.0,0.0)           #end of chamfer
      +    Pnt7 = Base.Vector(dia/2.0+r,0.0,0.0)     #start of fillet between head and shank
      +    Pnt8 = Base.Vector(dia/2.0+r-r*sqrt2_,0.0,-r+r*sqrt2_) #arc-point of fillet
      +    Pnt9 = Base.Vector(dia/2.0,0.0,-r)        # end of fillet
      +    Pnt10 = Base.Vector(dia/2.0,0.0,-a_point)        # start of thread
      +    
      +    edge1 = Part.makeLine(Pnt0,Pnt1)
      +    edge2 = Part.makeLine(Pnt1,Pnt2)
      +    edge3 = Part.Arc(Pnt2,Pnt3,Pnt4).toShape()
      +    edge4 = Part.makeLine(Pnt4,Pnt5)
      +    edge5 = Part.makeLine(Pnt5,Pnt6)
      +    edge6 = Part.makeLine(Pnt6,Pnt7)
      +    edge7 = Part.Arc(Pnt7,Pnt8,Pnt9).toShape()
      +    
      +    '''
      +    # bolt points
      +    PntB1 = Base.Vector(dia/2.0,0.0,-l-P)  # Chamfer is made with a cut later
      +    PntB2 = Base.Vector(0.0,0.0,-l-P)
      +    #PntB3 = Base.Vector(0.0,0.0,-l)
      +
      +    edgeB0 = Part.makeLine(Pnt10,PntB1)
      +    edgeB1 = Part.makeLine(PntB1,PntB2)
      +    #edgeB2 = Part.makeLine(PntB2,PntB3)
      +    edgeZ0 = Part.makeLine(PntB2,Pnt0)
      +    
      +    
      +    aWire=Part.Wire([edge1,edge2,edge3,edge4,edge5,edge6,edge7,edge8, \
      +        edgeB0, edgeB1, edgeZ0])
      +    '''
      +
      +
      +    
      +    if self.rThread:
      +      aWire=Part.Wire([edge2,edge3,edge4,edge5,edge6,edge7])
      +    
      +    else:
      +      # bolt points
      +      cham_t = P*math.sqrt(3.0)/2.0*17.0/24.0
      +      
      +      PntB1 = Base.Vector(dia/2.0,0.0,-l+cham_t)
      +      PntB2 = Base.Vector(dia/2.0-cham_t,0.0,-l)
      +      PntB3 = Base.Vector(0.0,0.0,-l)
      +      
      +      #edgeB1 = Part.makeLine(Pnt10,PntB1)
      +      edgeB2 = Part.makeLine(PntB1,PntB2)
      +      edgeB3 = Part.makeLine(PntB2,PntB3)
      +
      +      if a_point <= r:
      +        edgeB1 = Part.makeLine(Pnt9,PntB1)
      +        aWire=Part.Wire([edge2,edge3,edge4,edge5,edge6,edge7, \
      +            edgeB1, edgeB2, edgeB3])
      +      else:
      +        edge8 = Part.makeLine(Pnt9,Pnt10)
      +        edgeB1 = Part.makeLine(Pnt10,PntB1)
      +        aWire=Part.Wire([edge2,edge3,edge4,edge5,edge6,edge7,edge8, \
      +            edgeB1, edgeB2, edgeB3])
      +      #Part.show(aWire)
      +
      +    headShell = aWire.revolve(Base.Vector(0.0,0.0,0.0),Base.Vector(0.0,0.0,1.0),360)
      +    #head = Part.Solid(headShell)
      +    #Part.show(aWire)
      +    #FreeCAD.Console.PrintMessage("der Kopf mit revolve: " + str(dia) + "\n")
      +    headFaces = headShell.Faces
      +
      +    
      +    if SType == 'ISO14579':
      +      #recess = self.makeIso10664(tt, t, k) # hexalobular recess
      +      recess, recessShell = self.makeIso10664_3(tt, t, k) # hexalobular recess
      +    else:
      +      recess, recessShell = self.makeAllen2(s_mean, t, k )
      +
      +    recessShell = recessShell.cut(hCut)
      +    topFace = hCut.Faces[1]
      +    #topFace = hCut.Faces[0]
      +    topFace = topFace.cut(recess)
      +    #Part.show(topFace)
      +    #Part.show(recessShell)
      +    #Part.show(headShell)
      +    headFaces.append(topFace.Faces[0])
      +    #headFaces.append(hCut.Faces[2])
      +
      +    #allenscrew = head.cut(recess)
      +    #Part.show(hCut)
      +    headFaces.extend(recessShell.Faces)
      +
      +    #if self.RealThread.isChecked():
      +    if self.rThread:
      +      #if (dia < 3.0) or (dia > 5.0):
      +      if True:
      +        # head = self.cutIsoThread(head, dia, P, turns, l)
      +        rthread = self.makeShellthread(dia, P, halfturns, True, offSet)
      +        rthread.translate(Base.Vector(0.0, 0.0,-a_point-2.0*P))
      +        #Part.show(rthread)
      +        for tFace in rthread.Faces:
      +          headFaces.append(tFace)
      +        headShell = Part.Shell(headFaces)
      +        allenscrew = Part.Solid(headShell)
      +
      +      else:
      +        # head = self.cutIsoThread(head, dia, P, turns, l)
      +        rthread = self.makeShellthread(dia, P, halfturns, False, offSet)
      +        rthread.translate(Base.Vector(0.0, 0.0,-a_point-2.0*P))
      +        for tFace in rthread.Faces:
      +          headFaces.append(tFace)
      +        headShell = Part.Shell(headFaces)
      +        allenscrew = Part.Solid(headShell)
      +        cyl = self.cutChamfer(dia, P, l)
      +        # FreeCAD.Console.PrintMessage("vor Schnitt Ende: " + str(dia) + "\n")
      +        allenscrew = allenscrew.cut(cyl)
      +    else:
      +      headShell = Part.Shell(headFaces)
      +      allenscrew = Part.Solid(headShell)
      +      
      +
      +    return allenscrew
      +
      +
      +
      +
      +  # make ISO 7380-1 Button head Screw 
      +  # make ISO 7380-2 Button head Screw with collar 
      +  # make DIN 967 cross recessed pan head Screw with collar 
      +  def makeIso7380(self, SType ='ISO7380-1', ThreadType ='M6',l=25.0):
      +    dia = self.getDia(ThreadType)
      +    #todo: different radii for screws with thread to head or with shaft?
      +    sqrt2_ = 1.0/math.sqrt(2.0)
      +    
      +    if (SType =='DIN967'):
      +      P, b, c, da, dk, r, k, rf, x, cT, mH, mZ = din967def[ThreadType]
      +      
      +      rH = rf # radius of button arc
      +      alpha = math.acos((rf-k+c)/rf)
      +
      +      #Head Points
      +      Pnt0 = Base.Vector(0.0,0.0,k) 
      +      PntArc = Base.Vector(rf*math.sin(alpha/2.0),0.0,k-rf + rf*math.cos(alpha/2.0)) #arc-point of button
      +      Pnt1 = Base.Vector(rf*math.sin(alpha),0.0,c)     #end of button arc
      +      PntC0 = Base.Vector((dk)/2.0,0.0,c)     #collar points
      +      PntC2 = Base.Vector((dk)/2.0,0.0,0.0)     #collar points
      +      Pnt4 = Base.Vector(dia/2.0+r,0.0,0.0)     #start of fillet between head and shank
      +
      +      edge1 = Part.Arc(Pnt0,PntArc,Pnt1).toShape()
      +      edgeC0 = Part.makeLine(Pnt1,PntC0)
      +      edgeC1 = Part.makeLine(PntC0,PntC2)
      +      edge2 = Part.Wire([edgeC0, edgeC1])
      +      edge3 = Part.makeLine(PntC2,Pnt4)
      +      #Points for recessShell cutter
      +      PntH0 = Base.Vector(0.0,0.0,2.0*k) 
      +      PntH1 = Base.Vector(rf*math.sin(alpha),0.0,2.0*k)  
      +      recess, recessShell = self.makeCross_H3(cT, mH, k)
      +      
      +    else:
      +      if (SType =='ISO7380-1'):
      +        P, b, a, da, dk, dk_mean,s_mean, t_min, r, k, e, w = iso7380def[ThreadType]
      +        
      +        # Bottom of recess
      +        e_cham = 2.0 * s_mean / math.sqrt(3.0) / 0.99
      +        #depth = s_mean / 3.0
      +        
      +        ak = -(4*k**2 + e_cham**2 - dk**2)/(8*k) # helper value for button arc
      +        rH = math.sqrt((dk/2.0)**2 + ak**2) # radius of button arc
      +        alpha = (math.atan(2*(k + ak)/e_cham) + math.atan((2*ak)/dk))/2
      +  
      +        Pnt2 = Base.Vector(rH*math.cos(alpha),0.0,-ak + rH*math.sin(alpha)) #arc-point of button
      +        Pnt3 = Base.Vector(dk/2.0,0.0,0.0)   #end of fillet
      +        Pnt4 = Base.Vector(dia/2.0+r,0.0,0.0)     #start of fillet between head and shank
      +        edge3 = Part.makeLine(Pnt3,Pnt4)
      +  
      +      if (SType =='ISO7380-2'):
      +        P, b, c, da, dk, dk_c,s_mean,t_min, r, k, e, w = iso7380_2def[ThreadType]
      +        
      +        # Bottom of recess
      +        e_cham = 2.0 * s_mean / math.sqrt(3.0) / 0.99
      +        #depth = s_mean / 3.0
      +        
      +        ak = -(4*(k-c)**2 + e_cham**2 - dk**2)/(8*(k-c)) # helper value for button arc
      +        rH = math.sqrt((dk/2.0)**2 + ak**2) # radius of button arc
      +        alpha = (math.atan(2*(k -c + ak)/e_cham) + math.atan((2*ak)/dk))/2
      +  
      +        Pnt2 = Base.Vector(rH*math.cos(alpha),0.0,c -ak + rH*math.sin(alpha)) #arc-point of button
      +        Pnt3 = Base.Vector(dk/2.0,0.0,c)   #end of fillet
      +        Pnt4 = Base.Vector(dia/2.0+r,0.0,0.0)     #start of fillet between head and shank
      +        PntC0 = Base.Vector((dk_c-c)/2.0,0.0,c)     #collar points
      +        PntC1 = Base.Vector(dk_c/2.0,0.0,c/2.0)     #collar points
      +        PntC2 = Base.Vector((dk_c-c)/2.0,0.0,0.0)     #collar points
      +  
      +        edgeC0 = Part.makeLine(Pnt3,PntC0)
      +        edgeC1 = Part.Arc(PntC0,PntC1,PntC2).toShape()
      +        edge3 = Part.makeLine(PntC2,Pnt4)
      +        edge3 = Part.Wire([edgeC0, edgeC1, edge3])
      +  
      +      #Head Points
      +      Pnt0 = Base.Vector(e_cham/4.0,0.0,k-e_cham/4.0) #Center Point for chamfer
      +      Pnt1 = Base.Vector(e_cham/2.0,0.0,k)     #inner chamfer edge at head
      +      #Points for recessShell cutter
      +      PntH0 = Base.Vector(e_cham/4.0,0.0,2.0*k) 
      +      PntH1 = Base.Vector(e_cham/2.0,0.0,2.0*k)  
      +      
      +      edge1 = Part.makeLine(Pnt0,Pnt1)
      +      edge2 = Part.Arc(Pnt1,Pnt2,Pnt3).toShape()
      +      recess, recessShell = self.makeAllen2(s_mean, t_min, k)
      +
      +    if (b > (l - 1.0*P)):
      +       bmax = l- 1.0*P
      +    else:
      +       bmax = b
      +
      +    ### make the new code with math.modf(l)
      +    residue, turns = math.modf((bmax)/P)
      +    halfturns = 2*int(turns)
      +    if residue < 0.5:
      +      a_point = l - (turns+1.0) * P 
      +      halfturns = halfturns +1
      +    else:
      +      halfturns = halfturns + 2
      +      a_point = l - (turns+2.0) * P
      +    offSet = r - a_point
      +         
      +
      +    Pnt5 = Base.Vector(dia/2.0+r-r*sqrt2_,0.0,-r+r*sqrt2_) #arc-point of fillet
      +    Pnt6 = Base.Vector(dia/2.0,0.0,-r)        # end of fillet
      +    Pnt7 = Base.Vector(dia/2.0,0.0,-a_point)        # start of thread
      +
      +    edge4 = Part.Arc(Pnt4,Pnt5,Pnt6).toShape()
      +    edge5 = Part.makeLine(Pnt6,Pnt7)
      +
      +    if (SType =='DIN967'):
      +      # bolt points
      +      PntB1 = Base.Vector(dia/2.0,0.0,-l)
      +      PntB2 = Base.Vector(0.0,0.0,-l)
      +      edgeB2 = Part.makeLine(PntB1,PntB2)
      +    else:
      +      # bolt points
      +      cham_b = P*math.sqrt(3.0)/2.0*17.0/24.0
      +      
      +      PntB1 = Base.Vector(dia/2.0,0.0,-l+cham_b)
      +      PntB2 = Base.Vector(dia/2.0-cham_b,0.0,-l)
      +      PntB3 = Base.Vector(0.0,0.0,-l)
      +      
      +      edgeB2 = Part.makeLine(PntB1,PntB2)
      +      edgeB3 = Part.makeLine(PntB2,PntB3)
      +      edgeB2 = Part.Wire([edgeB2, edgeB3])
      +
      +    if self.rThread:
      +      aWire=Part.Wire([edge2,edge3,edge4])
      +    else:
      +      if a_point <= r:
      +        edgeB1 = Part.makeLine(Pnt6,PntB1)
      +        aWire=Part.Wire([edge2,edge3,edge4, edgeB1, edgeB2])
      +      else:
      +        edge5 = Part.makeLine(Pnt6,Pnt7)
      +        edgeB1 = Part.makeLine(Pnt7,PntB1)
      +        aWire=Part.Wire([edge2,edge3,edge4,edge5, edgeB1, edgeB2])
      +
      +    #Part.show(aWire)
      +    headShell = aWire.revolve(Base.Vector(0.0,0.0,0.0),Base.Vector(0.0,0.0,1.0),360)
      +    #Part.show(headShell)
      +    headFaces = headShell.Faces
      +    
      +    edgeH1 = Part.makeLine(Pnt1,PntH1)
      +    edgeH2 = Part.makeLine(PntH1,PntH0)
      +    edgeH3 = Part.makeLine(PntH0,Pnt0)
      +    hWire = Part.Wire([edge1,edgeH1,edgeH2,edgeH3]) # Cutter for recess-Shell
      +    hFace = Part.Face(hWire)
      +    hCut = hFace.revolve(Base.Vector(0.0,0.0,0.0),Base.Vector(0.0,0.0,1.0),360)
      +    #Part.show(hWire)
      +    topFace = hCut.Faces[0]
      +
      +    recessShell = recessShell.cut(hCut)
      +    topFace = topFace.cut(recess)
      +    #Part.show(topFace)
      +    #Part.show(recessShell)
      +    #Part.show(headShell)
      +    headFaces.append(topFace.Faces[0])
      +    headFaces.extend(recessShell.Faces)
      +
      +
      +    if self.rThread:
      +      #if (dia < 3.0) or (dia > 5.0):
      +      if True:
      +        if (SType =='DIN967'):
      +          rthread = self.makeShellthread(dia, P, halfturns, False, offSet)
      +        else:
      +          rthread = self.makeShellthread(dia, P, halfturns, True, offSet)
      +        rthread.translate(Base.Vector(0.0, 0.0,-a_point -2.0*P))
      +        for threadFace in rthread.Faces:
      +          headFaces.append(threadFace)
      +
      +        screwShell = Part.Shell(headFaces)
      +        screw = Part.Solid(screwShell)
      +      else:
      +        rthread = self.makeShellthread(dia, P, halfturns, False, offSet)
      +        rthread.translate(Base.Vector(0.0, 0.0,-a_point -2.0*P))
      +        for threadFace in rthread.Faces:
      +          headFaces.append(threadFace)
      +
      +        screwShell = Part.Shell(headFaces)
      +        screw = Part.Solid(screwShell)
      +        cyl = self.cutChamfer(dia, P, l)
      +        screw = screw.cut(cyl)
      +    else:
      +      screwShell = Part.Shell(headFaces)
      +      screw = Part.Solid(screwShell)
      +      
      +    return screw
      +
      +
      +
      +
      +  def makeHextool(self,s_hex, k_hex, cir_hex):
      +    # makes a cylinder with an inner hex hole, used as cutting tool
      +    # create hexagon
      +    mhex=Base.Matrix()
      +    mhex.rotateZ(math.radians(60.0))
      +    polygon = []
      +    vhex=Base.Vector(s_hex/math.sqrt(3.0),0.0,-k_hex*0.1)
      +    for i in range(6):
      +       polygon.append(vhex)
      +       vhex = mhex.multiply(vhex)
      +    polygon.append(vhex)
      +    hexagon = Part.makePolygon(polygon)
      +    # create circle
      +    circ=Part.makeCircle(cir_hex/2.0,Base.Vector(0.0,0.0,-k_hex*0.1))
      +    # Create the face with the circle as outline and the hexagon as hole
      +    face=Part.Face([Part.Wire(circ),hexagon])
      +    
      +    # Extrude in z to create the final cutting tool
      +    exHex=face.extrude(Base.Vector(0.0,0.0,k_hex*1.2))
      +    # Part.show(exHex)
      +    return exHex
      +
      +
      +  def makeShellthread(self, d, P, halfrots, withcham, offSet):
      +    d = float(d)
      +    
      +    #rotations = int(rots)-1
      +    halfrots_int = int(halfrots)
      +    rotations = (halfrots_int / 2)-1
      +    if halfrots_int % 2 == 1:
      +      #FreeCAD.Console.PrintMessage("got half turn: " + str(halfrots_int) + "\n")
      +      halfturn = True
      +      # bot_off = - P/2.0 # transition of half a turn
      +      bot_off = 0.0 # nominal length
      +    else:
      +      halfturn = False
      +      bot_off = 0.0 # nominal length
      +
      +    H=P*math.cos(math.radians(30)) # Gewindetiefe H
      +    r=d/2.0
      +    
      +    # helix = Part.makeHelix(P,P,d*511/1000.0,0) # make just one turn, length is identical to pitch
      +    helix = Part.makeHelix(P,P,d*self.Tuner/1000.0,0) # make just one turn, length is identical to pitch
      +    helix.translate(FreeCAD.Vector(0.0, 0.0,-P*9.0/16.0))
      +  
      +    extra_rad = P
      +    # points for screw profile
      +    ps0 = (r,0.0, 0.0)
      +    ps1 = (r-H*5.0/8.0,0.0, -P*5.0/16.0)
      +    ps2 = (r-H*17.0/24.0,0.0, -P*7.0/16.0) # Center of Arc
      +    ps3 = (r-H*5.0/8.0,0.0, -P*9.0/16.0 )
      +    ps4 =  (r, 0.0, -P*14.0/16.0)
      +    ps5 = (r,0.0, -P)
      +    ps6 = (r+extra_rad,0.0, -P)
      +    ps7 = (r+extra_rad,0.0, 0.0) 
      +     
      +    edge0 = Part.makeLine(ps0,ps1)
      +    edge1 = Part.Arc(FreeCAD.Vector(ps1),FreeCAD.Vector(ps2),FreeCAD.Vector(ps3)).toShape()
      +    edge2 = Part.makeLine(ps3,ps4)
      +    edge3 = Part.makeLine(ps4,ps5)
      +    edge4 = Part.makeLine(ps5,ps6)
      +    edge5 = Part.makeLine(ps6,ps7)
      +    edge6 = Part.makeLine(ps7,ps0)
      +     
      +    W0 = Part.Wire([edge0, edge1, edge2, edge3, edge4, edge5, edge6])
      +    
      +    makeSolid=True
      +    isFrenet=True
      +    pipe0 = Part.Wire(helix).makePipeShell([W0],makeSolid,isFrenet)
      +    # pipe1 = pipe0.copy()
      +  
      +    TheFaces = [] 
      +    TheFaces.append(pipe0.Faces[0])
      +    #Part.show(pipe0.Faces[0])
      +    TheFaces.append(pipe0.Faces[1])
      +    #Part.show(pipe0.Faces[1])
      +    TheFaces.append(pipe0.Faces[2])
      +    #Part.show(pipe0.Faces[2])
      +    TheFaces.append(pipe0.Faces[3])
      +    #Part.show(pipe0.Faces[3])
      +    
      +    TheShell = Part.Shell(TheFaces)
      +    # print "Shellpoints: ", len(TheShell.Vertexes)
      +
      +    
      +    i = 1
      +    for i in range(rotations-2):
      +       TheShell.translate(FreeCAD.Vector(0.0, 0.0,- P))
      +  
      +       for flaeche in TheShell.Faces:
      +         TheFaces.append(flaeche)
      +    
      +    #FreeCAD.Console.PrintMessage("Base-Shell: " + str(i) + "\n")
      +    # Make separate faces for the tip of the screw
      +    botFaces = []
      +    for i in range(rotations-2, rotations, 1):
      +       TheShell.translate(FreeCAD.Vector(0.0, 0.0,- P))
      +  
      +       for flaeche in TheShell.Faces:
      +         botFaces.append(flaeche)
      +    #FreeCAD.Console.PrintMessage("Bottom-Shell: " + str(i) + "\n")
      +  
      +    # making additional faces for transition to cylinder
      +  
      +    pc1 = (r + H/16.0,0.0,P*1/32.0)
      +    pc2 = (r-H*5.0/8.0,0.0,-P*5.0/16.0 )
      +    pc3 = (r-H*17.0/24.0,0.0, -P*7.0/16.0 ) # Center of Arc
      +    pc4 = (r-H*5.0/8.0,0.0, -P*9.0/16.0 )
      +    pc5 =  (r+ H/16.0, 0.0, -P*29.0/32.0 )    
      +       
      +    edgec0 = Part.makeLine(pc5,pc1)
      +    edgec1 = Part.makeLine(pc1,pc2)
      +    edgec2 = Part.Arc(FreeCAD.Vector(pc2),FreeCAD.Vector(pc3),FreeCAD.Vector(pc4)).toShape()
      +    edgec3 = Part.makeLine(pc4,pc5)
      +  
      +    cut_profile = Part.Wire([edgec1, edgec2, edgec3, edgec0 ])
      +    
      +    alpha_rad = math.atan(2*H*17.0/24.0/P)
      +    alpha = math.degrees(alpha_rad)
      +    Hyp = P/math.cos(alpha_rad)
      +    # tuning = 511/1000.0
      +    tuning = self.Tuner/1000.0
      +    angled_Helix = Part.makeHelix(Hyp,Hyp*1.002/2.0,d*tuning,alpha)
      +    
      +    SH_faces = []
      +    
      +    if halfturn:
      +      half_Helix = Part.makeHelix(P,P/2.0,d*self.Tuner/1000.0,0) # make just half a turn
      +      angled_Helix.rotate(Base.Vector(0,0,0),Base.Vector(0,0,1),180)
      +      angled_Helix.translate(FreeCAD.Vector(0.0, 0.0,P/2.0))
      +      # Part.show(half_Helix)
      +      # Part.show(angled_Helix)
      +      pipe_cut = Part.Wire([half_Helix, angled_Helix]).makePipeShell([cut_profile],True,isFrenet)
      +      SH_faces.append(pipe_cut.Faces[0])
      +      SH_faces.append(pipe_cut.Faces[1])
      +      SH_faces.append(pipe_cut.Faces[2])
      +      SH_faces.append(pipe_cut.Faces[4])
      +      SH_faces.append(pipe_cut.Faces[5])
      +      SH_faces.append(pipe_cut.Faces[6])
      +      
      +    else:
      +      pipe_cut = Part.Wire(angled_Helix).makePipeShell([cut_profile],True,isFrenet)
      +      SH_faces.append(pipe_cut.Faces[0])
      +      SH_faces.append(pipe_cut.Faces[1])
      +      SH_faces.append(pipe_cut.Faces[2])
      +        
      +    # Part.show(pipe_cut)
      +  
      +    
      +    Shell_helix = Part.Shell(SH_faces)
      +    
      +    # rect_helix_profile, needed for cutting a tube-shell
      +    pr1 = (r +H/16.0, 0.0, 0.0)
      +    pr2 = (r -H/16.0, 0.0, 0.0)
      +    pr3 = (r -H/16.0, 0.0, P)
      +    pr4 = (r +H/16.0, 0.0, P)
      +  
      +    edge_r1 = Part.makeLine(pr1,pr2)
      +    edge_r2 = Part.makeLine(pr2,pr3)
      +    edge_r3 = Part.makeLine(pr3,pr4)
      +    edge_r4 = Part.makeLine(pr4,pr1)
      +    rect_profile = Part.Wire([edge_r1, edge_r2, edge_r3, edge_r4 ])
      +    rect_helix = Part.Wire(helix).makePipeShell([rect_profile], True, isFrenet)
      +    # if halfturn:
      +    #   rect_helix.rotate(Base.Vector(0,0,0),Base.Vector(0,0,1),180)
      +    rect_helix.translate(FreeCAD.Vector(0.0, 0.0,- P))
      +    # Part.show(rect_helix)
      +    
      +    # rect_ring, nedded for cutting the Shell_helix
      +    pr5 = (r +H*1.1, 0.0, P*1.1)
      +    pr6 = (r, 0.0, P*1.1)
      +    pr7 = (r, 0.0, -P*1.1)
      +    pr8 = (r +H*1.1, 0.0, -P*1.1)
      +    
      +    edge_r5 = Part.makeLine(pr5,pr6)
      +    edge_r6 = Part.makeLine(pr6,pr7)
      +    edge_r7 = Part.makeLine(pr7,pr8)
      +    edge_r8 = Part.makeLine(pr8,pr5)
      +    rect_profile = Part.Wire([edge_r5, edge_r6, edge_r7, edge_r8 ])
      +    
      +    rect_Face =Part.Face(rect_profile)
      +    rect_ring= rect_Face.revolve(Base.Vector(0.0,0.0,0.0),Base.Vector(0.0,0.0,1.0),360)
      +    #Part.show(rect_ring)
      +    
      +    Shell_helix = Shell_helix.cut(rect_ring)
      +    Shell_helix.translate(FreeCAD.Vector(0.0, 0.0, P))
      +    # Part.show(Shell_helix)
      +    
      +    # shell_ring, the transition to a cylinder
      +    pr9 = (r, 0.0, P-offSet)
      +    pr10 = (r, 0.0, -P )
      +    edge_r9 = Part.makeLine(pr9,pr10)
      +    shell_ring= edge_r9.revolve(Base.Vector(0.0,0.0,0.0),Base.Vector(0.0,0.0,1.0),360)
      +  
      +    shell_ring = shell_ring.cut(pipe_cut)
      +    #Part.show(shell_ring)
      +    shell_ring = shell_ring.cut(rect_helix)
      +    shell_ring.translate(FreeCAD.Vector(0.0, 0.0, P))
      +    #Part.show(shell_ring)
      +    
      +    for flaeche in shell_ring.Faces:
      +      TheFaces.append(flaeche)
      +  
      +    for flaeche in Shell_helix.Faces:
      +      TheFaces.append(flaeche)
      +  
      +    if withcham:
      +      #FreeCAD.Console.PrintMessage("with chamfer: " + str(i) + "\n")
      +      # cutting of the bottom Faces
      +      # bot_off = 0.0 # nominal length
      +      cham_off = H/8.0
      +      cham_t = P*math.sqrt(3.0)/2.0*17.0/24.0
      +      
      +      # points for chamfer: common-Method
      +      pch0 =  (0.0, 0.0, -(rotations)*P + bot_off) # bottom center
      +      pch1 =  (r-cham_t,0.0, -(rotations)*P + bot_off)
      +      pch2 =  (r+cham_off, 0.0, -(rotations)*P + cham_t +cham_off  + bot_off)
      +      pch3 =  (r+cham_off, 0.0, -(rotations)*P + 3.0*P + bot_off)
      +      pch4 =  (0.0, 0.0, -(rotations)*P + 3.0*P + bot_off)
      +    
      +      edgech0 = Part.makeLine(pch0,pch1)
      +      edgech1 = Part.makeLine(pch1,pch2)
      +      edgech2 = Part.makeLine(pch2,pch3)
      +      edgech3 = Part.makeLine(pch3,pch4)
      +      edgech4 = Part.makeLine(pch4,pch0)
      +    
      +      Wch_wire = Part.Wire([edgech0, edgech1, edgech2, edgech3, edgech4])
      +      cham_Face =Part.Face(Wch_wire)
      +      cham_Solid = cham_Face.revolve(Base.Vector(0.0,0.0,-(rotations-1)*P),Base.Vector(0.0,0.0,1.0),360)
      +      # Part.show(cham_Solid)
      +      
      +      BotShell = Part.Shell(botFaces)
      +      BotShell = BotShell.common(cham_Solid)
      +      # Part.show(BotShell)
      +      
      +      cham_faces = []
      +      cham_faces.append(cham_Solid.Faces[0])
      +      cham_faces.append(cham_Solid.Faces[1])
      +      cham_Shell = Part.Shell(cham_faces)
      +      # Part.show(cham_Shell)
      +    
      +      pipe0.translate(FreeCAD.Vector(0.0, 0.0, -(rotations-1)*P))
      +      # Part.show(pipe0)
      +      
      +      # Part.show(Fillet_shell)
      +      cham_Shell = cham_Shell.cut(pipe0)
      +      pipe0.translate(FreeCAD.Vector(0.0, 0.0, -P))
      +      # Part.show(pipe0)
      +      cham_Shell = cham_Shell.cut(pipe0)
      +    
      +      '''
      +      botFaces2 = []
      +      for flaeche in BotShell.Faces:
      +        botFaces2.append(flaeche)
      +      for flaeche in cham_Shell.Faces:
      +        botFaces2.append(flaeche)
      +      '''
      +        
      +    else: # tip of screw without chamfer
      +      #FreeCAD.Console.PrintMessage("without chamfer: " + str(i) + "\n")
      +
      +      commonbox = Part.makeBox(d+4.0*P, d+4.0*P, 3.0*P)
      +      commonbox.translate(FreeCAD.Vector(-(d+4.0*P)/2.0, -(d+4.0*P)/2.0,-(rotations)*P+bot_off))
      +      #commonbox.translate(FreeCAD.Vector(-(d+4.0*P)/2.0, -(d+4.0*P)/2.0,-(rotations+3)*P+bot_off))
      +      #Part.show(commonbox)
      +     
      +      BotShell = Part.Shell(botFaces)
      +      #Part.show(BotShell)
      +    
      +      BotShell = BotShell.common(commonbox)
      +      #BotShell = BotShell.cut(commonbox)
      +      bot_edges =[]
      +      bot_z =  1.0e-5 -(rotations)*P + bot_off
      +      
      +      for kante in BotShell.Edges:
      +         if (kante.Vertexes[0].Point.z<=bot_z) and (kante.Vertexes[1].Point.z<=bot_z):
      +            bot_edges.append(kante)
      +            # Part.show(kante)
      +      bot_wire = Part.Wire(Part.__sortEdges__(bot_edges))
      +         
      +      #botFaces2 = []
      +      #for flaeche in BotShell.Faces:
      +      #  botFaces2.append(flaeche)      
      +      
      +      bot_face = Part.Face(bot_wire)
      +      bot_face.reverse()
      +      #botFaces2.append(bot_face)
      +    
      +    '''
      +
      +    BotShell2 = Part.Shell(botFaces2)
      +    # Part.show(BotShell2)
      +    
      +    TheShell2 = Part.Shell(TheFaces)
      +    
      +    # This gives a shell
      +    FaceList = []
      +    for flaeche in TheShell2.Faces:
      +      FaceList.append(flaeche)
      +    for flaeche in BotShell2.Faces:
      +      FaceList.append(flaeche)
      +    
      +    TheShell = Part.Shell(FaceList)
      +    # Part.show(TheShell)
      +    '''
      +    for flaeche in BotShell.Faces:
      +      TheFaces.append(flaeche)
      +    if withcham:
      +      for flaeche in cham_Shell.Faces:
      +        TheFaces.append(flaeche)
      +    else:  
      +      TheFaces.append(bot_face)
      +    TheShell = Part.Shell(TheFaces)
      +    
      +    #print self.Tuner, " ", TheShell.ShapeType, " ", TheShell.isValid(), " hrots: ", halfrots_int, " Shellpunkte: ", len(TheShell.Vertexes)
      +
      +    return TheShell
      +
      +
      +
      +
      +
      +  # if da<>None: make Shell for a nut else: make a screw tap
      +  def makeInnerThread_2(self, d, P, rotations, da, l):
      +    d = float(d)
      +    bot_off = 0.0 # nominal length
      +
      +    H=P*math.cos(math.radians(30)) # Gewindetiefe H
      +    r=d/2.0
      +    
      +    helix = Part.makeHelix(P,P,d*self.Tuner/1000.0,0) # make just one turn, length is identical to pitch
      +    helix.translate(FreeCAD.Vector(0.0, 0.0,-P*9.0/16.0))
      +  
      +    extra_rad = P
      +
      +    # points for inner thread profile
      +    ps0 = (r,0.0, 0.0)
      +    ps1 = (r-H*5.0/8.0,0.0, -P*5.0/16.0)
      +    ps2 = (r-H*5.0/8.0,0.0, -P*9.0/16.0 )
      +    ps3 =  (r, 0.0, -P*14.0/16.0)
      +    ps4 = (r+H*1/24.0,0.0, -P*31.0/32.0) # Center of Arc
      +    ps5 = (r,0.0, -P)
      +    ps6 = (r+extra_rad,0.0, -P)
      +    ps7 = (r+extra_rad,0.0, 0.0) 
      +
      +    #ps6 = (r-extra_rad,0.0, -P)
      +    #ps7 = (r-extra_rad,0.0, 0.0) 
      +     
      +    edge0 = Part.makeLine(ps0,ps1)
      +    edge1 = Part.makeLine(ps1,ps2)
      +    edge2 = Part.makeLine(ps2,ps3)
      +    edge3 = Part.Arc(FreeCAD.Vector(ps3),FreeCAD.Vector(ps4),FreeCAD.Vector(ps5)).toShape()
      +    edge4 = Part.makeLine(ps5,ps6)
      +    edge5 = Part.makeLine(ps6,ps7)
      +    edge6 = Part.makeLine(ps7,ps0)
      +     
      +    W0 = Part.Wire([edge0, edge1, edge2, edge3, edge4, edge5, edge6])
      +    # Part.show(W0)
      +    
      +    makeSolid=True
      +    isFrenet=True
      +    pipe0 = Part.Wire(helix).makePipeShell([W0],makeSolid,isFrenet)
      +    # pipe1 = pipe0.copy()
      +  
      +    TheFaces = [] 
      +    TheFaces.append(pipe0.Faces[0])
      +    TheFaces.append(pipe0.Faces[1])
      +    TheFaces.append(pipe0.Faces[2])
      +    TheFaces.append(pipe0.Faces[3])
      +    
      +    TheShell = Part.Shell(TheFaces)
      +    # print "Shellpoints: ", len(TheShell.Vertexes)
      +
      +    # Handling of the top faces
      +    if da <> None:
      +      TheShell.translate(FreeCAD.Vector(0.0, 0.0,- P))
      +      for flaeche in TheShell.Faces:
      +       TheFaces.append(flaeche)
      +      TheShell.translate(FreeCAD.Vector(0.0, 0.0,- P))
      +      for flaeche in TheShell.Faces:
      +       TheFaces.append(flaeche)
      +
      +      cham_i_delta = da/2.0 - (r-H)
      +      cham_i = cham_i_delta * math.tan(math.radians(15.0))
      +      
      +      offSet = rotations*P - l
      +      #FreeCAD.Console.PrintMessage("Der Offset: " + str(offSet/P) + "\n")
      +      
      +      # points for chamfer: common-Method
      +      pch0 =  (da/2.0-cham_i_delta, 0.0, -cham_i - offSet) # bottom chamfer
      +      pch1 =  (da/2.0, 0.0, 0.0 - offSet)  #
      +      pch2 =  (da/2.0, 0.0, -4.0*P - offSet)
      +      pch3 =  (da/2.0-cham_i_delta, 0.0, -4.0*P - offSet)
      +    
      +      edgech0 = Part.makeLine(pch0,pch1)
      +      edgech1 = Part.makeLine(pch1,pch2)
      +      edgech2 = Part.makeLine(pch2,pch3)
      +      edgech3 = Part.makeLine(pch3,pch0)
      +    
      +      Wch_wire = Part.Wire([edgech0, edgech1, edgech2, edgech3])
      +      cham_Face =Part.Face(Wch_wire)
      +      cham_Solid = cham_Face.revolve(Base.Vector(0.0,0.0,-(rotations-1)*P),Base.Vector(0.0,0.0,1.0),360)
      +      #Part.show(cham_Solid)
      +      #Part.show(Wch_wire)
      +      
      +      rawTopShell = Part.Shell(TheFaces)
      +      topShell = rawTopShell.common(cham_Solid)
      +
      +      # Making a Cutter for the cham face
      +      commonbox = Part.makeBox(d+4.0*P, d+4.0*P, 2.0*P)
      +      commonbox.translate(FreeCAD.Vector(-(d+4.0*P)/2.0, -(d+4.0*P)/2.0,-2.0*P))
      +      #Part.show(commonbox)
      +      
      +      cutterShell = rawTopShell.common(commonbox)
      +      bot_edges =[]
      +      bot_z =  1.0e-5 -2.0*P
      +      
      +      for kante in cutterShell.Edges:
      +         if (kante.Vertexes[0].Point.z<=bot_z) and (kante.Vertexes[1].Point.z<=bot_z):
      +            bot_edges.append(kante)
      +            # Part.show(kante)
      +      bot_wire = Part.Wire(Part.__sortEdges__(bot_edges))
      +         
      +      bot_face = Part.Face(bot_wire)
      +      bot_face.reverse()
      +      t_face = bot_face.copy()
      +      t_face.translate(Base.Vector(0.0, 0.0, 2.0*P))
      +      cutterFaces = cutterShell.Faces
      +      cutterFaces.append(bot_face.Faces[0])
      +      cutterFaces.append(t_face.Faces[0])
      +      cutShell = Part.Shell(cutterFaces)
      +      chamFcutter = Part.Solid(cutShell)
      +      
      +      #Part.show(chamFcutter) 
      +      topCham = cham_Solid.Faces[0]
      +      topCham = topCham.cut(chamFcutter)
      +
      +      #Part.show(topCham)
      +      TheFaces = [topCham.Faces[0]]
      +      TheFaces.extend(topShell.Faces)
      +
      +      for i in range(rotations-4):
      +         TheShell.translate(FreeCAD.Vector(0.0, 0.0,- P))
      +         for flaeche in TheShell.Faces:
      +           TheFaces.append(flaeche)
      +
      +
      +    else:
      +      commonbox = Part.makeBox(d+4.0*P, d+4.0*P, 3.0*P)
      +      commonbox.translate(FreeCAD.Vector(-(d+4.0*P)/2.0, -(d+4.0*P)/2.0,-(3.0)*P))
      +      topShell = TheShell.common(commonbox)
      +      top_edges =[]
      +      top_z =  -1.0e-5 
      +      
      +      for kante in topShell.Edges:
      +         if (kante.Vertexes[0].Point.z>=top_z) and (kante.Vertexes[1].Point.z>=top_z):
      +            top_edges.append(kante)
      +            # Part.show(kante)
      +      top_wire = Part.Wire(Part.__sortEdges__(top_edges))
      +      top_face = Part.Face(top_wire)
      +      
      +      TheFaces = [top_face.Faces[0]]
      +      TheFaces.extend(topShell.Faces)
      +
      +      for i in range(rotations-2):
      +         TheShell.translate(FreeCAD.Vector(0.0, 0.0,- P))
      +         for flaeche in TheShell.Faces:
      +           TheFaces.append(flaeche)
      +    
      +    #FreeCAD.Console.PrintMessage("Base-Shell: " + str(i) + "\n")
      +    # Make separate faces for the tip of the screw
      +    botFaces = []
      +    for i in range(rotations-2, rotations, 1):
      +       TheShell.translate(FreeCAD.Vector(0.0, 0.0,- P))
      +  
      +       for flaeche in TheShell.Faces:
      +         botFaces.append(flaeche)
      +    #FreeCAD.Console.PrintMessage("Bottom-Shell: " + str(i) + "\n")
      +    
      +    if da <> None:
      +      # points for chamfer: common-Method
      +      pch0 =  (da/2.0-cham_i_delta, 0.0, -(rotations)*P + cham_i) # bottom chamfer
      +      pch1 =  (da/2.0, 0.0, -(rotations)*P)  #
      +      pch2 =  (da/2.0, 0.0, -(rotations)*P + 3.0*P)
      +      pch3 =  (da/2.0-cham_i_delta, 0.0, -(rotations)*P + 3.0*P)
      +      #pch4 =  (r-2.0*cham_i_delta, 0.0, -(rotations)*P + 3.0*P)
      +    
      +      edgech0 = Part.makeLine(pch0,pch1)
      +      edgech1 = Part.makeLine(pch1,pch2)
      +      edgech2 = Part.makeLine(pch2,pch3)
      +      edgech3 = Part.makeLine(pch3,pch0)
      +    
      +      Wch_wire = Part.Wire([edgech0, edgech1, edgech2, edgech3])
      +      cham_Face =Part.Face(Wch_wire)
      +      cham_Solid = cham_Face.revolve(Base.Vector(0.0,0.0,-(rotations-1)*P),Base.Vector(0.0,0.0,1.0),360)
      +      #Part.show(cham_Solid)
      +      #Part.show(Wch_wire)
      +      
      +      BotShell = Part.Shell(botFaces)
      +      #Part.show(BotShell)
      +      chamFcutter.translate(FreeCAD.Vector(0.0, 0.0,-(rotations-1)*P))
      +      #Part.show(chamFcutter)
      +      
      +      
      +      BotShell = BotShell.common(cham_Solid)
      +      #Part.show(BotShell)
      +      
      +      cham_face = cham_Solid.Faces[0]
      +      cham_face = cham_face.cut(chamFcutter)
      +      #Part.show(cham_face)
      +    
      +      for flaeche in BotShell.Faces:
      +        TheFaces.append(flaeche)
      +      if da <> None:
      +        TheFaces.append(cham_face.Faces[0])
      +      else:  
      +        TheFaces.append(bot_face)
      +      TheShell = Part.Shell(TheFaces)
      +    
      +      #print self.Tuner, " ", TheShell.ShapeType, " ", TheShell.isValid(), " hrots: ", halfrots_int, " Shellpunkte: ", len(TheShell.Vertexes)
      +  
      +      return TheShell
      +
      +
      +        
      +    else: # make of screw tap
      +      #FreeCAD.Console.PrintMessage("without chamfer: " + str(i) + "\n")
      +
      +      commonbox = Part.makeBox(d+4.0*P, d+4.0*P, 3.0*P)
      +      commonbox.translate(FreeCAD.Vector(-(d+4.0*P)/2.0, -(d+4.0*P)/2.0,-(rotations)*P+bot_off))
      +      #commonbox.translate(FreeCAD.Vector(-(d+4.0*P)/2.0, -(d+4.0*P)/2.0,-(rotations+3)*P+bot_off))
      +      #Part.show(commonbox)
      +     
      +      BotShell = Part.Shell(botFaces)
      +      #Part.show(BotShell)
      +    
      +      BotShell = BotShell.common(commonbox)
      +      #BotShell = BotShell.cut(commonbox)
      +      bot_edges =[]
      +      bot_z =  1.0e-5 -(rotations)*P + bot_off
      +      
      +      for kante in BotShell.Edges:
      +         if (kante.Vertexes[0].Point.z<=bot_z) and (kante.Vertexes[1].Point.z<=bot_z):
      +            bot_edges.append(kante)
      +            # Part.show(kante)
      +      bot_wire = Part.Wire(Part.__sortEdges__(bot_edges))
      +         
      +      bot_face = Part.Face(bot_wire)
      +      bot_face.reverse()
      +    
      +      for flaeche in BotShell.Faces:
      +        TheFaces.append(flaeche)
      +      if da <> None:
      +        for flaeche in cham_Shell.Faces:
      +          TheFaces.append(flaeche)
      +      else:  
      +        TheFaces.append(bot_face)
      +      TheShell = Part.Shell(TheFaces)
      +      TheSolid = Part.Solid(TheShell)
      +    
      +      #print self.Tuner, " ", TheShell.ShapeType, " ", TheShell.isValid(), " hrots: ", halfrots_int, " Shellpunkte: ", len(TheShell.Vertexes)
      +  
      +      return TheSolid
      +
      +
      +
      +
      +
      +
      +  # make the ISO 4032 Hex-nut
      +  # make the ISO 4033 Hex-nut
      +  def makeIso4032(self,SType ='ISO4032', ThreadType ='M6'):
      +    dia = self.getDia(ThreadType)
      +    if SType == 'ISO4032':
      +      # P, c, damax,  dw,    e,     m,   mw,   s_nom
      +      P, c, da, dw, e, m, mw, s = iso4032def[ThreadType]
      +    if SType == 'ISO4033':
      +      # P, c, damax,  dw,    e,     m,   mw,   s_nom
      +      P, c, da, dw, e, m, mw, s = iso4033def[ThreadType]
      +    if SType == 'ISO4035':
      +      # P, c, damax,  dw,    e,     m,   mw,   s_nom
      +      P, c, da, dw, e, m, mw, s = iso4035def[ThreadType]
      +      
      +    residue, turns = math.modf(m/P)
      +    #halfturns = 2*int(turns)
      +      
      +    if residue > 0.0:
      +      turns += 1.0
      +      #halfturns = halfturns +2
      +    #offSet = r - a
      +    
      +    sqrt2_ = 1.0/math.sqrt(2.0)
      +    cham = (e-s)*math.sin(math.radians(15)) # needed for chamfer at nut top
      +    H=P*math.cos(math.radians(30)) # Gewindetiefe H
      +    cham_i_delta = da/2.0 - (dia/2.0-H*5.0/8.0)
      +    cham_i = cham_i_delta * math.tan(math.radians(15.0))
      +  
      +
      +    if self.rThread:
      +      Pnt0 = Base.Vector(da/2.0-2.0*cham_i_delta,0.0,m - 2.0*cham_i)
      +      Pnt7 = Base.Vector(da/2.0-2.0*cham_i_delta,0.0,0.0+ 2.0*cham_i)
      +    else:
      +      Pnt0 = Base.Vector(dia/2.0-H*5.0/8.0,0.0,m - cham_i)
      +      Pnt7 = Base.Vector(dia/2.0-H*5.0/8.0,0.0,0.0+ cham_i)
      +
      +    Pnt1 = Base.Vector(da/2.0,0.0,m)
      +    Pnt2 = Base.Vector(s/2.0,0.0,m)
      +    Pnt3 = Base.Vector(s/math.sqrt(3.0),0.0,m-cham)
      +    Pnt4 = Base.Vector(s/math.sqrt(3.0),0.0,cham)
      +    Pnt5 = Base.Vector(s/2.0,0.0,0.0)
      +    Pnt6 = Base.Vector(da/2.0,0.0,0.0)
      +    
      +    edge0 = Part.makeLine(Pnt0,Pnt1)
      +    edge1 = Part.makeLine(Pnt1,Pnt2)
      +    edge2 = Part.makeLine(Pnt2,Pnt3)
      +    edge3 = Part.makeLine(Pnt3,Pnt4)
      +    edge4 = Part.makeLine(Pnt4,Pnt5)
      +    edge5 = Part.makeLine(Pnt5,Pnt6)
      +    edge6 = Part.makeLine(Pnt6,Pnt7)
      +    edge7 = Part.makeLine(Pnt7,Pnt0)
      +    
      +    # create cutting tool for hexagon head 
      +    # Parameters s, k, outer circle diameter =  e/2.0+10.0     
      +    extrude = self.makeHextool(s, m, s*2.0)
      +
      +    aWire=Part.Wire([edge0,edge1,edge2,edge3,edge4,edge5,edge6,edge7])
      +    #Part.show(aWire)
      +    aFace =Part.Face(aWire)
      +    head = aFace.revolve(Base.Vector(0.0,0.0,0.0),Base.Vector(0.0,0.0,1.0),360.0)
      +    #Part.show(head)
      +  
      +    #Part.show(extrude)
      +    nut = head.cut(extrude)
      +    # Part.show(nut)
      +
      +    if self.rThread:
      +      '''
      +      threadCutter = self.makeInnerThread(dia, P, int(turns), None, m)
      +      # Part.show(threadCutter)
      +      threadCutter.translate(Base.Vector(0.0, 0.0,turns*P))
      +      nut = nut.cut(threadCutter)
      +      '''
      +      nutFaces = [nut.Faces[2]]
      +      for i in range(4,25):
      +        nutFaces.append(nut.Faces[i])
      +
      +
      +      threadShell = self.makeInnerThread_2(dia, P, int(turns), da, m)
      +      threadShell.translate(Base.Vector(0.0, 0.0,turns*P))
      +      #Part.show(threadShell)
      +      nutFaces.extend(threadShell.Faces)
      +      
      +      nutShell = Part.Shell(nutFaces)
      +      nut = Part.Solid(nutShell)
      +      #Part.show(nutShell)
      +    
      +    return nut
      +
      +
      +
      +
      +  # EN 1661 Hexagon nuts with flange
      +  # chamfer at top of hexagon is wrong = more than 30°
      +  def makeEN1661(self, ThreadType ='M8'):
      +    dia = self.getDia(ThreadType)
      +    P, da, c, dc, dw, e, m, mw, r1, s = en1661def[ThreadType]
      +
      +    residue, turns = math.modf(m/P)
      +    #halfturns = 2*int(turns)
      +      
      +    if residue > 0.0:
      +      turns += 1.0
      +    
      +    #FreeCAD.Console.PrintMessage("the nut with isoEN1661: " + str(c) + "\n")
      +    cham = s*(2.0/math.sqrt(3.0)-1.0)*math.sin(math.radians(25)) # needed for chamfer at head top
      +
      +    sqrt2_ = 1.0/math.sqrt(2.0)
      + 
      +    # Flange is made with a radius of c
      +    beta = math.radians(25.0)
      +    tan_beta = math.tan(beta)
      +    
      +    # Calculation of Arc points of flange edge using dc and c
      +    arc1_x = dc/2.0 - c/2.0 + (c/2.0)*math.sin(beta)
      +    arc1_z = c/2.0 + (c/2.0)*math.cos(beta)
      +    
      +    hF = arc1_z + (arc1_x -s/2.0) * tan_beta  # height of flange at center
      +    
      +    #kmean = arc1_z + (arc1_x - s/math.sqrt(3.0)) * tan_beta + mw * 1.1 + cham
      +    #kmean = k * 0.95
      +    
      +
      +    #Hex-Head Points
      +    #FreeCAD.Console.PrintMessage("the nut with kmean: " + str(m) + "\n")
      +    PntH0 = Base.Vector(da/2.0,0.0,m)
      +    PntH1 = Base.Vector(s/2.0,0.0,m)
      +    edgeH1 = Part.makeLine(PntH0,PntH1)
      +
      +    hWire=Part.Wire([edgeH1])
      +    topShell = hWire.revolve(Base.Vector(0.0,0.0,0.0),Base.Vector(0.0,0.0,1.0),360)
      +    #Part.show(hWire)
      +    #Part.show(topShell)
      +    
      +    # create a cutter ring to generate the chamfer at the top of the hex
      +    chamHori = s/math.sqrt(3.0) - s/2.0
      +    PntC1 = Base.Vector(s/2.0-chamHori,0.0,m+m)
      +    PntC2 = Base.Vector(s/math.sqrt(3.0)+chamHori,0.0,m+m)
      +    PntC3 = Base.Vector(s/2.0-chamHori,0.0,m+cham)
      +    PntC4 = Base.Vector(s/math.sqrt(3.0)+chamHori,0.0,m-cham-cham)   #s/math.sqrt(3.0)
      +    edgeC1 = Part.makeLine(PntC3, PntC1)
      +    edgeC2 = Part.makeLine(PntC1, PntC2)
      +    edgeC3 = Part.makeLine(PntC2, PntC4)
      +    edgeC4 = Part.makeLine(PntC4, PntC3)
      +    cWire = Part.Wire([edgeC4, edgeC1, edgeC2, edgeC3])
      +    cFace = Part.Face(cWire)
      +    chamCut = cFace.revolve(Base.Vector(0.0,0.0,0.0),Base.Vector(0.0,0.0,1.0),360)
      +    #Part.show(cWire)
      +    #Part.show(chamCut)
      +
      +
      +    # create hexagon
      +    mhex=Base.Matrix()
      +    mhex.rotateZ(math.radians(60.0))
      +    polygon = []
      +    vhex=Base.Vector(s/math.sqrt(3.0),0.0,m)
      +    for i in range(6):
      +       polygon.append(vhex)
      +       vhex = mhex.multiply(vhex)
      +    polygon.append(vhex)
      +    hexagon = Part.makePolygon(polygon)
      +    hexFace = Part.Face(hexagon)
      +    solidHex = hexFace.extrude(Base.Vector(0.0,0.0,c-m))
      +    #Part.show(solidHex)
      +    hexCham = solidHex.cut(chamCut)
      +    #Part.show(hexCham)
      +    
      +    topFaces = topShell.Faces
      +    
      +    topFaces.append(hexCham.Faces[1])
      +    topFaces.append(hexCham.Faces[2])
      +    topFaces.append(hexCham.Faces[8])
      +    topFaces.append(hexCham.Faces[13])
      +    topFaces.append(hexCham.Faces[14])
      +    topFaces.append(hexCham.Faces[12])
      +    topFaces.append(hexCham.Faces[6])
      +    
      +    hexFaces = [hexCham.Faces[5], hexCham.Faces[11], hexCham.Faces[10]]
      +    hexFaces.extend([hexCham.Faces[9], hexCham.Faces[3], hexCham.Faces[0]])
      +    hexShell = Part.Shell(hexFaces)
      +
      +
      +    H=P*math.cos(math.radians(30)) # Gewindetiefe H
      +    cham_i_delta = da/2.0 - (dia/2.0-H*5.0/8.0)
      +    cham_i = cham_i_delta * math.tan(math.radians(15.0))
      +  
      +    # Center of flange:
      +    Pnt0 = Base.Vector(0.0,0.0,hF)
      +    Pnt1 = Base.Vector(s/2.0,0.0,hF)
      +    
      +    # arc edge of flange:
      +    Pnt2 = Base.Vector(arc1_x,0.0,arc1_z)
      +    Pnt3 = Base.Vector(dc/2.0,0.0,c/2.0)
      +    Pnt4 = Base.Vector((dc-c)/2.0,0.0,0.0)
      +    Pnt5 = Base.Vector(da/2.0,0.0,0.0)     #start of fillet between flat and thread
      +    
      +    edge1 = Part.makeLine(Pnt0,Pnt1)
      +    edge2 = Part.makeLine(Pnt1,Pnt2)
      +    edge3 = Part.Arc(Pnt2,Pnt3,Pnt4).toShape()
      +    edge4 = Part.makeLine(Pnt4,Pnt5)
      +
      +    # make a cutter for the hexShell
      +    PntHC1 = Base.Vector(0.0,0.0,arc1_z)
      +    PntHC2 = Base.Vector(0.0,0.0,0.0)
      +    
      +    edgeHC1 = Part.makeLine(Pnt2,PntHC1)
      +    edgeHC2 = Part.makeLine(PntHC1,PntHC2)
      +    edgeHC3 = Part.makeLine(PntHC2,Pnt0)
      +
      +    HCWire = Part.Wire([edge2, edgeHC1, edgeHC2, edgeHC3, edge1])
      +    HCFace = Part.Face(HCWire)
      +    hex2Cut = HCFace.revolve(Base.Vector(0.0,0.0,0.0),Base.Vector(0.0,0.0,1.0),360)
      +    
      +    hexShell = hexShell.cut(hex2Cut)
      +    #Part.show(hexShell)
      +    
      +    topFaces.extend(hexShell.Faces)
      +    
      +    if self.rThread:
      +      aWire=Part.Wire([edge2,edge3,edge4])
      +      boltIndex = 3
      +    
      +    else:
      +      Pnt7 = Base.Vector(dia/2.0-H*5.0/8.0,0.0,m - cham_i)
      +      Pnt6 = Base.Vector(dia/2.0-H*5.0/8.0,0.0,0.0+ cham_i)
      +      edge5 = Part.makeLine(Pnt5,Pnt6)
      +      edge6 = Part.makeLine(Pnt6,Pnt7)
      +      edge7 = Part.makeLine(Pnt7,PntH0)
      +      aWire=Part.Wire([edge2,edge3,edge4,edge5,edge6,edge7])
      +      boltIndex = 6
      +
      +
      +    #aFace =Part.Face(aWire)
      +    #Part.show(aWire)
      +    headShell = aWire.revolve(Base.Vector(0.0,0.0,0.0),Base.Vector(0.0,0.0,1.0),360)
      +    #FreeCAD.Console.PrintMessage("der Kopf mit revolve: " + str(dia) + "\n")
      +    #Part.show(headShell)
      +    chamFace = headShell.Faces[0].cut(solidHex)
      +    #Part.show(chamFace)
      +    
      +    topFaces.append(chamFace.Faces[0])
      +    for i in range(1,boltIndex):
      +      topFaces.append(headShell.Faces[i])
      +
      +    
      +    if self.rThread:
      +      #rthread = self.makeShellthread(dia, P, halfturns, True, offSet)
      +      #rthread.translate(Base.Vector(0.0, 0.0,-a_point-2.0*P))
      +      threadShell = self.makeInnerThread_2(dia, P, int(turns), da, m)
      +      threadShell.translate(Base.Vector(0.0, 0.0,turns*P))
      +      #Part.show(threadShell)
      +      for tFace in threadShell.Faces:
      +        topFaces.append(tFace)
      +      headShell = Part.Shell(topFaces)
      +      screw = Part.Solid(headShell)
      +    else:
      +      screwShell = Part.Shell(topFaces)
      +      screw = Part.Solid(screwShell)
      +
      +    return screw
      +
      +
      +
      +
      +  # make ISO 7380-1 Button head Screw 
      +  # make ISO 7380-2 Button head Screw with collar 
      +  # make DIN 967 cross recessed pan head Screw with collar 
      +  def makeScrewTap(self, ThreadType ='M6',l=25.0):
      +    dia = self.getDia(ThreadType)
      +
      +    P, tunIn, tunEx  = tuningTable[ThreadType]
      +
      +    residue, turns = math.modf((l)/P)
      +    turns += 1.0
      +    #FreeCAD.Console.PrintMessage("ScrewTap residue: " + str(residue) + " turns: " + str(turns) + "\n")
      +    
      +
      +    if self.rThread:
      +      screwTap = self.makeInnerThread_2(dia, P, int(turns), None, 0.0)
      +      screwTap.translate(Base.Vector(0.0, 0.0,(1-residue)*P))
      +    else:
      +      H=P*math.cos(math.radians(30)) # Gewindetiefe H
      +      r=dia/2.0
      +    
      +      # points for inner thread profile
      +      Pnt0 = Base.Vector(0.0,0.0,(1-residue)*P) 
      +      Pnt1 = Base.Vector(r-H*5.0/8.0,0.0,(1-residue)*P) 
      +      Pnt2 = Base.Vector(r-H*5.0/8.0,0.0,-l) 
      +      Pnt3 = Base.Vector(0.0,0.0,-l) 
      +      
      +      edge1 = Part.makeLine(Pnt0,Pnt1)
      +      edge2 = Part.makeLine(Pnt1,Pnt2)
      +      edge3 = Part.makeLine(Pnt2,Pnt3)
      +      aWire=Part.Wire([edge1,edge2,edge3])
      +      headShell = aWire.revolve(Base.Vector(0.0,0.0,0.0),Base.Vector(0.0,0.0,1.0),360.0)
      +      screwTap = Part.Solid(headShell)
      +
      +    return screwTap
      +
      +
      +
      +
      +
      +
      +
      +
      +
      +  def cutChamfer(self, dia_cC, P_cC, l_cC):
      +    cham_t = P_cC*math.sqrt(3.0)/2.0*17.0/24.0
      +    PntC0 = Base.Vector(0.0,0.0,-l_cC)
      +    PntC1 = Base.Vector(dia_cC/2.0-cham_t,0.0,-l_cC)
      +    PntC2 = Base.Vector(dia_cC/2.0+cham_t,0.0,-l_cC+cham_t+cham_t)
      +    PntC3 = Base.Vector(dia_cC/2.0+cham_t,0.0,-l_cC-P_cC-cham_t)
      +    PntC4 = Base.Vector(0.0,0.0,-l_cC-P_cC-cham_t)
      +    
      +    edgeC1 = Part.makeLine(PntC0,PntC1)
      +    edgeC2 = Part.makeLine(PntC1,PntC2)
      +    edgeC3 = Part.makeLine(PntC2,PntC3)
      +    edgeC4 = Part.makeLine(PntC3,PntC4)
      +    edgeC5 = Part.makeLine(PntC4,PntC0)
      +    CWire=Part.Wire([edgeC1,edgeC2,edgeC3,edgeC4,edgeC5])
      +    #Part.show(CWire)
      +    CFace =Part.Face(CWire)
      +    cyl = CFace.revolve(Base.Vector(0.0,0.0,0.0),Base.Vector(0.0,0.0,1.0),360)
      +    return cyl
      +
      +
      +  # cross recess type H
      +  def makeCross_H3(self, CrossType = '2', m = 6.9, h = 0.0):
      +    # m = diameter of cross at top of screw at reference level for penetration depth
      +    b, e_mean, g, f_mean, r, t1, alpha, beta = iso4757def[CrossType]
      +    
      +    rad265 = math.radians(26.5)
      +    rad28 = math.radians(28.0)
      +    tg = (m-g)/2.0/math.tan(rad265) # depth at radius of g
      +    t_tot = tg + g/2.0 * math.tan(rad28) # total depth
      +    
      +    # print 'tg: ', tg,' t_tot: ', t_tot
      +    hm = m / 4.0
      +    hmc = m / 2.0
      +    rmax = m / 2.0 + hm*math.tan(rad265)
      +    
      +    Pnt0 = Base.Vector(0.0,0.0,hm)
      +    Pnt1 = Base.Vector(rmax,0.0,hm)
      +    Pnt3 = Base.Vector(0.0,0.0,0.0)
      +    Pnt4 = Base.Vector(g/2.0,0.0,-tg)
      +    Pnt5 = Base.Vector(0.0,0.0,-t_tot)
      +    
      +    edge1 = Part.makeLine(Pnt0,Pnt1)
      +    edge3 = Part.makeLine(Pnt1,Pnt4)
      +    edge4 = Part.makeLine(Pnt4,Pnt5)
      +    # FreeCAD.Console.PrintMessage("Edges made Pnt2: " + str(Pnt2) + "\n")
      +    
      +    aWire=Part.Wire([edge1,edge3,edge4])
      +    crossShell = aWire.revolve(Pnt3,Base.Vector(0.0,0.0,1.0),360)
      +    # FreeCAD.Console.PrintMessage("Peak-wire revolved: " + str(e_mean) + "\n")
      +    cross = Part.Solid(crossShell)
      +    #Part.show(cross)
      + 
      +    # the need to cut 4 corners out of the above shape.
      +    # Definition of corner
      +    # The angles 92 degrees and alpha are defined on a plane which has 
      +    # an angle of beta against our coordinate system.
      +    # The projected angles are needed for easier calculation!
      +    rad_alpha = math.radians(alpha/2.0)
      +    rad92 = math.radians(92.0/2.0)
      +    rad_beta = math.radians(beta)
      +    
      +    rad_alpha_p = math.atan(math.tan(rad_alpha)/math.cos(rad_beta))
      +    rad92_p = math.atan(math.tan(rad92)/math.cos(rad_beta))
      +    
      +    tb = tg + (g-b)/2.0 * math.tan(rad28) # depth at dimension b
      +    rbtop = b/2.0 + (hmc + tb)*math.tan(rad_beta) # radius of b-corner at hm
      +    rbtot = b/2.0 - (t_tot - tb)*math.tan(rad_beta) # radius of b-corner at t_tot
      +    
      +    dre = e_mean/2.0 / math.tan(rad_alpha_p)  # delta between corner b and corner e in x direction
      +    #FreeCAD.Console.PrintMessage("delta calculated: " + str(dre) + "\n")
      + 
      +    dx = m/2.0 * math.cos(rad92_p)
      +    dy = m/2.0 * math.sin(rad92_p)
      + 
      +    PntC0 = Base.Vector(rbtop,0.0,hmc)
      +    PntC1 = Base.Vector(rbtot,0.0,-t_tot)
      +    PntC2 = Base.Vector(rbtop+dre,+e_mean/2.0,hmc)
      +    PntC3 = Base.Vector(rbtot+dre,+e_mean/2.0,-t_tot)
      +    PntC4 = Base.Vector(rbtop+dre,-e_mean/2.0,hmc)
      +    PntC5 = Base.Vector(rbtot+dre,-e_mean/2.0,-t_tot)
      +    
      +    PntC6 = Base.Vector(rbtop+dre+dx,+e_mean/2.0+dy,hmc)
      +    #PntC7 = Base.Vector(rbtot+dre+dx,+e_mean/2.0+dy,-t_tot)
      +    PntC7 = Base.Vector(rbtot+dre+2.0*dx,+e_mean+2.0*dy,-t_tot)
      +    PntC8 = Base.Vector(rbtop+dre+dx,-e_mean/2.0-dy,hmc)
      +    #PntC9 = Base.Vector(rbtot+dre+dx,-e_mean/2.0-dy,-t_tot)
      +    PntC9 = Base.Vector(rbtot+dre+2.0*dx,-e_mean-2.0*dy,-t_tot)
      + 
      +    #wire_hm = Part.makePolygon([PntC0,PntC2,PntC6,PntC8,PntC4,PntC0])
      +    #face_hm =Part.Face(wire_hm)
      +    #Part.show(face_hm)
      + 
      +    wire_t_tot = Part.makePolygon([PntC1,PntC3,PntC7,PntC9,PntC5,PntC1])
      +    # Part.show(wire_t_tot)
      +    edgeC1 = Part.makeLine(PntC0,PntC1)
      +    #FreeCAD.Console.PrintMessage("edgeC1 mit PntC9" + str(PntC9) + "\n")
      + 
      +    makeSolid=True
      +    isFrenet=False
      +    corner = Part.Wire(edgeC1).makePipeShell([wire_t_tot],makeSolid,isFrenet)
      +    #Part.show(corner)
      +    
      +    rot_axis = Base.Vector(0.,0.,1.0)
      +    sin_res = math.sin(math.radians(90)/2.0)
      +    cos_res = math.cos(math.radians(90)/2.0)
      +    rot_axis.multiply(-sin_res) # Calculation of Quaternion-Elements
      +    #FreeCAD.Console.PrintMessage("Quaternion-Elements" + str(cos_res) + "\n")
      + 
      +    pl_rot = FreeCAD.Placement()
      +    pl_rot.Rotation = (rot_axis.x,rot_axis.y,rot_axis.z,cos_res) #Rotation-Quaternion 90° z-Axis
      +    
      +    crossShell = crossShell.cut(corner)
      +    #Part.show(crossShell)
      +    cutplace = corner.Placement
      +    
      +    cornerFaces = []
      +    cornerFaces.append(corner.Faces[0])
      +    cornerFaces.append(corner.Faces[1])
      +    cornerFaces.append(corner.Faces[3])
      +    cornerFaces.append(corner.Faces[4])
      +      
      +    cornerShell = Part.Shell(cornerFaces)
      +    cornerShell = cornerShell.common(cross)
      +    addPlace = cornerShell.Placement
      +    
      +    crossFaces = cornerShell.Faces
      + 
      +    for i in range(3):
      +      cutplace.Rotation = pl_rot.Rotation.multiply(corner.Placement.Rotation)
      +      crossShell = crossShell.cut(corner)
      +      addPlace.Rotation = pl_rot.Rotation.multiply(cornerShell.Placement.Rotation)
      +      for coFace in cornerShell.Faces:
      +        crossFaces.append(coFace)
      +
      +    #Part.show(crossShell)
      +    for i in range(1,6):
      +      crossFaces.append(crossShell.Faces[i])
      +
      +    crossShell0 = Part.Shell(crossFaces)
      +    
      +    crossFaces.append(crossShell.Faces[0])
      +    crossShell = Part.Shell(crossFaces)
      +    
      +    cross = Part.Solid(crossShell)
      +    
      +
      +    #FreeCAD.Console.PrintMessage("Placement: " + str(pl_rot) + "\n")
      +       
      +    cross.Placement.Base = Base.Vector(0.0,0.0,h)
      +    crossShell0.Placement.Base = Base.Vector(0.0,0.0,h)
      +    #Part.show(crossShell0)
      +    #Part.show(cross)
      +    return cross, crossShell0
      +
      +
      +
      +  # Allen recess cutting tool
      +  # Parameters used: s_mean, k, t_min, dk
      +  def makeAllen2(self, s_a = 3.0, t_a = 1.5, h_a = 2.0 ):
      +    # h_a  top height location of cutting tool 
      +    # s_a hex width
      +    # t_a dept of the allen
      +    # dk_a diameter not needed anymore
      +
      +    e_cham = 2.0 * s_a / math.sqrt(3.0)
      +    depth = s_a / 3.0
      +    #FreeCAD.Console.PrintMessage("allen tool: " + str(s_a) + "\n")
      +
      +
      +    # Points for an arc at the peak of the cone
      +    rCone = e_cham/4.0
      +    hyp = (depth*math.sqrt(e_cham**2/depth**2+1.0)*rCone)/e_cham
      +    radAlpha = math.atan(e_cham/depth)
      +    radBeta = math.pi/2.0 - radAlpha
      +    zrConeCenter=hyp - depth -t_a
      +    xArc1=math.sin(radBeta)*rCone
      +    zArc1=zrConeCenter - math.cos(radBeta)*rCone
      +    xArc2=math.sin(radBeta/2.0)*rCone
      +    zArc2=zrConeCenter - math.cos(radBeta/2.0)*rCone
      +    zArc3 = zrConeCenter - rCone
      +
      +    # The round part of the cutting tool, we need for the allen hex recess
      +    PntH1 = Base.Vector(0.0,0.0,-t_a-depth-depth)
      +    PntH2 = Base.Vector(e_cham,0.0,-t_a-depth-depth)
      +    PntH3 = Base.Vector(e_cham,0.0,-t_a+depth)
      +    PntH4 = Base.Vector(0.0,0.0,-t_a-depth)
      +
      +    PntA1 = Base.Vector(xArc1,0.0,zArc1)
      +    PntA2 = Base.Vector(xArc2,0.0,zArc2)
      +    PntA3 = Base.Vector(0.0,0.0,zArc3)
      +    
      +    edgeA1 = Part.Arc(PntA1,PntA2,PntA3).toShape()
      +    
      +    edgeH1 = Part.makeLine(PntH1,PntH2)
      +    edgeH2 = Part.makeLine(PntH2,PntH3)
      +    edgeH3 = Part.makeLine(PntH3,PntA1)
      +    edgeH4 = Part.makeLine(PntA3,PntH1)
      +
      +    hWire=Part.Wire([edgeH1,edgeH2,edgeH3,edgeA1,edgeH4])
      +    # Part.show(hWire)
      +    hFace =Part.Face(hWire)
      +    roundtool = hFace.revolve(Base.Vector(0.0,0.0,0.0),Base.Vector(0.0,0.0,1.0),360)
      +
      +    # create hexagon
      +    mhex=Base.Matrix()
      +    mhex.rotateZ(math.radians(60.0))
      +    polygon = []
      +    vhex=Base.Vector(s_a/math.sqrt(3.0),0.0,1.0)
      +    for i in range(6):
      +       polygon.append(vhex)
      +       vhex = mhex.multiply(vhex)
      +    polygon.append(vhex)
      +    hexagon = Part.makePolygon(polygon)
      +    hexFace = Part.Face(hexagon)
      +    solidHex = hexFace.extrude(Base.Vector(0.0,0.0,-1.0-t_a-depth*1.1))
      +    allen = solidHex.cut(roundtool)
      +    #Part.show(allen)
      +
      +    allenFaces = [allen.Faces[0]]
      +    for i in range(2,9):
      +      allenFaces.append(allen.Faces[i])
      +    allenShell = Part.Shell(allenFaces)
      +    solidHex.Placement.Base = Base.Vector(0.0,0.0,h_a)
      +    allenShell.Placement.Base = Base.Vector(0.0,0.0,h_a)
      +    return solidHex, allenShell  
      +
      +
      +
      +  # ISO 10664 Hexalobular internal driving feature for bolts and screws
      +  def makeIso10664_3(self,RType ='T20',t_hl=3.0, h_hl = 0):
      +    # t_hl depth of the recess
      +    # h_hl top height location of Cutting tool
      +    A, B, Re = iso10664def[RType]
      +    sqrt_3 = math.sqrt(3.0)
      +    depth=A/4.0
      +    offSet = 1.0
      +
      +    # Chamfer cutter for the hexalobular recess
      +    PntH1 = Base.Vector(0.0,0.0,-t_hl-depth-1.0)
      +    #PntH2 = Base.Vector(A/2.0*1.02,0.0,-t_hl-depth-1.0)
      +    #PntH3 = Base.Vector(A/2.0*1.02,0.0,-t_hl)
      +    PntH2 = Base.Vector(A,0.0,-t_hl-depth-1.0)
      +    PntH3 = Base.Vector(A,0.0,-t_hl+depth)
      +    PntH4 = Base.Vector(0.0,0.0,-t_hl-depth)
      +    
      +    # Points for an arc at the peak of the cone
      +    rCone = A/4.0
      +    hyp = (depth*math.sqrt(A**2/depth**2+1.0)*rCone)/A
      +    radAlpha = math.atan(A/depth)
      +    radBeta = math.pi/2.0 - radAlpha
      +    zrConeCenter=hyp - depth -t_hl
      +    xArc1=math.sin(radBeta)*rCone
      +    zArc1=zrConeCenter - math.cos(radBeta)*rCone
      +    xArc2=math.sin(radBeta/2.0)*rCone
      +    zArc2=zrConeCenter - math.cos(radBeta/2.0)*rCone
      +    zArc3 = zrConeCenter - rCone
      +
      +    PntA1 = Base.Vector(xArc1,0.0,zArc1)
      +    PntA2 = Base.Vector(xArc2,0.0,zArc2)
      +    PntA3 = Base.Vector(0.0,0.0,zArc3)
      +    
      +    edgeA1 = Part.Arc(PntA1,PntA2,PntA3).toShape()
      +    
      +    edgeH1 = Part.makeLine(PntH1,PntH2)
      +    edgeH2 = Part.makeLine(PntH2,PntH3)
      +    edgeH3 = Part.makeLine(PntH3,PntA1)
      +    edgeH4 = Part.makeLine(PntA3,PntH1)
      +
      +    hWire=Part.Wire([edgeH1,edgeH2,edgeH3,edgeA1])
      +    cutShell = hWire.revolve(Base.Vector(0.0,0.0,0.0),Base.Vector(0.0,0.0,1.0),360)
      +    cutTool = Part.Solid(cutShell)
      +    
      +    
      +    Ri = -((B+sqrt_3*(2.*Re-A))*B+(A-4.*Re)*A)/(4.*B-2.*sqrt_3*A+(4.*sqrt_3-8.)*Re)
      +    #print '2nd  Ri last solution: ', Ri
      +    beta=math.acos(A/(4*Ri+4*Re)-(2*Re)/(4*Ri+4*Re))-math.pi/6
      +    #print 'beta: ', beta
      +    Rh=(sqrt_3*(A/2.0-Re))/2.0
      +    Re_x = A/2.0 - Re + Re*math.sin(beta)
      +    Re_y = Re*math.cos(beta)
      +    Ri_y = B/4.0
      +    Ri_x = sqrt_3*B/4.0
      +    
      +    mhex=Base.Matrix()
      +    mhex.rotateZ(math.radians(60.0))
      +    hexlobWireList = []
      +    
      +    PntRe0=Base.Vector(Re_x,-Re_y,offSet)
      +    PntRe1=Base.Vector(A/2.0,0.0,offSet)
      +    PntRe2=Base.Vector(Re_x,Re_y,offSet)
      +    edge0 = Part.Arc(PntRe0,PntRe1,PntRe2).toShape()
      +    #Part.show(edge0)
      +    hexlobWireList.append(edge0)
      +    
      +    PntRi = Base.Vector(Ri_x,Ri_y,offSet)
      +    PntRi2 = mhex.multiply(PntRe0)
      +    edge1 = Part.Arc(PntRe2,PntRi,PntRi2).toShape()
      +    #Part.show(edge1)
      +    hexlobWireList.append(edge1)
      +  
      +    for i in range(5):
      +       PntRe1 = mhex.multiply(PntRe1)
      +       PntRe2 = mhex.multiply(PntRe2)
      +       edge0 = Part.Arc(PntRi2,PntRe1,PntRe2).toShape()
      +       hexlobWireList.append(edge0)
      +       PntRi = mhex.multiply(PntRi)
      +       PntRi2 = mhex.multiply(PntRi2)
      +       if i == 5:
      +          edge1 = Part.Arc(PntRe2,PntRi,PntRe0).toShape()
      +       else:
      +          edge1 = Part.Arc(PntRe2,PntRi,PntRi2).toShape()
      +       hexlobWireList.append(edge1)
      +    hexlobWire=Part.Wire(hexlobWireList)
      +    #Part.show(hWire)
      +  
      +    face=Part.Face(hexlobWire)
      +    
      +    # Extrude in z to create the cutting tool for the screw-head-face
      +    Helo=face.extrude(Base.Vector(0.0,0.0,-t_hl-depth-offSet))
      +    # Make the recess-shell for the screw-head-shell
      +    
      +    hexlob = Helo.cut(cutTool)
      +    #Part.show(hexlob)
      +    hexlobFaces = [hexlob.Faces[0]]
      +    for i in range(2,15):
      +      hexlobFaces.append(hexlob.Faces[i])
      +
      +    hexlobShell = Part.Shell(hexlobFaces)
      +      
      +    hexlobShell.Placement.Base = Base.Vector(0.0,0.0,h_hl)
      +    Helo.Placement.Base = Base.Vector(0.0,0.0,h_hl)
      +
      +    return Helo, hexlobShell
      +
      +  def setThreadType(self, TType = 'simple'):
      +    self.simpThread = False
      +    self.symThread = False
      +    self.rThread = False
      +    if TType == 'simple':
      +      self.simpThread = True
      +    if TType == 'symbol':
      +      self.symThread = True
      +    if TType == 'real':
      +      self.rThread = True
      +
      +  def setTuner(self, myTuner = 511):
      +    self.Tuner = myTuner
      +
      +  def getDia(self,ThreadType):
      +    if '(' in ThreadType:
      +      threadString = ThreadType.lstrip('(M')
      +      dia = float(threadString.rstrip(')'))
      +    else:
      +      dia=float(ThreadType.lstrip('M'))
      +    return dia
      +
      +    
      +class ScrewMacro(object):
      +  d = QtGui.QWidget()
      +  d.ui = Ui_ScrewMaker()
      +  d.ui.setupUi(d)
      +  if __name__ == '__main__':
      +    d.show()
      +
      +
      +def main():
      +  o = ScrewMacro()
      +
      +if __name__ == '__main__':
      +  main()
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Macro_triangleAH.html b/localwiki/Macro_triangleAH.html new file mode 100644 index 0000000..4d0ad5e --- /dev/null +++ b/localwiki/Macro_triangleAH.html @@ -0,0 +1,133 @@ +Macro triangleAH

      Macro triangleAH

      (Redirected from Macro triangleAH)
      + +
      + + + + + + + + + + + + + + + + + + + + + + + + + + +
      +

      Text-x-python.png Macro Triangle AH

      +
      Description +
      This macro create one triangle creates a triangle by giving the head angle and the height of the triangle. +
      Author +
      mario52 +
      Links +
      Macros recipes
      How to install macros
      How to customize toolbars +
      Version +
      00.02 +
      Date last modification +
      2015-05-03 +
      +

      + +
      +


      +

      +

      Description

      +

      This macro create one isosceles triangle by giving the head angle and the height of the triangle (the triangle of the head is positioned to the xyz coordinates 0.0.0) +

      +

      Use

      +

      Copy the macro Triangle AH complete in the Python console FreeCAD and type: +

      +
      triangleAH(angle=90, height=10)
      +# or
      +triangleAH(90, 10)
      +# or
      +triangleAH(45, hypo=10)
      +# or
      +triangleAH(90, base=10) 
      +

      Script

      +

      Macro_triangleAH.FCMacro +

      +
      __title__   = "triangleAH"
      +__author__  = "Mario52"
      +__version__ = "00.02"
      +__date__    = "03/05/2015"
      +# Give angle and on choice : height or base or hypo
      +from math import cos, sin, tan, degrees, radians, sqrt
      +import Draft, Part
      +def triangleAH(angle, height=0.0, base=0.0, hypo=0.0):
      +    def line_length(x1 = 0.0, y1 = 0.0, z1 = 0.0, length = 10.0, angle2 = 0.0):  # search coordinates
      +        x2 = x1 + (length * cos(radians(angle2)))
      +        y2 = y1 + (length * sin(radians(angle2)))
      +        z2 = z1 #+ ()
      +        return x2,y2,z2                                                          # return coordinates (xyz) to point
      + 
      +    x0 = y0 = z0 = 0.0
      +    angle = float(angle)
      +    height = float(height)
      +    base = float(base)
      +
      +    if base != 0:
      +        height = ( (base/2) / (tan(radians(angle/2))) )                          # imposing base and calculate height
      +    if hypo != 0:
      +        height = hypo * (cos(radians(angle/2)))                                  # imposing hypo and calculate height 
      +    else:
      +        hypo = height / cos(radians(angle/2))                                    # calculate hypotenuse
      +    if base==0:                                                                  # base of triangle
      +        base = (tan(radians(angle/2) ) * height) * 2                             # calculate base
      +
      +    a0 = line_length(x1=x0,y1=y0,z1=z0,length=height,angle2=0 )                  # coord height of triangle
      +    a0 = line_length(x1=x0,y1=y0,z1=z0,length=0, angle2 = angle )                # point 0 (begin vertex)
      +    a  = line_length(x1=a0[0],y1=a0[1],z1=a0[2],length= hypo, angle2=-(angle/2)) #
      +    b  = line_length(a[0],a[1],a[2],length= (abs(a[1])*2), angle2=90.0)          # base of triangle = (abs(a[1])*2)
      +
      +    print "angle theet : ", angle
      +    print "angles base : (", (180-angle)/2,"),(",(180-angle)/2,")"
      +    print "height      : ", height
      +    print "base        : ", base
      +    print "hypotenuse  : ", hypo
      +    print "surface     : ", (base * height) / 2
      +    print "_________________________"
      +    return Draft.makeWire([FreeCAD.Vector(a0),FreeCAD.Vector(a),FreeCAD.Vector(b)],closed=True,face=True,support=None) # create triangle 
      +

      Version

      +

      ver 00.02 03/05/2015 : adding "base=0.0", "hypo=0.0" and print data of triangle +

      ver 00.01 20/03/2015 : +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Macro_unrollRuledSurface_01.png b/localwiki/Macro_unrollRuledSurface_01.png new file mode 100644 index 0000000..8ed9bf4 Binary files /dev/null and b/localwiki/Macro_unrollRuledSurface_01.png differ diff --git a/localwiki/Macros.html b/localwiki/Macros.html new file mode 100644 index 0000000..788cf94 --- /dev/null +++ b/localwiki/Macros.html @@ -0,0 +1,59 @@ +Macros

      Macros

      + +

      Macros are a convenient way to create complex actions in FreeCAD. You simply record actions as you do them, then save that under a name, and replay them whenever you want. Since macros are in reality a list of python commands, you can also edit them, and create very complex scripts. +

      + + +

      How it works

      +

      If you enable console output (Menu Edit -> Preferences -> General -> Macros -> Show scripts commands in python console), you will see that in FreeCAD, every action you do, such as pressing a button, outputs a python command. Thos commands are what can be recorded in a macro. The main tool for making macros is the macros toolbar: Macros toolbar.jpg. On it you have 4 buttons: Record, stop recording, edit and play the current macro. +

      It is very simple to use: Press the record button, you will be asked to give a name to your macro, then perform some actions. When you are done, click the stop recording button, and your actions will be saved. You can now access the macro dialog with the edit button: +

      Macros.png +

      There you can manage your macros, delete, edit or create new ones from scratch. If you edit a macro, it will be opened in an editor window where you can make changes to its code. +

      +

      Example

      +

      Press the record button, give a name, let's say "cylinder 10x10", then, in the Part Workbench, create a cylinder with radius = 10 and height = 10. Then, press the "stop recording" button. In the edit macros dialog, you can see the python code that has been recorded, and, if you want, make alterations to it. To execute your macro, simply press the execute button on the toolbar while your macro is in the editor. You macro is always saved to disk, so any change you make, or any new macro you create, will always be available next time you start FreeCAD. +

      +

      Customizing

      +

      Of course it is not practical to load a macro in the editor in order to use it. FreeCAD provides much better ways to use your macro, such as assigning a keyboard shortcut to it or putting an entry in the menu. Once your macro is created, all this can be done via the Tools -> Customize menu: +

      Macros config.jpg +

      Customize Toolbars This way you can make your macro become a real tool, just like any standard FreeCAD tool. This, added to the power of python scripting within FreeCAD, makes it possible to easily add your own tools to the interface. Read on to the Scripting page if you want to know more about python scripting... +

      +

      Creating macros without recording

      +

      How to install macros You can also directly copy/paste python code into a macro, without recording GUI action. Simply create a new macro, edit it, and paste your code. You can then save your macro the same way as you save a FreeCAD document. Next time you start FreeCAD, the macro will appear under the "Installed Macros" item of the Macro menu. +

      +

      Macros repository

      +

      Visit the Macros recipes page to pick some useful macros to add to your FreeCAD installation. +

      +

      Links

      +

      Installing more workbenches +

      +

      Tutorials

      +

      How to install additional workbenches +

      + +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Macros.png b/localwiki/Macros.png new file mode 100644 index 0000000..fd1caa8 Binary files /dev/null and b/localwiki/Macros.png differ diff --git a/localwiki/Macros_config.jpg b/localwiki/Macros_config.jpg new file mode 100644 index 0000000..6dae5a9 Binary files /dev/null and b/localwiki/Macros_config.jpg differ diff --git a/localwiki/Macros_recipes.html b/localwiki/Macros_recipes.html new file mode 100644 index 0000000..7fab8e8 --- /dev/null +++ b/localwiki/Macros_recipes.html @@ -0,0 +1,433 @@ +Macros recipes

      Macros recipes

      + +
      + + + + + + + + + + + + + + + + + + + + + + + + + + + +
      +

      Base ExampleCommandModel.png Tutorial

      +
      Topic +
      Macros +
      Level +
      Beginner +
      Time to complete +
      +
      Author +
      +
      FreeCAD version +
      +
      Example File(s) +
      +

      + +
      +


      +This page contains macros to add functionality to your freecad installation +

      +

      Macros

      +
      +

      Part CheckGeometry.svg 3D View operations

      +
      +
      • Text-x-python.png Macro Rotate View: This macro rotates the current view by 90° to the left. Only works if you are in Top view.
      • +
      • Text-x-python.png Macro View Rotation: Provides a GUI to permit rotation of view by precise amounts in all three directions.
      • +
      • Text-x-python.png Macro Texture Objects: This macro allows you to temporarily put a texture image on the selected objects.
      • +
      • Text-x-python.png Macro Mouse Cross: This small macro turns the arrow of the mouse in a precision cross.
      • +
      • Text-x-python.png Macro Align View to Face: This macro aligns the current view to a selected face.
      • +
      • Text-x-python.png Macro Align Object to View: This macro align the selected object to the current View and set the coordinates Placement of the camera.
      • +
      • Text-x-python.png Macro Align Camera to Working Plane: This macro aligns the camera to the current Draft Working Plane
      • +
      • Text-x-python.png Macro Align Working Plane to Camera: This macro moves the current Draft Working Plane to the center of the current view
      • +
      • Text-x-python.png Macro Align Face Object to View: This macro align the face of the selected object to the current View (in case face hole the hole is placed to the view).
      • +
      • Macro Toggle Views Visibility.png Macro Toggle Panels Visibility: This macro toggles the visibility of various supporting panels in FreeCAD, allowing the main window to be viewed with all available screen space.
      • +
      • FCCamera 00.png Macro FCCamera: This macro can rotate the screen in a defined angle and the defined axis and creates a plan to face the screen to create a form in the specified plan positions the selected face facing the screen, to detect the position of the camera ...
      • +
      • Macro SelectVisible.png Macro Toggle Visibility: Set of three macro, macro 1: hidden the objects not selected, macro 2: displayed alls objects, macro 3: hidden alls objects.
      • +
      • Macro SelectVisible2.png Macro Toggle Visibility2: Set of two macro, macro 1: hidden the objects not selected, macro 2: displayed alls objects, macro with the original visibility.
      • +
      • SelectVisible.png Macro SelectVisible: All visible objects in the tree will be selected.
      • +
      • Text-x-python.png Macro Manage Navigational Style: This pair of macros allow you to alter the Navigation Style while in the Sketcher.
      • +
      • Text-x-python.png Macro Duplicate Selection: This macro testing if one selection are duplicate , select the object IN THE 3D VIEW the "ForbiddenCursor" stay if the or one selection is duplicate, the macro stay resident.
      • +
      • Macro Copy3DViewToClipboard.png Macro Copy3DViewToClipboard: Copy contents of 3DView resized 640, 480 px to clipboard .
      • +
      • Macro Perpendicular To Wire.png Macro Perpendicular To Wire: This macro positioned your object perpendicularly to wire selected.
      • +
      • Macro Rotate To Point.png Macro Rotate To Point: Macro for rotate on object on itself with the axis of rotation the boundbox center, center of mass or last point clicked
      • +
      • Macro FCTreeView.png Macro FCTreeView: Macro for list all objects in the project in one list without hierarchy, options sort by name, label, visibility, group, by length option search by name, label .... without case sensitive or with case sensitive and select all objects displayed in the macro window.
      • +
      • Macro Select Hovering.png Macro Select Hovering: this macro select a choice Face, Edge, Vertex hovering by the mouse.
      +
      +
      +
      +

      Draft FlipDimension.svg Animation

      +
      + +
      +
      +
      +

      Applications-python.svg Code and Scripting

      +
      +
      • Text-x-python.png Macro MessageBox: shows how to give information to the user through the GUI.
      • +
      • Macro Python Assistant Window.png Macro Python Assistant Window: This macro provides a cut/copy/paste workspace for Python code, it is segmented so different sections can be selected and it is persistent between FreeCAD sessions.
      • +
      • Macro Build Utility.png Macro Build Utility: This macro provides a utility to assemble a project from sub-project files using the Merge Project facility.
      • +
      • Macro Global Variable Watcher.png Macro Global Variable Watcher: This macro facilitates the user selecting global variables and monitoring their values.
      +
      +
      +
      +

      Arch MeshToShape.svg Conversion

      +
      +
      • Text-x-python.png Macro Extract Wires from Mesh: Extracts boundary wires from selected meshes
      • +
      • Text-x-python.png Macro MeshToPart: converts selected meshes to parts
      • +
      • PartToVRML.png Macro PartToVRML: Converts selected parts to VRML meshes for small size and faster loading (VRML models Kicad and Blender compatible)
      • +
      • Text-x-python.png Macro FaceToSketch: Converts the selected Face to a single Sketch without constraints.
      • +
      • Macro FCWire To Volume.png Macro FCWire To Volume: This macro create boolean operation with the objects selected just select the wires give the thickness and click "Create"
      • +
      • Macro DeepCopy.png Macro DeepCopy: Make a compound out of a part with a copy of all its shapes.
      +
      +
      +
      +

      Drawing-orthoviews.svg Drawing Workbench

      +
      +
      • Text-x-python.png Macro Automatic drawing: allows the user to get the view of his object in a drawing with 4 different position (front,top,iso,right). Needs some modification to be perfectly effective
      • +
      • Text-x-python.png Macro CartoucheFC: This GUI macro to fill simply all fields of the cartridge of the plan implementation worksheet FreeCAD, the format of the date and the symbol of the projection mode adapt to the EU region or US selected.
      • +
      • Macro CartoucheFC Full.png Macro CartoucheFC Full: This GUI macro to fill simply all fields of the cartridge templates_Full of the plan implementation worksheet FreeCAD, the format of the date and the symbol of the projection mode adapt to the EU region or US selected.
      • +
      • Text-x-python.png Macro CartoucheFC 2: This GUI macro to fill simply all fields of the cartridge model 2 of the plan implementation worksheet FreeCAD.
      • +
      • Text-x-python.png Macro Normal Vector: Get the normal vector of a preselected face for creating a drawing view normal to that face
      +
      +
      +
      +

      Draft BSpline.svg Dxf 2D Draft

      +
      + +
      +
      +
      +

      Fem ResultDisplacement.svg Fem

      +
      +
      • Text-x-python.png Macro GMSH: Create FEM Meshes by GMSH Mesh Generator
      +
      +
      +
      +

      Part Measure Clear All.svg Info and measures

      +
      +
      • FCInfo.png Macro FCInfo: Gives a series of information about the selected shape and can display a conversion of length, inclination (degrees, radian, grade) shape, surface, volume and the weight of the form in the density selected in various international and Anglo-Saxon units
      • +
      • FCInfo.png Macro FCInfo Alternate Linux: same as above, but for Linux
      • +
      • Macro FCInfoGlass.png Macro FCInfoGlass: Gives a series of information about the selected shape and displayed in screen 3D
      • +
      • FCInfoToMouse.png Macro FCInfoToMouse: Provide informations coordinates, length and angles in real time on the mouse in a bubble annotation displayed in the 3D screen
      • +
      • Text-x-python.png Macro Delta xyz: Gives the Delta values and the distance between 2 points
      • +
      • Text-x-python.png Macro ObjectInfo: User-friendly "Info" module created by a FreeCAD user
      • +
      • Macro Dump Objects.png Macro Dump Objects: This macro generates a listing of all objects in the current document - the list can be in a window or on the Report view.
      • +
      • Macro MeasureCircle.png Macro MeasureCircle: Compute the radius of a circle by 3 points or a circular edge.
      +
      +
      +
      +

      Draft VisGroup.svg Libraries

      +
      + +
      +
      +
      +

      Bound-expression.svg Mathematical functions

      +
      + +

      equations. +

      +
      +
      +
      +

      IFC.svg Multifunctional

      +
      +
      • WF wf.png Macro WorkFeatures: Tool utility to create plans of the axes, planes from 3 points, axes on a form, information on the coordinates of the shape and many other useful features to facilitate the creation of your project. This utility is up next in the combo view.
      +
      +
      +
      +

      Workbench Image.svg Object creation

      +
      +
      • Macro makeCube.png Macro Make Cube: creates a rectangular cuboid from 4 points
      • +
      • Text-x-python.png Macro Solid Sweep: creates a solid by sweeping a 2D profile along a trajectory previously selected in the 3D view. The 2D elements can be created through the regular tools in FreeCAD's GUI.
      • +
      • Text-x-python.png Macro Geodesic Dome: This macro creates a geodesic dome shell
      • +
      • Text-x-python.png Macro Line Length: Create a line giving coordinate XYZ length and angle to plane X Y
      • +
      • Text-x-python.png Macro Cut Line: Cut a line and create x points, giving the number of points, create line or not, create points or not, create bicolor or not on choice.
      • +
      • Text-x-python.png Macro Circle: Create a circle or arc giving radius, diameter, circumference, area, startangle, endangle, arc, anglecenter, cord, arrow, center (point) on choice.
      • +
      • Text-x-python.png Macro Cut Circle: Cut a circle or arc and create x arcs, giving the number of cut.
      • +
      • Text-x-python.png Macro Triangle AH: This macro create one triangle creates a triangle by giving the head angle and the height of the triangle (the triangle of the head is positioned to the xyz coordinates 0.0)
      • +
      • FCTexture.png Macro Texture: Create a project from a bmp image to create a texture easily
      • +
      • FCCreaLoft.png Macro Loft: Create a loft with a list of wire (specially created for Macro Texture see above)
      • +
      • FCCircularTextButtom.png Macro Circular Text: This macro create a text around a cylinder
      • +
      • Text-x-python.png Macro WireXYZ: This macro creates a Wire with the coordinates extracted from a file. The coordinates X Y Z are separated by a space.
      • +
      • Macro ReproWire.png Macro Repro Wire: This macro reproduce all element selected subobject wire or face.
      • +
      • Part Prism Apothem.png Macro Apothem Based Prism GUI: A GUI dialog that creates an Apothem, (inradius) Based Prism from user input.
      • +
      • FCSpring Helix Variable.png Macro FCSpring Helix Variable: This macro create one spring truncate, the troncature is adjustable on the all coil to choice.
      • +
      • Text-x-python.png Macro Guitar fretboard: Guitar Fretboard Maker
      +
      +
      +
      +

      Workbench PartDesign.svg Object transformation

      +
      +
      • Text-x-python.png Macro ArrayCopy: copies the selected object several times, on an array grid
      • +
      • Text-x-python.png Macro FlattenWire: flattens draft wires that are not planar to their median Z coordinate
      • +
      • Text-x-python.png Macro FlattenWire3Points: flattens draft wires that are not planar to a plane defined by 3 points
      • +
      • Text-x-python.png Macro JointWire: allows to find and joint all non connected edge to the closest non connected one using a line
      • +
      • Text-x-python.png Macro Remove parametric history: removes all parametric associativity from an object, leaving it as a "dumb" shape
      • +
      • Text-x-python.png Macro SuperWire: Forces the creation of a Wire from lines and arcs that don't necessarily touch each other. Use this if normal wire operation fails
      • +
      • Text-x-python.png Macro HealArcs: Sometimes arcs are transformed into BSplines, for example when scale operations have been applied to them. This macro recreates valid arcs from them. Useful before exporting to dxf
      • +
      • Macro CloneConvert.png Macro CloneConvert: Creates a clone of the object and the converted in the chosen position and size (inch, mm, m, µm...). The base object is recognized in mm (FreeCAd base)
      • +
      • Text-x-python.png Macro Image Scaling: Macro for easy scaling drawings, graphics, diagram, blueprint and similar 2D images in Image workbench.
      • +
      • Text-x-python.png Macro MatrixTransform: apply linear space transformations to distort shapes. E.g., non-uniform scaling, shearing, mirroring, axes swapping.
      • +
      • Macro Connect And Sweep.png Macro Connect And Sweep: This macro easily creates a connection between two objects, an object and a point or between two points (the center of the objects are the starting and ending points of the sweep) can be selected form a configurable ellipse polygon circle
      • +
      • Part Section.png Macro Section: (parametric): alternative implementation of Part Section tool, more suitable for making sweep paths.
      • +
      • Macro Overlap.png Macro Overlap: (parametric): Boolean operation. Similar to Part Common, but with custom overlap count threshold.
      +
      +
      +
      +

      View.svg Printer 3D

      +
      + +
      +
      +
      +

      Preferences-raytracing.svg Raytracing

      +
      + +
      +
      +
      +

      Spreadsheet.svg Spreadsheet Workbench

      +
      +
      • Aliasmanager icon.png Macro Alias Manager: helps managing aliases inside FreeCAD Spreadsheet workbench. It is able to create, delete, move aliases and create a 'part family' group of files.
      • +
      • Text-x-python.png Macro Spreadsheet Tools: This macro helps managing cells inside FreeCAD Spreadsheet workbench.
      • +
      • Macro FCTreeView.png Macro FCTreeView: Macro for list all objects in the project in one list without hierarchy, options sort by name, label, visibility, group, by length option search by name, label .... without case sensitive or with case sensitive and select all objects displayed in the macro window.
      • +
      • Macro FCSpreadsheet Extract.png Macro FCSpreadSheet Extract: This macro save the data in a csv file with the formula or in a xml file.
      +
      +
      +
      +

      Arch Survey.svg Utility

      +
      + +
      +
      +
      +

      Bulb.svg Wizards

      +
      +
      • Text-x-python.png Macro Sheet Metal Unfolder: Creates an unfolded part from a sheet-metal-part.
      • +
      • Text-x-python.png Macro Unroll Ruled Surface: allows to unroll ruled surfaces and to draw them on a page.
      • +
      • Text-x-python.png Macro Unfold Box: allows to unfold the surfaces of a box of any shape and to draw them on a page.
      • +
      • Text-x-python.png Macro Airfoil Import & Scale: Imports and scales a .dat airfoil to desired chord length.
      • +
      • GW Dim.png Macro Geneva Wheel: Allows the user to create a Geneva wheel mechanism from scratch. Must edit values within the Macro to alter the size of the object.
      • +
      • GW Dim.png Macro Geneva Wheel GUI: A GUI front end that allows the user to create a Geneva wheel mechanism from scratch.
      • +
      • Cabinets32.png Macro Cabinets32: creates side and top/bottom walls for a cabinet with drilled holes for connection parts of manufacturer Hettich.
      • +
      • Text-x-python.png Macro Half_turn_stairs: Creates a half turn (left/right) stair from a Data-file.
      • +
      • Macro Half Hull Model.png Macro Half-Hull Model: This macro generates both three dimensional half-hull and full-hull models from a series of 2D line drawings.
      • +
      • Text-x-python.png Macro Stairs: Create stair helix, create your stair nosing select and run the macro.
      • +
      • Gearworkbech.png Macro FCGear: Additional Workbench to create different types of gears, involute gear, involute rack, cycloide gear, bevel gear.
      • +
      • Text-x-python.png Macro Corner shapes wizard: 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
      • +
      • PropertyMemo.png Macro PropertyMemo: This little macro create one Property additional (memo or other text) for you object (only Draft)
      +
      +
      +
      +

      Std FreeCADWebsite.png Other interesting macros create by FreeCAD users and deposit in extra wiki.

      +
      +
      • 2364.png By microelly2 : freeCAD_macro, geodata, Animation, freecad-nurbs, PieMenu, ..... other
      • +
      • Text-x-python.png By hamish2014: FreeCAD_assembly2, FreeCAD_drawing_dimensioning, ...
      • +
      • Text-x-python.png By triplus: IconThemes, ShortCuts, NavigationIndicator, TabBar, Launcher, PersistentToolbars, PieMenu, ....
      • +
      • 681.jpg By rockn: FreeCAD-Timber, FreeCAD-addons, FreeCAD-library, FreeCAD-StructuresBois, .... other
      • +
      • Text-x-python.png By oddtopus: flamingo (workbench for metal structures)
      • +
      • Text-x-python.png By dprojects: getDimensions FreeCAD macro to get chipboards dimensions to cut (woodworking)
      • +
      • Text-x-python.png By Siardeni: workbench for create metal profiles, square tubing, z profile, palette, rotation, drawing ...
      +
      +
      +


      +

      +

      How to use?

      +
      Macro how to install
      +

      The above macros can easily be plugged on any FreeCAD installation +

      +
      • Starting from FreeCAD v 0.17, a new Tools -> Addons Manager allows you to easily install any macro from this page. The instructions below must still be followed if your version of FreeCAD doesn't have the Addons Manager yet.
      • +
      • Copy the macro python code from the corresponding macro page
      • +
      • In FreeCAD, Macro->Macros->Create new, and give it a name
      • +
      • Paste the python code you copied
      • +
      • Hit the Save button, and restart FreeCAD
      • +
      • Open the Macro manager, select your new macro and click "execute"
      • +
      • Tutorial How to install macros
      +

      Additionally, you can also add your new macro to a custom toolbar +

      +
      • In FreeCAD, go to Tools -> Customize
      • +
      • In the Macros tab, add a new macro, and, if you like, define an icon and a keyboard shortcut
      • +
      • In the Toolbars tab, create a new toolbar, and add your macro, taking it from the "Macros" category.
      • +
      • Tutorial Customize Toolbars
      +
      +


      +

      +

      Adding new macros to this repository

      +
      • Create a new page, beginning its name with "Macro", for example "Macro_My_Excellent_Macro", this can be done simply by editing this page, and adding a new link to your macro, like this:
        +
        • example :
      +
      * {{MacroLink|Text-x-python|Macro My Excellent Macro|Macro My Excellent Macro title}} : My excellent macro description. 
      +
      • Text-x-python : icon by default (replace with your name icon with the exact same name as your macro page if there is. The format always .png only)
      • +
      • Macro My Excellent Macro : macro name
      • +
      • Macro My Excellent Macro title : macro name or title
      +

      A new page (red link) will be created. +

      +
      • In that page, paste the following text:
      +

      (With the default icon) +

      +
      {{Macro|Icon=Text-x-python|Name=Macro_My_Excellent_Macro|Description=What my excellent macro does|Author=your username|Version=1.0|Date=YYYY-MM-DD}
      +
      +

      (With the icon custom) +

      +
      {{Macro|Icon=Macro_My_Excellent_Macro|Name=Macro_My_Excellent_Macro|Description=What my excellent macro does|Author=your username|Version=1.0|Date=YYYY-MM-DD}}
      +
      +

      (Another language with the default icon (example "/fr" "/de" "/it"....)) +

      +
      {{Macro/fr|Icon=Text-x-python|Name=Macro_My_Excellent_Macro|Name/fr=Macro_My_Excellent_Macro|Description=
      + What my excellent macro does|Author=your username|Version=1.0|Date=YYYY-MM-DD}
      +
      +

      (Another language with the icon custom (example "/fr" "/de" "/it"....)) +

      +
      {{Macro/fr|Icon=Macro_My_Excellent_Macro|Name=Macro_My_Excellent_Macro|Name/fr=Macro_My_Excellent_Macro|Description=
      + What my excellent macro does|Author=your username|Version=1.0|Date=YYYY-MM-DD}}
      +
      +
      • You can also Upload a custom format icon.png
        Note that the name of the icon must have the same name as the name of the macro. +
        • example: " Macro_My_Excellent_Macro " without extension (the extension is given by the system), and, replace " Icon=Text-x-python " by " Icon=Macro_My_Excellent_Macro "
        • +
        • Text-x-python Text-x-python.png is the default icon of the page dedicated to the Macro.
      +
      • Paste your macro, and use the Code template to avoid adding spaces into your script. This will display the macro in a monospace font inside a light grey box like the example above.
      • +
      • If you like, upload a .png icon with the exact same name as your macro page (ex. Macro_My_Excellent_Macro.png)
      • +
      • Add an image: an image is useful to show what the macro does. Optionally you can create an animated gif that represents the object in context. The gif image should have a maximum size of 500x500px as the wiki does not resize animated gifs; if the gif is any bigger the animation won't work.
      • +
      • Optionally you can add some more info on how to use your macro, tips, limitations and workaround.
      • +
      • It is also interesting to include version information in your macro. This macro allows you to locate in time compared to the evolution of FreeCAD, do "Menu > Help > About FreeCAD and click to Copy to clipboard" and paste it your macro
      +

      Ex: +

      +
      #OS: Windows Vista
      +#Platform: 32-bit
      +#Version: 0.14.3389
      +#Python version: 2.6.2
      +#Qt version: 4.5.2
      +#Coin version: 3.1.0
      +#SoQt version: 1.4.1
      +#OCC version: 6.5.1 
      +

      It is also advisable to create a macro in your header, this header can be used by the Plugin Loader program to install the macro and check versions. Also available addons_installer.FCMacro +

      Ex: +

      +
      __Title__="Title_Of_macro"
      +__Author__ = "User_Name"
      +__Version__ = "00.11"
      +__Date__    = "2015-07-25"
      +
      +__Comment__ = "This is the comment of the macro"
      +__Web__ = "http://forum.freecadweb.org/viewtopic.php?f=3&t=7384"
      +__Wiki__ = "http://www.freecadweb.org/wiki/index.php?title=Macro_Title_Of_macro"
      +__Icon__  = "/usr/lib/freecad/Mod/plugins/icons/Title_Of_macro"
      +__IconW__  = "C:/Documents and Settings/YourUserName/Application Data/FreeCAD"
      +__Help__ = "start the macro and follow the instructions"
      +__Status__ = "stable"
      +__Requires__ = "freecad 0.14.3706"
      +__Communication__ = "http://www.freecadweb.org/wiki/index.php?title=User:User_Name" 
      +


      +

      +
      • Add it to the above categories, create a new category if needed.
      +

      Tutorials

      + +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Macros_toolbar.jpg b/localwiki/Macros_toolbar.jpg new file mode 100644 index 0000000..4b79785 Binary files /dev/null and b/localwiki/Macros_toolbar.jpg differ diff --git a/localwiki/Manipulator-WB-%40Work.png b/localwiki/Manipulator-WB-%40Work.png new file mode 100644 index 0000000..8a5e845 Binary files /dev/null and b/localwiki/Manipulator-WB-%40Work.png differ diff --git a/localwiki/Manipulator-WB-Aligner.gif b/localwiki/Manipulator-WB-Aligner.gif new file mode 100644 index 0000000..28cd18a Binary files /dev/null and b/localwiki/Manipulator-WB-Aligner.gif differ diff --git a/localwiki/Manipulator-WB-Assembly-Parts.gif b/localwiki/Manipulator-WB-Assembly-Parts.gif new file mode 100644 index 0000000..d294e85 Binary files /dev/null and b/localwiki/Manipulator-WB-Assembly-Parts.gif differ diff --git a/localwiki/Manipulator-WB-Dimension-2.gif b/localwiki/Manipulator-WB-Dimension-2.gif new file mode 100644 index 0000000..b7dcad2 Binary files /dev/null and b/localwiki/Manipulator-WB-Dimension-2.gif differ diff --git a/localwiki/Manipulator-WB-Dimension.gif b/localwiki/Manipulator-WB-Dimension.gif new file mode 100644 index 0000000..dee562b Binary files /dev/null and b/localwiki/Manipulator-WB-Dimension.gif differ diff --git a/localwiki/Manipulator-WB-Measure-Angles.gif b/localwiki/Manipulator-WB-Measure-Angles.gif new file mode 100644 index 0000000..9909f17 Binary files /dev/null and b/localwiki/Manipulator-WB-Measure-Angles.gif differ diff --git a/localwiki/Manipulator-WB-Measure-Radius.gif b/localwiki/Manipulator-WB-Measure-Radius.gif new file mode 100644 index 0000000..287f6c9 Binary files /dev/null and b/localwiki/Manipulator-WB-Measure-Radius.gif differ diff --git a/localwiki/Manipulator-WB-Mover-with-App_Part%26Body.gif b/localwiki/Manipulator-WB-Mover-with-App_Part%26Body.gif new file mode 100644 index 0000000..e24a3ad Binary files /dev/null and b/localwiki/Manipulator-WB-Mover-with-App_Part%26Body.gif differ diff --git a/localwiki/Manipulator-WB-Mover-with-External-Reference.gif b/localwiki/Manipulator-WB-Mover-with-External-Reference.gif new file mode 100644 index 0000000..8d1d5db Binary files /dev/null and b/localwiki/Manipulator-WB-Mover-with-External-Reference.gif differ diff --git a/localwiki/Manipulator-WB-Mover.gif b/localwiki/Manipulator-WB-Mover.gif new file mode 100644 index 0000000..7b007d8 Binary files /dev/null and b/localwiki/Manipulator-WB-Mover.gif differ diff --git a/localwiki/Manipulator-WB-Parallel-Planes-Distance.gif b/localwiki/Manipulator-WB-Parallel-Planes-Distance.gif new file mode 100644 index 0000000..6f52dac Binary files /dev/null and b/localwiki/Manipulator-WB-Parallel-Planes-Distance.gif differ diff --git a/localwiki/Manipulator-ico.png b/localwiki/Manipulator-ico.png new file mode 100644 index 0000000..c14ad57 Binary files /dev/null and b/localwiki/Manipulator-ico.png differ diff --git a/localwiki/Manipulator.html b/localwiki/Manipulator.html new file mode 100644 index 0000000..4ea15a8 --- /dev/null +++ b/localwiki/Manipulator.html @@ -0,0 +1,21 @@ +Manipulator

      Manipulator

      + +

      A manipulator is a handle that can be used to modify an object's appearance, shape, or other parameters. +

      Manipulators.png +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Manipulator_Workbench.html b/localwiki/Manipulator_Workbench.html new file mode 100644 index 0000000..d665e5a --- /dev/null +++ b/localwiki/Manipulator_Workbench.html @@ -0,0 +1,101 @@ +Manipulator Workbench

      Manipulator Workbench

      + +
      + +

      Introduction

      +

      FreeCAD Manipulator WorkBench

      +

      Manipulator-ico.png Manipulator WB is aimed to help FreeCAD users in Aligning, Moving, Rotating and Measuring 3D objects through a friendly GUI. +

      Features: +

      Aligner-ico.png Aligner: a set of tools to move and align 3D parts +

      Mover-ico.png Mover: a set of tools to move and rotate 3D parts on different Axis +

      Caliper-ico.png Caliper: a set of tools to measure 3D parts, with some Snap facility and Radius, Length, Angle measurements. +

      These helpers work with Part, App::Part and Body objects. +

      The Tools can be Floating or Docked Left or Right. +

      Each Tool has a Help Button Help-btn.png to get some useful tips +

      +

      References

      + +

      Tools

      +

      Detailed description here +

      Manipulator-WB-@Work.png +

      YouTube Tutorial Manipulator-WB-@Work +

      +

      Aligner

      +

      Manipulator-WB-Aligner.gif +

      +
      +

      Mover

      +

      Manipulator-WB-Mover.gif +


      +Manipulator-WB-Mover-with-App Part&Body.gif +


      +Manipulator-WB-Mover-with-External-Reference.gif +

      +
      +

      Caliper

      +

      Manipulator-WB-Measure-Radius.gif +


      +Manipulator-WB-Measure-Angles.gif +


      +Manipulator-WB-Dimension.gif +


      +Manipulator-WB-Dimension-2.gif +


      +Manipulator-WB-Parallel-Planes-Distance.gif +

      +
      +

      Manipulator

      +

      Manipulator-WB-Assembly-Parts.gif +

      +

      Installation

      +

      Automatic installation

      +

      - automatically using the FreeCAD Add-on Manager (bundled in to 0.17 dev version under Tools Menu) +

      +

      From GitHub

      +

      - manually by copying the Manipulator folder to the Mod sub-directory of the FreeCAD application. +

      Manipulator github page +

      +

      Supports

      +
      • FreeCAD v0.15 4671
      • +
      • FreeCAD v0.16 >= 6712
      • +
      • FreeCAD v0.17 >= 11707
      +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Manipulators.png b/localwiki/Manipulators.png new file mode 100644 index 0000000..f372d4e Binary files /dev/null and b/localwiki/Manipulators.png differ diff --git a/localwiki/Mantis_logo_262x90.png b/localwiki/Mantis_logo_262x90.png new file mode 100644 index 0000000..2f1c16d Binary files /dev/null and b/localwiki/Mantis_logo_262x90.png differ diff --git a/localwiki/Material.html b/localwiki/Material.html new file mode 100644 index 0000000..fd5094c --- /dev/null +++ b/localwiki/Material.html @@ -0,0 +1,334 @@ +Material

      Material

      + +

      This page is about the material data system in FreeCAD. +

      + + +

      Abstract

      +

      Since it is hard, or even impossible, to define a fixed or complete set of material properties, we go a more open way. Every object in FreeCAD which +has to deal with material will have a Property named "Material", which is a key/value list that can hold an infinite number of material properties. Since this is a very open and extensible way to deal with such data, it also holds the danger of chaos. Therefore this page defines some rules and basic properties for dealing with such material-property-maps. +

      +

      Rules

      +

      Every property set has only one mandatory entry which is "Name". This is the primary key of the material. The rest of the material properties are optional or can be retrieved out of a material DB. +

      Property names (key) are ordered by strings separated by underscores. The first substring is named by the application or standard, the following can be used to further group the properties. The Values can also be grouped by underscores, e.g. to separate different sorts of steel. Examples: +

      +
      • Name=Steel_Cast
      • +
      • SpecificWeight=7.85 (at 20° in kg/mm3)
      • +
      • EN10027_name = S235JR+AR (steel standard EN 10027-1)
      • +
      • FEM_YoungsModulus = xx (in mm−1·kg·s−2)
      • +
      • FEM_YoungsModulus_Z
      • +
      • FEM_YoungsModulus_X
      +

      Each property has a human readably description on this Material page, with links to further information (e.g. Wikipedia). +

      For each property a unit has to be defined, based on the FreeCAD internal unit mm-kg-s! That allows consistent usage and translation. +

      The key (name) and the value of the property uses only ASCII characters (7-bit). The keys are written in Camel-Case but interpreted case-insensitive. +

      The underscores allow later a tree view property editor/viewer which allow folding. +

      +

      Tools

      +

      There are some good resources out there handle materials more easy: +

      + +

      Material Database

      +

      Given that above standard is implemented, it would be stupid to store all the properties again and again to objects. Basically we can build up a Material DB with the Name as a primary key. So if you have no special needs for your material, you just define e.g. Name=Steel and FreeCAD can retrieve all properties from that DB. Every additional property you set in the map overrides the one from the DB. +

      In the future we can host that DB somwhere in the Web and build up a general OpenSource material DB. +

      At the moment I think of a compiled in mini dataset with a set of "basic" materials and its basic properties and a SQLite based full version. +

      +

      Material.py

      +

      Since handling material-properties is a tedious work we should implement a Python front-end module calls Material.py. This will be the place to implement all kind of helper methods for material handling. +

      +
      • Calculation of Mass out of Volume and Density
      • +
      • Translation in different unit systems
      • +
      • Calculation needed in special application (e.g. FEM)
      • +
      • and anything else we don't know yet
      +

      The module should be implemented that way it can run in FreeCAD or stand alone on the command line (material-property-map has be given as python map). +

      +

      The FreeCAD material card file format

      +

      Working with materials means often import/export material-definitions. There fore a file format is needed. Since we have only key/value form, we can use a simple and easy to read and parse file format. There fore the ini-file format is chosen. Its standardized and there are already parser available. E.g the Config parser module in python. +

      Each material definition reside in a file with the ending .FCMat. Some of this files are part of the FreeCAD source and get compiled into the binary. This is to save overhead in distribution and access. But also files can be placed and searched on different places to allow additional non-standard material definitions. +

      +

      Examples

      +
      ; last modified 1 April 2001 by John Doe
      +
      +Name=Steel_Cast
      +Father=Steel
      +Source=Some material book everyone knows (or not) ;Some comment
      + 
      +[EN10027]
      +; steel standard EN 10027-1
      +Name=S235JR+AR      
      +
      +[Graphic]
      +Color_Emissiv = 255,255,255
      +
      +

      Material properties

      +

      Here now the description of agreed material-properties. Feel free to add a subsection for the material-properties of you field of expertise. +

      +

      General

      + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
      General material properties +
      property name + Description + Unit/Data-Type +
      Name + Unique name of the property, following the rules described above ASCII string 7-bit +
      Father + Name of the material group this material belongs to. If defined this material inherits all the father properties. That means if not defined the father properties will be used. ASCII string 7-bit +
      Description + A placeholder for a longer description of the material ASCII string 7-bit +
      SpecificWeight + The specific weight (also known as the unit weight) is the weight per unit volume of a material. see: Specific_weight kg/mm^3 +
      Vendor + Specifies the brand or vendor of the material ASCII string 7-bit +
      ProductURL + An URL where to find more information about the material ASCII string 7-bit +
      SpecificPrice + The price per unit of this material. Units can vary a lot (USD/m³, EUR/piece, etc...) ASCII string 7-bit +
      +

      ToDos: add some properties with an ordering system for materials (metal, alloy, mineral, wood, ....) +

      +

      Mechanical

      + + + + + + + + + + + + + + + + + + + + + +
      Material properties used in mechanical engineering +
      property name + Description + Unit/Data-Type +
      YoungsModulus + Young's modulus, also known as the tensile modulus or elastic modulus, is a measure of the stiffness of an elastic material and is a quantity used to characterize materials. See: Young's modulus + kg*mm^-1*s^-2 (kPa) +
      UltimateTensileStrength + Des... + N'*mm^-2 (MPa) +
      Hardness + Des... + +
      EN-10027-1 + In case of steel material the Steel grade as defined in the European standard No. 10027-1. string ASCII 7-bit +
      +

      ToDos: further add properties needed for mechanical design. +

      +

      Graphical

      +

      This section defines material-properties which are related to the visual appearance of the material. The +

      + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
      visual appearance +
      property name + Description + Unit/Data-Type +
      AmbientColor + Ambient color in the Coin3D color model float,float,float range: 0.0-1.0 +
      DiffuseColor + Diffuse color in the Coin3D color model float,float,float range: 0.0-1.0 +
      SpecularColor + Specular color in the Coin3D color model float,float,float range: 0.0-1.0 +
      EmissiveColor + Emissive color in the Coin3D color model float,float,float range: 0.0-1.0 +
      Shininess + Ambient color in the Coin3D color model float range: 0.0-1.0 +
      Transparency + Ambient color in the Coin3D color model float range: 0.0-1.0 +
      VertxShader + Vertex shader program as defined in GlSl Multi line string ASCII 7-bit +
      FragmentShader + Fragment shader program as defined in GlSl Multi line string ASCII 7-bit +
      +


      +

      +

      Finite Element Method

      +

      ToDos: Build up collection of FEM material properties. +

      +

      Computational Fluid Dynamics

      +

      ToDos: Build up collection of CFM material properties. +

      +

      Architecture and BIM

      + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
      Material properties used in architectural design +
      property name + Description + Unit/Data-Type +
      StandardFormat + The standard specification system used in this material (ASTM, MasterFormat, CSI, OmniClass, etc...) String ASCII 7-bit +
      StandardCode + The specific code of this material in the above standard format String ASCII 7-bit +
      FireStandard + The fire rating standard used in the material String ASCII 7-bit +
      FireClass + The fire resistance class of the material in the above standard String ASCII 7-bit +
      ThermalConductivity + The thermal conductivity (R or lambda coefficient) that indicates the capacity to transfer heat of a material W/m²K +
      SoundTransmission + The sound transmission coefficient of this material W/m²K +
      Finish + The type of finishing/coating of this material String ASCII 7-bit +
      Color + The color of this material String ASCII 7-bit +
      UnitsArea + The number of units of this material necessary to fill a certain area String ASCII 7-bit +
      +

      ToDos: add sustainability & LEED properties +

      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Material.svg b/localwiki/Material.svg new file mode 100644 index 0000000..f39bfbc --- /dev/null +++ b/localwiki/Material.svg @@ -0,0 +1,589 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + + + + + + + + diff --git a/localwiki/MaterialDragNDrop.png b/localwiki/MaterialDragNDrop.png new file mode 100644 index 0000000..eb369b0 Binary files /dev/null and b/localwiki/MaterialDragNDrop.png differ diff --git a/localwiki/MaterialListView.png b/localwiki/MaterialListView.png new file mode 100644 index 0000000..088ba50 Binary files /dev/null and b/localwiki/MaterialListView.png differ diff --git a/localwiki/MaterialProperties.png b/localwiki/MaterialProperties.png new file mode 100644 index 0000000..d254a40 Binary files /dev/null and b/localwiki/MaterialProperties.png differ diff --git a/localwiki/MaterialSelection.png b/localwiki/MaterialSelection.png new file mode 100644 index 0000000..e293665 Binary files /dev/null and b/localwiki/MaterialSelection.png differ diff --git a/localwiki/Material_data_model.html b/localwiki/Material_data_model.html new file mode 100644 index 0000000..b5efbed --- /dev/null +++ b/localwiki/Material_data_model.html @@ -0,0 +1,248 @@ +Material data model

      Material data model

      + +
      + +

      Purpose and principles

      +

      By storing material properties in an unified data structure, one aims to ease data retrieval that can be carried out in different contexts: +

      +
      • when building a finite element model
      • +
      • when rendering a 3D model
      • +
      • to be able to track changes in a material of a component created in FreeCAD, for PDM applications,
      • +
      • BIM application (architecture and construction industry)
      +

      To manage material properties, it is proposed to create a specific data model that will be instanced when a new material is created whithin FreeCAD. +

      It will be possible to create a material either by defining by hand its properties through a material workbench, or by reading material properties from a file. The formats of such files is to be defined (some already exist, like MatML, STEP AP235 & IGR45...). +

      Also, it will be possible to save the material properties in a collection of files in a format still to be chosen as well. The collection of files that can be stored in a common directory will form the FreeCAD material database. +

      Through this data model, material can be defined in FreeCAD without the need to define a component. +

      A new pointer will be created in the component data model, to link to a material that has been defined through the material data model. +

      +

      Outcome

      +

      Through this material data model, it is proposed to offer a tool to manage easily material data within FreeCAD. +

      +

      Brainstorming

      +

      Organizing

      +

      Different kinds of data need to be managed to describe a material. +A material data model is proposed below. +Some examples of the data that can be stored within this structure are given as well. +

      +

      Material data model

      +

      In addition to classical "string" attributes like a name, and a family, 3 different specific kinds of information need to be managed to describe a material in FreeCAD. +

      +
      • properties: generic structure to store data describing the engineering properties of the material
      • +
      • chemical composition: chemical composition of the material
      • +
      • appearance: information describing how the material will look like in FreeCAD (color, shininess...)
      +

      All of these kind of information do not need necessarily to be defined for the material to exist. Finally, below is the list of attributes retained to describe a material in FreeCAD. +

      +

      Name

      +

      A string indicating the name of the material. It is its designation. +

      +

      Family

      +

      A string indicating the family of the material, such as for instance: +

      +
      • metal
      • +
      • plastic
      • +
      • ...
      +

      Additionnally, it is proposed to create a map between the families (for instance stored in a XML file) so as to be able to browse the FreeCAD material database. +

      Such a map could for instance contain a tree presenting relationships between families, like: +

      +
      • metal -> steel -> flat carbon steel -> advanced high strength steel
      • +
      • metal -> aluminium -> casted aluminium
      +

      Manufacturer

      +

      A string indicating the manufacturer of the material. +

      +

      URL

      +

      A string indicating the web page presenting the material. +

      +

      Properties

      +
      Description
      +

      The material data model includes a collection of properties. +The size of such a collection is not fixed and may be extended with new user-defined properties. +

      A property contains the following attributes. +

      +
      • name: string
      • +
      • symbol: string to write the symbol of the properties (?in Latex math format?)
      • +
      • type: "scalar" or "array"
      • +
      • value: scalar (if it is a scalar)
      • +
      • values: array (if it is an array)
      • +
      • parameterNames: array of strings (for "array" type property)
      • +
      • parameterValues: array of scalars (for "array" type property)
      • +
      • unit & unitMagnitude (specific object described in Units) (to be noted: examples include unitMagnitude, while I am not completely sure that this should be defined at property level. The unit system may be defined at material level)
      • +
      • direction: a vector indicating in which direction is to be understood the property value. The vector is itself a FreeCAD object expressed in the global coordinate system or in a user-defined coordinate system
      • +
      • notes: string that can be used to describe a bit more the property like what is its meaning, how has it been measured... It can also help to understand the name of the properties
      +

      Material properties will be identified thanks to their name in order to process them, i.e. for instance writing the Yield strength in a finite element model. In order to ease material data creation within FreeCAD, a standardized list of property names along with their standard units will be proposed to the user. Nonetheless, the user is free to create new properties, with new names, new units, and so on... +

      Below is proposed the dictionary of standard properties. Feel free to add new ones. +

      +
      <?xml version="1.0" encoding="UTF-8"?>
      +<MatPropDictionary LastUpdate="2011-10-24T09:00:00">
      +   <Property Name="Yield Stress" Symbol="YS" UnitSignature="-1 1 -2 0 0 0 0" />
      +   <Property Name="Ultimate tensile strength" Symbol="UTS" UnitSignature="-1 1 -2 0 0 0 0" />
      +   <Property Name="Mean Lankford coefficient" Symbol="r_{mean}" UnitSignature="0 0 0 0 0 0 0" />        
      +   <Property Name="Hardening coefficient" Symbol="n" UnitSignature="0 0 0 0 0 0 0" />     
      +   <Property Name="Strain hardening" UnitSignature="-1 1 -2 0 0 0 0" />
      +   <Property Name="Elastic modulus" Symbol="E" UnitSignature="-1 1 -2 0 0 0 0" />
      +   <Property Name="Density" Symbol="\rho" UnitSignature="-3 1 0 0 0 0 0" />
      +   <Property Name="Poisson coefficient" Symbol="\nu" UnitSignature="0 0 0 0 0 0 0" />
      +   <Property Name="Uniform elongation" Symbol="UE" UnitSignature="0 0 0 0 0 0 0" />
      +   <Property Name="Total elongation" Symbol="TE" UnitSignature="0 0 0 0 0 0 0" />
      +</MatPropDictionary>
      +
      +

      Notes: "Mean Lankford coefficient is representative of the anisotropy of a thin metal sheet." "The Hardening coefficient is representative of the hardening capacity of a metal. It appears in Hollomon formula that can relates cumulated plastic strain to stress." +

      +
      Example 1: Cost per tonne
      +

      A first example is given below to show how a Cost per tonne property can be stored. +

      +
      • name: Cost per tonne
      • +
      • symbol: not applicable
      • +
      • type: scalar
      • +
      • value: 500
      • +
      • values: not applicable (but could be: for instance different cost values per different countries)
      • +
      • parameterNames: not applicable (but could be: for instance different cost values for different countries)
      • +
      • parameterValues: not applicable (but could be: for instance different cost values for different countries)
      • +
      • parameterUnits: not applicable
      • +
      • unit & unitMagnitude: [[ 0, -3, 0, 0, 0, 0, 0], 1] +
        • meaning m^(-3) (more details about unit & unit system specifications in Units page)
      • +
      • direction: not applicable
      +
      Example 2: Yield strength
      +

      A second example is given below to show how the Yield strength property can be stored. +

      +
      • name: Yield stress
      • +
      • symbol: YS
      • +
      • type: scalar
      • +
      • value: 450
      • +
      • values: not applicable
      • +
      • parameterNames: not applicable
      • +
      • parameterValues: not applicable
      • +
      • parameterUnits: not applicable
      • +
      • unit & unitMagnitude: [[ -1, 1, -2, 0, 0, 0, 0], 1] +
        • meaning Pa (more details about unit & unit system specifications in Units page)
      • +
      • direction: [ 1, 0, 0] in global coordinate system +
        • given a steel sheet, this means that the Yield strength given is expressed in x direction, that can be for instance the rolling direction
      +
      Example 3: Strain hardening
      +

      A third example is given below to show how the Strain hardening property can be stored. +This is a more complex example because Strain hardening is represented by a serie of curves. +The curves represent the stress evolution with respect to plastic strain. +3 curves have been obtained at different strain rates. +All curves have been obtained at room temperature. +

      +
      • name: Strain hardening
      • +
      • symbol: not applicable
      • +
      • type: scalar
      • +
      • value: not applicable
      • +
      • values: [[0., 100, 150, 200], [ 0., 120, 180, 210], [ 0., 140, 190, 220]]
      • +
      • parameterNames: [Plastic strain, Strain rate, Temperature]
      • +
      • parameterValues: +
        • The 1st three arrays represents plastic strain evolutions
        • +
        • The 2nd serie of three arrays represents the strain rate evolutions. A single value is given in each of the arrays, meaning that the strain rate doesn't change for each the corresponding stress evolutions.
        • +
        • The last serie of a single array represents temperature evolutions. This time a single value is written in a single array, meaning that temperature doesn't change for a given array of stress, and this applies for all stress arrays. +
          1. 1st serie: [[[0. , 0.4, 0.8, 1], [ 0, 0.4, 0.8, 1], [ 0, 0.4, 0.8, 1]],
          2. +
          3. 2nd serie: [[0.] , [100] , [1000.] ],
          4. +
          5. 3rd serie: [[18.] ],]
      • +
      • parameterUnits & parameterUnitMagnitudes: [[[ 0, 0, 0, 0, 0, 0, 0], 1], [[ 0, 0, -1, 0, 0, 0, 0], 1], [[ 0, 0, 0, 0, 1, 0, 0], 1]] +
        • meaning none, s^(-1) and, K (more details about unit & unit system specifications in Units page)
      • +
      • unit & unitMagnitude: [[ -1, 1, -2, 0, 0, 0, 0], 1] +
        • meaning Pa (more details about unit & unit system specifications in Units page)
      • +
      • direction: not applicable
      +

      Chemical composition

      +

      [Yet to be filled up] +

      +

      Appearance

      +

      [Yet to be filled up] +

      +

      Notes

      +

      A string where the user can add its own comments about the material. +

      +

      Material data model applications: some examples

      +
      Example 1: Brick masonry
      +
      Name
      +

      Brick masonry +

      +
      Family
      +

      ?string? +

      +
      Properties
      +
      • Weight: 1kg/m³
      • +
      • Cost per cubic meter: 1€/m³
      • +
      • Number of bricks por base unit: ?float?
      • +
      • Volume of mortar por base unit: ?float?
      • +
      • Mortar type: ?string?
      • +
      • Brick type: ?string?
      • +
      • Fire resistance class: ?string?
      • +
      • Thermal conductivity: 1 W/mK
      +
      Manufacturer
      +

      ?string? +

      +
      URL
      +

      ?string? +

      +
      Notes
      +

      Notes about maintainance, special cares to be taken, etc... +

      CSI/MasterFormat code (as there are several systems used in the industry which give to all material a special code, I propose to enter it in the notes, because it doesn't appear to me relevant create a specific properties that we won't be able to name exactly). +

      +

      Next actions

      +
      • Define a set of names for classical properties, that we can define in a dictionary (FreeCAD configuration file). These properties will most notably be re-used in other contexts like the FEM module.
      • +
      • Fill up Chemical composition section.
      • +
      • Fill up Appearance section.
      • +
      • Define a set of default chemical components.
      • +
      • Review by other people.
      • +
      • Implement in C++ data model and ability to write/read in a file (ISO 10303-45 through SCL?).
      • +
      • Implement XML dictionaries to store default properties, with their units, that can be used by the user.
      • +
      • Implement python GUI to handle this data.
      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Material_editor.html b/localwiki/Material_editor.html new file mode 100644 index 0000000..5b9e259 --- /dev/null +++ b/localwiki/Material_editor.html @@ -0,0 +1,38 @@ +Material editor

      Material editor

      + +

      The Material Editor allows you to edit and save the information contained in a FreeCAD material. Currently such materials are used by the FEM and Arch workbenches. +

      Material editor.jpg +

      The material editor can currently be accessed by: +

      + +
       import MaterialEditor
      + MaterialEditor.openEditor()
      +

      Options

      +
      • Browser button: Opens the contents of the URL property in a browser
      • +
      • Material card: Allows to choose a preset to fill in the fields
      • +
      • Open: Opens a .FCMat file
      • +
      • Save as: Saves the contents of the editor as a new .FCMat file
      • +
      • Preview: Not implemented yet
      • +
      • Properties editor: Allows to edit the contents of the material properties
      • +
      • Add property: Allows to add a new custom property
      • +
      • Delete property: Deletes a selected property. Only custom properties can be deleted
      +

      Note: +

      +
      • The OK and Cancel buttons have the same effect when the Material editor is not used to edit directly the material property of an existing object.
      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Material_editor.jpg b/localwiki/Material_editor.jpg new file mode 100644 index 0000000..c6f6eba Binary files /dev/null and b/localwiki/Material_editor.jpg differ diff --git a/localwiki/Matrix_API.html b/localwiki/Matrix_API.html new file mode 100644 index 0000000..f9c582e --- /dev/null +++ b/localwiki/Matrix_API.html @@ -0,0 +1,303 @@ +Matrix API

      Matrix API

      + +

      4x4 Matrixes are used everywhere throughout FreeCAD and can be created by one of the following manners: +

      +
      m=FreeCAD.Matrix()          # m = the [http://en.wikipedia.org/wiki/Identity_matrix identity matrix]
      +m=FreeCAD.Base.Matrix()
      +print m.A21()               # print m[1][0] 
      +


      +

      +
      +
      Method.png A ( )
      +
      +

      Description: +

      Returns: all the matrix elements. +

      +
      +
      +


      +

      +
      +
      Method.png A11 ( )
      +
      +

      Description: +

      Returns: a matrix element. +

      +
      +
      +


      +

      +
      +
      Method.png A12 ( )
      +
      +

      Description: +

      Returns: a matrix element. +

      +
      +
      +


      +

      +
      +
      Method.png A13 ( )
      +
      +

      Description: +

      Returns: a matrix element. +

      +
      +
      +


      +

      +
      +
      Method.png A14 ( )
      +
      +

      Description: +

      Returns: a matrix element. +

      +
      +
      +


      +

      +
      +
      Method.png A21 ( )
      +
      +

      Description: +

      Returns: a matrix element. +

      +
      +
      +


      +

      +
      +
      Method.png A22 ( )
      +
      +

      Description: +

      Returns: a matrix element. +

      +
      +
      +


      +

      +
      +
      Method.png A23 ( )
      +
      +

      Description: +

      Returns: a matrix element. +

      +
      +
      +


      +

      +
      +
      Method.png A24 ( )
      +
      +

      Description: +

      Returns: a matrix element. +

      +
      +
      +


      +

      +
      +
      Method.png A31 ( )
      +
      +

      Description: +

      Returns: a matrix element. +

      +
      +
      +


      +

      +
      +
      Method.png A32 ( )
      +
      +

      Description: +

      Returns: a matrix element. +

      +
      +
      +


      +

      +
      +
      Method.png A33 ( )
      +
      +

      Description: +

      Returns: a matrix element. +

      +
      +
      +


      +

      +
      +
      Method.png A34 ( )
      +
      +

      Description: +

      Returns: a matrix element. +

      +
      +
      +


      +

      +
      +
      Method.png A41 ( )
      +
      +

      Description: +

      Returns: a matrix element. +

      +
      +
      +


      +

      +
      +
      Method.png A42 ( )
      +
      +

      Description: +

      Returns: a matrix element. +

      +
      +
      +


      +

      +
      +
      Method.png A43 ( )
      +
      +

      Description: +

      Returns: a matrix element. +

      +
      +
      +


      +

      +
      +
      Method.png A44 ( )
      +
      +

      Description: +

      Returns: a matrix element. +

      +
      +
      +


      +

      +
      +
      Method.png determinant ( )
      +
      +

      Description: Computes the determinant of the matrix +

      Returns: a number. +

      +
      +
      +


      +

      +
      +
      Method.png inverse ( )
      +
      +

      Description: Inverts this matrix, if possible +

      Returns: nothing. +

      +
      +
      +


      +

      +
      +
      Method.png invert ( )
      +
      +

      Description: Returns the inverse of this matrix, if possible +

      Returns: a Matrix +

      +
      +
      +


      +

      +
      +
      Method.png move ( Vector )
      +
      +

      Description: Makes this matrix a translation matrix +

      Returns: nothing. +

      +
      +
      +


      +

      +
      +
      Method.png multiply ( Matrix or Vector )
      +
      +

      Description: Returns the cross product of a matrix or vector with this matrix +

      Returns: a Matrix +

      +
      +
      +


      +

      +
      +
      Method.png rotateX ( Float(radians) )
      +
      +

      Description: Makes this matrix a rotation about X transform +

      Returns: nothing. +

      +
      +
      +


      +

      +
      +
      Method.png rotateY ( Float(radians) )
      +
      +

      Description: Makes this matrix a rotation about Y transform +

      Returns: nothing. +

      +
      +
      +


      +

      +
      +
      Method.png rotateZ ( Float(radians) )
      +
      +

      Description: Makes this matrix a rotation about Z transform +

      Returns: nothing. +

      +
      +
      +


      +

      +
      +
      Method.png scale ( Vector )
      +
      +

      Description: Makes this matrix a scaling transform +

      Returns: nothing. +

      +
      +
      +


      +

      +
      +
      Method.png transform ( Vector, Matrix )
      +
      +

      Description: Makes this matrix a transformation matrix based on Vector and Matrix +

      Returns: nothing. +

      +
      +
      +


      +

      +
      +
      Method.png unity ( )
      +
      +

      Description: Makes this matrix the identity matrix +

      Returns: nothing. +

      +
      +
      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/MeasureAngular1.PNG b/localwiki/MeasureAngular1.PNG new file mode 100644 index 0000000..719717d Binary files /dev/null and b/localwiki/MeasureAngular1.PNG differ diff --git a/localwiki/MeasureLinear3D1.png b/localwiki/MeasureLinear3D1.png new file mode 100644 index 0000000..7bcf223 Binary files /dev/null and b/localwiki/MeasureLinear3D1.png differ diff --git a/localwiki/MeasureLinear3DandDelta1.PNG b/localwiki/MeasureLinear3DandDelta1.PNG new file mode 100644 index 0000000..608a2d6 Binary files /dev/null and b/localwiki/MeasureLinear3DandDelta1.PNG differ diff --git a/localwiki/MeasureLinearDelta1.PNG b/localwiki/MeasureLinearDelta1.PNG new file mode 100644 index 0000000..c98ba89 Binary files /dev/null and b/localwiki/MeasureLinearDelta1.PNG differ diff --git a/localwiki/Media-playback-start.svg b/localwiki/Media-playback-start.svg new file mode 100644 index 0000000..494dab5 --- /dev/null +++ b/localwiki/Media-playback-start.svg @@ -0,0 +1,387 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + Lapo Calamandrei + + + + + + play + media + music + video + player + + + + + Jakub Steiner + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Media-playback-stop.svg b/localwiki/Media-playback-stop.svg new file mode 100644 index 0000000..763ff1f --- /dev/null +++ b/localwiki/Media-playback-stop.svg @@ -0,0 +1,650 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + Lapo Calamandrei + + + + + + media + stop + playback + video + music + + + + + Jakub Steiner + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Media-record.svg b/localwiki/Media-record.svg new file mode 100644 index 0000000..7d508fc --- /dev/null +++ b/localwiki/Media-record.svg @@ -0,0 +1,588 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + + + + + + + diff --git a/localwiki/Member.svg b/localwiki/Member.svg new file mode 100644 index 0000000..66b6945 --- /dev/null +++ b/localwiki/Member.svg @@ -0,0 +1,190 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + diff --git a/localwiki/Menu_Std_DlgMacroRecord_it.png b/localwiki/Menu_Std_DlgMacroRecord_it.png new file mode 100644 index 0000000..1980560 Binary files /dev/null and b/localwiki/Menu_Std_DlgMacroRecord_it.png differ diff --git a/localwiki/Mesh.png b/localwiki/Mesh.png new file mode 100644 index 0000000..5032550 Binary files /dev/null and b/localwiki/Mesh.png differ diff --git a/localwiki/MeshFace.svg b/localwiki/MeshFace.svg new file mode 100644 index 0000000..da2cb1f --- /dev/null +++ b/localwiki/MeshFace.svg @@ -0,0 +1,419 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + New Document + + + Jakub Steiner + + + http://jimmac.musichall.cz + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/MeshWorkbench.svg b/localwiki/MeshWorkbench.svg new file mode 100644 index 0000000..6dd12f8 --- /dev/null +++ b/localwiki/MeshWorkbench.svg @@ -0,0 +1,367 @@ + + + + + MeshWorkbench + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + MeshWorkbench + + + FreeCAD LGPL2+ + + + + + mesh + sphere + workbench + tesselated + + + + Tesselated sphere mesh, lit from top + + + [agryson] Alexander Gryson + + + + + + FreeCAD + + + + + [triplus] + + + Fri Feb 26 23:17:43 2016 +0100 + FreeCAD/src/Mod/Mesh/Gui/Resources/icons/MeshWorkbench.svg + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Mesh_API.html b/localwiki/Mesh_API.html new file mode 100644 index 0000000..734d713 --- /dev/null +++ b/localwiki/Mesh_API.html @@ -0,0 +1,736 @@ +Mesh API

      Mesh API

      + +

      The Mesh objects can be manipulated by adding new facets, deleting facets, importing from an STL file, transforming the mesh and much more. For a complete overview of what can be done see also the Mesh Module documentation. A mesh object cannot be added to an existing document directly. Therefore the document must create an object with a property class that supports meshes. Example: +

      +
      m = Mesh.Mesh()
      +... # Manipulate the mesh
      +d = FreeCAD.activeDocument() # Get a reference to the actie document
      +f = d.addObject("Mesh::Feature", "Mesh") # Create a mesh feature
      +f.Mesh = m # Assign the mesh object to the internal property
      +d.recompute() 
      +


      +

      +
      +
      Method.png addFacet ( Facet )
      +
      +

      Description: Adds a facet to the mesh +

      Returns: +

      +
      +
      +


      +

      +
      +
      Method.png addFacets ( list )
      +
      +

      Description: Adds a list of facets to the mesh +

      Returns: +

      +
      +
      +


      +

      +
      +
      Method.png addMesh ( Mesh )
      +
      +

      Description: Combines this mesh with another mesh. +

      Returns: +

      +
      +
      +


      +

      +
      +
      Method.png clear ( )
      +
      +

      Description: Clears the mesh +

      Returns: +

      +
      +
      +


      +

      +
      +
      Method.png coarsen ( )
      +
      +

      Description: Coarsens the mesh +

      Returns: +

      +
      +
      +


      +

      +
      +
      Method.png collapseEdge ( Edge )
      +
      +

      Description: Removes an edge and both facets that share this edge +

      Returns: +

      +
      +
      +


      +

      +
      +
      Method.png collapseFacet ( Facet )
      +
      +

      Description: Removes a facet +

      Returns: +

      +
      +
      +


      +

      +
      +
      Method.png collapseFacets ( list )
      +
      +

      Description: Removes a list of facets +

      Returns: +

      +
      +
      +


      +

      +
      +
      Method.png copy ( )
      +
      +

      Description: Creates a copy of this mesh +

      Returns: a Mesh object +

      +
      +
      +


      +

      +
      +
      Method.png countComponents ( )
      +
      +

      Description: Get the number of topological independent areas +

      Returns: an integer +

      +
      +
      +


      +

      +
      +
      Method.png countNonUniformOrientedFacets ( )
      +
      +

      Description: Get the number of wrong oriented facets +

      Returns: an integer +

      +
      +
      +


      +

      +
      +
      Method.png countSegments ( )
      +
      +

      Description: Get the number of segments which may also be 0 +

      Returns: an integer +

      +
      +
      +


      +

      +
      +
      Method.png crossSections ( )
      +
      +

      Description: Get cross-sections of the mesh through several planes +

      Returns: +

      +
      +
      +


      +

      +
      +
      Method.png difference ( Mesh )
      +
      +

      Description: Difference of this and the given mesh object. +

      Returns: +

      +
      +
      +


      +

      +
      +
      Method.png fillupHoles ( )
      +
      +

      Description: Fillup holes +

      Returns: +

      +
      +
      +


      +

      +
      +
      Method.png fixDeformations ( )
      +
      +

      Description: Repair deformed facets +

      Returns: +

      +
      +
      +


      +

      +
      +
      Method.png fixDegenerations ( )
      +
      +

      Description: Remove degenerated facets +

      Returns: +

      +
      +
      +


      +

      +
      +
      Method.png fixIndices ( )
      +
      +

      Description: Repair any invalid indices +

      Returns: +

      +
      +
      +


      +

      +
      +
      Method.png fixSelfIntersections ( )
      +
      +

      Description: Repair self-intersections +

      Returns: +

      +
      +
      +


      +

      +
      +
      Method.png flipNormals ( )
      +
      +

      Description: Flip the mesh normals +

      Returns: +

      +
      +
      +


      +

      +
      +
      Method.png foraminate ( )
      +
      +

      Description: Get a list of facet indices and intersection points +

      Returns: +

      +
      +
      +


      +

      +
      +
      Method.png getPlanes ( )
      +
      +

      Description: Get all planes of the mesh as segment. In the worst case each triangle can be regarded as single plane if none of its neighbors is coplanar. +

      Returns: +

      +
      +
      +


      +

      +
      +
      Method.png getSegment ( integer )
      +
      +

      Description: Get a list of facet indices that describes a segment +

      Returns: +

      +
      +
      +


      +

      +
      +
      Method.png getSeparateComponents ( )
      +
      +

      Description: Returns a list containing the different components (separated areas) of the mesh as separate meshes +

      Returns: a list +

      +
      +
      +


      +

      +
      +
      Method.png harmonizeNormals ( )
      +
      +

      Description: Adjust wrong oriented facets +

      Returns: +

      +
      +
      +


      +

      +
      +
      Method.png hasNonManifolds ( )
      +
      +

      Description: Check if the mesh has non-manifolds +

      Returns: a boolean +

      +
      +
      +


      +

      +
      +
      Method.png hasNonUniformOrientedFacets ( )
      +
      +

      Description: Checks if the mesh has facets with inconsistent orientation +

      Returns: +

      +
      +
      +


      +

      +
      +
      Method.png hasSelfIntersections ( )
      +
      +

      Description: Check if the mesh intersects itself +

      Returns: +

      +
      +
      +


      +

      +
      +
      Method.png inner ( )
      +
      +

      Description: Get the part inside of the intersection +

      Returns: +

      +
      +
      +


      +

      +
      +
      Method.png insertVertex ( Vertex )
      +
      +

      Description: Inserts a vertex into a facet +

      Returns: +

      +
      +
      +


      +

      +
      +
      Method.png intersect ( Mesh )
      +
      +

      Description: Intersection of this and the given mesh object. +

      Returns: +

      +
      +
      +


      +

      +
      +
      Method.png isSolid ( )
      +
      +

      Description: Check if the mesh is a solid +

      Returns: +

      +
      +
      +


      +

      +
      +
      Method.png meshFromSegment ( )
      +
      +

      Description: Create a mesh from segment +

      Returns: +

      +
      +
      +


      +

      +
      +
      Method.png nearestFacetOnRay ( tuple, tuple )
      +
      +

      Description: Get the index and intersection point of the nearest facet to a ray. The first parameter is a tuple of three floats the base point of the ray, the second parameter is ut uple of three floats for the direction. The result is a dictionary with an index and the intersection point or an empty dictionary if there is no intersection. +

      Returns: a dictionary +

      +
      +
      +


      +

      +
      +
      Method.png offset ( float )
      +
      +

      Description: Move the point along their normals +

      Returns: +

      +
      +
      +


      +

      +
      +
      Method.png offsetSpecial ( float )
      +
      +

      Description: Move the point along their normals +

      Returns: +

      +
      +
      +


      +

      +
      +
      Method.png optimizeEdges ( )
      +
      +

      Description: Optimize the edges to get nicer facets +

      Returns: +

      +
      +
      +


      +

      +
      +
      Method.png optimizeTopology ( )
      +
      +

      Description: Optimize the edges to get nicer facets +

      Returns: +

      +
      +
      +


      +

      +
      +
      Method.png outer ( )
      +
      +

      Description: Get the part outside the intersection +

      Returns: +

      +
      +
      +


      +

      +
      +
      Method.png printInfo ( )
      +
      +

      Description: Get detailed information about the mesh +

      Returns: +

      +
      +
      +


      +

      +
      +
      Method.png read ( )
      +
      +

      Description: Read in a mesh object from file. +

      Returns: +

      +
      +
      +


      +

      +
      +
      Method.png refine ( )
      +
      +

      Description: Refine the mesh +

      Returns: +

      +
      +
      +


      +

      +
      +
      Method.png removeComponents ( integer )
      +
      +

      Description: Remove components with less or equal to number of given facets +

      Returns: +

      +
      +
      +


      +

      +
      +
      Method.png removeDuplicatedFacets ( )
      +
      +

      Description: Remove duplicated facets +

      Returns: +

      +
      +
      +


      +

      +
      +
      Method.png removeDuplicatedPoints ( )
      +
      +

      Description: Remove duplicated points +

      Returns: +

      +
      +
      +


      +

      +
      +
      Method.png removeFacets ( list )
      +
      +

      Description: Remove a list of facet indices from the mesh +

      Returns: +

      +
      +
      +


      +

      +
      +
      Method.png removeFoldsOnSurface ( )
      +
      +

      Description: Remove folds on surfaces +

      Returns: +

      +
      +
      +


      +

      +
      +
      Method.png removeNonManifolds ( )
      +
      +

      Description: Remove non-manifolds +

      Returns: +

      +
      +
      +


      +

      +
      +
      Method.png rotate ( )
      +
      +

      Description: Apply a rotation to the mesh +

      Returns: +

      +
      +
      +


      +

      +
      +
      Method.png setPoint ( int, Vector )
      +
      +

      Description: Sets the point at index. +

      Returns: +

      +
      +
      +


      +

      +
      +
      Method.png smooth ( )
      +
      +

      Description: Smooth the mesh +

      Returns: +

      +
      +
      +


      +

      +
      +
      Method.png snapVertex ( )
      +
      +

      Description: Insert a new facet at the border +

      Returns: +

      +
      +
      +


      +

      +
      +
      Method.png splitEdge ( )
      +
      +

      Description: Split edge +

      Returns: +

      +
      +
      +


      +

      +
      +
      Method.png splitEdges ( )
      +
      +

      Description: Split all edges +

      Returns: +

      +
      +
      +


      +

      +
      +
      Method.png splitFacet ( )
      +
      +

      Description: Split facet +

      Returns: +

      +
      +
      +


      +

      +
      +
      Method.png swapEdge ( )
      +
      +

      Description: Swap the common edge with the neighbor +

      Returns: +

      +
      +
      +


      +

      +
      +
      Method.png transform ( )
      +
      +

      Description: Apply a transformation to the mesh +

      Returns: +

      +
      +
      +


      +

      +
      +
      Method.png transformToEigen ( )
      +
      +

      Description: Transform the mesh to its eigenbase +

      Returns: +

      +
      +
      +


      +

      +
      +
      Method.png translate ( Vector )
      +
      +

      Description: Apply a translation to the mesh +

      Returns: +

      +
      +
      +


      +

      +
      +
      Method.png unite ( Mesh )
      +
      +

      Description: Union of this and the given mesh object. +

      Returns: +

      +
      +
      +


      +

      +
      +
      Method.png write ( string )
      +
      +

      Description: Write the mesh object into file. +

      Returns: +

      +
      +
      +


      +

      +
      +
      Method.png writeInventor ( )
      +
      +

      Description: Write the mesh in OpenInventor format to a string. +

      Returns: a string +

      +
      +
      +


      +

      +
      +
      Property.png Area
      +
      +

      Returns: the area of the mesh object. +

      +
      +
      +


      +

      +
      +
      Property.png CountFacets
      +
      +

      Returns: the number of facets of the mesh object. +

      +
      +
      +


      +

      +
      +
      Property.png CountPoints
      +
      +

      Returns: the number of vertices of the mesh object. +

      +
      +
      +


      +

      +
      +
      Property.png Facets
      +
      +

      Returns: A collection of facets; With this attribute it is possible to get access to the facets of the mesh: for f in mesh.Facets: print f. Facet.Points is a list of coordinate-tupels for the vertices. Facet.PointIndices is a list of indice for the vertices of the facet. WARNING! store Facets in a local variable as it is generated on the fly, each time it is accessed. +

      +
      +
      +


      +

      +
      +
      Property.png Points
      +
      +

      Returns: A collection of the mesh points; With this attribute it is possible to get access to the points of the mesh: for p in mesh.Points: print p.x, p.y, p.z,p.Index.WARNING! store Points in a local variable as it is generated on the fly, each time it is accessed. +

      +
      +
      +


      +

      +
      +
      Property.png Topology
      +
      +

      Returns: the points and face indices as tuple. Topology[0] is a list of all vertices. Each being a tuple of 3 coordinates. Topology[1] is a list of all polygons. Each being a list of vertex indice into Topology[0] WARNING! store Topology in a local variable as it is generated on the fly, each time it is accessed. +

      +
      +
      +


      +

      +
      +
      Property.png Volume
      +
      +

      Returns: the volume of the mesh object. +

      +
      +
      +


      +

      +
      +
      Property.png BoundBox
      +
      +

      Returns: the BoundBox of the object +

      +
      +
      +


      +

      +
      +
      Property.png Matrix
      +
      +

      Returns: the current transformation of the object as matrix +

      +
      +
      +


      +

      +
      +
      Property.png Placement
      +
      +

      Returns: the current transformation of the object as placement +

      +
      +
      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Mesh_AddTriangle.html b/localwiki/Mesh_AddTriangle.html new file mode 100644 index 0000000..38fa13a --- /dev/null +++ b/localwiki/Mesh_AddTriangle.html @@ -0,0 +1,73 @@ +Mesh AddTriangle

      Mesh AddTriangle

      + +

      +

      This documentation is not finished. Please help and contribute documentation. +

      See Draft ShapeString for good documented Command. Gui Command gives an overview over commands. And see List of Commands for other commands. +

      Go to Help FreeCAD to contribute. +

      +
      +


      +

      + + + + + + + + + + + + + + + + + + + + +
      +

      Mesh AddTriangle.png Mesh AddTriangle‏‎

      +
      Menu location +
      Mesh → Add Triangle +
      Workbenches +
      Mesh +
      Default shortcut +
      +
      See also +
      +

      + +
      +


      +

      +

      Introduction

      +

      Use

      +

      Limitations

      +

      Links

      +
      +


      +

      + + +
      + +
      +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Mesh_AddTriangle.png b/localwiki/Mesh_AddTriangle.png new file mode 100644 index 0000000..782eb4d Binary files /dev/null and b/localwiki/Mesh_AddTriangle.png differ diff --git a/localwiki/Mesh_BoundingBox.html b/localwiki/Mesh_BoundingBox.html new file mode 100644 index 0000000..3c6f959 --- /dev/null +++ b/localwiki/Mesh_BoundingBox.html @@ -0,0 +1,83 @@ +Mesh BoundingBox

      Mesh BoundingBox

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Mesh BoundingBox.png Mesh BoundingBox‏‎

      +
      Menu location +
      Meshes → Analyze → Boundings info... +
      Workbenches +
      Mesh +
      Default shortcut +
      +
      See also +
      +

      + +
      +


      +

      +

      Introduction

      +

      Gives you the Min/Max-coordinates of a bounding box for a single mesh. +

      +

      Use

      +
      1. Select mesh in tree-view
      2. +
      3. Choose Meshes Analyze Boundings Info... from the top menu.
      4. +
      5. A pop-up will display the Min/Max-coordinates of the bounding box
      +

      Mesh BoundingsInfo.jpg +


      +

      +

      Limitations

      +

      This command will only evaluate the bounding box of single meshes. +
      +You can merge meshes for evaluating bounding box of these. +
      +For other cases you may want to install 3rd-party software: Lattice2-Workbench +


      +

      +

      Notes

      +


      +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Mesh_BoundingBox.png b/localwiki/Mesh_BoundingBox.png new file mode 100644 index 0000000..782eb4d Binary files /dev/null and b/localwiki/Mesh_BoundingBox.png differ diff --git a/localwiki/Mesh_BoundingsInfo.jpg b/localwiki/Mesh_BoundingsInfo.jpg new file mode 100644 index 0000000..d74a102 Binary files /dev/null and b/localwiki/Mesh_BoundingsInfo.jpg differ diff --git a/localwiki/Mesh_BuildRegularSolid.html b/localwiki/Mesh_BuildRegularSolid.html new file mode 100644 index 0000000..981eb57 --- /dev/null +++ b/localwiki/Mesh_BuildRegularSolid.html @@ -0,0 +1,84 @@ +Mesh BuildRegularSolid

      Mesh BuildRegularSolid

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Mesh RegularSolid.png Mesh RegularSolid

      +
      Menu location +
      Meshes → Regular solid... +
      Workbenches +
      Mesh +
      Default shortcut +
      +
      See also +
      +

      + +
      +


      +


      +

      +

      Introduction

      +

      Create mesh primitives, like cubes, cylinders, cones, spheres, ellipsoid, torus. +


      +

      +

      Use

      +

      Choose MeshesMesh RegularSolid.png Regular solid... from the top menu. +
      +
      +Meshes RegularSolid Cube.jpg Meshes RegularSolid Cylinder.jpg Meshes RegularSolid Cone.jpg +
      +
      +Meshes RegularSolid Sphere.jpg Meshes RegularSolid Ellipsoid.jpg Meshes RegularSolid Torus.jpg +


      +

      +

      Limitations

      +


      +


      +

      +

      Notes

      +

      To change the parameters of these meshed regular solids highlight them in the tree-view and switch to the data-tab. +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Mesh_Cone.svg b/localwiki/Mesh_Cone.svg new file mode 100644 index 0000000..206b2b9 --- /dev/null +++ b/localwiki/Mesh_Cone.svg @@ -0,0 +1,265 @@ + + + + + Mesh_Cone + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + Mesh_Cone + + + + [agryson] Alexander Gryson + + + Tesselated conic mesh, lit from top + + + mesh + cone + tesselated + + + http://www.freecadweb.org/wiki/index.php?title=Artwork + FreeCAD/src/Mod/Mesh/Gui/Resources/icons/RegularSolids/Mesh_Cone.svg + + + FreeCAD + + + + + FreeCAD LGPL2+ + + + Sat Dec 21 21:54:56 2013 +1100 + + + [jmaustpc] + + + + + + + + + + + + + + + diff --git a/localwiki/Mesh_CreateMeshSegment.html b/localwiki/Mesh_CreateMeshSegment.html new file mode 100644 index 0000000..6b91324 --- /dev/null +++ b/localwiki/Mesh_CreateMeshSegment.html @@ -0,0 +1,73 @@ +Mesh CreateMeshSegment

      Mesh CreateMeshSegment

      + +

      +

      This documentation is not finished. Please help and contribute documentation. +

      See Draft ShapeString for good documented Command. Gui Command gives an overview over commands. And see List of Commands for other commands. +

      Go to Help FreeCAD to contribute. +

      +
      +


      +

      + + + + + + + + + + + + + + + + + + + + +
      +

      Mesh CreateMeshSegment.png Mesh CreateMeshSegment‏‎

      +
      Menu location +
      Meshes → Create mesh segments... +
      Workbenches +
      Mesh +
      Default shortcut +
      +
      See also +
      +

      + +
      +


      +

      +

      Introduction

      +

      Use

      +

      Limitations

      +

      Links

      +
      +


      +

      + + +
      + +
      +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Mesh_CreateMeshSegment.png b/localwiki/Mesh_CreateMeshSegment.png new file mode 100644 index 0000000..782eb4d Binary files /dev/null and b/localwiki/Mesh_CreateMeshSegment.png differ diff --git a/localwiki/Mesh_Cube.svg b/localwiki/Mesh_Cube.svg new file mode 100644 index 0000000..8d00d6d --- /dev/null +++ b/localwiki/Mesh_Cube.svg @@ -0,0 +1,373 @@ + + + + + Mesh_Cube + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + Mesh_Cube + + Sat Dec 21 21:54:56 2013 +1100 + + + [jmaustpc] + + + + + FreeCAD LGPL2+ + + + + + FreeCAD + + + FreeCAD/src/Mod/Mesh/Gui/Resources/icons/RegularSolids/Mesh_Cube.svg + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + mesh + cube + tesselated + + + Tesselated cube mesh, lit from top + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Mesh_CurvatureInfo.html b/localwiki/Mesh_CurvatureInfo.html new file mode 100644 index 0000000..8d68fa9 --- /dev/null +++ b/localwiki/Mesh_CurvatureInfo.html @@ -0,0 +1,64 @@ +Mesh CurvatureInfo

      Mesh CurvatureInfo

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Official icon not found Mesh_CurvatureInfo

      +
      Menu location +
      {{{MenuLocation}}} +
      Workbenches +
      All +
      Default shortcut +
      None +
      See also +
      ... +

      Contents

      + +
      + +
      +


      +Synopsis +ToDo. +


      +

      +
      +

      This documentation is not finished. Please help and contribute documentation. +

      See Draft ShapeString for good documented Command. Gui Command gives an overview over commands. And see List of Commands for other commands. +

      Go to Help FreeCAD to contribute. +

      +
      + + + +
      + +
      +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Mesh_CurvaturePlot.html b/localwiki/Mesh_CurvaturePlot.html new file mode 100644 index 0000000..16c33f3 --- /dev/null +++ b/localwiki/Mesh_CurvaturePlot.html @@ -0,0 +1,75 @@ +Mesh CurvaturePlot

      Mesh CurvaturePlot

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Mesh CurvaturePlot.png Mesh CurvaturePlot‏‎

      +
      Menu location +
      Meshes → Curvature plot +
      Workbenches +
      Mesh +
      Default shortcut +
      +
      See also +
      +

      + +
      +


      +

      +

      Description

      +

      Creates a colored 3d-plot with information about the deviation of the faces in relation to their neighbouring faces. +

      +

      Use

      +
      1. Select the mesh you would like to make a curvature plot from in the tree view.
      2. +
      3. Click on Mesh CurvaturePlot.png or choose MeshesMesh CurvaturePlot.png Curvature plot from the top menu.
      4. +
      5. The plot will be created as a seperate new object in the tree view.
      6. +
      7. Hide all other objects but the curvature plot to make the plot visible.
      +

      Limitations

      +


      +

      +

      Notes

      +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Mesh_Curvature_Plot.svg b/localwiki/Mesh_Curvature_Plot.svg new file mode 100644 index 0000000..b6fe5a5 --- /dev/null +++ b/localwiki/Mesh_Curvature_Plot.svg @@ -0,0 +1,227 @@ + + + + + Mesh_Curvature_Plot + + + + + + + + + + + + + + + + + + + image/svg+xml + + Mesh_Curvature_Plot + + + + [agryson] Alexander Gryson + + + Mesh with color coded faces and a multicolored bar shaped legend + + + mesh + color + plot + + + http://www.freecadweb.org/wiki/index.php?title=Artwork + FreeCAD/src/Mod/Mesh/Gui/Resources/icons/Mesh_Curvature_Plot.svg + + + FreeCAD + + + + + FreeCAD LGPL2+ + + + + + [wmayer] + + + Fri Dec 20 16:28:14 2013 +0100 + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Mesh_Cut.html b/localwiki/Mesh_Cut.html new file mode 100644 index 0000000..156b01e --- /dev/null +++ b/localwiki/Mesh_Cut.html @@ -0,0 +1,73 @@ +Mesh Cut

      Mesh Cut

      + +

      +

      This documentation is not finished. Please help and contribute documentation. +

      See Draft ShapeString for good documented Command. Gui Command gives an overview over commands. And see List of Commands for other commands. +

      Go to Help FreeCAD to contribute. +

      +
      +


      +

      + + + + + + + + + + + + + + + + + + + + +
      +

      Mesh Cut.png Mesh Cut‏‎

      +
      Menu location +
      Meshes → Cut mesh +
      Workbenches +
      Mesh +
      Default shortcut +
      +
      See also +
      +

      + +
      +


      +

      +

      Introduction

      +

      Use

      +

      Limitations

      +

      Links

      +
      +


      +

      + + +
      + +
      +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Mesh_Cylinder.svg b/localwiki/Mesh_Cylinder.svg new file mode 100644 index 0000000..f97ab24 --- /dev/null +++ b/localwiki/Mesh_Cylinder.svg @@ -0,0 +1,370 @@ + + + + + Mesh_Cylinder + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + Mesh_Cylinder + + FreeCAD/src/Mod/Mesh/Gui/Resources/icons/RegularSolids/Mesh_Cylinder.svg + + + FreeCAD + + + + + FreeCAD LGPL2+ + + + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + [agryson] Alexander Gryson + + + Tesselated cylindrical mesh, lit from top + + + mesh + cylinder + tesselated + + + Sat Dec 21 21:54:56 2013 +1100 + + + [jmaustpc] + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Mesh_Demolding.html b/localwiki/Mesh_Demolding.html new file mode 100644 index 0000000..df85dea --- /dev/null +++ b/localwiki/Mesh_Demolding.html @@ -0,0 +1,64 @@ +Mesh Demolding

      Mesh Demolding

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Official icon not found Mesh_Demolding

      +
      Menu location +
      {{{MenuLocation}}} +
      Workbenches +
      All +
      Default shortcut +
      None +
      See also +
      ... +

      Contents

      + +
      + +
      +


      +Synopsis +ToDo. +


      +

      +
      +

      This documentation is not finished. Please help and contribute documentation. +

      See Draft ShapeString for good documented Command. Gui Command gives an overview over commands. And see List of Commands for other commands. +

      Go to Help FreeCAD to contribute. +

      +
      + + + +
      + +
      +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Mesh_Difference.html b/localwiki/Mesh_Difference.html new file mode 100644 index 0000000..f13822e --- /dev/null +++ b/localwiki/Mesh_Difference.html @@ -0,0 +1,74 @@ +Mesh Difference

      Mesh Difference

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Mesh Difference.png Mesh Difference

      +
      Menu location +
      Meshes → Boolean → Difference +
      Workbenches +
      Mesh +
      Default shortcut +
      +
      See also +
      +

      + +
      +


      +

      +

      Introduction

      +

      Does a difference (cut) on two selected meshes. +

      The result is created as a new seperate mesh. +

      +

      Use

      +
      1. Select meshes to be cut in the tree-view or in the 3D-view.
      2. +
      3. Choose MeshesBooleanDifference
      +


      +

      Example: Cube cut with sphere +

      Meshes Boolean Difference.jpg +

      +

      Limitations

      +

      Links

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Mesh_Difference.png b/localwiki/Mesh_Difference.png new file mode 100644 index 0000000..782eb4d Binary files /dev/null and b/localwiki/Mesh_Difference.png differ diff --git a/localwiki/Mesh_Ellipsoid.svg b/localwiki/Mesh_Ellipsoid.svg new file mode 100644 index 0000000..6232768 --- /dev/null +++ b/localwiki/Mesh_Ellipsoid.svg @@ -0,0 +1,401 @@ + + + + + Mesh_Ellipsoid + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + Mesh_Ellipsoid + + Sat Dec 21 21:54:56 2013 +1100 + + + [jmaustpc] + + + + + FreeCAD LGPL2+ + + + + + FreeCAD + + + FreeCAD/src/Mod/Mesh/Gui/Resources/icons/RegularSolids/Mesh_Ellipsoid.svg + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + mesh + ellipsoid + tessealted + + + Tesselated ellipsoid mesh, lit from top + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Mesh_EvaluateCurvature.html b/localwiki/Mesh_EvaluateCurvature.html new file mode 100644 index 0000000..dd4649f --- /dev/null +++ b/localwiki/Mesh_EvaluateCurvature.html @@ -0,0 +1,73 @@ +Mesh EvaluateCurvature

      Mesh EvaluateCurvature

      + +

      +

      This documentation is not finished. Please help and contribute documentation. +

      See Draft ShapeString for good documented Command. Gui Command gives an overview over commands. And see List of Commands for other commands. +

      Go to Help FreeCAD to contribute. +

      +
      +


      +

      + + + + + + + + + + + + + + + + + + + + +
      +

      Mesh EvaluateCurvature.png Mesh EvaluateCurvature‏‎

      +
      Menu location +
      Meshes → Analyze → Curvature info +
      Workbenches +
      Mesh +
      Default shortcut +
      +
      See also +
      +

      + +
      +


      +

      +

      Introduction

      +

      Use

      +

      Limitations

      +

      Links

      +
      +


      +

      + + +
      + +
      +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Mesh_EvaluateCurvature.png b/localwiki/Mesh_EvaluateCurvature.png new file mode 100644 index 0000000..782eb4d Binary files /dev/null and b/localwiki/Mesh_EvaluateCurvature.png differ diff --git a/localwiki/Mesh_EvaluateFacet.html b/localwiki/Mesh_EvaluateFacet.html new file mode 100644 index 0000000..b065a6f --- /dev/null +++ b/localwiki/Mesh_EvaluateFacet.html @@ -0,0 +1,78 @@ +Mesh EvaluateFacet

      Mesh EvaluateFacet

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Mesh EvaluateFacet.png Mesh_EvaluateFacet

      +
      Menu location +
      Meshes → Analyze → Face info +
      Workbenches +
      Mesh +
      Default shortcut +
      +
      See also +
      +

      + +
      +


      +


      +

      +

      Introduction

      +

      Gives info on faces. +

      +

      Use

      +
      1. Choose Meshes Analyze Face info from the top menu.
      2. +
      3. Cursor will change to a pipette.
      4. +
      5. Click on a face to display its indes on-screen.
      6. +
      7. Right-click in the 3D-view and choose "Leave info mode" to end command.
      +

      Limitations

      +


      +


      +

      +

      Notes

      +


      +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Mesh_EvaluateRepair.html b/localwiki/Mesh_EvaluateRepair.html new file mode 100644 index 0000000..67033fe --- /dev/null +++ b/localwiki/Mesh_EvaluateRepair.html @@ -0,0 +1,82 @@ +Mesh EvaluateRepair

      Mesh EvaluateRepair

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Mesh EvaluateRepair.png Mesh EvaluateRepair‏‎

      +
      Menu location +
      Meshes → Analyze → Evaluate & Repair mesh... +
      Workbenches +
      Mesh +
      Default shortcut +
      +
      See also +
      +

      + +
      +


      +

      +

      Introduction

      +

      Evaluates and repairs meshes. +

      +

      Use

      +
      1. Select mesh in treeview or choose Meshes Analyze Evaluate & Repair mesh... from the top menu.
      2. +
      3. The corresponding menu will pop up.
      4. +
      5. With the selection view you can change the mesh to be analyzed and repaired.
      6. +
      7. Choose subject to be analyzed by checking appropriate box and clicking on "Analyze".
      8. +
      9. If no problems were found the text beside the box will change to reflect that.
      10. +
      11. If problems were found you will be able to click on "Repair" and try a repair of the mesh.
      12. +
      13. As last option on the bottom you will find option to do all test in one sweep.
      +

      Mesh EvaluateRepairMesh.jpg +

      +

      Limitations

      +


      +


      +

      +

      Notes

      +


      +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Mesh_EvaluateRepair.png b/localwiki/Mesh_EvaluateRepair.png new file mode 100644 index 0000000..782eb4d Binary files /dev/null and b/localwiki/Mesh_EvaluateRepair.png differ diff --git a/localwiki/Mesh_EvaluateRepairMesh.jpg b/localwiki/Mesh_EvaluateRepairMesh.jpg new file mode 100644 index 0000000..03a45d0 Binary files /dev/null and b/localwiki/Mesh_EvaluateRepairMesh.jpg differ diff --git a/localwiki/Mesh_EvaluateSolid.html b/localwiki/Mesh_EvaluateSolid.html new file mode 100644 index 0000000..3278940 --- /dev/null +++ b/localwiki/Mesh_EvaluateSolid.html @@ -0,0 +1,73 @@ +Mesh EvaluateSolid

      Mesh EvaluateSolid

      + +

      +

      This documentation is not finished. Please help and contribute documentation. +

      See Draft ShapeString for good documented Command. Gui Command gives an overview over commands. And see List of Commands for other commands. +

      Go to Help FreeCAD to contribute. +

      +
      +


      +

      + + + + + + + + + + + + + + + + + + + + +
      +

      Mesh EvaluateSolid.png Mesh EvaluateSolid‏‎

      +
      Menu location +
      Meshes → Analyze → Check Solid mesh +
      Workbenches +
      Mesh +
      Default shortcut +
      +
      See also +
      +

      + +
      +


      +

      +

      Introduction

      +

      Use

      +

      Limitations

      +

      Links

      +
      +


      +

      + + +
      + +
      +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Mesh_EvaluateSolid.png b/localwiki/Mesh_EvaluateSolid.png new file mode 100644 index 0000000..782eb4d Binary files /dev/null and b/localwiki/Mesh_EvaluateSolid.png differ diff --git a/localwiki/Mesh_Evaluation.html b/localwiki/Mesh_Evaluation.html new file mode 100644 index 0000000..6a2976c --- /dev/null +++ b/localwiki/Mesh_Evaluation.html @@ -0,0 +1,64 @@ +Mesh Evaluation

      Mesh Evaluation

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Official icon not found Mesh_Evaluation

      +
      Menu location +
      {{{MenuLocation}}} +
      Workbenches +
      All +
      Default shortcut +
      None +
      See also +
      ... +

      Contents

      + +
      + +
      +


      +Synopsis +ToDo. +


      +

      +
      +

      This documentation is not finished. Please help and contribute documentation. +

      See Draft ShapeString for good documented Command. Gui Command gives an overview over commands. And see List of Commands for other commands. +

      Go to Help FreeCAD to contribute. +

      +
      + + + +
      + +
      +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Mesh_ExMakeMesh.html b/localwiki/Mesh_ExMakeMesh.html new file mode 100644 index 0000000..62a8c5e --- /dev/null +++ b/localwiki/Mesh_ExMakeMesh.html @@ -0,0 +1,64 @@ +Mesh ExMakeMesh

      Mesh ExMakeMesh

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Official icon not found Mesh_ExMakeMesh

      +
      Menu location +
      {{{MenuLocation}}} +
      Workbenches +
      All +
      Default shortcut +
      None +
      See also +
      ... +

      Contents

      + +
      + +
      +


      +Synopsis +ToDo. +


      +

      +
      +

      This documentation is not finished. Please help and contribute documentation. +

      See Draft ShapeString for good documented Command. Gui Command gives an overview over commands. And see List of Commands for other commands. +

      Go to Help FreeCAD to contribute. +

      +
      + + + +
      + +
      +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Mesh_ExMakeTool.html b/localwiki/Mesh_ExMakeTool.html new file mode 100644 index 0000000..dfbb551 --- /dev/null +++ b/localwiki/Mesh_ExMakeTool.html @@ -0,0 +1,64 @@ +Mesh ExMakeTool

      Mesh ExMakeTool

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Official icon not found Mesh_ExMakeTool

      +
      Menu location +
      {{{MenuLocation}}} +
      Workbenches +
      All +
      Default shortcut +
      None +
      See also +
      ... +

      Contents

      + +
      + +
      +


      +Synopsis +ToDo. +


      +

      +
      +

      This documentation is not finished. Please help and contribute documentation. +

      See Draft ShapeString for good documented Command. Gui Command gives an overview over commands. And see List of Commands for other commands. +

      Go to Help FreeCAD to contribute. +

      +
      + + + +
      + +
      +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Mesh_ExMakeUnion.html b/localwiki/Mesh_ExMakeUnion.html new file mode 100644 index 0000000..4341ac3 --- /dev/null +++ b/localwiki/Mesh_ExMakeUnion.html @@ -0,0 +1,64 @@ +Mesh ExMakeUnion

      Mesh ExMakeUnion

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Official icon not found Mesh_ExMakeUnion

      +
      Menu location +
      {{{MenuLocation}}} +
      Workbenches +
      All +
      Default shortcut +
      None +
      See also +
      ... +

      Contents

      + +
      + +
      +


      +Synopsis +ToDo. +


      +

      +
      +

      This documentation is not finished. Please help and contribute documentation. +

      See Draft ShapeString for good documented Command. Gui Command gives an overview over commands. And see List of Commands for other commands. +

      Go to Help FreeCAD to contribute. +

      +
      + + + +
      + +
      +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Mesh_Export.html b/localwiki/Mesh_Export.html new file mode 100644 index 0000000..df8b067 --- /dev/null +++ b/localwiki/Mesh_Export.html @@ -0,0 +1,70 @@ +Mesh Export

      Mesh Export

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Mesh ExportMesh.png Mesh ExportMesh‏‎

      +
      Menu location +
      Meshes → Export Mesh +
      Workbenches +
      Mesh +
      Default shortcut +
      None +
      See also +
      Std Export +

      + +
      +


      +

      +

      Introduction

      +

      This tool allows you to export a mesh object as file *.STL, *.AST, *.BMS, *.OBJ, *.OFF, *.iv, *.PLY from the current document. +

      +

      Use

      +
      1. Select mesh object to be exported
      2. +
      3. Click on Mesh ExportMesh.png or choose MeshMesh ExportMesh.png Export Mesh... from the top menu.
      +

      Links

      +


      +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Mesh_Export_Mesh.svg b/localwiki/Mesh_Export_Mesh.svg new file mode 100644 index 0000000..f90c3a8 --- /dev/null +++ b/localwiki/Mesh_Export_Mesh.svg @@ -0,0 +1,414 @@ + + + + + Mesh_Export_Mesh + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + Mesh_Export_Mesh + + Tesselated cube mesh with arrow pointing away from document + + + [agryson] Alexander Gryson + + + + + mesh + cube + tesselated + arrow + document + + + http://www.freecadweb.org/wiki/index.php?title=Artwork + FreeCAD/src/Mod/Mesh/Gui/Resources/icons/Mesh_Export_Mesh.svg + + + FreeCAD + + + + + FreeCAD LGPL2+ + + + Fri Dec 20 16:28:14 2013 +0100 + + + [wmayer] + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Mesh_FillHoles.html b/localwiki/Mesh_FillHoles.html new file mode 100644 index 0000000..9801290 --- /dev/null +++ b/localwiki/Mesh_FillHoles.html @@ -0,0 +1,74 @@ +Mesh FillHoles

      Mesh FillHoles

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Mesh FillHoles.png Mesh FillHoles‏‎

      +
      Menu location +
      Meshes → Fill Holes... +
      Workbenches +
      Mesh +
      Default shortcut +
      +
      See also +
      +

      + +
      +


      +

      +

      Introduction

      +

      Fill up holes of selected mesh(es). +

      +

      Use

      +
      1. Select mesh(es) in tree-view
      2. +
      3. Choose Meshes Fill holes... from the top menu.
      4. +
      5. A menu will pop up asking you about the maximum number of edges for the holes to be filled up.
      +

      Limitations

      +


      +

      +

      Notes

      +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Mesh_FillHoles.png b/localwiki/Mesh_FillHoles.png new file mode 100644 index 0000000..782eb4d Binary files /dev/null and b/localwiki/Mesh_FillHoles.png differ diff --git a/localwiki/Mesh_FillInteractiveHole.html b/localwiki/Mesh_FillInteractiveHole.html new file mode 100644 index 0000000..d3f87d8 --- /dev/null +++ b/localwiki/Mesh_FillInteractiveHole.html @@ -0,0 +1,75 @@ +Mesh FillInteractiveHole

      Mesh FillInteractiveHole

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Mesh FillInteractiveHole.png Mesh FillInteractiveHole‏‎

      +
      Menu location +
      Meshes → Close hole +
      Workbenches +
      Mesh +
      Default shortcut +
      +
      See also +
      +

      + +
      +


      +

      +

      Introduction

      +

      Close holes in meshes by manual selection. +

      +

      Use

      +
      1. Choose MeshesMesh FillInteractiveHole.png Close hole from the top menu.
      2. +
      3. The cursor will change to a small white cross with a triangle-face-with-hole sign on the right lower corner.
      4. +
      5. Click on a bordering vertice of a hole in a mesh to automatically close this hole.
      6. +
      7. End the command by right-ckling in the 3D-view and choosing "Leave hole-filling mode".
      +

      Limitations

      +


      +

      +

      Notes

      +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Mesh_FlipNormals.html b/localwiki/Mesh_FlipNormals.html new file mode 100644 index 0000000..65da566 --- /dev/null +++ b/localwiki/Mesh_FlipNormals.html @@ -0,0 +1,77 @@ +Mesh FlipNormals

      Mesh FlipNormals

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Mesh FlipNormals.png Mesh FlipNormals‏‎

      +
      Menu location +
      Meshes → Flip Normals +
      Workbenches +
      Mesh +
      Default shortcut +
      +
      See also +
      +

      + +
      +


      +

      +

      Introduction

      +

      Flips (inverts the direction) of the normals of the selected mesh(es). +

      +

      Use

      +
      1. Select mesh(es) in tree-view
      2. +
      3. Choose MeshesMesh FlipNormals.png Flip normals from the top menu.
      +

      Limitations

      +


      +

      +

      Notes

      +

      Verify this action by +

      +
      • selecting the mesh in the tree-view
      • +
      • switching to the view-tab
      • +
      • setting Lighting to "one side"
      • +
      • faces with normals pointing away from the screen will turn black
      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Mesh_Flip_Normals.svg b/localwiki/Mesh_Flip_Normals.svg new file mode 100644 index 0000000..4047f40 --- /dev/null +++ b/localwiki/Mesh_Flip_Normals.svg @@ -0,0 +1,403 @@ + + + + + Mesh_Flip_Normals + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + Mesh_Flip_Normals + + Single mesh face with arrow pointing upwards and a double pointed curved arrow pointing from one side of the face to the other + + + [agryson] Alexander Gryson + + + + + mesh + face + arrow + + + http://www.freecadweb.org/wiki/index.php?title=Artwork + FreeCAD/src/Mod/Mesh/Gui/Resources/icons/Mesh_Flip_Normals.svg + + + FreeCAD + + + + + FreeCAD LGPL2+ + + + + + [wmayer] + + + Fri Dec 20 16:28:14 2013 +0100 + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Mesh_FromGeometry.html b/localwiki/Mesh_FromGeometry.html new file mode 100644 index 0000000..81304fe --- /dev/null +++ b/localwiki/Mesh_FromGeometry.html @@ -0,0 +1,64 @@ +Mesh FromGeometry

      Mesh FromGeometry

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Official icon not found Mesh_FromGeometry

      +
      Menu location +
      {{{MenuLocation}}} +
      Workbenches +
      All +
      Default shortcut +
      None +
      See also +
      ... +

      Contents

      + +
      + +
      +


      +Synopsis +ToDo. +


      +

      +
      +

      This documentation is not finished. Please help and contribute documentation. +

      See Draft ShapeString for good documented Command. Gui Command gives an overview over commands. And see List of Commands for other commands. +

      Go to Help FreeCAD to contribute. +

      +
      + + + +
      + +
      +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Mesh_HarmonizeNormals.html b/localwiki/Mesh_HarmonizeNormals.html new file mode 100644 index 0000000..2c161d1 --- /dev/null +++ b/localwiki/Mesh_HarmonizeNormals.html @@ -0,0 +1,74 @@ +Mesh HarmonizeNormals

      Mesh HarmonizeNormals

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Mesh HarmonizeNormals.png Mesh HarmonizeNormals‏‎

      +
      Menu location +
      Meshes → Harmonize normals +
      Workbenches +
      Mesh +
      Default shortcut +
      +
      See also +
      +

      + +
      +


      +

      +

      Introduction

      +

      Harmonize the normals of the selected mesh(es). +

      +

      Use

      +
      1. Select mesh(es) in tree-view
      2. +
      3. Choose MeshesMesh HarmonizeNormals.png Harmonize normals from the top menu.
      +

      Limitations

      +


      +

      +

      Notes

      +


      +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Mesh_Harmonize_Normals.svg b/localwiki/Mesh_Harmonize_Normals.svg new file mode 100644 index 0000000..f705a3a --- /dev/null +++ b/localwiki/Mesh_Harmonize_Normals.svg @@ -0,0 +1,489 @@ + + + + + Mesh_Harmonize_Normals + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + Mesh_Harmonize_Normals + + Fri Dec 20 16:28:14 2013 +0100 + + + [wmayer] + + + + + FreeCAD LGPL2+ + + + + + FreeCAD + + + FreeCAD/src/Mod/Mesh/Gui/Resources/icons/Mesh_Harmonize_Normals.svg + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + [agryson] Alexander Gryson + + + + + mesh + plane + tesselated + normal + arrow + + + Planar tesselatad mesh with each face having an arrow pointing upwards + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Mesh_Import.html b/localwiki/Mesh_Import.html new file mode 100644 index 0000000..861dfe0 --- /dev/null +++ b/localwiki/Mesh_Import.html @@ -0,0 +1,70 @@ +Mesh Import

      Mesh Import

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Mesh ImportMesh.png Mesh ImportMesh‏‎

      +
      Menu location +
      Meshes → Import Mesh +
      Workbenches +
      Mesh +
      Default shortcut +
      None +
      See also +
      Std Import +

      + +
      +


      +

      +

      Introduction

      +

      This tool allows you to add a file *.STL, *.AST, *.BMS, *.OBJ, *.OFF, *.iv, *.PLY to the current document. +

      +

      Use

      +
      1. Click on Mesh ImportMesh.png or choose MeshMesh ImportMesh.png Import Mesh... from the top menu.
      2. +
      3. Select the file to be imported
      +

      Links

      +


      +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Mesh_Import_Mesh.svg b/localwiki/Mesh_Import_Mesh.svg new file mode 100644 index 0000000..cb88553 --- /dev/null +++ b/localwiki/Mesh_Import_Mesh.svg @@ -0,0 +1,384 @@ + + + + + Mesh_Import_Mesh + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + Mesh_Import_Mesh + + Fri Dec 20 16:28:14 2013 +0100 + + + [wmayer] + + + + + FreeCAD LGPL2+ + + + + + FreeCAD + + + FreeCAD/src/Mod/Mesh/Gui/Resources/icons/Mesh_Import_Mesh.svg + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + cube + mesh + tesselated + arrow + file + document + + + Tesselated cube mesh with arrow pointing towards document + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Mesh_Intersection.html b/localwiki/Mesh_Intersection.html new file mode 100644 index 0000000..273d1e1 --- /dev/null +++ b/localwiki/Mesh_Intersection.html @@ -0,0 +1,74 @@ +Mesh Intersection

      Mesh Intersection

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Mesh Intersection.png Mesh Intersection‏‎

      +
      Menu location +
      Meshes → Boolean → Intersection +
      Workbenches +
      Mesh +
      Default shortcut +
      +
      See also +
      +

      + +
      +


      +

      +

      Introduction

      +

      Does an intersection (common) on two selected meshes. +

      The result is created as a new seperate mesh. +

      +

      Use

      +
      1. Select meshes to be intersected in the tree-view or in the 3D-view.
      2. +
      3. Choose MeshesBooleanIntersection
      +


      +

      Example: Cube intersected with sphere +

      Meshes Boolean Intersection.jpg +

      +

      Limitations

      +

      Links

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Mesh_Intersection.png b/localwiki/Mesh_Intersection.png new file mode 100644 index 0000000..782eb4d Binary files /dev/null and b/localwiki/Mesh_Intersection.png differ diff --git a/localwiki/Mesh_MakeSegment.html b/localwiki/Mesh_MakeSegment.html new file mode 100644 index 0000000..6f18cc3 --- /dev/null +++ b/localwiki/Mesh_MakeSegment.html @@ -0,0 +1,73 @@ +Mesh MakeSegment

      Mesh MakeSegment

      + +

      +

      This documentation is not finished. Please help and contribute documentation. +

      See Draft ShapeString for good documented Command. Gui Command gives an overview over commands. And see List of Commands for other commands. +

      Go to Help FreeCAD to contribute. +

      +
      +


      +

      + + + + + + + + + + + + + + + + + + + + +
      +

      Mesh MakeSegment.png Mesh MakeSegment‏‎

      +
      Menu location +
      Meshes → Make segment +
      Workbenches +
      Mesh +
      Default shortcut +
      +
      See also +
      +

      + +
      +


      +

      +

      Introduction

      +

      Use

      +

      Limitations

      +

      Links

      +
      +


      +

      + + +
      + +
      +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Mesh_Merge.html b/localwiki/Mesh_Merge.html new file mode 100644 index 0000000..3ce4958 --- /dev/null +++ b/localwiki/Mesh_Merge.html @@ -0,0 +1,81 @@ +Mesh Merge

      Mesh Merge

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Mesh Merge.png Mesh Merge‏‎

      +
      Menu location +
      Meshes → Merge +
      Workbenches +
      Mesh +
      Default shortcut +
      +
      See also +
      Boolean Union +

      + +
      +


      +

      +

      Introduction

      +

      Merges two ore more selected meshes. +


      +

      +

      Use

      +
      1. Select meshes in tree-view
      2. +
      3. Choose Meshes Merge from the top menu.
      +

      The resulting mesh will be created as a new and seperate object. +


      +

      +

      Limitations

      +

      Up to FreeCAD version 0.16.6651 placment of meshes was disregarded. +With FreeCAD 0.16.6651 this was fixed. +


      +

      +

      Notes

      +

      Opposed to Meshes Boolean Union no inner faces are removed. +All faces will transeferred to the mergeed mesh. +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Mesh_Merge.png b/localwiki/Mesh_Merge.png new file mode 100644 index 0000000..782eb4d Binary files /dev/null and b/localwiki/Mesh_Merge.png differ diff --git a/localwiki/Mesh_MeshFromShape.html b/localwiki/Mesh_MeshFromShape.html new file mode 100644 index 0000000..0b1049b --- /dev/null +++ b/localwiki/Mesh_MeshFromShape.html @@ -0,0 +1,109 @@ +Mesh MeshFromShape

      Mesh MeshFromShape

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Mesh MeshFromShape.png Mesh MeshFromShape‏‎

      +
      Menu location +
      Meshes → Create Mesh from Shape +
      Workbenches +
      Mesh +
      Default shortcut +
      None +
      See also +
      +

      + +
      +


      +

      +

      Introduction

      +

      This command creates a mesh from a shape object. +

      +

      Use

      +
      1. Select the shape object.
      2. +
      3. Choose MeshesMesh Mesh from Shape.svg Create Mesh from shape... from the top menu.
      4. +
      5. A menu will ask for the mesher to use and the appropriate values for the mesher
      +


      +Just selecting MeshesMesh Mesh from Shape.svg Create Mesh from shape... will give you an additional menu to choose your shape to mesh +


      +Standard Mesher +

      Mesh Mesher Standard.jpg +

      Surface deviation: If this number is smaller the mesh becomes finer. Smallest value is 0,001. +


      +Mefisto Mesher +

      Mesh Mesher Mefisto.jpg +

      Maximum edge length: If this number is smaller the mesh becomes finer. Smallest value is 0,000. +


      +Netgen Mesher +

      Mesh Mesher Netgen.jpg +

      You can choose between mesh being: +

      +
      • Very coarse
      • +
      • Coarse
      • +
      • Moderate
      • +
      • Fine
      • +
      • Very fine
      • +
      • User defined
      +


      +For Mesh being "user defined" you can set these values: +

      +
        • Mesh size grading : If this parameter is smaller, mesh becomes finer. A value in the range of 0.1-10.
        • +
        • Element per edge : If this parameter is larger, mesh becomes finer. A value in the range of 0.1-10.
        • +
        • Element per curvature radius : If this parameter is larger, mesh becomes finer. A value in the range of 0.1-10.
      +


      +For every main option you can also choose: +

      +
      • Optimize surface : Whether optimization of surface shape will be done.
      • +
      • Second order elements:Whether second order elments will be generated.
      • +
      • Quad dominant:Whether meshes will be arranged like hexahedral.
      +

      Limitations

      +


      +
      +

      +

      Notes

      + +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Mesh_Mesh_from_Shape.svg b/localwiki/Mesh_Mesh_from_Shape.svg new file mode 100644 index 0000000..cd3e1a1 --- /dev/null +++ b/localwiki/Mesh_Mesh_from_Shape.svg @@ -0,0 +1,376 @@ + + + + + Mesh_Mesh_from_Shape + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + Mesh_Mesh_from_Shape + + Solid cube with arrow pointing towards a tesselated cube mesh + + + [agryson] Alexander Gryson + + + + + cube + mesh + solid + convert + + + http://www.freecadweb.org/wiki/index.php?title=Artwork + FreeCAD/src/Mod/Mesh/Gui/Resources/icons/Mesh_Mesh_from_Shape.svg + + + FreeCAD LGPL2+ + + + + + FreeCAD + + + Sat Dec 14 00:58:58 2013 +1100 + + + [jmaustpc] + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Mesh_Mesher_Mefisto.jpg b/localwiki/Mesh_Mesher_Mefisto.jpg new file mode 100644 index 0000000..861c088 Binary files /dev/null and b/localwiki/Mesh_Mesher_Mefisto.jpg differ diff --git a/localwiki/Mesh_Mesher_Netgen.jpg b/localwiki/Mesh_Mesher_Netgen.jpg new file mode 100644 index 0000000..72a3ac9 Binary files /dev/null and b/localwiki/Mesh_Mesher_Netgen.jpg differ diff --git a/localwiki/Mesh_Mesher_Standard.jpg b/localwiki/Mesh_Mesher_Standard.jpg new file mode 100644 index 0000000..af72f5b Binary files /dev/null and b/localwiki/Mesh_Mesher_Standard.jpg differ diff --git a/localwiki/Mesh_Module.html b/localwiki/Mesh_Module.html new file mode 100644 index 0000000..07d59c5 --- /dev/null +++ b/localwiki/Mesh_Module.html @@ -0,0 +1,86 @@ +Mesh Module

      Mesh Module

      (Redirected from Mesh Module)
      + +

      The Mesh Workbench handles triangle meshes. Meshes are a special type of 3D object, composed of triangles connected by their edges and their corners (also called vertices). +

      An example of a mesh object +

      An example of a mesh object +

      Many 3D applications use meshes as their primary type of 3D object, like sketchup, blender, maya or 3d studio max. Since meshes are very simple objects, containing only vertices (points), edges and (triangular) faces, they are very easy to create, modify, subdivide, stretch, and can easily be passed from one application to another without any loss. Besides, since they contain very simple data, 3D applications can usually manage very large quantities of them without any problem. For those reasons, meshes are often the 3D object type of choice for applications dealing with movies, animation, and image creation. +

      In the field of engineering, however, meshes present one big limitation: They are very dumb objects, only composed of points, lines and faces. They are only made of surfaces, and have no mass information, so they don't behave as solids. In a mesh there is no automatic way to know if a point is inside or outside the object. This means that all solid-based operations, such as addition or subtraction, are always a bit difficult to perform on meshes, and return errors often. +

      In FreeCAD, since it is an engineering application, we would obviously prefer to work with more intelligent types of 3D objects, that can carry more information, such as mass, solid behaviour, or even custom parameters. The mesh module was first created to serve as a testbed, but to be able to read, manipulate and convert meshes is also highly important for FreeCAD. Very often, in your workflow, you will receive 3D data in mesh format. You will need to handle that data, analyse it to detect errors or other problems that prevent converting them to more intelligent objects, and finally, convert them to more intelligent objects, handled by the Part Module. +

      +

      Using the mesh module

      +

      The mesh module has currently a very simple interface, all its functions are grouped in the Mesh menu entry. The most important operations you can currently do with meshes are: +

      + +


      +

      + +


      +

      +
      • Mesh Regular Solid.png Regular solid... Create mesh primitives, like cubes, cylinders, cones, or spheres: +
        • Mesh Cube.png Create a mesh cube
        • +
        • Mesh Cylinder.png Create a mesh cylinder
        • +
        • Mesh Cone.png Create a mesh cone
        • +
        • Mesh Sphere.png Create a mesh sphere
        • +
        • Mesh Ellipsoid.png Create a mesh ellipsoid
        • +
        • Mesh Torus.png Create a mesh torus
      +


      +

      +
      • Do Boolean operations with meshes +
        • Union: Does a union (fusion) on meshes
        • +
        • Intersection: Does an intersection (common) on meshes
        • +
        • Difference: Does a difference (cut) on meshes
      +


      +

      + +


      +

      + +

      These are only some of the basic operations currently present in the Mesh module interface. +
      +More mesh tools are available in the OpenSCAD Workbench. +
      +But the FreeCAD meshes can also be handled in many more ways by scripting. +

      +

      Links

      + +


      +

      + +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Mesh_PolyCut.html b/localwiki/Mesh_PolyCut.html new file mode 100644 index 0000000..e72c092 --- /dev/null +++ b/localwiki/Mesh_PolyCut.html @@ -0,0 +1,64 @@ +Mesh PolyCut

      Mesh PolyCut

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Official icon not found Mesh_PolyCut

      +
      Menu location +
      {{{MenuLocation}}} +
      Workbenches +
      All +
      Default shortcut +
      None +
      See also +
      ... +

      Contents

      + +
      + +
      +


      +Synopsis +ToDo. +


      +

      +
      +

      This documentation is not finished. Please help and contribute documentation. +

      See Draft ShapeString for good documented Command. Gui Command gives an overview over commands. And see List of Commands for other commands. +

      Go to Help FreeCAD to contribute. +

      +
      + + + +
      + +
      +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Mesh_PolySegm.html b/localwiki/Mesh_PolySegm.html new file mode 100644 index 0000000..cc1bc99 --- /dev/null +++ b/localwiki/Mesh_PolySegm.html @@ -0,0 +1,64 @@ +Mesh PolySegm

      Mesh PolySegm

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Official icon not found Mesh_PolySegm

      +
      Menu location +
      {{{MenuLocation}}} +
      Workbenches +
      All +
      Default shortcut +
      None +
      See also +
      ... +

      Contents

      + +
      + +
      +


      +Synopsis +ToDo. +


      +

      +
      +

      This documentation is not finished. Please help and contribute documentation. +

      See Draft ShapeString for good documented Command. Gui Command gives an overview over commands. And see List of Commands for other commands. +

      Go to Help FreeCAD to contribute. +

      +
      + + + +
      + +
      +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Mesh_PolySplit.html b/localwiki/Mesh_PolySplit.html new file mode 100644 index 0000000..4ff27f5 --- /dev/null +++ b/localwiki/Mesh_PolySplit.html @@ -0,0 +1,64 @@ +Mesh PolySplit

      Mesh PolySplit

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Official icon not found Mesh_PolySplit

      +
      Menu location +
      {{{MenuLocation}}} +
      Workbenches +
      All +
      Default shortcut +
      None +
      See also +
      ... +

      Contents

      + +
      + +
      +


      +Synopsis +ToDo. +


      +

      +
      +

      This documentation is not finished. Please help and contribute documentation. +

      See Draft ShapeString for good documented Command. Gui Command gives an overview over commands. And see List of Commands for other commands. +

      Go to Help FreeCAD to contribute. +

      +
      + + + +
      + +
      +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Mesh_Regular_Solid.svg b/localwiki/Mesh_Regular_Solid.svg new file mode 100644 index 0000000..ca42180 --- /dev/null +++ b/localwiki/Mesh_Regular_Solid.svg @@ -0,0 +1,613 @@ + + + + + Mesh_Regular_Solid + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + Mesh_Regular_Solid + + A tesselated cube mesh in front of a tesselated cylindrical mesh + + + [agryson] Alexander Gryson + + + http://www.freecadweb.org/wiki/index.php?title=Artwork + FreeCAD/src/Mod/Mesh/Gui/Resources/icons/Mesh_Regular_Solid.svg + + + FreeCAD LGPL2+ + + + + + FreeCAD + + + + + mesh + cube + cylinder + tesselated + + + Fri Dec 20 16:28:14 2013 +0100 + + + [wmayer] + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Mesh_RemoveCompByHand.html b/localwiki/Mesh_RemoveCompByHand.html new file mode 100644 index 0000000..c70f26b --- /dev/null +++ b/localwiki/Mesh_RemoveCompByHand.html @@ -0,0 +1,80 @@ +Mesh RemoveCompByHand

      Mesh RemoveCompByHand

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Mesh RemoveCompByHand.png Mesh RemoveCompByHand‏‎

      +
      Menu location +
      Meshes → Remove components by hand... +
      Workbenches +
      Mesh +
      Default shortcut +
      +
      See also +
      +

      + +
      +


      +

      +

      Introduction

      +

      Remove components by manually selecting them in 3D-view. +

      +

      Use

      +
      1. Choose Meshes Remove components by hand... from the top menu.
      2. +
      3. Select component(s) in the 3D-view. Selected components are shown in red.
      +

      Right-click in the 3D-view will give you the possibility to +

      +
      • Leave removal mode
      • +
      • Delete selected faces
      • +
      • Clear selected faces
      +

      Limitations

      +


      +


      +

      +

      Notes

      +


      +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Mesh_RemoveCompByHand.png b/localwiki/Mesh_RemoveCompByHand.png new file mode 100644 index 0000000..782eb4d Binary files /dev/null and b/localwiki/Mesh_RemoveCompByHand.png differ diff --git a/localwiki/Mesh_RemoveComponents.html b/localwiki/Mesh_RemoveComponents.html new file mode 100644 index 0000000..cf37ddf --- /dev/null +++ b/localwiki/Mesh_RemoveComponents.html @@ -0,0 +1,83 @@ +Mesh RemoveComponents

      Mesh RemoveComponents

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Mesh RemoveComponents.png Mesh RemoveComponents‏‎

      +
      Menu location +
      Meshes → Remove components +
      Workbenches +
      Mesh +
      Default shortcut +
      +
      See also +
      +

      + +
      +


      +

      +

      Introduction

      +

      Remove components of meshes. +

      +

      Use

      +

      Meshes RemoveComponents.jpg +

      Select/Deselect: +

      +
      • Region: click left mouse button, keep pressed an move mouse to draw a spline defining a selection region.
      • +
      • All: will select/deselect all components in the active document
      • +
      • Components: will select all components with less than the entered number of faces
      • +
      • Pick Triangle: lets you select a single triangle face
      +

      If "Select whole component" is marked, using any of the four selection choices will select the whole component. +

      Region options +

      +
      • Respect only visible triangles
      • +
      • Respect only triangles with normals facing the screen
      +

      Limitations

      +


      +

      +

      Notes

      +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Mesh_Remove_Components.svg b/localwiki/Mesh_Remove_Components.svg new file mode 100644 index 0000000..99ef495 --- /dev/null +++ b/localwiki/Mesh_Remove_Components.svg @@ -0,0 +1,358 @@ + + + + + Mesh_Remove_Components + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + Mesh_Remove_Components + + + + FreeCAD LGPL2+ + + + + + FreeCAD + + + FreeCAD/src/Mod/Mesh/Gui/Resources/icons/Mesh_Remove_Components.svg + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + [agryson] Alexander Gryson + + + + + mesh + red cross + delete + remove + + + Two sets of mesh triangles, one of which is marked with a red cross + Fri Dec 20 16:28:14 2013 +0100 + + + [wmayer] + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Mesh_Scripting.html b/localwiki/Mesh_Scripting.html new file mode 100644 index 0000000..47ecaa1 --- /dev/null +++ b/localwiki/Mesh_Scripting.html @@ -0,0 +1,107 @@ +Mesh Scripting

      Mesh Scripting

      + +
      + +

      Introduction

      +

      First of all you have to import the Mesh module: +

      +
      import Mesh
      +

      After that you have access to the Mesh module and the Mesh class which facilitate the functions +of the FreeCAD C++ Mesh-Kernel. +

      +

      Creation and Loading

      +

      To create an empty mesh object just use the standard constructor: +

      +
      mesh = Mesh.Mesh()
      +

      You can also create an object from a file +

      +
      mesh = Mesh.Mesh('D:/temp/Something.stl')
      +

      (A list of compatible filetypes can be found under 'Meshes' here.) +

      Or create it out of a set of triangles described by their corner points: +

      +
      planarMesh = [
      +# triangle 1
      +[-0.5000,-0.5000,0.0000],[0.5000,0.5000,0.0000],[-0.5000,0.5000,0.0000],
      +#triangle 2
      +[-0.5000,-0.5000,0.0000],[0.5000,-0.5000,0.0000],[0.5000,0.5000,0.0000],
      +]
      +planarMeshObject = Mesh.Mesh(planarMesh)
      +Mesh.show(planarMeshObject)
      +

      The Mesh-Kernel takes care about creating a topological correct data structure by sorting +coincident points and edges together. +

      Later on you will see how you can test and examine mesh data. +

      +

      Modeling

      +

      To create regular geometries you can use the Python script BuildRegularGeoms.py. +

      +
      import BuildRegularGeoms
      +

      This script provides methods to define simple rotation bodies like spheres, ellipsoids, cylinders, toroids and cones. And it also has a method to create a simple cube. +To create a toroid, for instance, can be done as follows: +

      +
      t = BuildRegularGeoms.Toroid(8.0, 2.0, 50) # list with several thousands triangles
      +m = Mesh.Mesh(t)
      +

      The first two parameters define the radiuses of the toroid and the third parameter is a sub-sampling factor for how many triangles are created. The higher this value the smoother and the lower the coarser the body is. +The Mesh class provides a set of boolean functions that can be used for modeling purposes. It provides union, intersection and difference of two mesh objects. +

      +
      m1, m2              # are the input mesh objects
      +m3 = Mesh.Mesh(m1)  # create a copy of m1
      +m3.unite(m2)        # union of m1 and m2, the result is stored in m3
      +m4 = Mesh.Mesh(m1)
      +m4.intersect(m2)    # intersection of m1 and m2
      +m5 = Mesh.Mesh(m1)
      +m5.difference(m2)   # the difference of m1 and m2
      +m6 = Mesh.Mesh(m2)
      +m6.difference(m1)   # the difference of m2 and m1, usually the result is different to m5
      +

      Finally, a full example that computes the intersection between a sphere and a cylinder that intersects the sphere. +

      +
      import Mesh, BuildRegularGeoms
      +sphere = Mesh.Mesh( BuildRegularGeoms.Sphere(5.0, 50) )
      +cylinder = Mesh.Mesh( BuildRegularGeoms.Cylinder(2.0, 10.0, True, 1.0, 50) )
      +diff = sphere
      +diff = diff.difference(cylinder)
      +d = FreeCAD.newDocument()
      +d.addObject("Mesh::Feature","Diff_Sphere_Cylinder").Mesh=diff
      +d.recompute()
      +

      Examining and Testing

      +

      Write your own Algorithms

      +

      Exporting

      +

      You can even write the mesh to a python module: +

      +
      m.write("D:/Develop/Projekte/FreeCAD/FreeCAD_0.7/Mod/Mesh/SavedMesh.py")
      +import SavedMesh
      +m2 = Mesh.Mesh(SavedMesh.faces)
      +

      Gui related stuff

      +

      Odds and Ends

      +

      An extensive (though hard to use) source of Mesh related scripting are the unit test scripts of the Mesh-Module. +In this unit tests literally all methods are called and all properties/attributes are tweaked. +So if you are bold enough, take a look at the Unit Test module. +

      See also Mesh API +

      + +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Mesh_SelectMesh.html b/localwiki/Mesh_SelectMesh.html new file mode 100644 index 0000000..2367d0e --- /dev/null +++ b/localwiki/Mesh_SelectMesh.html @@ -0,0 +1,73 @@ +Mesh SelectMesh

      Mesh SelectMesh

      + +

      +

      This documentation is not finished. Please help and contribute documentation. +

      See Draft ShapeString for good documented Command. Gui Command gives an overview over commands. And see List of Commands for other commands. +

      Go to Help FreeCAD to contribute. +

      +
      +


      +

      + + + + + + + + + + + + + + + + + + + + +
      +

      Mesh SelectMesh.png Mesh SelectMesh‏‎

      +
      Menu location +
      Meshes → Select mesh +
      Workbenches +
      Mesh +
      Default shortcut +
      +
      See also +
      +

      + +
      +


      +

      +

      Introduction

      +

      Use

      +

      Limitations

      +

      Links

      +
      +


      +

      + + +
      + +
      +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Mesh_SelectMesh.png b/localwiki/Mesh_SelectMesh.png new file mode 100644 index 0000000..782eb4d Binary files /dev/null and b/localwiki/Mesh_SelectMesh.png differ diff --git a/localwiki/Mesh_Smooth.html b/localwiki/Mesh_Smooth.html new file mode 100644 index 0000000..dba1d19 --- /dev/null +++ b/localwiki/Mesh_Smooth.html @@ -0,0 +1,85 @@ +Mesh Smooth

      Mesh Smooth

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Mesh Smooth.png Mesh Smooth‏‎

      +
      Menu location +
      Mesh → Smooth +
      Workbenches +
      Mesh +
      Default shortcut +
      +
      See also +
      +

      + +
      +


      +

      +

      Introduction

      +

      Smooths meshes. +


      +

      +

      Use

      +
      1. Select mesh(es) in tree-view
      2. +
      3. Choose Meshes Smooth... from the top menu.
      +


      +A menu will pop up to allow choosing of smoothing-method. +
      +With LaPlace-method there is no "µ"-parameter to choose. +
      +When "Only Selection" is checked you will get an additional menu with additional options. +Meshes Smooth.jpg +


      +

      +

      Limitations

      +


      +


      +

      +

      Notes

      +


      +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Mesh_Smooth.png b/localwiki/Mesh_Smooth.png new file mode 100644 index 0000000..782eb4d Binary files /dev/null and b/localwiki/Mesh_Smooth.png differ diff --git a/localwiki/Mesh_Sphere.svg b/localwiki/Mesh_Sphere.svg new file mode 100644 index 0000000..0c99b30 --- /dev/null +++ b/localwiki/Mesh_Sphere.svg @@ -0,0 +1,328 @@ + + + + + Mesh_Sphere + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + Mesh_Sphere + + Sat Dec 21 21:54:56 2013 +1100 + + + [jmaustpc] + + + + + FreeCAD LGPL2+ + + + + + FreeCAD + + + FreeCAD/src/Mod/Mesh/Gui/Resources/icons/RegularSolids/Mesh_Sphere.svg + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + mesh + sphere + tesselated + + + Tesselated sphere mesh, lit from top + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Mesh_SplitMesh.html b/localwiki/Mesh_SplitMesh.html new file mode 100644 index 0000000..c5744fc --- /dev/null +++ b/localwiki/Mesh_SplitMesh.html @@ -0,0 +1,73 @@ +Mesh SplitMesh

      Mesh SplitMesh

      + +

      +

      This documentation is not finished. Please help and contribute documentation. +

      See Draft ShapeString for good documented Command. Gui Command gives an overview over commands. And see List of Commands for other commands. +

      Go to Help FreeCAD to contribute. +

      +
      +


      +

      + + + + + + + + + + + + + + + + + + + + +
      +

      Mesh SplitMesh.png Mesh SplitMesh‏‎

      +
      Menu location +
      Meshes → Split mesh +
      Workbenches +
      Mesh +
      Default shortcut +
      +
      See also +
      +

      + +
      +


      +

      +

      Introduction

      +

      Use

      +

      Limitations

      +

      Links

      +
      +


      +

      + + +
      + +
      +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Mesh_SplitMesh.png b/localwiki/Mesh_SplitMesh.png new file mode 100644 index 0000000..782eb4d Binary files /dev/null and b/localwiki/Mesh_SplitMesh.png differ diff --git a/localwiki/Mesh_ToolMesh.html b/localwiki/Mesh_ToolMesh.html new file mode 100644 index 0000000..6800a0c --- /dev/null +++ b/localwiki/Mesh_ToolMesh.html @@ -0,0 +1,64 @@ +Mesh ToolMesh

      Mesh ToolMesh

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Official icon not found Mesh_ToolMesh

      +
      Menu location +
      {{{MenuLocation}}} +
      Workbenches +
      All +
      Default shortcut +
      None +
      See also +
      ... +

      Contents

      + +
      + +
      +


      +Synopsis +ToDo. +


      +

      +
      +

      This documentation is not finished. Please help and contribute documentation. +

      See Draft ShapeString for good documented Command. Gui Command gives an overview over commands. And see List of Commands for other commands. +

      Go to Help FreeCAD to contribute. +

      +
      + + + +
      + +
      +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Mesh_Torus.svg b/localwiki/Mesh_Torus.svg new file mode 100644 index 0000000..59da9d9 --- /dev/null +++ b/localwiki/Mesh_Torus.svg @@ -0,0 +1,388 @@ + + + + + Mesh_Torus + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + Mesh_Torus + + + FreeCAD LGPL2+ + + + + + FreeCAD + + + FreeCAD/src/Mod/Mesh/Gui/Resources/icons/RegularSolids/Mesh_Torus.svg + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + [agryson] Alexander Gryson + + + Tesselated torus mesh, lit from top + + + + mesh + torus + tesselated + + + Sat Dec 21 21:54:56 2013 +1100 + + + [jmaustpc] + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Mesh_Transform.html b/localwiki/Mesh_Transform.html new file mode 100644 index 0000000..defee27 --- /dev/null +++ b/localwiki/Mesh_Transform.html @@ -0,0 +1,64 @@ +Mesh Transform

      Mesh Transform

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Official icon not found Mesh_Transform

      +
      Menu location +
      {{{MenuLocation}}} +
      Workbenches +
      All +
      Default shortcut +
      None +
      See also +
      ... +

      Contents

      + +
      + +
      +


      +Synopsis +ToDo. +


      +

      +
      +

      This documentation is not finished. Please help and contribute documentation. +

      See Draft ShapeString for good documented Command. Gui Command gives an overview over commands. And see List of Commands for other commands. +

      Go to Help FreeCAD to contribute. +

      +
      + + + +
      + +
      +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Mesh_Tree_Curvature_Plot.svg b/localwiki/Mesh_Tree_Curvature_Plot.svg new file mode 100644 index 0000000..a51a100 --- /dev/null +++ b/localwiki/Mesh_Tree_Curvature_Plot.svg @@ -0,0 +1,222 @@ + + + + + Mesh_Tree_Curvature_Plot + + + + + + + + + + + + + + + + + + + image/svg+xml + + Mesh_Tree_Curvature_Plot + + + + FreeCAD LGPL2+ + + + + + FreeCAD + + + FreeCAD/src/Mod/Mesh/Gui/Resources/icons/Mesh_Tree_Curvature_Plot.svg + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + [agryson] Alexander Gryson + + + + + mesh + color + plot + diamond + + + Diamond Shaped mesh with color coded faces + Fri Dec 20 16:28:14 2013 +0100 + + + [wmayer] + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Mesh_TrimMesh.html b/localwiki/Mesh_TrimMesh.html new file mode 100644 index 0000000..cf81758 --- /dev/null +++ b/localwiki/Mesh_TrimMesh.html @@ -0,0 +1,73 @@ +Mesh TrimMesh

      Mesh TrimMesh

      + +

      +

      This documentation is not finished. Please help and contribute documentation. +

      See Draft ShapeString for good documented Command. Gui Command gives an overview over commands. And see List of Commands for other commands. +

      Go to Help FreeCAD to contribute. +

      +
      +


      +

      + + + + + + + + + + + + + + + + + + + + +
      +

      Mesh TrimMesh.png Mesh TrimMesh‏‎

      +
      Menu location +
      Meshes → Trim mesh +
      Workbenches +
      Mesh +
      Default shortcut +
      +
      See also +
      +

      + +
      +


      +

      +

      Introduction

      +

      Use

      +

      Limitations

      +

      Links

      +
      +


      +

      + + +
      + +
      +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Mesh_TrimMesh.png b/localwiki/Mesh_TrimMesh.png new file mode 100644 index 0000000..782eb4d Binary files /dev/null and b/localwiki/Mesh_TrimMesh.png differ diff --git a/localwiki/Mesh_TrimMeshWithPlane.html b/localwiki/Mesh_TrimMeshWithPlane.html new file mode 100644 index 0000000..02cf0ca --- /dev/null +++ b/localwiki/Mesh_TrimMeshWithPlane.html @@ -0,0 +1,73 @@ +Mesh TrimMeshWithPlane

      Mesh TrimMeshWithPlane

      + +

      +

      This documentation is not finished. Please help and contribute documentation. +

      See Draft ShapeString for good documented Command. Gui Command gives an overview over commands. And see List of Commands for other commands. +

      Go to Help FreeCAD to contribute. +

      +
      +


      +

      + + + + + + + + + + + + + + + + + + + + +
      +

      Mesh TrimMeshWithPlane.png Mesh TrimMeshWithPlane‏‎

      +
      Menu location +
      Meshes → Trim mesh with a plane +
      Workbenches +
      Mesh +
      Default shortcut +
      +
      See also +
      +

      + +
      +


      +

      +

      Introduction

      +

      Use

      +

      Limitations

      +

      Links

      +
      +


      +

      + + +
      + +
      +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Mesh_TrimMeshWithPlane.png b/localwiki/Mesh_TrimMeshWithPlane.png new file mode 100644 index 0000000..782eb4d Binary files /dev/null and b/localwiki/Mesh_TrimMeshWithPlane.png differ diff --git a/localwiki/Mesh_Union.html b/localwiki/Mesh_Union.html new file mode 100644 index 0000000..52c9877 --- /dev/null +++ b/localwiki/Mesh_Union.html @@ -0,0 +1,78 @@ +Mesh Union

      Mesh Union

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Mesh Union.png Mesh Union‏‎

      +
      Menu location +
      Meshes → Boolean → Union +
      Workbenches +
      Mesh +
      Default shortcut +
      +
      See also +
      Merge +

      + +
      +


      +

      +

      Introduction

      +

      Does a union (fusion) on selected meshes. +

      The command creates a new seperate mesh with all outer faces of all selected meshes. +

      Inner faces are removed. +

      +

      Use

      +
      1. Select meshes to be fused in the tree-view or in the 3D-view.
      2. +
      3. Choose MeshesBooleanUnion
      +


      +

      Example: Cube fused with sphere +

      Meshes Boolean Union.jpg +

      +

      Limitations

      +

      Notes

      +

      If you do not want remove the inner faces, you can use Merge +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Mesh_Union.png b/localwiki/Mesh_Union.png new file mode 100644 index 0000000..782eb4d Binary files /dev/null and b/localwiki/Mesh_Union.png differ diff --git a/localwiki/Mesh_VertexCurvature.html b/localwiki/Mesh_VertexCurvature.html new file mode 100644 index 0000000..fa6a505 --- /dev/null +++ b/localwiki/Mesh_VertexCurvature.html @@ -0,0 +1,64 @@ +Mesh VertexCurvature

      Mesh VertexCurvature

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Official icon not found Mesh_VertexCurvature

      +
      Menu location +
      {{{MenuLocation}}} +
      Workbenches +
      All +
      Default shortcut +
      None +
      See also +
      ... +

      Contents

      + +
      + +
      +


      +Synopsis +ToDo. +


      +

      +
      +

      This documentation is not finished. Please help and contribute documentation. +

      See Draft ShapeString for good documented Command. Gui Command gives an overview over commands. And see List of Commands for other commands. +

      Go to Help FreeCAD to contribute. +

      +
      + + + +
      + +
      +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Mesh_Workbench.html b/localwiki/Mesh_Workbench.html new file mode 100644 index 0000000..10b7909 --- /dev/null +++ b/localwiki/Mesh_Workbench.html @@ -0,0 +1,86 @@ +Mesh Workbench

      Mesh Workbench

      + +

      The Mesh Workbench handles triangle meshes. Meshes are a special type of 3D object, composed of triangles connected by their edges and their corners (also called vertices). +

      An example of a mesh object +

      An example of a mesh object +

      Many 3D applications use meshes as their primary type of 3D object, like sketchup, blender, maya or 3d studio max. Since meshes are very simple objects, containing only vertices (points), edges and (triangular) faces, they are very easy to create, modify, subdivide, stretch, and can easily be passed from one application to another without any loss. Besides, since they contain very simple data, 3D applications can usually manage very large quantities of them without any problem. For those reasons, meshes are often the 3D object type of choice for applications dealing with movies, animation, and image creation. +

      In the field of engineering, however, meshes present one big limitation: They are very dumb objects, only composed of points, lines and faces. They are only made of surfaces, and have no mass information, so they don't behave as solids. In a mesh there is no automatic way to know if a point is inside or outside the object. This means that all solid-based operations, such as addition or subtraction, are always a bit difficult to perform on meshes, and return errors often. +

      In FreeCAD, since it is an engineering application, we would obviously prefer to work with more intelligent types of 3D objects, that can carry more information, such as mass, solid behaviour, or even custom parameters. The mesh module was first created to serve as a testbed, but to be able to read, manipulate and convert meshes is also highly important for FreeCAD. Very often, in your workflow, you will receive 3D data in mesh format. You will need to handle that data, analyse it to detect errors or other problems that prevent converting them to more intelligent objects, and finally, convert them to more intelligent objects, handled by the Part Module. +

      +

      Using the mesh module

      +

      The mesh module has currently a very simple interface, all its functions are grouped in the Mesh menu entry. The most important operations you can currently do with meshes are: +

      + +


      +

      + +


      +

      +
      • Mesh Regular Solid.png Regular solid... Create mesh primitives, like cubes, cylinders, cones, or spheres: +
        • Mesh Cube.png Create a mesh cube
        • +
        • Mesh Cylinder.png Create a mesh cylinder
        • +
        • Mesh Cone.png Create a mesh cone
        • +
        • Mesh Sphere.png Create a mesh sphere
        • +
        • Mesh Ellipsoid.png Create a mesh ellipsoid
        • +
        • Mesh Torus.png Create a mesh torus
      +


      +

      +
      • Do Boolean operations with meshes +
        • Union: Does a union (fusion) on meshes
        • +
        • Intersection: Does an intersection (common) on meshes
        • +
        • Difference: Does a difference (cut) on meshes
      +


      +

      + +


      +

      + +

      These are only some of the basic operations currently present in the Mesh module interface. +
      +More mesh tools are available in the OpenSCAD Workbench. +
      +But the FreeCAD meshes can also be handled in many more ways by scripting. +

      +

      Links

      + +


      +

      + +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Mesh_boundary.svg b/localwiki/Mesh_boundary.svg new file mode 100644 index 0000000..872a9ef --- /dev/null +++ b/localwiki/Mesh_boundary.svg @@ -0,0 +1,199 @@ + + + + + mesh_boundary + + + + + + + + + + + + + + + + + + + image/svg+xml + + + mesh_boundary + A single triangular mesh face with a hole in it + + + [agryson] Alexander Gryson + + + + + mesh + triangle + face + hole + + + http://www.freecadweb.org/wiki/index.php?title=Artwork + FreeCAD/src/Mod/Mesh/Gui/Resources/icons/mesh_boundary.svg + + + FreeCAD + + + + + FreeCAD LGPL2+ + + + Mon Oct 10 13:44:52 2011 +0000 + + + [wmayer] + + + + + + + + + + + + + + + diff --git a/localwiki/Mesh_cut.svg b/localwiki/Mesh_cut.svg new file mode 100644 index 0000000..2bdd546 --- /dev/null +++ b/localwiki/Mesh_cut.svg @@ -0,0 +1,1043 @@ + + + + + mesh_cut + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + mesh_cut + + https://commons.wikimedia.org/wiki/Tango_icons#/media/File:Edit-cut.svg + FreeCAD/src/Mod/Mesh/Gui/Resources/icons/mesh_cut.svg + + + [agryson] Alexander Gryson + + + A tesselated planar mesh in between the blades of an open scissors + + + mesh + plane + tesselated + scissors + cut + + + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + + + FreeCAD LGPL2+ + + + Mon Oct 10 13:44:52 2011 +0000 + + + [wmayer] + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Mesh_example.jpg b/localwiki/Mesh_example.jpg new file mode 100644 index 0000000..07b9f54 Binary files /dev/null and b/localwiki/Mesh_example.jpg differ diff --git a/localwiki/Mesh_pipette.svg b/localwiki/Mesh_pipette.svg new file mode 100644 index 0000000..d83fa47 --- /dev/null +++ b/localwiki/Mesh_pipette.svg @@ -0,0 +1,253 @@ + + + + + mesh_pipette + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + mesh_pipette + + + + FreeCAD LGPL2+ + + + + + FreeCAD + + + FreeCAD/src/Mod/Mesh/Gui/Resources/icons/mesh_pipette.svg + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + pipette + eyedropper + sample + + + Pipette or eyedropper lit from above + + + [agryson] Alexander Gryson + + + Sat Feb 8 16:10:16 2014 +0100 + + + [wmayer] + + + + + + + + + + + + + + + + + diff --git a/localwiki/Mesh_to_Part.html b/localwiki/Mesh_to_Part.html new file mode 100644 index 0000000..1087828 --- /dev/null +++ b/localwiki/Mesh_to_Part.html @@ -0,0 +1,99 @@ +Mesh to Part

      Mesh to Part

      + +

      Converting Part objects to Meshes

      +

      Converting higher-level objects such as Part shapes into simpler objects such as meshes is a pretty simple operation, where all faces of a Part object get triangulated. The result of that triangulation (tessellation) is then used to construct a mesh: (let's assume our document contains one part object) +

      +
      #let's assume our document contains one part object
      +import Mesh
      +faces = []
      +shape = FreeCAD.ActiveDocument.ActiveObject.Shape
      +triangles = shape.tessellate(1) # the number represents the precision of the tessellation)
      +for tri in triangles[1]:
      +    face = []
      +    for i in range(3):
      +        vindex = tri[i]
      +        face.append(triangles[0][vindex])
      +    faces.append(face)
      +m = Mesh.Mesh(faces)
      +Mesh.show(m) 
      +

      Sometimes the triangulation of certain faces offered by OpenCascade is quite ugly. If the face has a rectangular parameter space and doesn't contain any holes or other trimming curves you can also create a mesh on your own: +

      +
      import Mesh
      +def makeMeshFromFace(u,v,face):
      +(a,b,c,d)=face.ParameterRange
      +pts=[]
      +for j in range(v):
      +for i in range(u):
      +s=1.0/(u-1)*(i*b+(u-1-i)*a)
      +t=1.0/(v-1)*(j*d+(v-1-j)*c)
      +pts.append(face.valueAt(s,t))
      +
      +mesh=Mesh.Mesh()
      +for j in range(v-1):
      +for i in range(u-1):
      +mesh.addFacet(pts[u*j+i],pts[u*j+i+1],pts[u*(j+1)+i])
      +mesh.addFacet(pts[u*(j+1)+i],pts[u*j+i+1],pts[u*(j+1)+i+1])
      +
      +return mesh 
      +

      Converting Meshes to Part objects

      +

      Converting Meshes to Part objects is an extremely important operation in CAD work, because very often you receive 3D data in mesh format from other people or outputted from other applications. Meshes are very practical to represent free-form geometry and big visual scenes, as it is very lightweight, but for CAD we generally prefer higher-level objects that carry much more information, such as the idea of solid, or faces made of curves instead of triangles. +

      Converting meshes to those higher-level objects (handled by the Part Module in FreeCAD) is not an easy operation. Meshes can be made of thousands of triangles (for example when generated by a 3D scanner), and having solids made of the same number of faces would be extremely heavy to manipulate. So you generally want to optimize the object when converting. +

      FreeCAD currently offers two methods to convert Meshes to Part objects. The first method is a simple, direct conversion, without any optimization: +

      +
      import Mesh,Part
      +mesh = Mesh.createTorus()
      +shape = Part.Shape()
      +shape.makeShapeFromMesh(mesh.Topology,0.05) # the second arg is the tolerance for sewing
      +solid = Part.makeSolid(shape)
      +Part.show(solid) 
      +

      The second method offers the possibility to consider mesh facets coplanar when the angle between them is under a certain value. This allows to build much simpler shapes: (let's assume our document contains one Mesh object) +

      +
      # let's assume our document contains one Mesh object
      +import Mesh,Part,MeshPart
      +faces = []
      +mesh = App.ActiveDocument.ActiveObject.Mesh
      +segments = mesh.getPlanes(0.00001) # use rather strict tolerance here
      + 
      +for i in segments:
      +  if len(i) > 0:
      +     # a segment can have inner holes
      +     wires = MeshPart.wireFromSegment(mesh, i)
      +     # we assume that the exterior boundary is that one with the biggest bounding box
      +     if len(wires) > 0:
      +        ext=None
      +        max_length=0
      +        for i in wires:
      +           if i.BoundBox.DiagonalLength > max_length:
      +              max_length = i.BoundBox.DiagonalLength
      +              ext = i
      +
      +        wires.remove(ext)
      +        # all interior wires mark a hole and must reverse their orientation, otherwise Part.Face fails
      +        for i in wires:
      +           i.reverse()
      +
      +        # make sure that the exterior wires comes as first in the lsit
      +        wires.insert(0, ext)
      +        faces.append(Part.Face(wires))
      +
      +shell=Part.Compound(faces)
      +Part.show(shell)
      +#solid = Part.Solid(Part.Shell(faces))
      +#Part.show(solid) 
      + +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Meshes_Boolean_Difference.jpg b/localwiki/Meshes_Boolean_Difference.jpg new file mode 100644 index 0000000..a2fae19 Binary files /dev/null and b/localwiki/Meshes_Boolean_Difference.jpg differ diff --git a/localwiki/Meshes_Boolean_Intersection.jpg b/localwiki/Meshes_Boolean_Intersection.jpg new file mode 100644 index 0000000..2c8ddac Binary files /dev/null and b/localwiki/Meshes_Boolean_Intersection.jpg differ diff --git a/localwiki/Meshes_Boolean_Union.jpg b/localwiki/Meshes_Boolean_Union.jpg new file mode 100644 index 0000000..08255a3 Binary files /dev/null and b/localwiki/Meshes_Boolean_Union.jpg differ diff --git a/localwiki/Meshes_RegularSolid_Cone.jpg b/localwiki/Meshes_RegularSolid_Cone.jpg new file mode 100644 index 0000000..e043bf9 Binary files /dev/null and b/localwiki/Meshes_RegularSolid_Cone.jpg differ diff --git a/localwiki/Meshes_RegularSolid_Cube.jpg b/localwiki/Meshes_RegularSolid_Cube.jpg new file mode 100644 index 0000000..2d6fed2 Binary files /dev/null and b/localwiki/Meshes_RegularSolid_Cube.jpg differ diff --git a/localwiki/Meshes_RegularSolid_Cylinder.jpg b/localwiki/Meshes_RegularSolid_Cylinder.jpg new file mode 100644 index 0000000..2110c90 Binary files /dev/null and b/localwiki/Meshes_RegularSolid_Cylinder.jpg differ diff --git a/localwiki/Meshes_RegularSolid_Ellipsoid.jpg b/localwiki/Meshes_RegularSolid_Ellipsoid.jpg new file mode 100644 index 0000000..6f62eef Binary files /dev/null and b/localwiki/Meshes_RegularSolid_Ellipsoid.jpg differ diff --git a/localwiki/Meshes_RegularSolid_Sphere.jpg b/localwiki/Meshes_RegularSolid_Sphere.jpg new file mode 100644 index 0000000..9e15751 Binary files /dev/null and b/localwiki/Meshes_RegularSolid_Sphere.jpg differ diff --git a/localwiki/Meshes_RegularSolid_Torus.jpg b/localwiki/Meshes_RegularSolid_Torus.jpg new file mode 100644 index 0000000..e331b49 Binary files /dev/null and b/localwiki/Meshes_RegularSolid_Torus.jpg differ diff --git a/localwiki/Meshes_RemoveComponents.jpg b/localwiki/Meshes_RemoveComponents.jpg new file mode 100644 index 0000000..2c0734f Binary files /dev/null and b/localwiki/Meshes_RemoveComponents.jpg differ diff --git a/localwiki/Meshes_Smooth.jpg b/localwiki/Meshes_Smooth.jpg new file mode 100644 index 0000000..b869843 Binary files /dev/null and b/localwiki/Meshes_Smooth.jpg differ diff --git a/localwiki/Method.png b/localwiki/Method.png new file mode 100644 index 0000000..146990f Binary files /dev/null and b/localwiki/Method.png differ diff --git a/localwiki/Method.svg b/localwiki/Method.svg new file mode 100644 index 0000000..7e2f669 --- /dev/null +++ b/localwiki/Method.svg @@ -0,0 +1,207 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Minkowski_example.jpg b/localwiki/Minkowski_example.jpg new file mode 100644 index 0000000..49992f1 Binary files /dev/null and b/localwiki/Minkowski_example.jpg differ diff --git a/localwiki/Mirrored_parameters.png b/localwiki/Mirrored_parameters.png new file mode 100644 index 0000000..6ae969b Binary files /dev/null and b/localwiki/Mirrored_parameters.png differ diff --git a/localwiki/Mirrored_parameters_v017.png b/localwiki/Mirrored_parameters_v017.png new file mode 100644 index 0000000..1fe215e Binary files /dev/null and b/localwiki/Mirrored_parameters_v017.png differ diff --git a/localwiki/Misc_templates.html b/localwiki/Misc_templates.html new file mode 100644 index 0000000..f482a78 --- /dev/null +++ b/localwiki/Misc_templates.html @@ -0,0 +1,111 @@ +Misc templates

      Misc templates

      + +

      This page lists some mixed templates.
      +All models are in SVG format directly downloadable and usable with or without modification.
      +All the templates and cartridges are equipped with editable texts in FreeCAD.
      +For use must rename in A3_Landscape.svg (has put in (Window) "C:\Program Files\you FreeCAD version\data\Mod\Drawing\Templates" ).
      +To access after you create the page, click on the page in Combo View > Properties > Data > Editable Texts > click 3 points... +


      +A macro is available for two major model 1 and model 2 cartridges.
      +Several custom attributes can be placed in templates. The list of currently supported attributes is available on the Svg Namespace page. +

      + + +

      A3 Landscape US Text Complet With Convention EU.svg

      +

      A3 Landscape US Text Complet With Convention EU +

      +

      A3 Landscape US Text Complet With Convention US

      +

      A3 Landscape US Text Complet With Convention US +

      +

      A3 Landscape US Text Complet Without Convention

      +

      A3 Landscape US Text Complet Without Convention +

      +

      A4 Landscape US Text Complet With Convention EU

      +

      A4_Landscape US Text Complet With Convention EU +

      +

      A4 Portrait US Text Complet With Convention EU

      +

      A4_Portrait US Text Complet With Convention EU +

      +

      The most used cartridges in templates FreeCAD

      +

      Convention EU US

      +

      Symbols used to define a projection. +

      +
      + +
      +

      Model Cartridge 1

      +

      Cartouche model 01 +

      +

      Model Cartridge 2

      +

      Cartouche model 02 +

      +

      Model Cartridge 3

      +

      Cartouche model 03 +

      +

      Model Cartridge 4

      +

      Cartouche model 04 +

      +

      CompassRose

      +

      CompassRose +

      +

      Templates in .FCStd format

      +

      The templates is complete and are equipped of cartouche and with a table (K to Z hidden by default) and symbols US (hidden by default) and EU. You just hide or erase what does not serve you. +

      Template A3_Landscape.FCStd +

      Template A4_Portrait.FCStd +

      CompassRose_2D CompassRose_2D.FCStd +

      CompassRose_3D CompassRose_3D.FCStd +

      +

      Other standards available

      + +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Misc_templates_Full.html b/localwiki/Misc_templates_Full.html new file mode 100644 index 0000000..1460e48 --- /dev/null +++ b/localwiki/Misc_templates_Full.html @@ -0,0 +1,49 @@ +Misc templates Full

      Misc templates Full

      + +

      These templates are completely empty cartridge (22 fields to fill) and dedicated to the macro Macro_CartoucheFC_Full +

      The same work can be done directly in FreeCAD +

      Copy the template in the directory : +

      for Windows : "C:\Program Files\FreeCAD 0.16\data\Mod\Drawing\Templates" +

      for Linux : "" +

      + + +

      English template

      +

      A3_Landscape_US

      +
      A3 Landscape US FULL.svg
      +
      +

      A3_Portrait_US

      +
      A3 Portrait US FULL.svg
      +
      +

      A4_Landscape_US

      +
      A4 Landscape US FULL.svg
      +
      +

      A4_Portrait_US

      +
      A4 Portrait US FULL.svg
      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Module_Creation.html b/localwiki/Module_Creation.html new file mode 100644 index 0000000..9866ce7 --- /dev/null +++ b/localwiki/Module_Creation.html @@ -0,0 +1,202 @@ +Module Creation

      Module Creation

      + +

      Adding new modules and workbenches in FreeCAD is very easy. A module is any extension of FreeCAD, while a workbench is a special GUI configuration that groups some toolbars and menus. Usually you create a new module which contains its own workbench. +

      Modules can be programmed in C++ or in python, or in a mixture of both, but the module init files must be in python. Setting up a new module with those init files is easy, and can be done either manually or with the FreeCAD build tool. +

      + + +

      Using the FreeCAD Build tool

      +

      Creating a new application module in FreeCAD is rather simple. The FreeCAD Build Tool (fcbt) does most of the heavy lifting for you. It is a Python script which can be found in the FreeCAD development tree under: +

      +
      + trunk/src/Tools/fcbt.py
      +
      +

      When your python interpreter is correctly installed, you can execute the script from a command line with +

      +
      + python fcbt.py
      +
      +

      It will display the following menu: +

      +
      + FreeCAD Build Tool
      + Usage:
      +    fcbt <command name> [command parameter] 
      + possible commands are:
      +  - DistSrc         (DS)   Build a source Distr. of the current source tree
      +  - DistBin         (DB)   Build a binary Distr. of the current source tree
      +  - DistSetup       (DI)   Build a Setup Distr. of the current source tree
      +  - DistSetup       (DUI)  Build a User Setup Distr. of the current source tree
      +  - DistAll         (DA)   Run all three above modules
      +  - NextBuildNumber (NBN)  Increase the Build Number of this Version
      +  - CreateModule    (CM)   Insert a new FreeCAD Module in the module directory
      +  - CreatePyModule  (CP)   Insert a new FreeCAD Python Module in the module directory
      +
      + For help on the modules type:
      +   fcbt <command name> ?
      +
      +

      At the command prompt enter CM to start the creation of a module: +

      +
      + Insert command: ''CM''
      +
      +

      You are now asked to specify a name for your new module. Lets call it TestMod for this example: +

      +
      + Please enter a name for your application: ''TestMod''
      +
      +

      After pressing Enter, fcbt starts copying all necessary files for your module into a new folder located at +

      +
      + trunk/src/Mod/TestMod/
      +
      +

      Then all files are modified with your new module name. The only thing you need to do now is to add the two new projects "appTestMod" and "appTestModGui" to your workspace (on Windows) or to your makefile targets (unix). Thats it! +

      +

      Setting up a new module manually

      +

      You need two things to create a new module: +

      +
      • A new folder in the FreeCAD Mod folder (either in InstalledPath/FreeCAD/Mod or in UserPath/.FreeCAD/Mod). You can name it as you like.
      • +
      • Inside that folder, an InitGui.py file. That file will be executed automatically on FreeCAD start (it can be empty, but just to test it,, put a print("hello world") inside)
      +

      Additionally, you can also add an Init.py file. InitGui.py file is loaded only when FreeCAD runs in GUI mode, whereas the Init.py file is always loaded. Since we're creating a workbench, however, we'll put our code in InitGui.py, since workbenches are GUI-only tools. +

      +

      Creating a new workbench

      +

      Inside the InitGui.py file, the first thing you will want to do is define a workbench. You can use the following example as a template: +

      +
       class MyWorkbench ( Workbench ):
      + "My workbench object"
      + Icon = """
      + /* XPM */
      + static const char *test_icon[]={
      + "16 16 2 1",
      + "a c #000000",
      + ". c None",
      + "................",
      + "................",
      + "..############..",
      + "..############..",
      + "..############..",
      + "......####......",
      + "......####......",
      + "......####......",
      + "......####......",
      + "......####......",
      + "......####......",
      + "......####......",
      + "......####......",
      + "......####......",
      + "................",
      + "................"};
      + """
      + MenuText = "My Workbench"
      + ToolTip = "This is my extraordinary workbench"
      + 
      +         def GetClassName(self):
      +                return "Gui::PythonWorkbench"
      + 
      + def Initialize(self):
      + import myModule1, myModule2
      + self.appendToolbar("My Tools", ["MyCommand1","MyCommand2"])
      + self.appendMenu("My Tools", ["MyCommand1","MyCommand2"])
      + Log ("Loading MyModule... done\n")
      + 
      + def Activated(self):
      +                # do something here if needed...
      + Msg ("MyWorkbench.Activated()\n")
      + 
      + def Deactivated(self):
      +                # do something here if needed...
      + Msg ("MyWorkbench.Deactivated()\n")
      + 
      + FreeCADGui.addWorkbench(MyWorkbench)
      +

      The workbench must have all these attributes defined: +

      +
      • Icon - An XPM image. Most image software (like GIMP) can convert an image into xpm format, which is a text file. You can then paste the contents here.
      • +
      • MenuText - The workbench name as it appears in the workbenches list
      • +
      • Tooltip - Defines the tooltip text
      • +
      • Initialize() - Executed when FreeCAD loads and creates all menus and toolbars that the workbench will use. If you are going to make your module in C++, you can also define your menus and toolbars inside the C++ module rather than the InitGui.py file. The important thing is that they are created now, before the module is activated.
      • +
      • Activated() - Executed when the user switches to your workbench
      • +
      • Deactivated() - Executed when the user switches away to another workbench or leaves FreeCAD
      +

      Creating FreeCAD commands in Python

      +

      Usually you define all your tools (called Commands in FreeCAD) in another module, then import that module before creating the toolbars and menus. Here is a simple example that can be used as a template: +

      +
       import FreeCAD,FreeCADGui
      + 
      + class MyTool:
      + "My tool object"
      + 
      +        def GetResources(self):
      +                return {"MenuText": "My Command",
      +                        "Accel": "Ctrl+M",
      +                        "ToolTip": "My extraordinary command",
      +                        "Pixmap"  : """
      + /* XPM */
      + static const char *test_icon[]={
      + "16 16 2 1",
      + "a c #000000",
      + ". c None",
      + "................",
      + "................",
      + "..############..",
      + "..############..",
      + "..############..",
      + "......####......",
      + "......####......",
      + "......####......",
      + "......####......",
      + "......####......",
      + "......####......",
      + "......####......",
      + "......####......",
      + "......####......",
      + "................",
      + "................"};
      + """}
      + 
      +        def IsActive(self):
      +                if FreeCAD.ActiveDocument == None:
      +                        return False
      +                else:
      +                        return True
      + 
      + def Activated(self):
      +                # do something here...
      + 
      + FreeCADGui.addCommand('MyCommand1',MyTool())
      +

      Note there are three methods defined: +

      +
      • GetResources() - Returns a dictionary with the visual attributes of your tool. The Accel parameter defines an optional shortcut key.
      • +
      • IsActive() - Determines whether or not the command is active. Inactive commands are indicated by a greyed-out icon in the menus and toolbars.
      • +
      • Activated() - Executed when the Command is called, whether through a toolbar button, menu or script API call.
      +

      Creating FreeCAD Commands in C++

      +

      To Be Documented +

      +

      Links

      + + +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Mouse_LMB%2BRMB.svg b/localwiki/Mouse_LMB%2BRMB.svg new file mode 100644 index 0000000..cf95252 --- /dev/null +++ b/localwiki/Mouse_LMB%2BRMB.svg @@ -0,0 +1,126 @@ + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + + + + + + + + diff --git a/localwiki/Mouse_Model.html b/localwiki/Mouse_Model.html new file mode 100644 index 0000000..0165ad5 --- /dev/null +++ b/localwiki/Mouse_Model.html @@ -0,0 +1,420 @@ +Mouse Model

      Mouse Model

      + +

      The FreeCAD mouse model consists of the commands used to visually navigate the 3D space and interact with the objects displayed. FreeCAD supports multiple mouse model navigation styles. The default navigation style is referred to as "CAD Navigation," and is very simple and practical, but FreeCAD also provides alternative navigation styles, that you can choose according to your preferences. +

      + + +

      Navigation

      +

      The object handling is common to all workbenches. The following mouse gestures can be used to control the object position and view according to which Navigation style is selected. +

      There are two ways to change the navigation style: +

      +
      • In the Preferences Editor, Display section, 3D View tab;
      • +
      • By right-clicking in empty space in the 3D view area, then selecting Navigation style in the contextual menu.
      +


      +

      +

      CAD Navigation (default)

      +

      This is the default navigation style and allows the user a simple control of the view, and does not require the use of keyboard keys except to make multi-selections. +

      + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
      Select +Pan +Zoom +Rotate View +Rotate View +

      Alternate Method +

      +
      Hand cursor.png +Pan cursor.png +Zoom cursor.png +Rotate cursor.png +Rotate cursor.png +
      to Select +to Pan +to Zoom in or out +to Rotate view +to Rotate view +
      Press the left mouse button over an object you want to select. Holding down ctrl allows the selection of multiple objects. +Click the middle mouse button and move the object around to pan +Use the mouse wheel to zoom in and out. Clicking the middle mouse button re-centers the view to the location of the cursor. +Click first with the middle mouse button, hold it down, and then click the left mouse button and drag the mouse in the desired direction. The cursor location at the middle mouse button click determines the center of rotation. Rotation works like spinning a ball which rotates around its center. If the buttons are released before you stop the mouse motion, the object continues spinning, if this is enabled. A double click with the middle mouse button sets a new center of rotation. +Click first with the middle mouse button, hold it down, and then click the right mouse button and drag the mouse in the desired direction. This method works just like the previously described Rotate View that uses Middle Mouse Button + Left Mouse Button, except that the middle mouse button may be released after the right mouse button is pressed. Users who use the mouse with their right hand may find this Rotate View method easier than the previous method. +
      +to Pan +to Zoom +to rotate + +
      +For the Pan mode, press the Ctrl key and press the right mouse button to pan (rev 0.17) +For the Zoom mode, press the Ctrl and Shift key and press the right mouse button to Zoom (rev 0.17) +For the Rotate mode, press the Shift key and press the right mouse button to rotate (rev 0.17) + +
      +


      +

      +

      OpenInventor Navigation

      +

      In OpenInventor (formerly Inventor) Navigation, modeled after Open Inventor (not to be confused with Autodesk Inventor), there is no mouse-only selection. In order to select objects, you must hold down the CTRL key. +

      + + + + + + + + + + + + + + + + + + + + +
      Select +Pan +Zoom +Rotate View +
      Hand cursor.png +Pan cursor.png +Zoom cursor.png +Rotate cursor.png +
      ctrl +to Select +to Pan +to Zoom in or out or to Zoom in or out +to Rotate +
      Hold ctrl and press the left mouse button over an object you want to select. +Click the middle mouse button and move the object around. +Use the mouse wheel to zoom in and out, or click and hold the middle mouse button and click the left mouse button. +Click and drag with the left mouse button to rotate +
      +


      +

      +

      Blender Navigation

      +

      The Blender Navigation was modeled after Blender. Previously there was no mouse-only panning, and it required use of the SHIFT key to pan the view. This changed in 2016 with a feature-addition. In order to pan the view, you can now press both left and right mouse buttons and drag in the view. +

      + + + + + + + + + + + + + + + + + + + + +
      Select +Pan +Zoom +Rotate View +
      Hand cursor.png +Pan cursor.png +Zoom cursor.png +Rotate cursor.png +
      to Select +shift+to Pan or Mouse LMB+RMB.svg +to Zoom in or out +to Rotate +
      Press the left mouse button over an object you want to select. +Hold shift and click the middle mouse button and move the object around, or hold down the Left and Right buttons and move. +Use the mouse wheel to zoom in and out. +Click and drag with the middle mouse button. +
      +


      +

      +

      Touchpad Navigation

      +

      In Touchpad Navigation, neither panning, nor zooming, nor rotating the view, are mouse-only (or touchpad-only) operations. +

      + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
      Select +Pan +Zoom +Rotate View +
      Hand cursor.png +Pan cursor.png +Zoom cursor.png +Rotate cursor.png +
      to Select +shift+to Pan +PgUp / PgDn +alt+to Rotate +
      Press the left mouse button over an object you want to select. +Hold shift and move the object around. +Use PgUp and PgDn to zoom in and out. +Hold alt and move the pointer. +
      + + or + or +
      + +shift+ctrl+to Zoom +shift+ctrl+to ROtate +
      + +Hold down both the shift and the ctrl keys, press the left mouse button, and move the pointer. +Hold down both the shift and the ctrl keys and move the pointer. +
      +


      +

      +

      Gesture Navigation (v0.16)

      +

      This navigation style was tailored for usability with touchscreen and pen, but is very usable with mouse too. +

      + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
      Select +Pan +Zoom +Rotate View +Tilt View +
      Hand cursor.png +Pan cursor.png +Zoom cursor.png +Rotate cursor.png +Rotate cursor.png +
      to Select +to Pan +to Zoom in or out +to Rotate view +to Tilt view +
      Press the left mouse button over an object you want to select. Holding down Ctrl allows the selection of multiple objects. +Hold right mouse button and drag to pan the view. +Use the mouse wheel to zoom in and out. The zoom is centered at the cursor location. +Hold Left mouse button and drag to rotate the view. +

      In Sketcher and other edit modes, this behavior is disabled. Hold Alt when pressing the mouse button to enter rotation mode. +

      Rotation is always around camera's focus point. To set camera's focus point, click the new point with middle mouse button; the view will center on that point. Alternatively, aim the cursor at the new point and press H on keyboard. +

      +
      Press both left and right mouse buttons, and drag left or right to tilt the view (adjust horizon). +
      Touch Tap.svg +Touch Tap-Hold-Drag.svg +

      or +

      Touch Two-Finger-Drag.svg +

      +
      Touch Pinch.svg +Touch One-Finger-Drag.svg +Touch Rotate.svg +
      Tap to select. +Drag with two fingers to pan the view. Alternatively, tap and hold, then drag (simulates pan with right mouse button). +Pinch to zoom (i.e., drag two fingers to each other/apart). +Drag with one finger to rotate. Hold Alt additionally when in Sketcher and some other edit modes. +Rotate to tilt the view (i.e., put two fingers on surface and rotate the imaginary line formed by two touch points). +
      +

      Notes on Gesture Navigation style: +

      +
      • on Windows, the actions of two-finger gestures are separated. The action depends on how one starts the gesture. For example, if one starts two-finger pan, the gesture will only pan. Changing the distance between fingers afterwards will not affect the scaling.
      +


      +

      +

      Maya-Gesture Navigation

      +

      In Maya-Gesture Navigation, all view movements are activated pressing ALT and a mouse button, so that it will be needed to have a 3 button mouse in order to correctly use this navigation mode. Alternately it's possible to use gestures as this mode was been developed over the normal Gesture Navigation mode. +

      + + + + + + + + + + + + + + + + + + + + +
      Select +Pan +Zoom +Rotate View +
      Hand cursor.png +Pan cursor.png +Zoom cursor.png +Rotate cursor.png +
      to Select +alt+to Pan +alt+to Zoom in or out or to Zoom in or out +alt+to Rotate +
      Press the left mouse button over an object you want to select. +Hold alt, hold the middle mouse button and drag to pan the view. +Hold alt, hold the right mouse button and drag to zoom in and out or use the mouse wheel to get the same effect. +Hold alt, hold the left mouse button and drag to rotate the object around. +
      +


      +

      +

      Selecting objects

      +

      Simple selection

      +

      Objects can be selected by a click with the left mouse button either by clicking on the object in the 3D-view or by selecting it in the tree view. +

      +

      Preselection

      +

      There is also a Preselection mechanism that highlights objects and displays information before selection by just hovering the mouse over the objects. If you don't like this behaviour or you have a slow machine, you can switch preselection off in the preferences. +


      +

      +

      Manipulating Objects

      +

      FreeCAD offers manipulators that are handles that can be used to modify an object's appearance, shape, or other parameters. +

      The clipping plane is an example of an object with manipulators. A clipping plane can be activated with the View→Clipping Plane menu +

      +

      Hardware support

      +

      FreeCAD also supports some 3D input devices. +

      +

      Mac OS X Issues

      +

      Recently we got reports on the forum from Mac users that those mouse button and key combination do not work as expected. Unfortunately, none of the developers owns a Mac, neither do the other regular contributors. We need your help to determine which mouse buttons and key combination work so we can update this wiki. +

      + +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Mouse_pointer.svg b/localwiki/Mouse_pointer.svg new file mode 100644 index 0000000..29868fb --- /dev/null +++ b/localwiki/Mouse_pointer.svg @@ -0,0 +1,168 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + + + + + + + + diff --git a/localwiki/Mover-ico.png b/localwiki/Mover-ico.png new file mode 100644 index 0000000..8a496af Binary files /dev/null and b/localwiki/Mover-ico.png differ diff --git a/localwiki/Movie.png b/localwiki/Movie.png new file mode 100644 index 0000000..0e9d62e Binary files /dev/null and b/localwiki/Movie.png differ diff --git a/localwiki/Multitransfrom_parameters.png b/localwiki/Multitransfrom_parameters.png new file mode 100644 index 0000000..d4654d7 Binary files /dev/null and b/localwiki/Multitransfrom_parameters.png differ diff --git a/localwiki/NamingExample.jpg b/localwiki/NamingExample.jpg new file mode 100644 index 0000000..e5188f5 Binary files /dev/null and b/localwiki/NamingExample.jpg differ diff --git a/localwiki/Naming_project.html b/localwiki/Naming_project.html new file mode 100644 index 0000000..65a9191 --- /dev/null +++ b/localwiki/Naming_project.html @@ -0,0 +1,107 @@ +Naming project

      Naming project

      + +

      This template is the guideline for a FreeCAD development project. It follows the rules of the Getting Things Done (GTD) process. The projects are collected in the Development roadmap. +

      + + +

      Purpose and principles

      +

      This is an development and design effort to implement a robust topological naming in FreeCAD. +


      +

      +

      Outcome

      +
      1. Interface in (Part::TopoShape) to robustly reference (name) shapes and sub-shapes (faces, edges, vertexes) through a string (sub-element name like "Face1")

        Here we need a interface to provide Part::TopoShape with all information need to do the Naming, e.g. NewShape, additional information from a algos like deleted faces, modeling step (for 2.) and ......

      2. +
      3. Association of modeling steps with the resulting faces/edges.

        In case of a big model the user is lost if he/she has hundreds of fillets or bore hole. So if the faces/edges would know what modeling step it created we could implement a double click on edge/face opens the right feature!

      4. +
      5. An algorithm to keep the naming stable throughout changes in modeling history, like splitting edge/faces and moving vertexes

        NamingExample.jpg

      6. +
      7. (optional) memory optimized data structure to keep only changed faces/edges in each modeling feature. <p> This will become important when the models get bigger. Its not efficient to copy most of the shape just through. Would be much more effective to share the unchanged faces/edges between Feautures and copy only whats changed.
      +

      Brainstorming

      +

      A lot was discussed in the "Robust Reference" Post +of jrheinlaender. +

      +

      Others

      + +

      Literature & Papers

      +
      • J Kripac, "A mechanism for persistently naming topological entities in history-based parametric solid models"
      +
      Describes a method to do the first three points in the List. Would say the is the approach used by Catia and OCC-TNaming. At least the interface looks the same. The paper was nowhere to download. I had to buy it. If someone is interested I can send it via E-Mail.
      + +
      Interesting approach via shell-graphs, tackles the point four on the list by reusing faces/edges not changed.
      + +
      Very good overview and Examples
      +
      • and some more to come....
      +

      Summary of Work To-Date

      +

      As of June 13th, 2016, here is a summary of the work that has been done for this project: +

      +
      • jrheinlaender produced a lot of code in 2012 that relies heavily on the Sketch workbench for resolving "Robust References"
      • +
      • ickby had taken a stab at incorporating some or jrheinlaender's code into modern freecad. This post has a link to his github repo.
      • +
      • In 2016, ezzieyguywuf revived jrheinlaender's thread and subsequently started his own. You can see it here
      • +
      • ezzieyguywuf developed a "light weight" opencascade program for duplicating the Topological Naming issue and for testing potential solutions. See his github repo here
      • +
      • ezzieyguywuf incorporated the opencascade TNaming toolkit into his test code, and showed how this could help resolve some of the Topological Naming issues. See the github repo
      +

      Organizing

      +

      Information about TNaming

      +

      See here for a decent write-up on ezzieyguywuf's github repo. Here are some highlights: +

      +
      • opencascade's TNaming relies upon the TDF_Data data framework.
      • +
      • TDF_Data is a key component of the opencascade OCAF thing, but can be used independent of it
      • +
      • TDF_Data is essentially a tree in which data is added and then read at a later date
      • +
      • Whenever a TNaming_NamedShape attribute is added to a node on the TDF_Data tree, a TNaming_UsedShapes attribute is added to the root of the tree +
        • NOTE: this TNaming_UsedShapes attribute is critical to the utility of the TNaming toolkit. It contains a history of all the TopoDS_Shape used during the 'history' of the part
      • +
      • TNaming_Builder is used to add information to the TDF_Data tree. It adds a TNaming_NamedShape to a given node on the tree, as well as updating the TNaming_UsedShapes database as necessary.
      • +
      • Any time the TopoDS_Shape is changed, it must be logged in the TDF_Data structure +
        • Again, TNaming_Builder is used for this
        • +
        • See here in the opencascade documentation for a table listing what must be stored in the database. NOTE: this table appears to be incomplete. Some additional testing may need to be done
        • +
        • In short, any time the TopoDS_Shape is modified, any modified/generated/deleted features must be logged. For the most part, since we're dealing with solids, this means we must log the modified/generated/deleted Faces on the solid
      • +
      • The TNaming_Selector class is used to "select" a feature that is being tracked on the TDF_Data tree +
        • a "selected" feature is one that opencascade's TNaming algorithm will maintain a constant reference to, regardless of topological changes
      +

      Next actions

      +
      • Defining the scope
      • +
      • Python test cases
      • +
      • Interface in Part::TopoShape (+ python binding)
      +

      Next Steps (as of June 13th, 2016)

      +
      1. Determine if opencascade TNaming toolkit fully resolves Topological Naming issue in FreeCAD +
        • What are all instances where Topological Naming is a problem?
        • +
        • What are complex scenarios where this approach will need to work?
      2. +
      3. Incorporate TNaming code into FreeCAD +
        1. Start with a bare-bones approach, i.e. Make a Cube and a Cylinder, Fuse, Fillet, and then re-size the Cylinder. Fillet should not move
        2. +
        3. Gradually add more functionality
      4. +
      5. Determine if TNaming will be the solution long-term
      6. +
      7. Whether or not TNaming is the long-term solution, figure out a way to 'serialize/deserialize' the data that TNaming uses for persistence across sessions
      +


      +

      +
      +

      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/NavigationBlender.svg b/localwiki/NavigationBlender.svg new file mode 100644 index 0000000..900083f --- /dev/null +++ b/localwiki/NavigationBlender.svg @@ -0,0 +1,27 @@ + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/NavigationBlender_Pan.svg b/localwiki/NavigationBlender_Pan.svg new file mode 100644 index 0000000..7aac193 --- /dev/null +++ b/localwiki/NavigationBlender_Pan.svg @@ -0,0 +1,39 @@ + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/NavigationBlender_PanAlt.svg b/localwiki/NavigationBlender_PanAlt.svg new file mode 100644 index 0000000..b4ee814 --- /dev/null +++ b/localwiki/NavigationBlender_PanAlt.svg @@ -0,0 +1,28 @@ + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/NavigationBlender_Rotate.svg b/localwiki/NavigationBlender_Rotate.svg new file mode 100644 index 0000000..130b13f --- /dev/null +++ b/localwiki/NavigationBlender_Rotate.svg @@ -0,0 +1,26 @@ + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/NavigationBlender_Select.svg b/localwiki/NavigationBlender_Select.svg new file mode 100644 index 0000000..6a32671 --- /dev/null +++ b/localwiki/NavigationBlender_Select.svg @@ -0,0 +1,28 @@ + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/NavigationBlender_Zoom.svg b/localwiki/NavigationBlender_Zoom.svg new file mode 100644 index 0000000..dce1106 --- /dev/null +++ b/localwiki/NavigationBlender_Zoom.svg @@ -0,0 +1,31 @@ + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/NavigationCAD.svg b/localwiki/NavigationCAD.svg new file mode 100644 index 0000000..f0f0a8a --- /dev/null +++ b/localwiki/NavigationCAD.svg @@ -0,0 +1,17 @@ + + + + + + + image/svg+xml + + + + + + + + + + diff --git a/localwiki/NavigationCADAlt.svg b/localwiki/NavigationCADAlt.svg new file mode 100644 index 0000000..ea33a5f --- /dev/null +++ b/localwiki/NavigationCADAlt.svg @@ -0,0 +1,16 @@ + + + + + + + image/svg+xml + + + + + + + + + diff --git a/localwiki/NavigationCAD_Pan.svg b/localwiki/NavigationCAD_Pan.svg new file mode 100644 index 0000000..130b13f --- /dev/null +++ b/localwiki/NavigationCAD_Pan.svg @@ -0,0 +1,26 @@ + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/NavigationCAD_Rotate.svg b/localwiki/NavigationCAD_Rotate.svg new file mode 100644 index 0000000..eafe26f --- /dev/null +++ b/localwiki/NavigationCAD_Rotate.svg @@ -0,0 +1,34 @@ + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/NavigationCAD_RotateAlt.svg b/localwiki/NavigationCAD_RotateAlt.svg new file mode 100644 index 0000000..6b7aa8a --- /dev/null +++ b/localwiki/NavigationCAD_RotateAlt.svg @@ -0,0 +1,34 @@ + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/NavigationCAD_Select.svg b/localwiki/NavigationCAD_Select.svg new file mode 100644 index 0000000..6a32671 --- /dev/null +++ b/localwiki/NavigationCAD_Select.svg @@ -0,0 +1,28 @@ + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/NavigationCAD_Zoom.svg b/localwiki/NavigationCAD_Zoom.svg new file mode 100644 index 0000000..dce1106 --- /dev/null +++ b/localwiki/NavigationCAD_Zoom.svg @@ -0,0 +1,31 @@ + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/NavigationGesture.svg b/localwiki/NavigationGesture.svg new file mode 100644 index 0000000..ebd25c1 --- /dev/null +++ b/localwiki/NavigationGesture.svg @@ -0,0 +1,22 @@ + + + + + + + image/svg+xml + + + + + + + + + + + + + + + diff --git a/localwiki/NavigationGesture_Pan.svg b/localwiki/NavigationGesture_Pan.svg new file mode 100644 index 0000000..36e1e1b --- /dev/null +++ b/localwiki/NavigationGesture_Pan.svg @@ -0,0 +1,28 @@ + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/NavigationGesture_PanTouch.svg b/localwiki/NavigationGesture_PanTouch.svg new file mode 100644 index 0000000..3e35f4b --- /dev/null +++ b/localwiki/NavigationGesture_PanTouch.svg @@ -0,0 +1,46 @@ + + + + + + + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/NavigationGesture_PanTouchAlt.svg b/localwiki/NavigationGesture_PanTouchAlt.svg new file mode 100644 index 0000000..0f8e0db --- /dev/null +++ b/localwiki/NavigationGesture_PanTouchAlt.svg @@ -0,0 +1,59 @@ + + + + + + + + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/NavigationGesture_Rotate.svg b/localwiki/NavigationGesture_Rotate.svg new file mode 100644 index 0000000..e27ed44 --- /dev/null +++ b/localwiki/NavigationGesture_Rotate.svg @@ -0,0 +1,48 @@ + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/NavigationGesture_RotateAlt.svg b/localwiki/NavigationGesture_RotateAlt.svg new file mode 100644 index 0000000..0039510 --- /dev/null +++ b/localwiki/NavigationGesture_RotateAlt.svg @@ -0,0 +1,39 @@ + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/NavigationGesture_RotateTouch.svg b/localwiki/NavigationGesture_RotateTouch.svg new file mode 100644 index 0000000..b5048a4 --- /dev/null +++ b/localwiki/NavigationGesture_RotateTouch.svg @@ -0,0 +1,41 @@ + + + + + + + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/NavigationGesture_Select.svg b/localwiki/NavigationGesture_Select.svg new file mode 100644 index 0000000..6a32671 --- /dev/null +++ b/localwiki/NavigationGesture_Select.svg @@ -0,0 +1,28 @@ + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/NavigationGesture_SelectTouch.svg b/localwiki/NavigationGesture_SelectTouch.svg new file mode 100644 index 0000000..ede1fb9 --- /dev/null +++ b/localwiki/NavigationGesture_SelectTouch.svg @@ -0,0 +1,26 @@ + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/NavigationGesture_Tilt.svg b/localwiki/NavigationGesture_Tilt.svg new file mode 100644 index 0000000..b4ee814 --- /dev/null +++ b/localwiki/NavigationGesture_Tilt.svg @@ -0,0 +1,28 @@ + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/NavigationGesture_TiltTouch.svg b/localwiki/NavigationGesture_TiltTouch.svg new file mode 100644 index 0000000..a4f4eb1 --- /dev/null +++ b/localwiki/NavigationGesture_TiltTouch.svg @@ -0,0 +1,62 @@ + + + + + + + + + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/NavigationGesture_Zoom.svg b/localwiki/NavigationGesture_Zoom.svg new file mode 100644 index 0000000..dce1106 --- /dev/null +++ b/localwiki/NavigationGesture_Zoom.svg @@ -0,0 +1,31 @@ + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/NavigationGesture_ZoomTouch.svg b/localwiki/NavigationGesture_ZoomTouch.svg new file mode 100644 index 0000000..dd8de80 --- /dev/null +++ b/localwiki/NavigationGesture_ZoomTouch.svg @@ -0,0 +1,58 @@ + + + + + + + + + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/NavigationMayaGesture.svg b/localwiki/NavigationMayaGesture.svg new file mode 100644 index 0000000..0f6a83b --- /dev/null +++ b/localwiki/NavigationMayaGesture.svg @@ -0,0 +1,18 @@ + + + + + + + image/svg+xml + + + + + + + + + + + diff --git a/localwiki/NavigationMayaGesture_Pan.svg b/localwiki/NavigationMayaGesture_Pan.svg new file mode 100644 index 0000000..262c62d --- /dev/null +++ b/localwiki/NavigationMayaGesture_Pan.svg @@ -0,0 +1,37 @@ + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/NavigationMayaGesture_PanTouch.svg b/localwiki/NavigationMayaGesture_PanTouch.svg new file mode 100644 index 0000000..3e35f4b --- /dev/null +++ b/localwiki/NavigationMayaGesture_PanTouch.svg @@ -0,0 +1,46 @@ + + + + + + + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/NavigationMayaGesture_PanTouchAlt.svg b/localwiki/NavigationMayaGesture_PanTouchAlt.svg new file mode 100644 index 0000000..0f8e0db --- /dev/null +++ b/localwiki/NavigationMayaGesture_PanTouchAlt.svg @@ -0,0 +1,59 @@ + + + + + + + + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/NavigationMayaGesture_Rotate.svg b/localwiki/NavigationMayaGesture_Rotate.svg new file mode 100644 index 0000000..0039510 --- /dev/null +++ b/localwiki/NavigationMayaGesture_Rotate.svg @@ -0,0 +1,39 @@ + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/NavigationMayaGesture_RotateTouch.svg b/localwiki/NavigationMayaGesture_RotateTouch.svg new file mode 100644 index 0000000..b5048a4 --- /dev/null +++ b/localwiki/NavigationMayaGesture_RotateTouch.svg @@ -0,0 +1,41 @@ + + + + + + + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/NavigationMayaGesture_Select.svg b/localwiki/NavigationMayaGesture_Select.svg new file mode 100644 index 0000000..6a32671 --- /dev/null +++ b/localwiki/NavigationMayaGesture_Select.svg @@ -0,0 +1,28 @@ + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/NavigationMayaGesture_SelectTouch.svg b/localwiki/NavigationMayaGesture_SelectTouch.svg new file mode 100644 index 0000000..ede1fb9 --- /dev/null +++ b/localwiki/NavigationMayaGesture_SelectTouch.svg @@ -0,0 +1,26 @@ + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/NavigationMayaGesture_Tilt.svg b/localwiki/NavigationMayaGesture_Tilt.svg new file mode 100644 index 0000000..cc475f3 --- /dev/null +++ b/localwiki/NavigationMayaGesture_Tilt.svg @@ -0,0 +1,39 @@ + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/NavigationMayaGesture_TiltTouch.svg b/localwiki/NavigationMayaGesture_TiltTouch.svg new file mode 100644 index 0000000..a4f4eb1 --- /dev/null +++ b/localwiki/NavigationMayaGesture_TiltTouch.svg @@ -0,0 +1,62 @@ + + + + + + + + + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/NavigationMayaGesture_Zoom.svg b/localwiki/NavigationMayaGesture_Zoom.svg new file mode 100644 index 0000000..dce1106 --- /dev/null +++ b/localwiki/NavigationMayaGesture_Zoom.svg @@ -0,0 +1,31 @@ + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/NavigationMayaGesture_ZoomAlt.svg b/localwiki/NavigationMayaGesture_ZoomAlt.svg new file mode 100644 index 0000000..a8133a3 --- /dev/null +++ b/localwiki/NavigationMayaGesture_ZoomAlt.svg @@ -0,0 +1,39 @@ + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/NavigationMayaGesture_ZoomTouch.svg b/localwiki/NavigationMayaGesture_ZoomTouch.svg new file mode 100644 index 0000000..dd8de80 --- /dev/null +++ b/localwiki/NavigationMayaGesture_ZoomTouch.svg @@ -0,0 +1,58 @@ + + + + + + + + + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/NavigationOpenCascade.svg b/localwiki/NavigationOpenCascade.svg new file mode 100644 index 0000000..6440544 --- /dev/null +++ b/localwiki/NavigationOpenCascade.svg @@ -0,0 +1,18 @@ + + + + + + + image/svg+xml + + + + + + + + + + + diff --git a/localwiki/NavigationOpenCascade_Pan.svg b/localwiki/NavigationOpenCascade_Pan.svg new file mode 100644 index 0000000..cf40421 --- /dev/null +++ b/localwiki/NavigationOpenCascade_Pan.svg @@ -0,0 +1,36 @@ + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/NavigationOpenCascade_PanAlt.svg b/localwiki/NavigationOpenCascade_PanAlt.svg new file mode 100644 index 0000000..130b13f --- /dev/null +++ b/localwiki/NavigationOpenCascade_PanAlt.svg @@ -0,0 +1,26 @@ + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/NavigationOpenCascade_Rotate.svg b/localwiki/NavigationOpenCascade_Rotate.svg new file mode 100644 index 0000000..4fa8aaa --- /dev/null +++ b/localwiki/NavigationOpenCascade_Rotate.svg @@ -0,0 +1,38 @@ + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/NavigationOpenCascade_Select.svg b/localwiki/NavigationOpenCascade_Select.svg new file mode 100644 index 0000000..6a32671 --- /dev/null +++ b/localwiki/NavigationOpenCascade_Select.svg @@ -0,0 +1,28 @@ + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/NavigationOpenCascade_Zoom.svg b/localwiki/NavigationOpenCascade_Zoom.svg new file mode 100644 index 0000000..dce1106 --- /dev/null +++ b/localwiki/NavigationOpenCascade_Zoom.svg @@ -0,0 +1,31 @@ + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/NavigationOpenCascade_ZoomAlt.svg b/localwiki/NavigationOpenCascade_ZoomAlt.svg new file mode 100644 index 0000000..7e2dd40 --- /dev/null +++ b/localwiki/NavigationOpenCascade_ZoomAlt.svg @@ -0,0 +1,38 @@ + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/NavigationOpenInventor.svg b/localwiki/NavigationOpenInventor.svg new file mode 100644 index 0000000..c0286f0 --- /dev/null +++ b/localwiki/NavigationOpenInventor.svg @@ -0,0 +1,19 @@ + + + + + + + image/svg+xml + + + + + + + + + + + + diff --git a/localwiki/NavigationOpenInventor_Pan.svg b/localwiki/NavigationOpenInventor_Pan.svg new file mode 100644 index 0000000..130b13f --- /dev/null +++ b/localwiki/NavigationOpenInventor_Pan.svg @@ -0,0 +1,26 @@ + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/NavigationOpenInventor_Rotate.svg b/localwiki/NavigationOpenInventor_Rotate.svg new file mode 100644 index 0000000..6a32671 --- /dev/null +++ b/localwiki/NavigationOpenInventor_Rotate.svg @@ -0,0 +1,28 @@ + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/NavigationOpenInventor_Select.svg b/localwiki/NavigationOpenInventor_Select.svg new file mode 100644 index 0000000..2286074 --- /dev/null +++ b/localwiki/NavigationOpenInventor_Select.svg @@ -0,0 +1,39 @@ + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/NavigationOpenInventor_Zoom.svg b/localwiki/NavigationOpenInventor_Zoom.svg new file mode 100644 index 0000000..dce1106 --- /dev/null +++ b/localwiki/NavigationOpenInventor_Zoom.svg @@ -0,0 +1,31 @@ + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/NavigationOpenInventor_ZoomAlt.svg b/localwiki/NavigationOpenInventor_ZoomAlt.svg new file mode 100644 index 0000000..eafe26f --- /dev/null +++ b/localwiki/NavigationOpenInventor_ZoomAlt.svg @@ -0,0 +1,34 @@ + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/NavigationTouchpad.svg b/localwiki/NavigationTouchpad.svg new file mode 100644 index 0000000..568479a --- /dev/null +++ b/localwiki/NavigationTouchpad.svg @@ -0,0 +1,18 @@ + + + + + + + image/svg+xml + + + + + + + + + + + diff --git a/localwiki/NavigationTouchpad_Pan.svg b/localwiki/NavigationTouchpad_Pan.svg new file mode 100644 index 0000000..95a0526 --- /dev/null +++ b/localwiki/NavigationTouchpad_Pan.svg @@ -0,0 +1,61 @@ + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/NavigationTouchpad_PanTouch.svg b/localwiki/NavigationTouchpad_PanTouch.svg new file mode 100644 index 0000000..9c3518e --- /dev/null +++ b/localwiki/NavigationTouchpad_PanTouch.svg @@ -0,0 +1,61 @@ + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/NavigationTouchpad_Rotate.svg b/localwiki/NavigationTouchpad_Rotate.svg new file mode 100644 index 0000000..d631d13 --- /dev/null +++ b/localwiki/NavigationTouchpad_Rotate.svg @@ -0,0 +1,57 @@ + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/NavigationTouchpad_RotateAlt.svg b/localwiki/NavigationTouchpad_RotateAlt.svg new file mode 100644 index 0000000..d2e5083 --- /dev/null +++ b/localwiki/NavigationTouchpad_RotateAlt.svg @@ -0,0 +1,41 @@ + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/NavigationTouchpad_RotateTouch.svg b/localwiki/NavigationTouchpad_RotateTouch.svg new file mode 100644 index 0000000..5ff3b44 --- /dev/null +++ b/localwiki/NavigationTouchpad_RotateTouch.svg @@ -0,0 +1,57 @@ + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/NavigationTouchpad_RotateTouchAlt.svg b/localwiki/NavigationTouchpad_RotateTouchAlt.svg new file mode 100644 index 0000000..2a5026d --- /dev/null +++ b/localwiki/NavigationTouchpad_RotateTouchAlt.svg @@ -0,0 +1,59 @@ + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/NavigationTouchpad_Select.svg b/localwiki/NavigationTouchpad_Select.svg new file mode 100644 index 0000000..6a32671 --- /dev/null +++ b/localwiki/NavigationTouchpad_Select.svg @@ -0,0 +1,28 @@ + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/NavigationTouchpad_SelectTouch.svg b/localwiki/NavigationTouchpad_SelectTouch.svg new file mode 100644 index 0000000..be0b444 --- /dev/null +++ b/localwiki/NavigationTouchpad_SelectTouch.svg @@ -0,0 +1,25 @@ + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + diff --git a/localwiki/NavigationTouchpad_Zoom.svg b/localwiki/NavigationTouchpad_Zoom.svg new file mode 100644 index 0000000..dce1106 --- /dev/null +++ b/localwiki/NavigationTouchpad_Zoom.svg @@ -0,0 +1,31 @@ + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/NavigationTouchpad_ZoomAlt.svg b/localwiki/NavigationTouchpad_ZoomAlt.svg new file mode 100644 index 0000000..b87910a --- /dev/null +++ b/localwiki/NavigationTouchpad_ZoomAlt.svg @@ -0,0 +1,51 @@ + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/NavigationTouchpad_ZoomTouch.svg b/localwiki/NavigationTouchpad_ZoomTouch.svg new file mode 100644 index 0000000..82674d1 --- /dev/null +++ b/localwiki/NavigationTouchpad_ZoomTouch.svg @@ -0,0 +1,49 @@ + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/NavigationUndefined.svg b/localwiki/NavigationUndefined.svg new file mode 100644 index 0000000..6f8f3bb --- /dev/null +++ b/localwiki/NavigationUndefined.svg @@ -0,0 +1,17 @@ + + + + + + + image/svg+xml + + + + + + + + + + diff --git a/localwiki/New_GW_GUI.png b/localwiki/New_GW_GUI.png new file mode 100644 index 0000000..686fec1 Binary files /dev/null and b/localwiki/New_GW_GUI.png differ diff --git a/localwiki/Object_API.html b/localwiki/Object_API.html new file mode 100644 index 0000000..37bf507 --- /dev/null +++ b/localwiki/Object_API.html @@ -0,0 +1,173 @@ +Object API

      Object API

      + +

      Being parametric, document objects in FreeCAD can have a lot of additional properties, but these are the basic ones, present in every FreeCAD Document Object. Objects can be retrieved simply by their name. Example: +

      +
      myObj = FreeCAD.ActiveDocument.myObjectName
      +print myObj.PropertiesList 
      +


      +

      +
      +
      Property.png Content
      +
      +

      Returns: An XML representation of the properties of an object. +

      +
      +
      +


      +

      +
      +
      Property.png Label
      +
      +

      Returns: Gets/sets the objects label. The string can be unicode. +

      +
      +
      +


      +

      +
      +
      Property.png Name
      +
      +

      Returns: The unique name of an object. +

      +
      +
      +


      +

      +
      +
      Property.png Placement
      +
      +

      Returns: Gets/sets the Placement of an object. A placement defines an orientation (rotation) and a position (base) in 3D space. It is used when no scaling or other distortion is needed. +

      +
      +
      +


      +

      +
      +
      Property.png PropertiesList
      +
      +

      Returns: A list of the properties of an object +

      +
      +
      +


      +

      +
      +
      Property.png State
      +
      +

      Returns: The FreeCAD state of an object (ie. if it needs to be recomputed) +

      +
      +
      +


      +

      +
      +
      Property.png Type
      +
      +

      Returns: A string describing the type of an object +

      +
      +
      +


      +

      +
      +
      Property.png ViewObject
      +
      +

      Returns: The associated View Provider (FreeCADGUI object) of an object +

      +
      +
      +


      +

      +
      +
      Method.png getAllDerivedFrom ( )
      +
      +

      Description: +

      Returns: All descendants of this object +

      +
      +
      +


      +

      +
      +
      Method.png getDocumentationOfProperty ( )
      +
      +

      Description: +

      Returns: The documentation string of the property of this class. +

      +
      +
      +


      +

      +
      +
      Method.png getGroupOfProperty ( )
      +
      +

      Description: +

      Returns: The name of the group which the property belongs to in this class. The properties are sorted in different named groups for convenience. +

      +
      +
      +


      +

      +
      +
      Method.png getPropertyByName ( )
      +
      +

      Description: +

      Returns: The value of a named property. +

      +
      +
      +


      +

      +
      +
      Method.png getTypeOfProperty ( )
      +
      +

      Description: +

      Returns: The type of a named property. This can be (Hidden,ReadOnly,Output) or any combination. +

      +
      +
      +


      +

      +
      +
      Method.png isDerivedFrom ( )
      +
      +

      Description: +

      Returns: True if given type is a father +

      +
      +
      +


      +

      +
      +
      Method.png purgeTouched ( )
      +
      +

      Description: Marks the object as unchanged +

      Returns: +

      +
      +
      +


      +

      +
      +
      Method.png touch ( )
      +
      +

      Description: Marks the object as changed (touched) +

      Returns: +

      +
      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Offsite_tutorials.html b/localwiki/Offsite_tutorials.html new file mode 100644 index 0000000..e1476c0 --- /dev/null +++ b/localwiki/Offsite_tutorials.html @@ -0,0 +1,31 @@ +Offsite tutorials

      Offsite tutorials

      + +

      This page lists FreeCAD tutorials found on other sites on the web. +

      + +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Online_Help_Startpage.html b/localwiki/Online_Help_Startpage.html new file mode 100644 index 0000000..e8b856a --- /dev/null +++ b/localwiki/Online_Help_Startpage.html @@ -0,0 +1,29 @@ +Online Help Startpage

      Online Help Startpage

      + +
      150
      +

      Welcome to the FreeCAD on-line help

      +

      This document has been automatically created from the contents of the official FreeCAD wiki documentation, which can be read online at http://www.freecadweb.org/wiki/index.php?title=Main_Page. Since the wiki is actively maintained and continuously developed by the FreeCAD community of developers and users, you may find that the online version contains more or newer information than this document. There you will also find in-progress translations of this documentation in several languages. But nevertheless, we hope you will find here all information you need. In case you have questions you can't find answers for in this document, have a look on the FreeCAD forum, where you can maybe find your question answered, or someone able to help you. +

      +

      How to use

      +

      This document is divided into several sections: introduction, usage, scripting and development, the last three address specifically the three broad categories of users of FreeCAD: end-users, who simply want to use the program, power-users, who are interested by the scripting capabilities of FreeCAD and would like to customize some of its aspects, and developers, who consider FreeCAD as a base for developing their own applications. If you are completely new to FreeCAD, we suggest you to start simply from the introduction. +

      +

      Contribute

      +

      As you may have experienced sometimes, programmers are really bad help writers! For them it is all completely clear because they made it that way. Therefore it's vital that experienced users help us to write and revise the documentation. Yes, we mean you! How, you might ask? Just go to the Wiki at http://www.freecadweb.org/wiki/index.php in the User section. You will need a FreeCAD wiki account to log in. Ask on the forum or on the irc channel for wiki write permission (the wiki is write-protected to avoid spamming) and we will create an account for you. Currently the wiki account is separate to the forum account but we will create the wiki account with the same name as your forum account. Then you can start editing! Also, check out the page at http://www.freecadweb.org/wiki/index.php?title=Help_FreeCAD for more ways you can help FreeCAD. +

      + +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Online_Help_Toc.html b/localwiki/Online_Help_Toc.html new file mode 100644 index 0000000..e7fac6d --- /dev/null +++ b/localwiki/Online_Help_Toc.html @@ -0,0 +1,106 @@ +Online Help Toc

      Online Help Toc

      + +

      This is the table of contents used for automatic building of the online help system in FreeCAD. A printable version of this manual is also available on the releases page +

      + + + + + + + + +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/OpenGL_on_MacOS.html b/localwiki/OpenGL_on_MacOS.html new file mode 100644 index 0000000..01504d0 --- /dev/null +++ b/localwiki/OpenGL_on_MacOS.html @@ -0,0 +1,20 @@ +OpenGL on MacOS

      OpenGL on MacOS

      + +

      Known Issue: Rendering problems on MacOS

      +

      Qt 4, the GUI software library used by FreeCAD, has a known limitation that can result in some odd-looking behaviour on modern versions of MacOS when windows within FreeCAD overlap. +

      This issue has been resolved by moving FreeCAD's Qt OpenGL usage to new classes introduced with Qt 5, as of the FreeCAD 0.17 development version in late March 2017. +

      See issue 1401. +

      + + +
      + +
      +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/OpenSCADWorkbench.svg b/localwiki/OpenSCADWorkbench.svg new file mode 100644 index 0000000..800057f --- /dev/null +++ b/localwiki/OpenSCADWorkbench.svg @@ -0,0 +1,159 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [triplus] + + + OpenSCADWorkbench + 2016-02-26 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/OpenSCAD/Resources/icons/OpenSCADWorkbench.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/OpenSCAD_AddOpenSCADElement.html b/localwiki/OpenSCAD_AddOpenSCADElement.html new file mode 100644 index 0000000..a66d3b5 --- /dev/null +++ b/localwiki/OpenSCAD_AddOpenSCADElement.html @@ -0,0 +1,87 @@ +OpenSCAD AddOpenSCADElement

      OpenSCAD AddOpenSCADElement

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      OpenSCAD AddOpenSCADElement.png OpenSCAD AddOpenSCADElement

      +
      Menu location +
      OpenSCAD -> Add OpenSCAD Element +
      Workbenches +
      OpenSCAD +
      Default shortcut +
      None +
      See also +
      None +

      + +
      +


      +

      +

      Description

      +

      Add an OpenSCAD element by entering OpenSCAD code into the task panel and executing the OpenSCAD binary (requires OpenSCAD) +

      When 'as mesh' is selected, OpenSCAD renders a Mesh. +

      Each time Add is pressed the OpenSCAD code is executed and elements are imported. +

      If OpenSCAD returns successfully, its messages are displayed as warnings in the report window. This will be the case if the path to imported, included and used files is broken. +In case of undesired results it is highly recommend to have a look at the report windows, as there might be a lot of other output, created by the importer. +If OpenSCAD fails, its messages will be loged as errors. +Libraries should be accessible as usual, whereas example can be reached as stated below +

      +
      include <../examples/example001.scad>; 
      +

      would include the first examples also known as the OpenSCAD icon +

      +

      Initial set up from within FreeCAD

      +
      • OpenSCAD needs to be installed on your computer before FreeCAD will have this functionality +
        • install OpenSCAD in the appropriate manner for your operating system. See the OpenSCAD web site for more information
      • +
      • FreeCAD needs to be told where to find the OpenSCAD executable +
        • Switch to the OpenSCAD Workbench Menu -> View Workbench -> OpenSCAD
        • +
        • Open the preferences dialog Menu -> Edit -> Preferences
        • +
        • Click on "OpenSCAD" on the left plane
        • +
        • Click on the button labled "..." in General Settings -> General OpenSCAD Settings -> OpenSCAD executable to browser the directory or enter the path (e.g. Ubuntu based Linux distributions /usr/bin/openscad) directly into the line input right to the button
        • +
        • close and restart FreeCAD, a new OpenSCAD icon will appear on the tool bar, and in the OpenSCAD menu, in the FreeCAD OpenSCAD workbench
      • +
      • It is also possible to add another optional Parameter which controls the maximum sides of a polygon before it is considered a circle (fn).
      +

      Starting from FreeCAD Version 0.14, FreeCAD will search for the OpenSCAD executable if the setting mentioned above is empty. +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/OpenSCAD_AddOpenSCADElement.svg b/localwiki/OpenSCAD_AddOpenSCADElement.svg new file mode 100644 index 0000000..fdbae5d --- /dev/null +++ b/localwiki/OpenSCAD_AddOpenSCADElement.svg @@ -0,0 +1,159 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [Sebastian Hoogen] + + + OpenSCAD_AddOpenSCADElement + 2012-07-10 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/OpenSCAD/Resources/icons/OpenSCAD_AddOpenSCADElement.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/OpenSCAD_CSG.html b/localwiki/OpenSCAD_CSG.html new file mode 100644 index 0000000..2c4fd19 --- /dev/null +++ b/localwiki/OpenSCAD_CSG.html @@ -0,0 +1,55 @@ +OpenSCAD CSG

      OpenSCAD CSG

      + +
      + +

      Import

      +

      Supported Elements

      +
      • primitives: cube, sphere, cylinder, square, circle, polygon, polyhedron
      • +
      • boolean: union, difference, intersection
      • +
      • linearextrude, rotateextrude
      • +
      • import (dxf, stl, off) (without scaling or transformation of origin)
      • +
      • multmatrix
      • +
      • color
      +

      Unsupported Elements

      +
      • projection
      • +
      • surface
      • +
      • render (ignored)
      • +
      • cgal operations: minkowski, glide, path, subdiv, hull
      +

      Export

      +

      Supported Elements

      +
      • primitives: Box, Cylinder, Cone, Torus
      • +
      • boolean: Cut, Fuse, Common
      +

      Fallback

      +

      Every object derived from Part::Feature which is not (yet) supported will get meshed and exported as a polyhedron element +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/OpenSCAD_ColorCodeShape.html b/localwiki/OpenSCAD_ColorCodeShape.html new file mode 100644 index 0000000..326cc2d --- /dev/null +++ b/localwiki/OpenSCAD_ColorCodeShape.html @@ -0,0 +1,73 @@ +OpenSCAD ColorCodeShape

      OpenSCAD ColorCodeShape

      + +
      +

      This documentation is not finished. Please help and contribute documentation. +

      See Draft ShapeString for good documented Command. Gui Command gives an overview over commands. And see List of Commands for other commands. +

      Go to Help FreeCAD to contribute. +

      +
      +


      +

      + + + + + + + + + + + + + + + + + + + + +
      +

      OpenSCAD ColorCodeShape.png OpenSCAD ColorCodeShape‏‎

      +
      Menu location +
      OpenSCAD → ColorCodeShape‏‎ +
      Workbenches +
      OpenSCAD +
      Default shortcut +
      none +
      See also +
      --- +

      + +
      +


      +

      +

      Description

      +

      Use

      +

      Limitations

      +

      Notes

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/OpenSCAD_ColorCodeShape.svg b/localwiki/OpenSCAD_ColorCodeShape.svg new file mode 100644 index 0000000..682e773 --- /dev/null +++ b/localwiki/OpenSCAD_ColorCodeShape.svg @@ -0,0 +1,94 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [Sebastian Hoogen] + + + OpenSCAD_ColorCodeShape + 2012-05-03 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/OpenSCAD/Resources/icons/OpenSCAD_ColorCodeShape.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/OpenSCAD_Edgestofaces.html b/localwiki/OpenSCAD_Edgestofaces.html new file mode 100644 index 0000000..8a92af7 --- /dev/null +++ b/localwiki/OpenSCAD_Edgestofaces.html @@ -0,0 +1,74 @@ +OpenSCAD Edgestofaces

      OpenSCAD Edgestofaces

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      OpenSCAD Edgestofaces.png OpenSCAD Edgestofaces

      +
      Menu location +
      OpenSCAD → EdgesToFaces‏‎ +
      Workbenches +
      OpenSCAD +
      Default shortcut +
      none +
      See also +
      --- +

      + +
      +


      +

      +

      Description

      +

      Convert edges to faces. Useful to prepare imported DXF geometry for extrusion. +

      +

      Use

      +
      1. Select edges to be converted in the 3D-View.
      2. +
      3. Choose OpenSCADOpenSCAD Edgestofaces.png Convert Edges to Faces from the top menu.
      +

      Limitations

      +


      +

      +

      Notes

      +

      See also Draft Upgrade for an alternative way to get faces. +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/OpenSCAD_ExpandPlacements.html b/localwiki/OpenSCAD_ExpandPlacements.html new file mode 100644 index 0000000..f6a9fd3 --- /dev/null +++ b/localwiki/OpenSCAD_ExpandPlacements.html @@ -0,0 +1,81 @@ +OpenSCAD ExpandPlacements

      OpenSCAD ExpandPlacements

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      OpenSCAD ExpandPlacements.png OpenSCAD ExpandPlacements

      +
      Menu location +
      OpenSCAD → ExpandPlacements‏‎ +
      Workbenches +
      OpenSCAD +
      Default shortcut +
      none +
      See also +
      --- +

      + +
      +


      +

      +

      Description

      +

      Expand all placements downwards the Feature-Tree. +

      +

      Use

      +
      1. Select object in the tree view.
      2. +
      3. Choose OpenSCADOpenSCAD ExpandPlacements.png Expand Placements from the top menu.
      +

      Limitations

      +


      +

      +

      Notes

      +

      This command "resets" the placement-values of an object, making the current position as 0/0/0. +
      +Works with: +

      +
      • boolean objects
      • +
      • extruded objects (derived from the part-workbench)
      • +
      • revolved objects (derived from the part-workbench)
      +


      +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/OpenSCAD_ExplodeGroup.html b/localwiki/OpenSCAD_ExplodeGroup.html new file mode 100644 index 0000000..65d6189 --- /dev/null +++ b/localwiki/OpenSCAD_ExplodeGroup.html @@ -0,0 +1,84 @@ +OpenSCAD ExplodeGroup

      OpenSCAD ExplodeGroup

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      OpenSCAD ExplodeGroup.png OpenSCAD ExplodeGroup

      +
      Menu location +
      OpenSCAD → Explode Group‏‎ +
      Workbenches +
      OpenSCAD +
      Default shortcut +
      none +
      See also +
      --- +

      + +
      +


      +

      +

      Description

      +

      This feature explodes a fusion or a compound back to single parts applying random colours to these parts. +

      +

      Use

      +
      1. Select fusion/compound to be exploded
      2. +
      3. Click on OpenSCAD ExplodeGroup.png or choose OpenSCADOpenSCAD ExplodeGroup.png Explode Group from the top menu.
      +

      Limitations

      +

      The feature works only on fusions/compounds consisting of +

      +
      • part primitives from part workbench
      • +
      • extruded parts from part workbench
      • +
      • revolved parts from part workbench
      +


      +
      +The feature will NOT work on +

      +
      • pads/revolution-parts from part design workbench
      • +
      • arrays from draft workbench
      +

      Notes

      +

      For dissolving arrays from draft workbench use the Draft Downgrade - tool from draft workbench. +
      +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/OpenSCAD_Explode_Group.svg b/localwiki/OpenSCAD_Explode_Group.svg new file mode 100644 index 0000000..17c565c --- /dev/null +++ b/localwiki/OpenSCAD_Explode_Group.svg @@ -0,0 +1,192 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [Sebastian Hoogen] + + + OpenSCAD_Explode_Group + 2014-02-21 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/OpenSCAD/Resources/icons/OpenSCAD_Explode_Group.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/OpenSCAD_Hull.html b/localwiki/OpenSCAD_Hull.html new file mode 100644 index 0000000..c22e902 --- /dev/null +++ b/localwiki/OpenSCAD_Hull.html @@ -0,0 +1,80 @@ +OpenSCAD Hull

      OpenSCAD Hull

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      OpenSCAD Hull.png OpenSCAD Hull

      +
      Menu location +
      OpenSCAD → Hull‏‎ +
      Workbenches +
      OpenSCAD +
      Default shortcut +
      none +
      See also +
      --- +

      + +
      +


      +

      +

      Description

      +

      Applies a hull to selected shapes. +
      +
      +Example of a hull operation performed on two cylinders +
      +Example of a hull operation performed on two cylinders +

      +

      Use

      +
      1. Select shapes in Tree-View or in 3D-View
      2. +
      3. Click on OpenSCAD Hull.png or choose OpenSCADOpenSCAD Hull.png Hull from the top menu.
      +

      Limitations

      +

      Feature needs OpenSCAD installed and configured in Edit Preferences +
      +

      +

      Notes

      +


      +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/OpenSCAD_Hull.svg b/localwiki/OpenSCAD_Hull.svg new file mode 100644 index 0000000..3a538d3 --- /dev/null +++ b/localwiki/OpenSCAD_Hull.svg @@ -0,0 +1,180 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [Keith Sloan] + + + OpenSCAD_Hull + 2013-10-30 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/OpenSCAD/Resources/icons/OpenSCAD_Hull.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/OpenSCAD_IncreaseTolerance.html b/localwiki/OpenSCAD_IncreaseTolerance.html new file mode 100644 index 0000000..24d05d8 --- /dev/null +++ b/localwiki/OpenSCAD_IncreaseTolerance.html @@ -0,0 +1,72 @@ +OpenSCAD IncreaseTolerance

      OpenSCAD IncreaseTolerance

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      OpenSCAD IncreaseTolerance.png OpenSCAD IncreaseTolerance‏‎

      +
      Menu location +
      OpenSCAD → Increase Tolerance Feature‏‎ +
      Workbenches +
      OpenSCAD +
      Default shortcut +
      none +
      See also +
      --- +

      + +
      +


      +

      +

      Description

      +

      Increases tolerance of edges/faces/vertex of selected object(s). +

      +

      Use

      +
      1. Select object in the tree view
      2. +
      3. Choose OpenSCADOpenSCAD IncreaseTolerance.png Increase Tolerance Feature from the top menu.
      4. +
      5. Select Tolerance-Object in feature tree in the tree view.
      6. +
      7. Select Data-Tab in Property View or Combo View.
      8. +
      9. Change values for Edges/Faces/Vertex to your liking.
      +

      Limitations

      +

      Notes

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/OpenSCAD_IncreaseToleranceFeature.svg b/localwiki/OpenSCAD_IncreaseToleranceFeature.svg new file mode 100644 index 0000000..34cb26b --- /dev/null +++ b/localwiki/OpenSCAD_IncreaseToleranceFeature.svg @@ -0,0 +1,76 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [Sebastian Hoogen] + + + OpenSCAD_IncreaseToleranceFeature + 2014-04-13 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/OpenSCAD/Resources/icons/OpenSCAD_IncreaseTolerance + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + diff --git a/localwiki/OpenSCAD_MeshBoolean.html b/localwiki/OpenSCAD_MeshBoolean.html new file mode 100644 index 0000000..0540b62 --- /dev/null +++ b/localwiki/OpenSCAD_MeshBoolean.html @@ -0,0 +1,75 @@ +OpenSCAD MeshBoolean

      OpenSCAD MeshBoolean

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      OpenSCAD MeshBoolean.png OpenSCAD MeshBoolean

      +
      Menu location +
      OpenSCAD → Mesh Boolean...‏‎ +
      Workbenches +
      OpenSCAD +
      Default shortcut +
      none +
      See also +
      --- +

      + +
      +


      +

      +

      Description

      +

      Creates new mesh object by boolean operation from shapes. +

      +

      Use

      +
      1. Select shapes in Tree-View.
      2. +
      3. Click on OpenSCAD MeshBoolean.png or choose OpenSCADOpenSCAD MeshBoolean.png MeshBoolean ... from the top menu.
      4. +
      5. Select bool operation to be performed on the shapes.
      6. +
      7. Select Perform
      +
      • New mesh object will be created
      +

      Limitations

      +

      Feature needs OpenSCAD installed and configured in Edit Preferences +
      +

      +

      Notes

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/OpenSCAD_MeshBooleans.svg b/localwiki/OpenSCAD_MeshBooleans.svg new file mode 100644 index 0000000..726c69b --- /dev/null +++ b/localwiki/OpenSCAD_MeshBooleans.svg @@ -0,0 +1,134 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [Keith Sloan] + + + OpenSCAD_MeshBooleans + 2013-10-30 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/OpenSCAD/Resources/icons/OpenSCAD_MeshBooleans.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/OpenSCAD_Minkowski.html b/localwiki/OpenSCAD_Minkowski.html new file mode 100644 index 0000000..61f5d16 --- /dev/null +++ b/localwiki/OpenSCAD_Minkowski.html @@ -0,0 +1,92 @@ +OpenSCAD Minkowski

      OpenSCAD Minkowski

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      OpenSCAD Minkowski.png OpenSCAD Minkowski

      +
      Menu location +
      OpenSCAD → Minkowski‏‎ +
      Workbenches +
      OpenSCAD +
      Default shortcut +
      none +
      See also +
      --- +

      + +
      +


      +

      +

      Description

      +

      Applies a minkowski sum to selected shapes. +
      +
      +Mathematical Definition: +
      +Add each element of subset A to each element of subset B to get minkowski sum. +
      +Geometrical Definition: +
      +Sweep element A along all boundaries of element B. Resulting space which is occupied by both elements +is minkowski sum. +
      +
      +An example of a minkowski sum +
      +Example of minkowski sum applied to cylinder and cube. +
      +Note that the height of minkowski sum is height of cylinder plus height of cube. +

      +

      Use

      +
      1. Select shapes in Tree-View or in 3D-View
      2. +
      3. Click on OpenSCAD Minkowski.png or choose OpenSCADOpenSCAD Minkowski.png Minkowski from the top menu.
      +

      Limitations

      +

      Feature needs OpenSCAD installed and configured in Edit Preferences +
      +

      +

      Notes

      +


      +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/OpenSCAD_Minkowski.svg b/localwiki/OpenSCAD_Minkowski.svg new file mode 100644 index 0000000..6ff69c5 --- /dev/null +++ b/localwiki/OpenSCAD_Minkowski.svg @@ -0,0 +1,181 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [Keith Sloan] + + + OpenSCAD_Minkowski + 2013-10-30 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/OpenSCAD/Resources/icons/OpenSCAD_Minkowski.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/OpenSCAD_Module.html b/localwiki/OpenSCAD_Module.html new file mode 100644 index 0000000..0cee409 --- /dev/null +++ b/localwiki/OpenSCAD_Module.html @@ -0,0 +1,80 @@ +OpenSCAD Module

      OpenSCAD Module

      + +

      The OpenSCAD module is in an early stage of development. +

      The OpenSCAD module offers interoperability with the open source software OpenSCAD. +


      +An example of imported OpenSCAD geometry +

      It contains an importer which allows you to open the .csg output from OpenSCAD in FreeCAD. +

      The exporter outputs a CSG based (sub-)tree to .csg. Geometry which is not based on CSG operations and is exported as a mesh. +The OpenSCAD module contains a toolbox with functions to modify the feature tree and repair models. +

      + + +

      OpenSCAD language and file format

      +

      The OpenSCAD language allows the use of variables and loops. It allows you to specify submodules to reuse geometry and code. This high degree of flexibility makes parsing very complex. Currently the OpenSCAD module in FreeCAD can not handle the OpenSCAD language natively. +Instead, if OpenSCAD is installed, it can be used to convert the input to an output format named 'CSG'. It is a subset of the OpenSCAD Language and can be used as the input to OpenSCAD for further processing. +During conversion all parametric behavior is lost - all variable names are discarded, loops expanded and mathematical expressions evaluated. +

      +

      GUI Commands

      +
      • OpenSCAD ColorCodeShape.png Color Code Shape: Change the color of selected or all shapes based on their validity.
      + +
      • OpenSCAD RemoveSubtree.png Remove Subtree: Removes the selected objects and all children that are not referenced from other objects.
      + + + + + + +
      • OpenSCAD MeshBoolean.png Mesh Boolean: Creates new mesh object by boolean operation from shapes.
      +
      • OpenSCAD Hull.png Hull: Apllies a hull to selected shapes.
      +
      • OpenSCAD Minkowski.png Minkowski: Applies a minkowski sum to selected shapes.
      +

      Preferences

      + +


      +


      +


      +

      +

      Limitations

      +

      OpenSCAD creates constructive solid geometry as well as importing mesh files and extruding 2d geometry (from dxf files). FreeCAD allows you to create CSG with primitives as well. The FreeCAD geometry kernel (OCCT) works using a boundary representation. +Therefore conversion from CSG to BREP should, in theory, be possible whereas conversion from BREP to CSG is, in general, not. +

      OpenSCAD works internally on meshes. Some operations which are useful on meshes are not meaningful on a BREP model and can not be fully supported. Among these are convex hull, minkowski sum, glide and subdiv. Currently we run the OpenSCAD binary in order to perform hull and minkwoski operations and import the result. This means that the involved geometry will be triangulated. In OpenSCAD non-uniform scaling is often used, which does not impose any problems when using meshes. In our geometry kernel geometric primitives (lines, circular sections, etc) are converted to BSpline prior to performing such deformations. Those BSplines are known to cause trouble in later boolean operations. An automatic solution is not available at the moment. Please feel free to post to the forum if you encounter such problems. Often such problems can be solved be remodeling small parts. A deformation of a cylinder can substituted by an extrusion of an ellipses. +

      +

      Hints

      +

      When importing DXF set the Draft precision to a sensible amount as this will affect the detection of connected edges. +

      If FreeCAD crashes when importing CSG, it is strongly recommended that you enable 'automatically check model after boolean operation' in Menu → Edit → Preferences → Part Design → Model setting +

      +

      Tutorials

      + +

      Links

      + + +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/OpenSCAD_Preferences.html b/localwiki/OpenSCAD_Preferences.html new file mode 100644 index 0000000..58f6f20 --- /dev/null +++ b/localwiki/OpenSCAD_Preferences.html @@ -0,0 +1,23 @@ +OpenSCAD Preferences

      OpenSCAD Preferences

      + +

      The preferences screen of the OpenScad are found in the Preferences window (Menu Edit → Preferences → OpenSCAD). +

      +

      General settings

      +

      Preference OpenSCAD Tab 01.png +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/OpenSCAD_RefineShapeFeature.html b/localwiki/OpenSCAD_RefineShapeFeature.html new file mode 100644 index 0000000..b53e8d0 --- /dev/null +++ b/localwiki/OpenSCAD_RefineShapeFeature.html @@ -0,0 +1,82 @@ +OpenSCAD RefineShapeFeature

      OpenSCAD RefineShapeFeature

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      OpenSCAD RefineShapeFeature.png OpenSCAD RefineShapeFeature

      +
      Menu location +
      OpenSCAD → Refine Shape Feature +
      Workbenches +
      OpenSCAD +
      Default shortcut +
      None +
      See also +
      --- +

      + +
      +


      +


      +

      +

      Description

      +

      Cleans unnecessary lines. After a Boolean operation some lines defining the previous form remain visible, this tool creates a copy of the totally cleaned. +

      PartRefineShape it.png +

      +

      Use

      +
      1. Select the shape to be cleaned.
      2. +
      3. Click the OpenSCAD → Refine shape menu.
      +
      • A parent-object is created and totally cleaned, the original object is rendered hiden.
      +

      Limitations

      +
      • The refinement algorithm only works on shells. Therefore it iterates over the shells of the input shape and then for each shell it creates a new shell with joined faces wherever possible. This means if your input shape is only a face, wire, edge or vertex then the algorithm does nothing.
      • +
      • As opposed to Part refine shape in the Part workbench, this feature WILL update when the underlying shapes are changed.
      +


      +

      +

      Notes

      +
      • the function does not modify the existing shape, but returns a new shape
      • +
      • the function is normally used as last step in the modelling history
      • +
      • the function can help to get difficult fillets to work
      • +
      • the function is intended to stop 3D printers from printing unwanted edges
      +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/OpenSCAD_RefineShapeFeature.svg b/localwiki/OpenSCAD_RefineShapeFeature.svg new file mode 100644 index 0000000..6ea9e04 --- /dev/null +++ b/localwiki/OpenSCAD_RefineShapeFeature.svg @@ -0,0 +1,144 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [Sebastian Hoogen] + + + OpenSCAD_RefineShapeFeature + 2012-05-03 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/OpenSCAD/Resources/icons/OpenSCAD_RefineShape + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/OpenSCAD_RemoveSubtree.html b/localwiki/OpenSCAD_RemoveSubtree.html new file mode 100644 index 0000000..32aa1ee --- /dev/null +++ b/localwiki/OpenSCAD_RemoveSubtree.html @@ -0,0 +1,74 @@ +OpenSCAD RemoveSubtree

      OpenSCAD RemoveSubtree

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      OpenSCAD RemoveSubtree.png OpenSCAD RemoveSubtree‏‎

      +
      Menu location +
      OpenSCAD → RemoveSubtree +
      Workbenches +
      OpenSCAD +
      Default shortcut +
      none +
      See also +
      --- +

      + +
      +


      +

      +

      Description

      +

      Removes the selected objects and all children that are not referenced from other objects. +

      +

      Use

      +
      1. Select object(s) to remove.
      2. +
      3. Click on OpenSCAD RemoveSubtree.png or choose OpenSCADOpenSCAD RemoveSubtree.png Remove Objects and their children from the top menu.
      +

      Limitations

      +


      +

      +

      Notes

      +


      +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/OpenSCAD_RemoveSubtree.svg b/localwiki/OpenSCAD_RemoveSubtree.svg new file mode 100644 index 0000000..5589571 --- /dev/null +++ b/localwiki/OpenSCAD_RemoveSubtree.svg @@ -0,0 +1,163 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [Sebastian Hoogen] + + + OpenSCAD_RemoveSubtree + 2012-05-03 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/OpenSCAD/Resources/icons/OpenSCAD_RemoveSubtree.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/OpenSCAD_ReplaceObject.html b/localwiki/OpenSCAD_ReplaceObject.html new file mode 100644 index 0000000..0c9b301 --- /dev/null +++ b/localwiki/OpenSCAD_ReplaceObject.html @@ -0,0 +1,75 @@ +OpenSCAD ReplaceObject

      OpenSCAD ReplaceObject

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      OpenSCAD ReplaceObject.png OpenSCAD ReplaceObject‏‎

      +
      Menu location +
      OpenSCAD → ReplaceObject‏‎ +
      Workbenches +
      OpenSCAD +
      Default shortcut +
      none +
      See also +
      --- +

      + +
      +


      +

      +

      Description

      +

      Replace an object in the feature tree. +

      +

      Use

      +
      1. Multi-select in correct order old, new and parent object in the tree view.
      2. +
      3. Click on OpenSCAD ReplaceObject.png or choose OpenSCADOpenSCAD ReplaceObject.png Replace Object from the top menu.
      +

      Limitations

      +


      +

      +

      Notes

      +

      You can use this feature for example to substitute a part inside a fusion/cut/common/compound-object. +
      +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/OpenSCAD_ReplaceObject.svg b/localwiki/OpenSCAD_ReplaceObject.svg new file mode 100644 index 0000000..dc1ee09 --- /dev/null +++ b/localwiki/OpenSCAD_ReplaceObject.svg @@ -0,0 +1,153 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [Sebastian Hoogen] + + + OpenSCAD_ReplaceObject + 2012-05-03 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/OpenSCAD/Resources/icons/OpenSCAD_ReplaceObject.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/OpenSCAD_Workbench.html b/localwiki/OpenSCAD_Workbench.html new file mode 100644 index 0000000..9f6fde8 --- /dev/null +++ b/localwiki/OpenSCAD_Workbench.html @@ -0,0 +1,80 @@ +OpenSCAD Workbench

      OpenSCAD Workbench

      (Redirected from OpenSCAD Workbench)
      + +

      The OpenSCAD module is in an early stage of development. +

      The OpenSCAD module offers interoperability with the open source software OpenSCAD. +


      +An example of imported OpenSCAD geometry +

      It contains an importer which allows you to open the .csg output from OpenSCAD in FreeCAD. +

      The exporter outputs a CSG based (sub-)tree to .csg. Geometry which is not based on CSG operations and is exported as a mesh. +The OpenSCAD module contains a toolbox with functions to modify the feature tree and repair models. +

      + + +

      OpenSCAD language and file format

      +

      The OpenSCAD language allows the use of variables and loops. It allows you to specify submodules to reuse geometry and code. This high degree of flexibility makes parsing very complex. Currently the OpenSCAD module in FreeCAD can not handle the OpenSCAD language natively. +Instead, if OpenSCAD is installed, it can be used to convert the input to an output format named 'CSG'. It is a subset of the OpenSCAD Language and can be used as the input to OpenSCAD for further processing. +During conversion all parametric behavior is lost - all variable names are discarded, loops expanded and mathematical expressions evaluated. +

      +

      GUI Commands

      +
      • OpenSCAD ColorCodeShape.png Color Code Shape: Change the color of selected or all shapes based on their validity.
      + +
      • OpenSCAD RemoveSubtree.png Remove Subtree: Removes the selected objects and all children that are not referenced from other objects.
      + + + + + + +
      • OpenSCAD MeshBoolean.png Mesh Boolean: Creates new mesh object by boolean operation from shapes.
      +
      • OpenSCAD Hull.png Hull: Apllies a hull to selected shapes.
      +
      • OpenSCAD Minkowski.png Minkowski: Applies a minkowski sum to selected shapes.
      +

      Preferences

      + +


      +


      +


      +

      +

      Limitations

      +

      OpenSCAD creates constructive solid geometry as well as importing mesh files and extruding 2d geometry (from dxf files). FreeCAD allows you to create CSG with primitives as well. The FreeCAD geometry kernel (OCCT) works using a boundary representation. +Therefore conversion from CSG to BREP should, in theory, be possible whereas conversion from BREP to CSG is, in general, not. +

      OpenSCAD works internally on meshes. Some operations which are useful on meshes are not meaningful on a BREP model and can not be fully supported. Among these are convex hull, minkowski sum, glide and subdiv. Currently we run the OpenSCAD binary in order to perform hull and minkwoski operations and import the result. This means that the involved geometry will be triangulated. In OpenSCAD non-uniform scaling is often used, which does not impose any problems when using meshes. In our geometry kernel geometric primitives (lines, circular sections, etc) are converted to BSpline prior to performing such deformations. Those BSplines are known to cause trouble in later boolean operations. An automatic solution is not available at the moment. Please feel free to post to the forum if you encounter such problems. Often such problems can be solved be remodeling small parts. A deformation of a cylinder can substituted by an extrusion of an ellipses. +

      +

      Hints

      +

      When importing DXF set the Draft precision to a sensible amount as this will affect the detection of connected edges. +

      If FreeCAD crashes when importing CSG, it is strongly recommended that you enable 'automatically check model after boolean operation' in Menu → Edit → Preferences → Part Design → Model setting +

      +

      Tutorials

      + +

      Links

      + + +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/OpenSCADexamaple1.png b/localwiki/OpenSCADexamaple1.png new file mode 100644 index 0000000..5f0254d Binary files /dev/null and b/localwiki/OpenSCADexamaple1.png differ diff --git a/localwiki/Organization_chart.html b/localwiki/Organization_chart.html new file mode 100644 index 0000000..7dafebd --- /dev/null +++ b/localwiki/Organization_chart.html @@ -0,0 +1,273 @@ +Organization chart

      Organization chart

      + +

      The following table shows who does what in the FreeCAD universe... +

      + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
      FreeCAD software + +
      Modules + FreeCAD base Part Mesh Sketcher + PartDesign Draft (Production) Drawing Arch +
      + jriegel, wmayer wmayer wmayer jriegel, logari81, mrlukeparry, wmayer, jrheinlaender yorik jriegel yorik +
      + Robot Simulation Splash Start CNC G-Code Family-Design Table Fold-Flat (Sheet-Metal) Assembly +
      + yorik danielfalck Jacques-Antoine Gaudin, Carlton Corbitt PE jriegel, ickby +
      + Units Material Properties Bill of Materials Mold Tooling ANSI/ISO/DIN Part Library FEM-FEA Undo Button +
      + Emagdalena Emagdalena +
      File formats + FcStd Obj Step + Iges Dxf IFC STL PDF +
      + jriegel, wmayer wmayer jriegel, wmayer yorik, danielfalck yorik +
      + SAT - ACIS postscript +
      + need vol +
      Compiled Binary + Linux Deb Ubuntu Linux Fedora Linux OpenSUSE MS Windows Apple Mac BSD / Unix Android +
      + wmayer,normandc jriegel +
      + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
      Package Maintainers +
      (stable) + Debian Ubuntu OpenSUSE Arch Fedora Gentoo +
      Florian Pritz 'bluewind' (repo) +
      (experimental) + Debian Ubuntu OpenSUSE Arch Fedora Gentoo +
      drhooves (repo) Prezmof (repo) +
      + + + + + + + + + + + + + + + + + + + + + + + + + + + +
      FreeCAD Translation +
      Language + Chinese Dutch French German Polish Portuguese Spanish Arabic +
      + yorik yorik, normandc kwahooo yorik Emagdalena +
      + Croatian +
      + Petar pperisin +
      + + + + + + + + + + + + + + + + + + + +
      FreeCAD Documentation +
      Documentation + wiki Forum Mailing List YouTube Tutorial Writer Manual Organization Chart +
      + yorik,normandc, Emagdalena, Jdurston kwahooo, Jdurston kwahooo Emagdalena Carlton Corbitt PE +
      + + + + + + + + + + + + + + + + + + + +
      FreeCAD Publicity +
      Publicity + Twitter Laconica Google+ BlogSpot Facebook Webpage Development Server & Domain Donation Account +
      + Emagdalena, Jdurston kwahooo, yorik, Emagdalena , Jdurston kwahooo yorik,Emagdalena yorik SF.net +
      +

      Volunteers to help can post on the Org Chart Thread on the forum. +


      +

      + + + + +
      + +
      +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Orthographic_Perspective.gif b/localwiki/Orthographic_Perspective.gif new file mode 100644 index 0000000..23cfc00 Binary files /dev/null and b/localwiki/Orthographic_Perspective.gif differ diff --git a/localwiki/Otherwisedefault270degree_Part_Cone.png b/localwiki/Otherwisedefault270degree_Part_Cone.png new file mode 100644 index 0000000..bccb65d Binary files /dev/null and b/localwiki/Otherwisedefault270degree_Part_Cone.png differ diff --git a/localwiki/PARTMirrorAfterv11.png b/localwiki/PARTMirrorAfterv11.png new file mode 100644 index 0000000..4b7c69b Binary files /dev/null and b/localwiki/PARTMirrorAfterv11.png differ diff --git a/localwiki/PARTMirrorBeforev11.png b/localwiki/PARTMirrorBeforev11.png new file mode 100644 index 0000000..fdcb822 Binary files /dev/null and b/localwiki/PARTMirrorBeforev11.png differ diff --git a/localwiki/PARTMirrorDialogv11.png b/localwiki/PARTMirrorDialogv11.png new file mode 100644 index 0000000..95d2b8b Binary files /dev/null and b/localwiki/PARTMirrorDialogv11.png differ diff --git a/localwiki/PD_WB_Tutorial001.png b/localwiki/PD_WB_Tutorial001.png new file mode 100644 index 0000000..f8ecfb4 Binary files /dev/null and b/localwiki/PD_WB_Tutorial001.png differ diff --git a/localwiki/PD_WB_Tutorial002.png b/localwiki/PD_WB_Tutorial002.png new file mode 100644 index 0000000..5f5f23f Binary files /dev/null and b/localwiki/PD_WB_Tutorial002.png differ diff --git a/localwiki/PD_WB_Tutorial003.png b/localwiki/PD_WB_Tutorial003.png new file mode 100644 index 0000000..ee86531 Binary files /dev/null and b/localwiki/PD_WB_Tutorial003.png differ diff --git a/localwiki/PD_WB_Tutorial004.png b/localwiki/PD_WB_Tutorial004.png new file mode 100644 index 0000000..4e71e6c Binary files /dev/null and b/localwiki/PD_WB_Tutorial004.png differ diff --git a/localwiki/PD_WB_Tutorial005.png b/localwiki/PD_WB_Tutorial005.png new file mode 100644 index 0000000..770aa96 Binary files /dev/null and b/localwiki/PD_WB_Tutorial005.png differ diff --git a/localwiki/PD_WB_Tutorial006.png b/localwiki/PD_WB_Tutorial006.png new file mode 100644 index 0000000..488f505 Binary files /dev/null and b/localwiki/PD_WB_Tutorial006.png differ diff --git a/localwiki/PD_WB_Tutorial007.png b/localwiki/PD_WB_Tutorial007.png new file mode 100644 index 0000000..d7155a1 Binary files /dev/null and b/localwiki/PD_WB_Tutorial007.png differ diff --git a/localwiki/PD_WB_Tutorial008.png b/localwiki/PD_WB_Tutorial008.png new file mode 100644 index 0000000..0c9899b Binary files /dev/null and b/localwiki/PD_WB_Tutorial008.png differ diff --git a/localwiki/PD_WB_Tutorial009.png b/localwiki/PD_WB_Tutorial009.png new file mode 100644 index 0000000..65d754f Binary files /dev/null and b/localwiki/PD_WB_Tutorial009.png differ diff --git a/localwiki/PD_WB_Tutorial010.png b/localwiki/PD_WB_Tutorial010.png new file mode 100644 index 0000000..1a76d55 Binary files /dev/null and b/localwiki/PD_WB_Tutorial010.png differ diff --git a/localwiki/PD_WB_Tutorial011.png b/localwiki/PD_WB_Tutorial011.png new file mode 100644 index 0000000..6beb83c Binary files /dev/null and b/localwiki/PD_WB_Tutorial011.png differ diff --git a/localwiki/PD_WB_Tutorial012.png b/localwiki/PD_WB_Tutorial012.png new file mode 100644 index 0000000..a573c1a Binary files /dev/null and b/localwiki/PD_WB_Tutorial012.png differ diff --git a/localwiki/PD_WB_Tutorial013.png b/localwiki/PD_WB_Tutorial013.png new file mode 100644 index 0000000..5ff60b0 Binary files /dev/null and b/localwiki/PD_WB_Tutorial013.png differ diff --git a/localwiki/PD_WB_Tutorial014.png b/localwiki/PD_WB_Tutorial014.png new file mode 100644 index 0000000..bc54eae Binary files /dev/null and b/localwiki/PD_WB_Tutorial014.png differ diff --git a/localwiki/PD_WB_Tutorial015.png b/localwiki/PD_WB_Tutorial015.png new file mode 100644 index 0000000..096c517 Binary files /dev/null and b/localwiki/PD_WB_Tutorial015.png differ diff --git a/localwiki/PD_WB_Tutorial016.png b/localwiki/PD_WB_Tutorial016.png new file mode 100644 index 0000000..bcc6102 Binary files /dev/null and b/localwiki/PD_WB_Tutorial016.png differ diff --git a/localwiki/PD_WB_Tutorial017.png b/localwiki/PD_WB_Tutorial017.png new file mode 100644 index 0000000..b1d8407 Binary files /dev/null and b/localwiki/PD_WB_Tutorial017.png differ diff --git a/localwiki/PD_WB_Tutorial018.png b/localwiki/PD_WB_Tutorial018.png new file mode 100644 index 0000000..b07fbff Binary files /dev/null and b/localwiki/PD_WB_Tutorial018.png differ diff --git a/localwiki/PD_WB_Tutorial019.png b/localwiki/PD_WB_Tutorial019.png new file mode 100644 index 0000000..6f18a8b Binary files /dev/null and b/localwiki/PD_WB_Tutorial019.png differ diff --git a/localwiki/PD_move_feature0.png b/localwiki/PD_move_feature0.png new file mode 100644 index 0000000..be6d991 Binary files /dev/null and b/localwiki/PD_move_feature0.png differ diff --git a/localwiki/PD_move_feature2.png b/localwiki/PD_move_feature2.png new file mode 100644 index 0000000..02ae6ae Binary files /dev/null and b/localwiki/PD_move_feature2.png differ diff --git a/localwiki/Pad_parameters_cropped.png b/localwiki/Pad_parameters_cropped.png new file mode 100644 index 0000000..17672a2 Binary files /dev/null and b/localwiki/Pad_parameters_cropped.png differ diff --git a/localwiki/Page.svg b/localwiki/Page.svg new file mode 100644 index 0000000..a14f12f --- /dev/null +++ b/localwiki/Page.svg @@ -0,0 +1,49 @@ + + + + + + + image/svg+xml + + + + [WandererFan] + + + TechDraw_Tree_Page + 2016-04-27 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/TechDraw/Gui/Resources/icons/TechDraw_Tree_Page.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Pages.svg b/localwiki/Pages.svg new file mode 100644 index 0000000..6346ee3 --- /dev/null +++ b/localwiki/Pages.svg @@ -0,0 +1,207 @@ + + + + + + + + image/svg+xml + + + + + [WandererFan] + + + TechDraw_Pages + 2016-04-27 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/TechDraw/Gui/Resources/icons/TechDraw_Pages.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + pages + page + + + Three pages in a pile + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Pan-mouse-CTRL.svg b/localwiki/Pan-mouse-CTRL.svg new file mode 100644 index 0000000..5080756 --- /dev/null +++ b/localwiki/Pan-mouse-CTRL.svg @@ -0,0 +1,164 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + + + + + + + CTRL + + diff --git a/localwiki/Pan-mouse-Ctrl.svg b/localwiki/Pan-mouse-Ctrl.svg new file mode 100644 index 0000000..22cba54 --- /dev/null +++ b/localwiki/Pan-mouse-Ctrl.svg @@ -0,0 +1,132 @@ + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + + + + + + + + + diff --git a/localwiki/Pan-mouse.svg b/localwiki/Pan-mouse.svg new file mode 100644 index 0000000..6e9b849 --- /dev/null +++ b/localwiki/Pan-mouse.svg @@ -0,0 +1,126 @@ + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + + + + + + + + diff --git a/localwiki/Pan_cursor.png b/localwiki/Pan_cursor.png new file mode 100644 index 0000000..7e312ca Binary files /dev/null and b/localwiki/Pan_cursor.png differ diff --git a/localwiki/Parallax.jpg b/localwiki/Parallax.jpg new file mode 100644 index 0000000..77748d7 Binary files /dev/null and b/localwiki/Parallax.jpg differ diff --git a/localwiki/Parallelism.svg b/localwiki/Parallelism.svg new file mode 100644 index 0000000..e5a76d4 --- /dev/null +++ b/localwiki/Parallelism.svg @@ -0,0 +1,117 @@ + + + + + Parallelism + + + + + + image/svg+xml + + Parallelism + + + bavariaSHAPE + + + + + bavariaSHAPE + + + + + bavariaSHAPE + + + 15.10.2016 + Geometric dimensioning and tolerancing symbols +All symbols in this repository are licensed under CC-BY 3.0 + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Param_Bool.svg b/localwiki/Param_Bool.svg new file mode 100644 index 0000000..da882a2 --- /dev/null +++ b/localwiki/Param_Bool.svg @@ -0,0 +1,104 @@ + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + + + + + + diff --git a/localwiki/Param_Float.svg b/localwiki/Param_Float.svg new file mode 100644 index 0000000..b7188c2 --- /dev/null +++ b/localwiki/Param_Float.svg @@ -0,0 +1,104 @@ + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + + + + + + diff --git a/localwiki/Param_Int.svg b/localwiki/Param_Int.svg new file mode 100644 index 0000000..3820dbe --- /dev/null +++ b/localwiki/Param_Int.svg @@ -0,0 +1,103 @@ + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + + + + + + diff --git a/localwiki/Param_Text.svg b/localwiki/Param_Text.svg new file mode 100644 index 0000000..9902ee2 --- /dev/null +++ b/localwiki/Param_Text.svg @@ -0,0 +1,104 @@ + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + + + + + + diff --git a/localwiki/Param_UInt.svg b/localwiki/Param_UInt.svg new file mode 100644 index 0000000..87d3d87 --- /dev/null +++ b/localwiki/Param_UInt.svg @@ -0,0 +1,103 @@ + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + + + + + + diff --git a/localwiki/Parameter_Editor.jpg b/localwiki/Parameter_Editor.jpg new file mode 100644 index 0000000..d3c37af Binary files /dev/null and b/localwiki/Parameter_Editor.jpg differ diff --git a/localwiki/ParametersBeam.svg b/localwiki/ParametersBeam.svg new file mode 100644 index 0000000..5084658 --- /dev/null +++ b/localwiki/ParametersBeam.svg @@ -0,0 +1,346 @@ + + + + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + LENGTH + HEIGHT + WIDTH + DENT + DENT + + CHAMFER + + HEIGHT + LENGTH + + diff --git a/localwiki/ParametersDent.svg b/localwiki/ParametersDent.svg new file mode 100644 index 0000000..7e00a29 --- /dev/null +++ b/localwiki/ParametersDent.svg @@ -0,0 +1,394 @@ + + + + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + WIDTH + LENGTH + HEIGHT + SLANT + LEVEL + + + + + + + + + + OFFSET + E + N + O + S + + diff --git a/localwiki/ParametersDoorGlass.svg b/localwiki/ParametersDoorGlass.svg new file mode 100644 index 0000000..4de9b4a --- /dev/null +++ b/localwiki/ParametersDoorGlass.svg @@ -0,0 +1,506 @@ + + + + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + WIDTH + HEIGHT + + + + + + + + + + + + + + + + + + H1 + H2 + W2 + O2 + W1 + O1 + + + + + + H3 + + diff --git a/localwiki/ParametersDoorSimple.svg b/localwiki/ParametersDoorSimple.svg new file mode 100644 index 0000000..a7f03f4 --- /dev/null +++ b/localwiki/ParametersDoorSimple.svg @@ -0,0 +1,413 @@ + + + + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + WIDTH + HEIGHT + + + + + + + + + + + + + + + + + H1 + W2 + O2 + W1 + O1 + + diff --git a/localwiki/ParametersIbeam.svg b/localwiki/ParametersIbeam.svg new file mode 100644 index 0000000..c81cd10 --- /dev/null +++ b/localwiki/ParametersIbeam.svg @@ -0,0 +1,289 @@ + + + + + + + + + + image/svg+xml + + + + + + + BASE + CHAMFER + + + + + + + + + + + + WIDTH + + + + + + + + HEIGHT + + LENGTH + + + + + + + + + + + + + diff --git a/localwiki/ParametersPanel.svg b/localwiki/ParametersPanel.svg new file mode 100644 index 0000000..753e6f5 --- /dev/null +++ b/localwiki/ParametersPanel.svg @@ -0,0 +1,350 @@ + + + + + + + + + + image/svg+xml + + + + + + + + + LENGTH + CHAMFER + DENTHEIGHT + + + + + + + HEIGHT + + + + + WIDTH + + + + + + + + + + + + DENTWIDTH + + + + + + + + + + + + + + diff --git a/localwiki/ParametersPillar.svg b/localwiki/ParametersPillar.svg new file mode 100644 index 0000000..6c58707 --- /dev/null +++ b/localwiki/ParametersPillar.svg @@ -0,0 +1,452 @@ + + + + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + + + + + + + HEIGHT + + + + + + + GROOVE + + + + + + + LENGTH + + + + + + WIDTH + + + + + + GROOVE + + + + + CHAMFER + SPACING + GROOVE + DEPTH + HEIGHT + + diff --git a/localwiki/ParametersSlab.svg b/localwiki/ParametersSlab.svg new file mode 100644 index 0000000..4018a09 --- /dev/null +++ b/localwiki/ParametersSlab.svg @@ -0,0 +1,444 @@ + + + + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + CHAMPAGNE + HAT + + + + + + + + WIDTH + HEIGHT + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + LENGTH + BASE + SPACING + MINOR R + MAJOR R + + diff --git a/localwiki/ParametersStairs.svg b/localwiki/ParametersStairs.svg new file mode 100644 index 0000000..c013696 --- /dev/null +++ b/localwiki/ParametersStairs.svg @@ -0,0 +1,434 @@ + + + + + + + + + + image/svg+xml + + + + + + + NUMBER + + + + + + + + + + + + LENGTH + + WIDTH + + THICKNESS + + + + + + + + + + + + + + + + + + + + + + + + + + + + LENGTH + UP + DOWN + OF + RISERS + RISER + TREAD + + + + diff --git a/localwiki/ParametersWindowDouble.svg b/localwiki/ParametersWindowDouble.svg new file mode 100644 index 0000000..69f84f4 --- /dev/null +++ b/localwiki/ParametersWindowDouble.svg @@ -0,0 +1,473 @@ + + + + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + WIDTH + HEIGHT + + + + + + + + + + + + + + + + + + H1 + H2 + W2 + O2 + W1 + O1 + + diff --git a/localwiki/ParametersWindowFixed.svg b/localwiki/ParametersWindowFixed.svg new file mode 100644 index 0000000..6cfe325 --- /dev/null +++ b/localwiki/ParametersWindowFixed.svg @@ -0,0 +1,344 @@ + + + + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + + + + + + + + + + + WIDTH + HEIGHT + + + + + + + + + + + + + H1 + W1 + O1 + + diff --git a/localwiki/ParametersWindowSimple.svg b/localwiki/ParametersWindowSimple.svg new file mode 100644 index 0000000..4a7c862 --- /dev/null +++ b/localwiki/ParametersWindowSimple.svg @@ -0,0 +1,466 @@ + + + + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + WIDTH + HEIGHT + + + + + + + + + + + + + + + + + + H1 + H2 + W2 + O2 + W1 + O1 + + diff --git a/localwiki/ParametersWindowStash.svg b/localwiki/ParametersWindowStash.svg new file mode 100644 index 0000000..cf753b6 --- /dev/null +++ b/localwiki/ParametersWindowStash.svg @@ -0,0 +1,498 @@ + + + + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + WIDTH + HEIGHT + + + + + + + + + + + + + + + + + + H1 + H2 + W2 + O2 + W1 + O1 + + + + diff --git a/localwiki/PartBooleansDialog.png b/localwiki/PartBooleansDialog.png new file mode 100644 index 0000000..931d051 Binary files /dev/null and b/localwiki/PartBooleansDialog.png differ diff --git a/localwiki/PartCheckGeometry.png b/localwiki/PartCheckGeometry.png new file mode 100644 index 0000000..cfce898 Binary files /dev/null and b/localwiki/PartCheckGeometry.png differ diff --git a/localwiki/PartConeProperty_en.png b/localwiki/PartConeProperty_en.png new file mode 100644 index 0000000..97a4974 Binary files /dev/null and b/localwiki/PartConeProperty_en.png differ diff --git a/localwiki/PartDesign.png b/localwiki/PartDesign.png new file mode 100644 index 0000000..368215b Binary files /dev/null and b/localwiki/PartDesign.png differ diff --git a/localwiki/PartDesignConstraintPointOnPointScriptingFigure3Bis.jpg b/localwiki/PartDesignConstraintPointOnPointScriptingFigure3Bis.jpg new file mode 100644 index 0000000..296175f Binary files /dev/null and b/localwiki/PartDesignConstraintPointOnPointScriptingFigure3Bis.jpg differ diff --git a/localwiki/PartDesignConstraintPointOnPointScriptingFigure4.jpg b/localwiki/PartDesignConstraintPointOnPointScriptingFigure4.jpg new file mode 100644 index 0000000..08a35fe Binary files /dev/null and b/localwiki/PartDesignConstraintPointOnPointScriptingFigure4.jpg differ diff --git a/localwiki/PartDesignExample.png b/localwiki/PartDesignExample.png new file mode 100644 index 0000000..db2b6ec Binary files /dev/null and b/localwiki/PartDesignExample.png differ diff --git a/localwiki/PartDesignWorkbench.svg b/localwiki/PartDesignWorkbench.svg new file mode 100644 index 0000000..b988862 --- /dev/null +++ b/localwiki/PartDesignWorkbench.svg @@ -0,0 +1,114 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [triplus] + + + PartDesignWorkbench + 2016-02-26 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/PartDesign/Gui/Resources/icons/PartDesignWorkbench.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/PartDesign_AddLoft_example.png b/localwiki/PartDesign_AddLoft_example.png new file mode 100644 index 0000000..b7d0e3b Binary files /dev/null and b/localwiki/PartDesign_AddLoft_example.png differ diff --git a/localwiki/PartDesign_AdditiveBox.html b/localwiki/PartDesign_AdditiveBox.html new file mode 100644 index 0000000..0ecb748 --- /dev/null +++ b/localwiki/PartDesign_AdditiveBox.html @@ -0,0 +1,83 @@ +PartDesign AdditiveBox

      PartDesign AdditiveBox

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      PartDesign AdditiveBox.png PartDesign AdditiveBox

      +
      Menu location +
      Part Design → Create an additive primitive → Additive Box +
      Workbenches +
      PartDesign +
      Default shortcut +
      None +
      See also +
      PartDesign CompPrimitiveAdditive +

      + +
      +


      +

      +

      Description

      +

      Inserts a primitive box in the active Body as the first feature, or fuses it to the existing feature(s). +

      available in version 0.17 +


      +PartDesign AdditiveBox example.png +

      +

      How to use

      +
      1. Press the PartDesign AdditiveBox.png Additive Box button. Note: the Additive Box is part of an icon menu labelled Create an additive primitive. After launching FreeCAD, the Additive Box is the one displayed in the toolbar. If a different primitive is displayed, click on the down arrow besides the icon and select Additive Box in the menu.
      2. +
      3. Set the Primitive parameters and Attachment.
      4. +
      5. Click OK.
      6. +
      7. A Box feature appears under the active Body.
      +

      Options

      +

      The Box can be edited after its creation in two ways: +

      +
      • Double-clicking it in the Model tree, or by right-clicking and selecting Edit primitive in the contextual menu; this brings up the Primitive parameters.
      • +
      • Via the Property editor.
      +

      Properties

      +
      • DATAAttachment: defines the attachment mode as well as the Attachment Offset. See Part Attachment.
      • +
      • DATALabel: Label given to the Box object. Change to suit your needs.
      • +
      • DATALength: the Box's dimension in the X-direction.
      • +
      • DATAWidth: the Box's dimension in the Y-direction.
      • +
      • DATAHeight: the Box's dimension in the Z-direction.
      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/PartDesign_AdditiveCone.html b/localwiki/PartDesign_AdditiveCone.html new file mode 100644 index 0000000..bb4b1da --- /dev/null +++ b/localwiki/PartDesign_AdditiveCone.html @@ -0,0 +1,84 @@ +PartDesign AdditiveCone

      PartDesign AdditiveCone

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      PartDesign AdditiveCone.png PartDesign AdditiveCone

      +
      Menu location +
      Part Design → Create an additive primitive → Additive Cone +
      Workbenches +
      PartDesign +
      Default shortcut +
      None +
      See also +
      PartDesign CompPrimitiveAdditive +

      + +
      +


      +

      +

      Description

      +

      Inserts a primitive cone in the active Body as the first feature, or fuses it to the existing feature(s). +

      available in version 0.17 +


      +PartDesign AdditiveCone example.png +

      +

      How to use

      +
      1. Press the PartDesign AdditiveCone.png Additive Cone button. Note: the Additive Cone is part of an icon menu labelled Create an additive primitive. After launching FreeCAD, the Additive Box is the one displayed in the toolbar. To get to the Cone button, click on the down arrow besides the visible icon and select Additive Cone in the menu.
      2. +
      3. Set the Primitive parameters and Attachment.
      4. +
      5. Click OK.
      6. +
      7. A Cone feature appears under the active Body.
      +

      Options

      +

      The Cone can be edited after its creation in two ways: +

      +
      • Double-clicking it in the Model tree, or by right-clicking and selecting Edit primitive in the contextual menu; this brings up the Primitive parameters.
      • +
      • Via the Property editor.
      +

      Properties

      +
      • DATAAttachment: defines the attachment mode as well as the Attachment Offset. See Part Attachment.
      • +
      • DATALabel: label given to the Cone object. Change to suit your needs.
      • +
      • DATARadius1: the radius value at the cone's base.
      • +
      • DATARadius2: the radius value at the cone's top. A non-zero value creates a truncated cone.
      • +
      • DATAHeight: the height of the cone along its axis.
      • +
      • DATAAngle: angle of rotation of the cross section (360 degrees in a full cone).
      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/PartDesign_AdditiveCylinder.html b/localwiki/PartDesign_AdditiveCylinder.html new file mode 100644 index 0000000..c3dbb85 --- /dev/null +++ b/localwiki/PartDesign_AdditiveCylinder.html @@ -0,0 +1,85 @@ +PartDesign AdditiveCylinder

      PartDesign AdditiveCylinder

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      PartDesign AdditiveCylinder.png PartDesign AdditiveCylinder

      +
      Menu location +
      Part Design → Create an additive primitive → Additive Cylinder +
      Workbenches +
      PartDesign +
      Default shortcut +
      None +
      See also +
      PartDesign CompPrimitiveAdditive +

      + +
      +


      +

      +

      Description

      +

      Inserts a primitive cylinder in the active Body as the first feature, or fuses it to the existing feature(s). +

      available in version 0.17 +


      +PartDesign AdditiveCylinder example.png +

      +

      How to use

      +
      1. Press the PartDesign AdditiveCylinder.png Additive Cylinder button. Note: the Additive Cylinder is part of an icon menu labelled Create an additive primitive. After launching FreeCAD, the Additive Box is the one displayed in the toolbar. To get to the Cylinder button, click on the down arrow besides the visible icon and select Additive cylinder in the menu.
      2. +
      3. Set the Primitive parameters and Attachment.
      4. +
      5. Click OK.
      6. +
      7. A Cylinder feature appears under the active Body.
      +

      Options

      +

      The Cylinder can be edited after its creation in two ways: +

      +
      • Double-clicking it in the Model tree, or by right-clicking and selecting Edit primitive in the contextual menu; this brings up the Primitive parameters.
      • +
      • Via the Property editor.
      +

      Properties

      +
      • DATAAttachment: defines the attachment mode as well as the Attachment Offset. See Part Attachment.
      • +
      • DATALabel: label given to the Cylinder object. Change to suit your needs.
      • +
      • DATARadius: the radius value of the cylinder.
      • +
      • DATAAngle: angle of rotation of the cross section (360 degrees forms a full cylinder).
      • +
      • DATAHeight: the length of the cylinder along its axis.
      +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/PartDesign_AdditiveEllipsoid.html b/localwiki/PartDesign_AdditiveEllipsoid.html new file mode 100644 index 0000000..915b42c --- /dev/null +++ b/localwiki/PartDesign_AdditiveEllipsoid.html @@ -0,0 +1,88 @@ +PartDesign AdditiveEllipsoid

      PartDesign AdditiveEllipsoid

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      PartDesign AdditiveEllipsoid.png PartDesign AdditiveEllipsoid

      +
      Menu location +
      Part Design → Create an additive primitive → Additive Ellipsoid +
      Workbenches +
      PartDesign +
      Default shortcut +
      None +
      See also +
      PartDesign CompPrimitiveAdditive +

      + +
      +


      +

      +

      Description

      +

      Inserts a primitive ellipsoid in the active Body as the first feature, or fuses it to the existing feature(s). +

      available in version 0.17 +


      +PartDesign AdditiveEllipsoid example.png +

      +

      How to use

      +
      1. Press the PartDesign AdditiveEllipsoid.png Additive Ellipsoid button. Note: the Additive Ellipsoid is part of an icon menu labelled Create an additive primitive. After launching FreeCAD, the Additive Box is the one displayed in the toolbar. To get to the Ellipsoid button, click on the down arrow besides the visible icon and select Additive Ellipsoid in the menu.
      2. +
      3. Set the Primitive parameters and Attachment.
      4. +
      5. Click OK.
      6. +
      7. An Ellipsoid feature appears under the active Body.
      +

      Options

      +

      The Ellipsoid can be edited after its creation in two ways: +

      +
      • Double-clicking it in the Model tree, or by right-clicking and selecting Edit primitive in the contextual menu; this brings up the Primitive parameters.
      • +
      • Via the Property editor.
      +

      Properties

      +
      • DATAAttachment: defines the attachment mode as well as the Attachment Offset. See Part Attachment.
      • +
      • DATALabel: label given to the Ellipsoid object. Change to suit your needs.
      • +
      • DATARadius1: the radius value along the ellipsoid's vertical axis; by default, parallel to the Z-axis.
      • +
      • DATARadius2: the radius value along the ellipsoid's length; by default, parallel to the X-axis.
      • +
      • DATARadius3: the radius value along the ellipsoid's width; by default, parallel to the Y-axis. At the default value of zero, the ellipsoid forms an oblate spheroid. This has the same form as if Radius3 is identical to Radius2.
      • +
      • DATAAngle1: (labelled V parameter in the Primitive parameters) lower truncation of the ellipsoid, parallel to the circular cross section (-90 degrees in a full spheroid)
      • +
      • DATAAngle2: (unlabelled in the Primitive parameters) upper truncation of the ellipsoid, parallel to the circular cross section (90 degrees in a full spheroid).
      • +
      • DATAAngle3: (labelled U parameter in the Primitive parameters) angle of rotation of the elliptical cross section (360 degrees in a full spheroid).
      +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/PartDesign_AdditiveLoft.html b/localwiki/PartDesign_AdditiveLoft.html new file mode 100644 index 0000000..bb79671 --- /dev/null +++ b/localwiki/PartDesign_AdditiveLoft.html @@ -0,0 +1,98 @@ +PartDesign AdditiveLoft

      PartDesign AdditiveLoft

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      PartDesign AdditiveLoft.png PartDesign AdditiveLoft

      +
      Menu location +
      Part Design → Additive loft +
      Workbenches +
      PartDesign +
      Default shortcut +
      None +
      See also +
      PartDesign AdditivePipe +

      + +
      +


      +

      +

      Description

      +

      Additive Loft creates a solid in the active Body by making a transition between two or more sketches (also referred to as cross-sections). If the Body already contains features, the additive loft will be merged to them. +

      available in version 0.17 +

      +
      PartDesign AddLoft example.png
      +

      On the left: cross-sections (A), (B) and (C); created Additive loft on the right. +

      +

      How to use

      +
      1. Press the PartDesign AdditiveLoft.png Additive loft button.
      2. +
      3. In the Select feature dialog, select a sketch to be used as first cross-section and click OK. +
        • Alternatively, a single sketch can be selected prior to pressing the Additive loft button.
      4. +
      5. In the Loft parameters, press the Add Section button.
      6. +
      7. Select a sketch in the 3D view. Repeat to select more sketches.
      8. +
      9. Set options if needed and click OK.
      +

      Options

      +
      • Ruled surface: makes straight transitions between cross-sections. Dos not apply to a loft with two cross-sections. If not checked, transitions will be smooth.
      • +
      • Closed: makes a transition from the last cross-section to the first, creating a loop.
      • +
      • Press the Remove Section button to remove a sketch, by selecting it in the 3D view.
      +

      Properties

      +
      • DATALabel: name given to the operation, this name can be changed at convenience.
      • +
      • DATASections: lists the sections used.
      • +
      • DATARuled: see Options.
      • +
      • DATAClosed: see Options.
      • +
      • DATAMidplane: non applicable.
      • +
      • DATAReversed: non applicable.
      • +
      • DATARefine: true or false. If set to true, cleans the solid from residual edges left by features. See Part RefineShape for more details.
      +

      Limitations

      +
      • Sketches must form closed profiles.
      • +
      • It is not possible to loft to a vertex.
      • +
      • A cross-section cannot lie on the same plane as the one immediately preceding it.
      • +
      • To better control the shape of the loft, it is recommended that all the cross-sections have the same number of segments. For example, for a loft between a rectangle and a circle, the circle may be broken down into 4 connected arcs.
      +

      Links

      + +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/PartDesign_AdditivePipe.html b/localwiki/PartDesign_AdditivePipe.html new file mode 100644 index 0000000..51a19e8 --- /dev/null +++ b/localwiki/PartDesign_AdditivePipe.html @@ -0,0 +1,97 @@ +PartDesign AdditivePipe

      PartDesign AdditivePipe

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      PartDesign AdditivePipe.png PartDesign AdditivePipe

      +
      Menu location +
      PartDesign → Additive pipe +
      Workbenches +
      PartDesign, Complete +
      Default shortcut +
      None +
      See also +
      PartDesign AdditiveLoft +

      + +
      +


      +

      +

      Description

      +

      Additive Pipe creates a solid in the active Body by sweeping one or more sketches (also referred to as cross-sections) along an open or closed path. If the Body already contains features, the additive pipe will be merged to them. +

      available in version 0.17 +

      +
      PartDesign AdditivePipe example.svg
      +

      On the left: cross-sections (A) and (B) to be swept along path (C); resulting Additive pipe on the right. +

      +

      How to use

      +
      1. Press the PartDesign AdditivePipe.png Additive pipe button.
      2. +
      3. In the Select feature dialog, select a sketch to be used as first cross-section and click OK. +
        • Alternatively, a single sketch can be selected prior to pressing the Additive pipe button.
      4. +
      5. In the Pipe parameters under Profile, press the Object button.
      6. +
      7. Select the sketch to be used as path in the 3D view: +
        • Alternatively, edges of the body can be selected by pressing Add Edge and selecting edges in the 3D view.
      8. +
      9. To use more than one cross-section, under Section transformation set the Transform mode to Multisection; press Add Section then select a sketch in the 3D view. Repeat for each additional cross-section.
      10. +
      11. Set options if needed and click OK.
      +

      Options

      +

      Properties

      +
      • DATALabel: name given to the operation, this name can be changed at convenience.
      • +
      • DATARefine: true or false. If set to true, cleans the solid from residual edges left by features. See Part RefineShape for more details.
      • +
      • DATASections: lists the sections used.
      • +
      • DATASpine Tangent: true or false (default). True extends the path to include tangent edges.
      • +
      • DATAAuxiliary Spine Tangent: true or false (default). True extends the auxiliary path to include tangent edges.
      • +
      • DATAAuxiliary Curvelinear: true or false (default). True calculates normal between equidistant points on both spines.
      • +
      • DATAMode: profile mode. See Options.
      • +
      • DATABinormal: binormal vector for corresponding orientation mode.
      • +
      • DATATransition: transition mode. Options are Transformed, Right Corner or Round Corner.
      • +
      • DATATransformation: Constant uses a single cross-section. Multisection uses two or more cross-sections. Linear, S-shape and Interpolation are currently not functional.
      +

      Limitations

      +
      • Sketches used for cross-sections must form closed profiles.
      • +
      • It is not possible to use a vertex as cross-section.
      • +
      • A cross-section cannot lie on the same plane as the one immediately preceding it.
      • +
      • To better control the shape of the pipe, it is recommended that all the cross-sections have the same number of segments. For example, for a pipe between a rectangle and a circle, the circle may be broken down into 4 connected arcs.
      +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/PartDesign_AdditivePipe_example.svg b/localwiki/PartDesign_AdditivePipe_example.svg new file mode 100644 index 0000000..b18df81 --- /dev/null +++ b/localwiki/PartDesign_AdditivePipe_example.svg @@ -0,0 +1,606 @@ + + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + + + + + + + + + + + (B) + (C) + + + + (A) + + + diff --git a/localwiki/PartDesign_AdditivePrism.html b/localwiki/PartDesign_AdditivePrism.html new file mode 100644 index 0000000..7471902 --- /dev/null +++ b/localwiki/PartDesign_AdditivePrism.html @@ -0,0 +1,84 @@ +PartDesign AdditivePrism

      PartDesign AdditivePrism

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      PartDesign AdditivePrism.png PartDesign AdditivePrism

      +
      Menu location +
      Part Design → Create an additive primitive → Additive Prism +
      Workbenches +
      PartDesign +
      Default shortcut +
      +
      See also +
      PartDesign CompPrimitiveAdditive +

      + +
      +


      +

      +

      Description

      +

      Inserts a primitive prism in the active Body as the first feature, or fuses it to the existing feature(s). +

      available in version 0.17 +

      PartDesign AdditivePrism example.png +

      +

      How to use

      +
      1. Press the PartDesign AdditivePrism.png Additive Prism button. Note: the Additive Prism is part of an icon menu labelled Create an additive primitive. After launching FreeCAD, the Additive Box is the one displayed in the toolbar. To get the Prism, click on the down arrow besides the visible icon and select Additive Prism in the menu.
      2. +
      3. Set the Primitive parameters and Attachment.
      4. +
      5. Click OK.
      6. +
      7. A Prism feature appears under the active Body.
      +

      Options

      +

      The Prism can be edited after its creation in two ways: +

      +
      • Double-clicking it in the Model tree, or by right-clicking and selecting Edit primitive in the contextual menu; this brings up the Primitive parameters.
      • +
      • Via the Property editor.
      +

      Properties

      +
      • DATAAttachment: defines the attachment mode as well as the Attachment Offset. See Part Attachment.
      • +
      • DATALabel: label given to the Prism object. Change to suit your needs.
      • +
      • DATAPolygon: number of sides in the polygon cross-section of the prism.
      • +
      • DATACircumradius: circumscribed radius of the polygon cross-section of the prism.
      • +
      • DATAHeight: height of the prism.
      +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/PartDesign_AdditiveSphere.html b/localwiki/PartDesign_AdditiveSphere.html new file mode 100644 index 0000000..40f47f7 --- /dev/null +++ b/localwiki/PartDesign_AdditiveSphere.html @@ -0,0 +1,85 @@ +PartDesign AdditiveSphere

      PartDesign AdditiveSphere

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      PartDesign AdditiveSphere.png PartDesign AdditiveSphere

      +
      Menu location +
      Part Design → Create an additive primitive → Additive Sphere +
      Workbenches +
      PartDesign +
      Default shortcut +
      None +
      See also +
      PartDesign CompPrimitiveAdditive +

      + +
      +


      +

      +

      Description

      +

      Inserts a primitive sphere in the active Body as the first feature, or fuses it to the existing feature(s). +

      available in version 0.17 +

      PartDesign AdditiveSphere example.png +

      +

      How to use

      +
      1. Press the PartDesign AdditiveSphere.png Additive Sphere button. Note: the Additive Sphere is part of an icon menu labelled Create an additive primitive. After launching FreeCAD, the Additive Box is the one displayed in the toolbar. To get the Sphere, click on the down arrow besides the visible icon and select Additive Sphere in the menu.
      2. +
      3. Set the Primitive parameters and Attachment.
      4. +
      5. Click OK.
      6. +
      7. A Sphere feature appears under the active Body.
      +

      Options

      +

      The Sphere can be edited after its creation in two ways: +

      +
      • Double-clicking it in the Model tree, or by right-clicking and selecting Edit primitive in the contextual menu; this brings up the Primitive parameters.
      • +
      • Via the Property editor.
      +

      Properties

      +
      • DATAAttachment: defines the attachment mode as well as the Attachment Offset. See Part Attachment.
      • +
      • DATALabel: Label given to the Sphere object. Change to suit your needs.
      • +
      • DATARadius: Radius of the sphere.
      • +
      • DATAAngle1: (labelled V parameter in the Primitive parameters) lower truncation of the sphere, parallel to the circular cross section (-90 degrees in a full sphere)
      • +
      • DATAAngle2: (unlabelled in the Primitive parameters) upper truncation of the ellipsoid, parallel to the circular cross section (90 degrees in a full sphere).
      • +
      • DATAAngle3: (labelled U parameter in the Primitive parameters) angle of rotation of the cross section (360 degrees in a full sphere).
      +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/PartDesign_AdditiveTorus.html b/localwiki/PartDesign_AdditiveTorus.html new file mode 100644 index 0000000..23dc41d --- /dev/null +++ b/localwiki/PartDesign_AdditiveTorus.html @@ -0,0 +1,86 @@ +PartDesign AdditiveTorus

      PartDesign AdditiveTorus

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      PartDesign AdditiveTorus.png PartDesign AdditiveTorus

      +
      Menu location +
      Part Design → Create an additive primitive → Additive Torus +
      Workbenches +
      PartDesign +
      Default shortcut +
      +
      See also +
      PartDesign CompPrimitiveAdditive +

      + +
      +


      +

      +

      Description

      +

      Inserts a primitive torus in the active Body as the first feature, or fuses it to the existing feature(s). +

      available in version 0.17 +

      PartDesign AdditiveTorus example.png +

      +

      How to use

      +
      1. Press the PartDesign AdditiveTorus.png Additive Torus button. Note: the Additive Torus is part of an icon menu labelled Create an additive primitive. After launching FreeCAD, the Additive Box is the one displayed in the toolbar. To get the Torus, click on the down arrow besides the visible icon and select Additive Torus in the menu.
      2. +
      3. Set the Primitive parameters and Attachment.
      4. +
      5. Click OK.
      6. +
      7. A Torus feature appears under the active Body.
      +

      Options

      +

      The Torus can be edited after its creation in two ways: +

      +
      • Double-clicking it in the Model tree, or by right-clicking and selecting Edit primitive in the contextual menu; this brings up the Primitive parameters.
      • +
      • Via the Property editor.
      +

      Properties

      +
      • DATAAttachment: defines the attachment mode as well as the Attachment Offset. See Part Attachment.
      • +
      • DATALabel: Label given to the Torus object. Change to suit your needs.
      • +
      • DATARadius1: Radius of the imaginary orbit around which the circular cross-section revolves. (The distance between the center of the torus and the center of the revolving cross section)
      • +
      • DATARadius2: Radius of the circular cross-section defining the form of the torus.
      • +
      • DATAAngle1: (labelled V parameter in the Primitive parameters) lower truncation of the torus, parallel to the circular cross section (-180 degrees in a full torus). A bug in the sources causes unexpected results at changing Angle1.
      • +
      • DATAAngle2: (unlabelled in the Primitive parameters) upper truncation of the ellipsoid, parallel to the circular cross section (180 degrees in a full torus). A bug in the sources causes unexpected results at changing Angle2.
      • +
      • DATAAngle3: (labelled U parameter in the Primitive parameters) angle of rotation of the circular cross section (360 degrees in a full torus).
      +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/PartDesign_AdditiveWedge.html b/localwiki/PartDesign_AdditiveWedge.html new file mode 100644 index 0000000..c689cc4 --- /dev/null +++ b/localwiki/PartDesign_AdditiveWedge.html @@ -0,0 +1,87 @@ +PartDesign AdditiveWedge

      PartDesign AdditiveWedge

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      PartDesign AdditiveWedge.png PartDesign AdditiveWedge

      +
      Menu location +
      Part Design → Create an additive primitive → Additive Wedge +
      Workbenches +
      PartDesign +
      Default shortcut +
      None +
      See also +
      PartDesign CompPrimitiveAdditive +

      + +
      +


      +

      +

      Description

      +

      Inserts a primitive wedge in the active Body as the first feature, or fuses it to the existing feature(s). +

      available in version 0.17 +


      +PartDesign AdditiveWedge example.png +

      +

      How to use

      +
      1. Press the PartDesign AdditiveWedge.png Additive Wedge button. Note: the Additive Wedge is part of an icon menu labelled Create an additive primitive. After launching FreeCAD, the Additive Box is the one displayed in the toolbar. To get the Wedge, click on the down arrow besides the visible icon and select Additive Wedge in the menu.
      2. +
      3. Set the Primitive parameters and Attachment.
      4. +
      5. Click OK.
      6. +
      7. A Wedge feature appears under the active Body.
      +

      Options

      +

      The Wedge can be edited after its creation in two ways: +

      +
      • Double-clicking it in the Model tree, or by right-clicking and selecting Edit primitive in the contextual menu; this brings up the Primitive parameters.
      • +
      • Via the Property editor.
      +

      Properties

      +

      Using the default placement, the below inputs are: +

      +
      • DATAX min/max : Base face X axis span
      • +
      • DATAY min/max: Wedge height span
      • +
      • DATAZ min/max : Base face Z axis span
      • +
      • DATAX2 min/max : Top face X axis span
      • +
      • DATAZ2 min/max : Top face Z axis span
      +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/PartDesign_Additive_Box.svg b/localwiki/PartDesign_Additive_Box.svg new file mode 100644 index 0000000..03853b1 --- /dev/null +++ b/localwiki/PartDesign_Additive_Box.svg @@ -0,0 +1,136 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [Stefan Tröger] + + + PartDesign_Additive_Box + 2015-05-18 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/PartDesign/Gui/Resources/icons/PartDesign_Additive_Box.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/PartDesign_Additive_Cone.svg b/localwiki/PartDesign_Additive_Cone.svg new file mode 100644 index 0000000..f590a8b --- /dev/null +++ b/localwiki/PartDesign_Additive_Cone.svg @@ -0,0 +1,110 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [Stefan Tröger] + + + PartDesign_Additive_Cone + 2015-05-20 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/PartDesign/Gui/Resources/icons/PartDesign_Additive_Cone.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/PartDesign_Additive_Cylinder.svg b/localwiki/PartDesign_Additive_Cylinder.svg new file mode 100644 index 0000000..e2fb74f --- /dev/null +++ b/localwiki/PartDesign_Additive_Cylinder.svg @@ -0,0 +1,117 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [Stefan Tröger] + + + PartDesign_Additive_Cylinder + 2015-05-18 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/PartDesign/Gui/Resources/icons/PartDesign_Additive_Cylinder.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/PartDesign_Additive_Ellipsoid.svg b/localwiki/PartDesign_Additive_Ellipsoid.svg new file mode 100644 index 0000000..f05b534 --- /dev/null +++ b/localwiki/PartDesign_Additive_Ellipsoid.svg @@ -0,0 +1,118 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [Stefan Tröger] + + + PartDesign_Additive_Ellipsoid + 2015-05-20 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/PartDesign/Gui/Resources/icons/PartDesign_Additive_Ellipsoid.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/PartDesign_Additive_Loft.svg b/localwiki/PartDesign_Additive_Loft.svg new file mode 100644 index 0000000..d38722e --- /dev/null +++ b/localwiki/PartDesign_Additive_Loft.svg @@ -0,0 +1,104 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [Stefan Tröger] + + + PartDesign_Additive_Loft + 2015-06-03 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/PartDesign/Gui/Resources/icons/PartDesign_Additive_Loft.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/PartDesign_Additive_Pipe.svg b/localwiki/PartDesign_Additive_Pipe.svg new file mode 100644 index 0000000..c9d9306 --- /dev/null +++ b/localwiki/PartDesign_Additive_Pipe.svg @@ -0,0 +1,103 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [Stefan Tröger] + + + PartDesign_Additive_Pipe + 2015-05-27 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/PartDesign/Gui/Resources/icons/PartDesign_Additive_Pipe.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/PartDesign_Additive_Prism.svg b/localwiki/PartDesign_Additive_Prism.svg new file mode 100644 index 0000000..5a39c2e --- /dev/null +++ b/localwiki/PartDesign_Additive_Prism.svg @@ -0,0 +1,141 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [Stefan Tröger] + + + PartDesign_Additive_Prism + 2015-05-20 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/PartDesign/Gui/Resources/icons/PartDesign_Additive_Prism.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/PartDesign_Additive_Sphere.svg b/localwiki/PartDesign_Additive_Sphere.svg new file mode 100644 index 0000000..e27e26f --- /dev/null +++ b/localwiki/PartDesign_Additive_Sphere.svg @@ -0,0 +1,101 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [Stefan Tröger] + + + PartDesign_Additive_Sphere + 2015-05-18 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/PartDesign/Gui/Resources/icons/PartDesign_Additive_Sphere.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/PartDesign_Additive_Torus.svg b/localwiki/PartDesign_Additive_Torus.svg new file mode 100644 index 0000000..87b5831 --- /dev/null +++ b/localwiki/PartDesign_Additive_Torus.svg @@ -0,0 +1,152 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [Stefan Tröger] + + + PartDesign_Additive_Torus + 2015-05-20 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/PartDesign/Gui/Resources/icons/PartDesign_Additive_Torus.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/PartDesign_Additive_Wedge.svg b/localwiki/PartDesign_Additive_Wedge.svg new file mode 100644 index 0000000..32b8c3c --- /dev/null +++ b/localwiki/PartDesign_Additive_Wedge.svg @@ -0,0 +1,136 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [Stefan Tröger] + + + PartDesign_Additive_Wedge + 2015-05-20 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/PartDesign/Gui/Resources/icons/PartDesign_Additive_Wedge.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/PartDesign_BaseFeature.svg b/localwiki/PartDesign_BaseFeature.svg new file mode 100644 index 0000000..27cf1a6 --- /dev/null +++ b/localwiki/PartDesign_BaseFeature.svg @@ -0,0 +1,503 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [triplus] + + + PartDesignWorkbench + 2016-02-26 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/PartDesign/Gui/Resources/icons/PartDesignWorkbench.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/PartDesign_Bearingholder_Tutorial_I.html b/localwiki/PartDesign_Bearingholder_Tutorial_I.html new file mode 100644 index 0000000..580abd0 --- /dev/null +++ b/localwiki/PartDesign_Bearingholder_Tutorial_I.html @@ -0,0 +1,143 @@ +PartDesign Bearingholder Tutorial I

      PartDesign Bearingholder Tutorial I

      + +
      This tutorial was originally written for a now deprecated development version of FreeCAD. This tutorial requires a complete rewrite to align with the PartDesign changes that will be in the upcoming v0.17 release. Rewrite was started in Sandbox:PartDesign Bearingholder Tutorial I. If you want to participate, please post to the Wiki section of the forum. - NormandC
      +


      +

      +
      Bearing Holder Tutorial - Finished bearing holder (top)
      +

      As the warning at the top of the page already indicates, this tutorial will NOT WORK unless you compile a special highly experimental branch from FreeCAD source code and is an introductory tutorial to modeling with the PartDesign workbench in FreeCAD using Datum planes which are a feature that does not yet exist in most FreeCAD versions. The purpose of the tutorial is to introduce you to two different work flows for creating a cast part with drafts and fillets. Depending on what other CAD programs you have been using, one or the other might be familiar to you. As a working example we will be modeling a simple bearing holder. +

      This is the first part of the tutorial. It will use what might be called the 'single body' work flow, using the (simpler) top part of the holder as an example. +

      Obviously, to follow through this tutorial you must activate the PartDesign workbench. +

      You can find my version of the part created by this tutorial [here]. The file is no longer available, a new one will be provided at some later date. +
      +

      + + +

      Design data

      +

      The holder should be able to hold a diameter 90mm bearing with a width of up to 33mm (e.g. DIN 630 type 2308). The bearing requires a shoulder height of at least 4.5mm in the holder (and on the shaft). The top part of the holder will be bolted to the bottom with two 12mm bolts. There should be a groove on both sides of the bearing able to hold a standard shaft sealing ring DIN 3760: 38x55x7 or 40x55x7 on one side, 50x68x8 on the other side. +

      The holder will be a sand cast with a minimum wall thickness of 5mm, a draft angle of 2 degrees, and a minimum fillet radius of 3mm. +


      +

      +

      Setting up the skeleton geometry

      +
      Bearing holder with the two most important skeleton planes
      +

      The idea of skeleton geometry is to capture the basic design dimensions in a single datum feature (e.g. a plane or an axis). When the design dimension changes, all that needs to be done is to change the skeleton feature. If the model is well built, then all its feature will recompute to reflect the design change. This reduces the danger that in a complex model, where the basic design dimensions are used in multiple places, you forget to change it somewhere. +

      The alternative to skeleton geometry is to have a table of the basic design dimensions that assign a symbolic name to each dimension, and then use the symbolic name wherever the dimensions is required to build the model. FreeCAD does not allow this approach yet. +

      +
      Base planes and all datum planes
      +

      For the case of the bearing holder, the two most important design dimensions are the distance between the bolts (which limits the size of the bearing that can be used) and the height of the bolt heads. The dimensions chosen are +

      +
      • Distance between bolts: Radius of bearing (45) + wall thickness (5) plus radius of hole for bolt (7) = 57mm, so the vertical plane will be 57mm offset from the YZ-plane. To create this datum plane, select the YZ-plane and then choose to create a new datum plane. Enter the offset in the dialog that opens up
      • +
      • Height of bolt heads: This was chosen as an offset of 28mm from the XZ-plane
      +

      For convenience, two further datum planes can be created to reflect the amount of material that must be cut away from the sides of the bearing holder. They are offset +22 and -22 from the XY-plane. +

      It is advisable to give clear names to the skeleton geometry. Most of the time, you will want to turn off visibility for datum planes because they clutter up the screen, and if the planes have self-explanatory names you can just pick them by name instead of from the screen. +
      +

      +

      The solid geometry

      +
      Sketch of the first pad
      +

      Now its time to start creating some real geometry. The sketch for the first pad is shown on the right. It is placed on the XY-plane. There are just three dimensions: The inner radius (22.5mm), the machining allowance (3mm) at the base as an offset to the XZ-plane and the distance from the datum plane representing the bolt axis (7mm). This means that if you later move the datum plane, the pad will automatically adjust its outer radius. Remember that before you can use the datum plane for dimensioning, you need to introduce it as external geometry to the sketcher. +

      You are probably wondering why there is a small straight segment at the bottom of each arc. This segment ensures that there will be a draft angle of 2 degrees on the arcs. This might look like a lot of work for a very small benefit, but many CAD programs (and maybe FreeCAD one day) have tools that highlight a solid model in different colours and immediately show you all faces where the draft angle is not correct. You don't want that to happen to your model, especially after putting on a lot of fillets! +

      When you have done the sketch (which is a bit tricky because of the 2 degree tangential lines), just pad it symmetrically to the sketch plane with a length of 62mm: 34mm for the bearing, 2x 9mm for the sealing rings, 2x 5mm for the wall thickness. +
      +

      +
      Sketch of the cut-away at the side of the pad
      +

      Next we want to cut away some material where the sealing rings are, because their outer diameter is much less than the bearing's. The easiest way to create the sketches is to select the sketch of the pad and then choose "Duplicate selection" from the edit menu. You can then remap the sketch to the side of the pad, and modify it as shown in the picture. +

      The only two important dimensions in the sketch are 3mm of machining allowance at the bottom, and a inner diameter of 78mm: 68mm for the outer diameter of the sealing ring + 2x 5mm wall thickness. Since the sealing ring on the other side will only have a diameter of 55mm, the cut-out can be 65mm here. +

      After you have created the sketch, pocket it up to the datum plane marking the bearing side plus 5mm wall thickness. If you ever want to modify the holder to be able to hold wider bearings, all you have to do is to change the dimension of these datum planes, and the cut-out depth will follow along. +
      +

      +
      Sketch of the cut-away inside the pad
      +

      To reduce the amount of machining required, we also want to cut away some material inside the holder. Again, duplicating the sketch of the first pad is convenient. It doesn't even have to be remapped. Again, the only important dimensions are the machining allowance (3mm) and the outer diameters: 84mm for the place where the bearing will be (90mm - 2x machining allowance), 49mm for the smaller sealing ring (55mm - 2x 3mm) and 62mm for the larger sealing ring. +

      After creating the sketches, pocket them: Symetrically 28mm for the bearing cut-out (34mm - 2x machining allowance) and one-sided 23mm for the cut-outs for the sealing rings: 34mm / 2 for half the bearing width + 9mm for the sealing rings - 3mm machining allowance. +
      +

      +
      Main geometry of the holder top
      +

      Your part should now look like the picture on the right. Note how the different cut-aways combine to create an almost uniform wall thickness, which will make the casting easier and less liable to have pores. +
      +

      +
      Sketch with draft where the bolts will be
      +

      Now all that remains is to create some material for the bolts to go through. You might be tempted to sketch these as a circle and then pad them, but this will head you for trouble when you try to put the draft onto them later (I assume that is a weakness of OpenCascade). So to circumvent the problems, it is better to create a sketch with the draft angle included and then rotate it through 360 degrees. +

      Here again the skeleton planes come in useful. You will need the bolt axis plane and the bolt head plane as external geometry. Then, create a straight line for the rotation axis and make sure it is constrained to the bolt axis plane reference. Toggle it to be construction geometry. Then, sketch the rest of the contour. The important dimensions are the machining allowance at the top and bottom and the radius of 12mm: 7mm for the hole radius + 5mm wall thickness. +
      +

      +
      Finished geometry of the holder top (without draft and fillets)
      +

      Create a revolution feature from the sketch and then mirror it on the YZ-plane. This is all the solid geometry we need to model. The rest is draft and fillets. +
      +

      +

      Applying draft to the side faces

      +
      The neutral plane for creating drafts
      +

      The next step is to apply drafts on all faces. Its important to consider the location of the neutral plane, that is, the plane which the face is "rotated" around. If we choose as neutral plane the bottom of the holder, then we will have a problem with the wall thickness in the top part of the holder. Therefore, we create a datum plane at an offset of 40mm from the XZ plane as a compromise between the top of the holder becoming to thin and the bottom becoming to wide. +
      +

      +
      Applying draft to the side faces of the holder
      +

      To put draft on a face, select this face and create the draft feature. You can then select more faces to apply the draft on. If you have a large part, it is advisable to draft only one face at a time. This means that if you change the geometry and a draft fails, only this one feature will fail, whereas if you put all faces in one draft feature, then the whole feature might fail because of one face failing. For a small part like the bearing holder, its sufficient to create two draft features: One for the four outside faces, and one for the inside faces. +

      The dialog will force you to select a neutral plane before completing. You can leave the pull direction empty, in this case it will be normal to the neutral plane. Don't forget to set the draft angle to 2 degrees. +
      +

      +

      Filleting the holder

      +
      Fillet where the bolts will go
      +

      We can now fillet the part. The picture shows the first set of fillets. Start with the small circular fillets and make them 4mm radius. Even though 3mm would be enough as per specification of the part, a radius of 4mm means that after machining 1mm of the fillet is left, reducing the sharp edge produced by the machining. The large fillets are 6mm radius to help spread the force from the bolts into the rest of the part. It would be nice to make this radius even larger, but unfortunately OpenCascade can't handle overlapping fillets yet. +

      As with drafts, in a complex part you should fillet only one edge at a time to avoid unnecessary failures if the base geometry changes. +
      +

      +
      Filleting the outside of the holder
      +

      The rest of the fillets are simply 3mm radius. Looking at the picture on the right, the two highlighted fillets could actually be filleted with 5mm to achieve a more uniform wall thickness for the casting. After machining, the minimum wall thickness of 5mm would still be maintained. But again the fact that OpenCascade can't handle overlapping fillets prevents us from doing this for the inner of the two highlighted fillets. +
      +

      +
      Filleting the inside of the holder - problematic edge
      +

      Filleting the inside of the part presents us with a difficulty that cannot be solved with the current tools in the PartDesign workbench. The highlighted edge cannot be filleted at all, again because the rounds would overlap. This could be worked around by creating a sweep instead of a fillet, except that sweeps are not implemented in PartDesign yet. For the time being, we are forced to leave the edge as it is. +
      +

      +
      The filleted part (except for the impossible edge)
      +

      The picture on the right shows the finished part in the state it will be before machining (except for the one edge that is impossible to fillet). You will notice that one edge that runs around the whole part has been left unfilleted on purpose. This is the edge where the bottom and the top of the mould meet. Here, no fillet is possible (and none is required anyway). +
      +

      +

      Machining

      +
      Machining the top and bottom of the holder
      +
      Machining the inside of the bearing holder
      +

      Now we can cut away the material that will be machined off the raw cast part. This is very easy with the skeleton geometry defined. The idea is to create all machining features (Pockets and Grooves) using datum features only. This means they will be totally independent of the solid geometry of the bearing holder, which gives us some big advantages: +

      +
      • No matter how you change the solid geometry, the features for the machining can never fail.
      • +
      • You can create the machining geometry before finalizing the solid, which gives you useful visual feedback.
      • +
      • If you move the skeleton datum planes, then both the solid geometry and the machining will adapt automatically.
      • +
      • If you make a mistake in your solid geometry, the machining will still be in the correct position, and very likely the mistake will become glaringly obvious (e.g. a wall thickness becoming 2mm instead of 5mm). Whereas if you reference the machining to the solid geometry, it will adapt to the error in the solid and e.g. maintain the 5mm wall thickness, just in the same wrong location as the solid is.
      +

      Before starting on the machining geometry, I like to place a datum point in the tree and name it something like "Machining_starts_here". This is useful if you want to switch between the raw and the machined state of the part because you can see at a glance where to move the insert point to get the raw state. +

      To machine the bottom of the holder, just sketch a large rectangle on the XZ plane and pocket it. For the top, sketch a circle on the datum plane defining the bolt head location, and then mirror the pocket on the YZ plane. In the same way, create a pocket for the hole which the bolt will go through and mirror it. To machine the inside of the holder, create a sketch on the YZ plane and groove it. +
      +

      +
      Finished part
      +

      Once you have done the machining, you can have a nice visual effect by colouring all the machined faces so that you can see at one glance which parts are raw casting and which are machined after casting. +


      +

      +

      Final notes

      +

      We have modelled the bearing holder top with the dimensions it will have after casting. To create the casting mould, you need to apply shrinkage to your part because after casting, when the hot metal cools down, it will shrink by a few percent (depending on the material). Usually it is best to leave the application of shrinkage to the foundry making the part because they have the required special knowledge. They should also tell you if your part has problematic areas, e.g. very thick walls suddenly joining to very thin sections without a properly tapered section between them. +

      +

      Part Two

      +

      PartDesign Bearingholder Tutorial II +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/PartDesign_Bearingholder_Tutorial_II.html b/localwiki/PartDesign_Bearingholder_Tutorial_II.html new file mode 100644 index 0000000..f39d6a1 --- /dev/null +++ b/localwiki/PartDesign_Bearingholder_Tutorial_II.html @@ -0,0 +1,133 @@ +PartDesign Bearingholder Tutorial II

      PartDesign Bearingholder Tutorial II

      + +
      This tutorial was originally written for a now deprecated development version of FreeCAD. As of April 2016 these features have been integrated in the 0.17 pre-development release available here. +


      +

      +Please note that this version of FreeCAD is still in an early stage of development. Moreover this tutorial may require updating. If you want to participate in its review and update, please post to the Wiki section of the forum.
      +


      +

      +
      Bearing Holder Tutorial - Finished bearing holder (top)
      +

      As the warning at the top of the page already indicates, this tutorial will NOT WORK unless you compile a special highly experimental branch from FreeCAD source code and is an introductory tutorial to modeling with the PartDesign workbench in FreeCAD using Datum planes which are a feature that does not yet exist in most FreeCAD versions. The purpose of the tutorial is to introduce you to two different work flows for creating a cast part with drafts and fillets. Depending on what other CAD programs you have been using, one or the other might be familiar to you. As a working example we will be modeling a simple bearing holder. +

      This is the second part of the tutorial. It will use what might be called the 'multiple body' workflow, using the (simpler) top part of the holder as an example. +

      Obviously, to follow through this tutorial you must activate the PartDesign workbench. +

      You can find my version of the part created in this tutorial [here] The file is no longer available, a new one will be provided at some later date. +
      +

      + + +

      Design data

      +

      The holder should be able to hold a diameter 90mm bearing with a width of up to 33mm (e.g. DIN 630 type 2308 which has an inside diameter of 40mm). The bearing requires a shoulder height of at least 4.5mm in the holder (and on the shaft). The top part of the holder will be bolted to the bottom with two 12mm bolts. The head of such a bolt will require at least 20mm diameter free space. There should be a groove on both sides of the bearing able to hold a standard shaft sealing ring DIN 3760: 38x55x7 or 40x55x7 on one side, 50x68x8 on the other side. +

      The holder will be a sand cast with a minimum wall thickness of 5mm, a draft angle of 2 degrees, and a minimum fillet radius of 3mm. +


      +

      +

      Setting up the skeleton geometry

      +
      Sketch of the skeleton geometry
      +

      Create a new part in the PartDesign workbench. Rename the Body that is created by default to Skeleton. This Body is probably activated already, which you can see by the blue background colour in the feature tree. Create a new sketch on the YZ plane containing the outline of the shaft, bearing and sealing rings. After finishing the sketch, make a revolution feature from it. This skeleton feature will later be used to reference the real geometry to it. This means that if you want to change any dimensions, all you need to do is adjust the skeleton feature's dimensions and the rest of the part will update accordingly. +

      +
      The skeleton geometry
      +


      +

      +

      The main body

      +
      Sketch of the first Pad
      +

      Create a new body and make it active. The sketch for the first pad is shown on the right. It is placed on a datum plane with an offset of 5mm (wall thickness) from the skeleton face marking the side of one of the bearing sealing rings. Because all the important dimensions are taken from the skeleton, there are just three dimensions: The machining allowance (3mm) at the base as an offset to the XY-plane, the 5mm wall thickness from the outer diameter of the skeleton, and the two degrees draft angle. Two create the 5mm dimension, you first need to select the outer circle (radius 45mm) of the skeleton geometry as external geometry in the sketcher, and then put in a construction line constrained tangential to this circle and at an angle of two degrees. +

      You are probably wondering why there is this small straight segment at the bottom of each arc. This segment ensures that there will be a draft angle of 2 degrees on the arcs. This might look like a lot of work for a very small benefit, but many CAD programs (and maybe FreeCAD one day) have tools that highlight a solid model in different colours and immediately show you all faces where the draft angle is not correct. You don't want that to happen to your model, especially after putting on a lot of fillets! +
      +

      +
      The first Pad
      +

      When you have done the sketch (which is a bit tricky because of the 2 degree tangential lines), create a Pad from it extending up to the other side of the skeleton geometry, again with a 5mm offset to the side face. You don't need to create a datum plane this time, the "up to face" mode of the Pad dialog offers to input an offset. +
      +

      +
      Sketch for Pad cut-out
      +

      Next, we will cut away some material on both ends of the Pad because it is always ideal for cast parts to have as uniform a wall thickness as possible. Create a sketch on each of the end faces of the Pad and dimension it at 5mm offset from the circle representing the bearing sealing ring (radius 27.5mm on one side and 34mm on the other). For the bottom line segment of the sketch, create another external geometry from the Pad and constrain to this. Thus the sketch has only a single dimension, the 5mm wall thickness (the 150mm and 75mm dimensions are not important as long as they are large enough to ensure that everything is cut away). +
      +

      +
      The Pad with cut-outs to achieve uniform wall thickness
      +

      Use the sketch you created to make a Pocket and extend it to the face of the skeleton geometry that represents the bearing, minus 5mm offset for the wall thickness. For the second Pocket, you can use the option "Duplicate selected object" from the Edit menu to duplicate the sketch you already made (choose not to duplicate dependend objects if the question pops up). Then, select the face you want to move this sketch to, and tell FreeCAD to map the sketch to this face (this is an item on the PartDesign menu). After creating the second Pocket, you can look at the result from the bottom to check that you have a uniform wall thickness of 5mm around the contour of the skeleton geometry. +
      +

      +
      Neutral plane for applying draft
      +

      Now it's time to create draft and fillets. The draft feature requires a neutral plane, meaning that the geometry that is cut by this plane will remain in its place, while the rest of the face is tilted at the draft angle. Using the bottom of the Pad for this purpose for this is not a good idea, because the wall thickness in the top part of the holder would become less than 5mm. So we create a datum plane offset about 35mm from the XY for this purpose. Activate the Skeleton body and create the plane there, because we will need it for applying draft to other bodies, too. +
      +

      +
      First body with draft and fillets
      +

      The picture on the right shows the finished first body with draft and fillets applied. Note that the outer (concave) edges have a larger fillet radius of 5mm, again with the purpose of creating a more uniform wall thickness (more than 5mm is not possible because then after machining the inside of the holder the wall thickness would become less than 5mm). +
      +

      +

      Adding the bodies for the bolts

      +
      The sketch for the body for the bolts
      +

      The bolts need two cylindrical bodies on both sides of the main Body. It is best to include the 2 degree draft angle in the sketch. I tried revolving a cylinder and later applying a draft, but weird things happened after mirroring it and I couldn't put fillets on it because the surface was warped somehow. +

      The sketch is dimensioned so that the rotation axis is 12mm distance to the outer diameter of the skeleton Body, 7mm for the radius of the hole plus 5mm for the wall thickness. For the sake of having a fully parametric part, it is a good idea to add a plane to the Skeleton about 25mm above the XY-plane to mark the top of the cylinders. Since this will be machined, the sketch is dimensioned 3mm above it. +


      +

      +
      The body for the bolts
      +

      Create a revolution from the sketch and apply a fillet of 4mm to the top. This means that after machining away 3mm, a slight radius will remain which helps to avoid a sharp edge where someone could cut their hand when tightening the bolt. +
      +

      +
      The main body with the two bodies for the bolts
      +

      Create a boolean feature to fuse the main Body and the bolt body. Then create a new body for the other side. Duplicate the sketch of the revolution, move it to this body and create the second body for the bolts (mirroring a Body is not supported yet so you need to redo most of it). Then fuse this second body into the main Body as well. Finally, apply a large fillet on the edge created by the boolean fuse operation. The largest I could get was 4mm. +
      +

      +

      Hollowing out the main body

      +
      The first Pad of the cut-out body inside the main body
      +

      We will now work on the inside of the holder and hollow it out to make space for the bearing and sealing rings. When doing this of course we need to keep in mind the 3mm machining allowance. Since this tutorial teaches the multi-body method, we will create the inside geometry as a separate body and then cut it out of the main body with a boolean operation. +

      Create a new body and make it active. First, we need a datum plane offset 3mm inside the skeleton face that shows the side of the bearing. Then, duplicate the sketch of the first Pad of the main body. It will be added to the main body, so right-click on it and choose to move it to the newly created body (this option is only available in the context menu if the PartDesign workbench is active). Map the sketch onto the datum plane (if the sketch turns upside-down after mapping, move the datum plane to the other side of the bearing, next to where the duplicated sketch is located). Now, modify the sketch so that the diameter is 3mm less than the outer diameter of the skeleton geometry that represents the bearing. All you need to do is remove the 5mm dimension, drag the sketch inside the reference circle, and create a new 3mm dimension. +
      +

      +
      The cut-out body inside the skeleton body
      +

      Next we want two more Pads to hollow out the place for the sealing rings. Duplicate the sketch of the first pad of the cut-out Body and map it to the XZ-plane. Edit the sketch and replace the external reference with the outer diameter of the bearing sealing ring. Extrude this sketch to an offset of 3mm of the side of the sealing ring. Repeat the whole process for the sealing ring on the other side. +

      After this we want to create two more Pads like the last two to give the shaft a clearance (e.g. 3mm) inside the holder. +
      +

      +
      The complete cut-out body (minus impossible fillets)
      +

      Now all that remains is to apply draft to the planar side faces, using the same neutral plane as for the main body, and filleting. Apply a general fillet of 3mm to all edges. You will notice that there are several edges that cannot be filleted... this is a defect of the underlying geometric kernel which FreeCAD uses. +
      +

      +
      The completed raw part of the holder (without machining)
      +

      We are ready to hollow out the main body. Select it and choose to create a new Boolean operation. Add the cut-out body to the list window and set the operation to "Cut". Put a 3mm fillet on the two edges resulting from the cut-out operation (again some edges remain that are "unfilletable"). The result should look like the picture on the right. +

      The raw part is now completed. This is what the holder will look like before machining. Note that since the mold will have a top and bottom half, the edge between these two cannot be filleted. Also, if you give away this model to a foundry make sure to point out that it has the dimensions after casting. The foundry will then have to apply a certain percentage of shrinkage to the model (making the digital model used to manufacture the mold larger so that when the metal cools down and shrinks after casting it will have the right size). +
      +

      +

      Machining

      +
      Sketch to "drill" the hole for the bolts
      +

      To take away the material for machining the inside of the holder, very conveniently we can use the Skeleton Body itself. If you don't want that because then the skeleton gets hidden somewhere deep in the tree, you can also duplicate the sketch of the skeleton Revolution feature and re-create the revolution in another body. This is not completely parametric, though, because the duplicated sketch is independent of the original, so you will have to work on both if you change a dimension. Dependent duplicated features might be supported in the future sometime. +

      For the rest of the machining, create a new Body. The bottom of the holder will be machined by a Pad sketched on the XY-plane extending downwards. Next, sketch a revolution to make a hole for the bolts. You will need to sketch on the XZ-plane and revolve it so that you can choose the outer diameter of the skeleton Body as an external reference. The top part of the sketch will serve to machine a flat place for the head of the bolt. It is dimensioned to leave at least 5mm wall thickness in the holder. If this does not give enough space for the bolt head then you can move the datum plane upwards. Of course, you could put this logic into the Skeleton, which is left as an exercise to the reader! +
      +

      +
      The machining Body
      +

      You can mirror the revolution on the YZ-axis. The picture on the right shows the "machining" Body. Of course, most of the dimensions of the Pads and Revolutions are not important as long as there is plenty of overlap. +
      +

      +
      The finished Holder with machining
      +

      Finally, create a boolean operation to cut the machining Body out of the main Body. If you want a nice visual effect, you can colour the machined surfaces differently from the rest of the part. This is also a useful optical feedback showing you whether you forgot to machine somewhere. +
      +

      +

      Part One

      +

      PartDesign Bearingholder Tutorial I +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/PartDesign_Body.html b/localwiki/PartDesign_Body.html new file mode 100644 index 0000000..fd3b508 --- /dev/null +++ b/localwiki/PartDesign_Body.html @@ -0,0 +1,119 @@ +PartDesign Body

      PartDesign Body

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      PartDesign Body.png PartDesign Body

      +
      Menu location +
      Part Design → Create body +
      Workbenches +
      PartDesign +
      Default shortcut +
      None +
      See also +
      Std Part +

      + +
      +


      +

      +

      Description

      +

      The PartDesign Body contains a series of sketches, datums and PartDesign features that form a single contiguous solid. It provides an Origin (with standard planes and axes) which can be used by the features as references. Furthermore, it can be freely moved as a unit without making it necessary to move the individual features. +

      available in version 0.17 +


      +PartDesign Body tree.pngPartDesign Body example.png +

      +

      Active Status

      +

      A FreeCAD document can contain multiple Bodies. Therefore, to add a new feature to a specific Body, it needs to be made active. An active body will be displayed in the tree by a light blue background color. +

      +
      PartDesign Body tree-01.png
      +

      Activating a Body also automatically switches the interface to the PartDesign workbench, if it was not already the active workbench. +

      +

      Origin

      +

      The Origin consists of the three standard axes (X, Y, Z) and three standard planes (XY, XZ and YZ). Sketches can be attached to these planes, and planes along with axes can be used to create other datum (reference) geometry. All elements inside the Body are referenced to the Body's Origin; which means that the body can be moved and rotated in reference to the global coordinate system without affecting the placement of elements inside the body. +

      +
      PartDesign Body tree-02.png
      +

      Base Feature

      +

      The base feature is by definition the first PartDesign feature created in the Body. But it is possible to use a solid shape, either imported or modelled in other workbenches, as a base feature to which sketches and other features can be added. +

      +
      PartDesign Body tree-03.png
      +

      Tip

      +

      The tip is the feature that is exposed outside the Body. It is automatically set to the last feature at the bottom of the tree. But sometimes it can be useful to change it to an earlier feature in the Body tree, which in effect rolls back its history; then it is possible to add features that should have been added earlier. In the Body tree, the feature set to tip displays a green dot with a white down arrow in it. +

      +
      PartDesign Body tree-04.png
      +

      For more details, see the PartDesign MoveTip.png Move Tip page. +

      +

      Visibility Management

      +

      The Body's visibility supersedes the visibility of any object it contains. If the Body is hidden, the objects it contains will be hidden as well, even if their visibility is set to true. Only one feature can be visible at a time. Selecting a hidden feature and pressing the space bar will make it visible, and automatically hide the previously visible feature. +

      +

      Interaction with other workbenches

      +

      By default, objects underneath a Body are selectable, and this is of course required to edit and add features in PartDesign. But selecting a Body's features to create operations from other workbenches (like Part or Draft) is not advised, as the results may be unexpected; in all cases, an error labelled Links go out of the allowed scope will appear in the Report view. +

      Therefore, for interactions with other workbenches, only the Body itself should be selected from the Model tree. In cases where it is necessary to select specific topology on the Body (vertex, edge, face), then the Body's Display Mode Body view property can be switched from Through (default) to Tip. This property is accessible from the View panel. In Tip mode, access to the objects under the Body (features, datums, sketches) is disabled; everything but the tip feature will be hidden in the 3D view, no matter which object is set as visible. +

      Once operations in other workbenches are completed, do not forget to reset the Display Mode Body property to Through to be able to edit the Body. +

      +

      How to use

      +
      • Press the PartDesign Body.png Create body button. The new body automatically becomes active.
      • +
      • Double-click the Body in the Model tree or right-click and select Toggle active body to activate or deactivate a body.
      • +
      • If a solid shape is selected first, a BaseFeature solid object is added to the Body; the BaseFeature is linked to the original solid shape. Accepted shapes can be an imported solid, or a solid made in any other FreeCAD workbench.
      • +
      • In a new document, if a sketch is created from the PartDesign workbench toolbar, a new Body will be automatically created.
      +

      Properties

      +
      • VIEWDisplay Mode Body: sets the display between two modes: +
        • Through (default) exposes everything inside the body (features, datums, sketches, etc.). It is the mode used in adding and editing features inside the body.
        • +
        • Tip exposes only the shape of the Body itself according to the set tip; everything else including sketches is hidden from view and cannot be displayed. Practical use: "Tip" allows selection of edges and faces of the Body to create operations from other workbenches.
      • +
      • DATATip: displays/sets the feature defined as tip.
      • +
      • DATABase Feature: displays/sets the external shape used as base feature. Does not apply if a PartDesign feature is the base feature.
      • +
      • DATAPlacement: specifies the orientation and position of the Body in the 3D space. See Placement.
      • +
      • DATALabel: the Label is the name given to the operation. This name can be changed at your convenience.
      • +
      • DATAGroup: lists the referenced objects inside the Body.
      +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/PartDesign_Body.svg b/localwiki/PartDesign_Body.svg new file mode 100644 index 0000000..0f2dd38 --- /dev/null +++ b/localwiki/PartDesign_Body.svg @@ -0,0 +1,155 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [jrheinlaender] + + + PartDesign_Body + 2013-05-22 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/PartDesign/Gui/Resources/icons/PartDesign_Body.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + diff --git a/localwiki/PartDesign_Body_Create_New.svg b/localwiki/PartDesign_Body_Create_New.svg new file mode 100644 index 0000000..4646c69 --- /dev/null +++ b/localwiki/PartDesign_Body_Create_New.svg @@ -0,0 +1,322 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + Path-Stock + 2015-07-04 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Path/Gui/Resources/icons/Path-Stock.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + diff --git a/localwiki/PartDesign_Body_Tree.svg b/localwiki/PartDesign_Body_Tree.svg new file mode 100644 index 0000000..4646c69 --- /dev/null +++ b/localwiki/PartDesign_Body_Tree.svg @@ -0,0 +1,322 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + Path-Stock + 2015-07-04 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Path/Gui/Resources/icons/Path-Stock.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + diff --git a/localwiki/PartDesign_Body_example.png b/localwiki/PartDesign_Body_example.png new file mode 100644 index 0000000..7c4f0d3 Binary files /dev/null and b/localwiki/PartDesign_Body_example.png differ diff --git a/localwiki/PartDesign_Body_tree-01.png b/localwiki/PartDesign_Body_tree-01.png new file mode 100644 index 0000000..914c9be Binary files /dev/null and b/localwiki/PartDesign_Body_tree-01.png differ diff --git a/localwiki/PartDesign_Body_tree-02.png b/localwiki/PartDesign_Body_tree-02.png new file mode 100644 index 0000000..3047c0d Binary files /dev/null and b/localwiki/PartDesign_Body_tree-02.png differ diff --git a/localwiki/PartDesign_Body_tree-03.png b/localwiki/PartDesign_Body_tree-03.png new file mode 100644 index 0000000..0839e22 Binary files /dev/null and b/localwiki/PartDesign_Body_tree-03.png differ diff --git a/localwiki/PartDesign_Body_tree-04.png b/localwiki/PartDesign_Body_tree-04.png new file mode 100644 index 0000000..4188924 Binary files /dev/null and b/localwiki/PartDesign_Body_tree-04.png differ diff --git a/localwiki/PartDesign_Body_tree.png b/localwiki/PartDesign_Body_tree.png new file mode 100644 index 0000000..37790b5 Binary files /dev/null and b/localwiki/PartDesign_Body_tree.png differ diff --git a/localwiki/PartDesign_Boolean.html b/localwiki/PartDesign_Boolean.html new file mode 100644 index 0000000..00cd902 --- /dev/null +++ b/localwiki/PartDesign_Boolean.html @@ -0,0 +1,96 @@ +PartDesign Boolean

      PartDesign Boolean

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      PartDesign Boolean.png PartDesign Boolean

      +
      Menu location +
      Part Design → Boolean operation +
      Workbenches +
      PartDesign +
      Default shortcut +
      None +
      See also +
      None +

      + +
      +


      +

      +

      Description

      +

      PartDesign Boolean imports one or more PartDesign Bodies or PartDesign Clones (designated as "tool bodies") into the active PartDesign Body and applies a Boolean operation (fuse, cut or common). +

      available in version 0.17 +


      +

      +
      PartDesign Boolean example.png
      +

      On the left: active body (A) with tool bodies (B) and (C); result on the right after a Boolean Cut. +

      +

      How to use

      +
      1. Activate the Body which is to receive the Boolean feature. Note: It is important that neither the active Body nor any of the features it contains be selected!
      2. +
      3. Press the PartDesign Boolean.png Boolean button.
      4. +
      5. In Boolean Parameters, click on the Add body button. The active body temporarily disappears from the 3D view to facilitate tool body selection.
      6. +
      7. In the 3D view, select the Body to use in the Boolean feature. Repeat to add more Bodies.
      8. +
      9. Select the type of Boolean operation in the drop down menu (Fuse, Cut or Common)
      10. +
      11. Click OK.
      +

      Alternatively, one or more Bodies can be selected prior to pressing the Boolean button; they will be automatically added. +

      +

      Options

      +
      • Fuse: merges the tool body or bodies to the active body.
      • +
      • Cut: subtracts the tool body or bodies from the active body.
      • +
      • Common: extracts the intersection from the selected body or bodies with the active body
      • +
      • Press the Remove body button to remove a body, by selecting it in the 3D view.
      +

      Properties

      +
      • DATAType: sets the Boolean operation (Fuse, Cut, Common)
      • +
      • DATALabel: name given to the operation, this name can be changed at convenience.
      • +
      • DATAGroup: lists the tool bodies.
      • +
      • VIEWDisplay: sets the display between 2 modes: +
        • Result (default): displays the result of the Boolean feature. In this mode, the tool Bodies cannot be displayed in their original state, even when their visibility is toggled on.
        • +
        • Tools: displays the tool Bodies in their original state. This mode is useful when editing tool Bodies is needed.
      • +
      • VIEWSelectable: true or false. If set to false, the feature cannot be selected in the 3D view.
      • +
      • VIEWVisibility: true or false. Toggles the feature's visibility in the 3D view.
      +

      Limitations

      +
      • For Common to work with more than one tool body, they must all intersect each other along with the active Body.
      • +
      • Tool bodies adopt the local origin of the active Body. If the active Body is not located at (0,0,0) in the global coordinate system, the tool bodies' placement need to be relative to the active Body. It may be easier to leave the active Body's placement at the origin before applying the Boolean feature, then to change its placement.
      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/PartDesign_Boolean.svg b/localwiki/PartDesign_Boolean.svg new file mode 100644 index 0000000..c69acb4 --- /dev/null +++ b/localwiki/PartDesign_Boolean.svg @@ -0,0 +1,71 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + [jrheinlaender] + + + PartDesign_Boolean + 2013-05-22 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/PartDesign/Gui/Resources/icons/PartDesign_Boolean.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + diff --git a/localwiki/PartDesign_Boolean_example.png b/localwiki/PartDesign_Boolean_example.png new file mode 100644 index 0000000..aebd540 Binary files /dev/null and b/localwiki/PartDesign_Boolean_example.png differ diff --git a/localwiki/PartDesign_Chamfer.html b/localwiki/PartDesign_Chamfer.html new file mode 100644 index 0000000..130db83 --- /dev/null +++ b/localwiki/PartDesign_Chamfer.html @@ -0,0 +1,81 @@ +PartDesign Chamfer

      PartDesign Chamfer

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      PartDesign Chamfer.png PartDesign Chamfer

      +
      Menu location +
      Part Design → Chamfer +
      Workbenches +
      PartDesign, Complete +
      Default shortcut +
      None +
      See also +
      Chamfer Part +

      + +
      +


      +

      +

      Description

      + + + +
      +
      Sélection des arêtes avant de démarrer la commande.
      +
      Réglage de la dimension du chanfrein dans les paramètres de chanfrein.
      +
      Un élément Chamfer est ajouté dans l'arborescence Projet.
      +
      +

      Usage

      +
      1. +
      2. +
      +

      PartDesign Chamfer VS. Part Chamfer

      +
      • +
      • +
      +
      +


      +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/PartDesign_Chamfer.svg b/localwiki/PartDesign_Chamfer.svg new file mode 100644 index 0000000..88f98bd --- /dev/null +++ b/localwiki/PartDesign_Chamfer.svg @@ -0,0 +1,97 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [wmayer] + + + PartDesign_Chamfer + 2012-09-10 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/PartDesign/Gui/Resources/icons/PartDesign_Chamfer.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/PartDesign_Clone.html b/localwiki/PartDesign_Clone.html new file mode 100644 index 0000000..c2b8127 --- /dev/null +++ b/localwiki/PartDesign_Clone.html @@ -0,0 +1,81 @@ +PartDesign Clone

      PartDesign Clone

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      PartDesign Clone.png PartDesign Clone

      +
      Menu location +
      PartDesign → Create a clone +
      Workbenches +
      PartDesign +
      Default shortcut +
      None +
      See also +
      Draft Clone +

      + +
      +


      +

      +

      Description

      +

      PartDesign Clone creates a linked copy of a selected object. Most types of objects are accepted, as long as they are single solids. The main use for the PartDesign Clone is to use an object created in another workbench for a PartDesign Boolean feature. It can also be simply used to create linked copies. +

      available in version 0.17 +


      +Clone.png +


      +Clone of the inner gear while beeing translated in 3D space as an independent object +

      +

      How to use

      +
      1. In the Model tree, select the object to be cloned.
      2. +
      3. Press the PartDesign Clone.png Create a clone button.
      +

      Properties

      +
      • DATABase Feature: sets the original object the clone is based on. To replace, press the ... button to get a list of available objects.
      • +
      • DATAPlacement: defines the orientation and position of the Clone in the 3D space. See Placement.
      • +
      • DATALabel: label given to the Clone object. Change to suit your needs.
      +

      Limitations

      + +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/PartDesign_Clone.svg b/localwiki/PartDesign_Clone.svg new file mode 100644 index 0000000..051b74a --- /dev/null +++ b/localwiki/PartDesign_Clone.svg @@ -0,0 +1,553 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + Fri May 4 19:21:54 2012 -0300 + + + [Yorik van Havre] + + + + + FreeCAD LGPL2+ + + + + + FreeCAD + + + FreeCAD/src/Mod/Draft/Resources/icons/Draft_Clone.svg + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + square + square + + + Two identical orange squares with dark outlines diagonally stacked from left to right and offset of each at the right corner of the leftmost bottom one + + + + diff --git a/localwiki/PartDesign_CompPrimitiveAdditive.html b/localwiki/PartDesign_CompPrimitiveAdditive.html new file mode 100644 index 0000000..4fe8d6b --- /dev/null +++ b/localwiki/PartDesign_CompPrimitiveAdditive.html @@ -0,0 +1,75 @@ +PartDesign CompPrimitiveAdditive

      PartDesign CompPrimitiveAdditive

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      PartDesign CompPrimitiveAdditive

      +
      Menu location +
      Part Design → Create an additive primitive +
      Workbenches +
      PartDesign +
      Default shortcut +
      None +
      See also +
      PartDesign CompPrimitiveSubtractive +

      + +
      +


      +

      +

      Description

      +

      Creates an additive primitive in the active Body as the first feature, or fuses it to the existing feature(s). If no Body is found in the document, one will be automatically created. +

      available in version 0.17 +


      +

      +

      Types of primitives

      + +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/PartDesign_CompPrimitiveSubtractive.html b/localwiki/PartDesign_CompPrimitiveSubtractive.html new file mode 100644 index 0000000..810b6c7 --- /dev/null +++ b/localwiki/PartDesign_CompPrimitiveSubtractive.html @@ -0,0 +1,75 @@ +PartDesign CompPrimitiveSubtractive

      PartDesign CompPrimitiveSubtractive

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      PartDesign CompPrimitiveSubtractive

      +
      Menu location +
      Part Design → Create a subtractive primitive +
      Workbenches +
      PartDesign +
      Default shortcut +
      None +
      See also +
      PartDesign CompPrimitiveAdditive +

      + +
      +


      +

      +

      Description

      +

      Creates a subtractive primitive in the active Body, subtracting its shape from the existing solid. +

      available in version 0.17 +


      +

      +

      Types of primitives

      + +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/PartDesign_CoordinateSystem.svg b/localwiki/PartDesign_CoordinateSystem.svg new file mode 100644 index 0000000..ea72b8b --- /dev/null +++ b/localwiki/PartDesign_CoordinateSystem.svg @@ -0,0 +1,129 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [Stefan Tröger] + + + PartDesign_CoordinateSystem + 2015-05-18 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/PartDesign/Gui/Resources/icons/PartDesign_CoordinateSystem.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/PartDesign_Draft.html b/localwiki/PartDesign_Draft.html new file mode 100644 index 0000000..878ff76 --- /dev/null +++ b/localwiki/PartDesign_Draft.html @@ -0,0 +1,110 @@ +PartDesign Draft

      PartDesign Draft

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      PartDesign Draft.png PartDesign Draft

      +
      Menu location +
      Part Design → Draft +
      Workbenches +
      Part Design +
      Default shortcut +
      None +
      See also +
      None +

      + +
      +


      +

      +

      Description

      +

      This tool creates angular draft on the selected faces of an object. A new separate Draft entry (followed by a sequential number if there are already existing drafts in the document) is created in the Project tree. +

      + + + +
      +
      Select one or more faces on the object before starting the tool. Here, 2 faces have been selected.
      +
      Showing Draft Parameter in TaskPanel.
      +
      2 faces have been added, and a 10 deg. draft applied. The bottom plane has remained dimensionally stable, while the draft has made the top plane smaller.
      +
      The Neutral Plane has been changed to the Top Surface. Now, the top plane has stayed dimensionally stable, while the draft has made the bottom plane larger.
      +
      Pull direction is set to the lower right edge, resulting in the draft pulling to the left.
      +
      Checking the Reverse Direction box has applied an inward draft rather than outward.
      +
      +

      Usage

      +
      • Select one or more faces on an object, then start the tool either by clicking its icon or going into the menu.
      • +
      • In Draft Parameters on the TaskPanel, set the required parameters and/or options as described below.
      • +
      • Click OK to validate.
      • +
      • To edit the draft after the function has been validated, either double-click on the Draft label in the Project tree, or right-click on it and select Edit Draft.
      +

      Parameters and Options

      +

      Add Face / Remove Face

      +

      Click Add Face or Remove Face, then select a single face to update the list of active faces. Repeat as needed. +

      +

      Draft Angle

      +

      Set the Draft Angle by entering a value or by clicking on the up/down arrows. The applied draft angle is shown in real time. +

      +

      Neutral Plane

      +

      Click Neutral Plane, then select the plane that must not change dimensionally. The change is made in real time. +

      +

      Pull Direction

      +

      Click Pull Direction, then select an edge. Pull Direction is only effective if the Neutral Plane has been set. Results can be unpredictable. +

      +

      Reverse Pull Direction

      +

      Checking Reverse Pull Direction will toggle the draft between positive and negative angles. +

      +

      Special Cases

      +

      The Draft tool will only function on faces that are normal to each other. If there are any tangential faces attached to the face you wish to apply draft to, it will fail. A common cause of failure is attempting to apply draft to a face that already has a fillet or chamfer applied to it. In this case, remove the tangential surface, apply the draft as need, then re-apply the fillet or chamfer. +

      +
      +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/PartDesign_Draft.svg b/localwiki/PartDesign_Draft.svg new file mode 100644 index 0000000..bb526af --- /dev/null +++ b/localwiki/PartDesign_Draft.svg @@ -0,0 +1,103 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [jrheinlaender] + + + PartDesign_Draft + 2012-11-25 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/PartDesign/Gui/Resources/icons/PartDesign_Draft.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/PartDesign_Fillet.html b/localwiki/PartDesign_Fillet.html new file mode 100644 index 0000000..e927343 --- /dev/null +++ b/localwiki/PartDesign_Fillet.html @@ -0,0 +1,107 @@ +PartDesign Fillet

      PartDesign Fillet

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      PartDesign Fillet.png PartDesign Fillet

      +
      Menu location +
      PartDesign → Fillet +
      Workbenches +
      PartDesign, Complete +
      Default shortcut +
      None +
      See also +
      Part Fillet +

      + +
      +


      +

      +

      Description

      +

      This tool creates fillets (rounds) on the selected edges of an object. A new separate Fillet entry (followed by a sequential number if there are already existing fillets in the document) is created in the Project tree. +

      +
      Select edges on the object before starting the tool.
      +
      Set the fillet radius in the Fillet parameters.
      +
      A Fillet object is added in the Project tree.
      +

      Usage

      +
      • Select a single or multiple edges on an object, then start the tool either by clicking its icon or going into the menu.
      • +
      • In Fillet parameters in the TaskPanel, set the fillet radius either by entering the value, or by clicking on the up/down arrows. The applied fillet is shown in real time.
      • +
      • Click OK to validate.
      • +
      • For a chain of edges tangential to one another, one single edge can be selected; the fillet will propagate along the chain.
      • +
      • To edit the fillet after the function has been validated, either double-click on the Fillet label in the Project tree, or right-click on it and select Edit Fillet.
      +

      PartDesign Fillet VS. Part Fillet

      +

      The PartDesign Fillet is not to be confused with its Part workbench counterpart. Although they share the same icon, they are not the same, and are not used the same way. +Here is how they differ from each other: +

      +
      • The PartDesign Fillet is parametric. After a fillet has been applied, its radius can be edited; this is not possible with the Part Fillet.
      • +
      • Edges must be selected on an object before activating the PartDesign Fillet. WIth the Part Fillet, the tool can be started, then a solid is selected, then edges.
      • +
      • The PartDesign Fillet creates a separate Fillet entry (followed by a sequential number if there are already existing fillets) in the Project tree. The Part Fillet becomes the parent of the object it was applied to.
      • +
      • The PartDesign Fillet offers a live preview of the fillet applied to the object before validating the function.
      • +
      • The Part Fillet supports variable radii (with a start radius and an end radius). The PartDesign fillet doesn't.
      +
      +


      +

      +

      Scripting

      +

      The tool text-top=Fillet Fillet can be used in a macro, and, from the Python console using the following function : +

      +
      Box = Box.makeFillet(3,[Box.Edges[0]]) # 1 Fillet
      +Box = Box.makeFillet(3,[Box.Edges[1],Box.Edges[2],Box.Edges[3],Box.Edges[4]]) # for several Fillets 
      +
      • 3 = radius
      • +
      • Box.Edges[2] = Edge with its number
      +


      +Example : +

      +
      import PartDesign
      +from FreeCAD import Base
      +
      +Box = Part.makeBox(10,10,10)
      +Box = Box.makeFillet(3,[Box.Edges[0]]) # pour 1 Fillet
      +Box = Box.makeFillet(3,[Box.Edges[1],Box.Edges[2],Box.Edges[3],Box.Edges[4]]) # for several Fillets
      +Part.show(Box) 
      +
      +


      +

      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/PartDesign_Fillet.svg b/localwiki/PartDesign_Fillet.svg new file mode 100644 index 0000000..aa7d0c1 --- /dev/null +++ b/localwiki/PartDesign_Fillet.svg @@ -0,0 +1,95 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [wmayer] + + + PartDesign_Fillet + 2012-09-10 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/PartDesign/Gui/Resources/icons/PartDesign_ + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/PartDesign_Groove.html b/localwiki/PartDesign_Groove.html new file mode 100644 index 0000000..a8f6d65 --- /dev/null +++ b/localwiki/PartDesign_Groove.html @@ -0,0 +1,118 @@ +PartDesign Groove

      PartDesign Groove

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      PartDesign Groove.png PartDesign Groove

      +
      Menu location +
      PartDesign → Groove +
      Workbenches +
      PartDesign, Complete +
      Default shortcut +
      None +
      See also +
      None +

      + +
      +


      +

      +

      Description

      +

      The Groove tool revolves a selected sketch or profile about a given axis, cutting out material from the support . +

      +
      PartDesign Groove example.svg
      +

      Above: sketch (A) is revolved around axis (B); resulting groove on solid (C) is shown right. +

      +

      How to use

      +
      1. Select the sketch to be revolved. +
        v0.17 and above A face on the existing solid can alternatively be used.
        +
        v0.16 and below The sketch must be mapped to the planar face of an existing solid or Part Design feature, or an error message will appear .
      2. +
      3. Press the PartDesign Groove.png Groove button.
      4. +
      5. Set the Groove parameters (see next section).
      6. +
      7. Press OK.
      +

      Options

      +

      When creating a groove, the Groove parameters dialogue offers several parameters specifying how the sketch should be revolved. +

      + + + +
      Partdesign groove parameters.png
      +
      +

      Axis

      +

      This option specifies the axis about which the sketch is to be revolved. +

      +
      • Vertical sketch axis: selects the vertical sketch axis .
      • +
      • Horizontal sketch axis: selects the horizontal sketch axis.
      • +
      • Sketch axis: v0.16 and below selects a construction line contained in the sketch used by the Groove. The first construction line created in the sketch will be labelled Sketch axis 0. The drop down list will contain one custom sketch axis for each construction line.
      • +
      • Construction line: v0.17 and above selects a construction line contained in the sketch used by the Groove. The drop down list will contain an entry for each construction line. The first construction line created in the sketch will be labelled Construction line 1.
      • +
      • Base (X/Y/Z) axis: v0.17 and above selects the X, Y or Z axis of the Body's Origin;
      • +
      • Select reference...: v0.17 and above allows selection in the 3D view of an edge on the Body, or a datum line.
      +

      Angle

      +

      This controls the angle through which the groove is to be formed, e.g. 360° would be a full, contiguous revolution. It is not possible to specify negative angles (use the Reversed option instead) or angles greater than 360° . +

      +

      Symmetric to plane

      +

      If checked, the groove will extend half of the specified angle in both directions from the sketch plane . +

      +

      Reversed

      +

      If checked, the direction of revolution is reversed from default clockwise to counterclockwise . +

      +
      +

      Properties

      +

      Below are properties which can be defined after creation of the feature. Data properties Base and Axis are uneditable . +

      +
      • DATAAngle: angle of rotation. See Angle .
      • +
      • DATALabel: label given to the operation, can be changed at convenience.
      • +
      • DATAMidplane: true or false. See Symmetric to plane.
      • +
      • DATAReversed: true or false. See Reversed.
      • +
      • DATARefine: v0.17 and above true or false. If set to true, cleans the solid from residual edges left by features. See Part RefineShape for more details.
      +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/PartDesign_Groove.svg b/localwiki/PartDesign_Groove.svg new file mode 100644 index 0000000..2620dc3 --- /dev/null +++ b/localwiki/PartDesign_Groove.svg @@ -0,0 +1,137 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [wmayer] + + + PartDesign_Groove + 2012-06-09 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/PartDesign/Gui/Resources/icons/PartDesign_Groove.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + diff --git a/localwiki/PartDesign_Groove_example.svg b/localwiki/PartDesign_Groove_example.svg new file mode 100644 index 0000000..4af9c48 --- /dev/null +++ b/localwiki/PartDesign_Groove_example.svg @@ -0,0 +1,864 @@ + + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + (C) + + (A) + (B) + + + diff --git a/localwiki/PartDesign_Hole.html b/localwiki/PartDesign_Hole.html new file mode 100644 index 0000000..8baf7e5 --- /dev/null +++ b/localwiki/PartDesign_Hole.html @@ -0,0 +1,115 @@ +PartDesign Hole

      PartDesign Hole

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      PartDesign Hole.png PartDesign Hole

      +
      Menu location +
      Part Design → Hole +
      Workbenches +
      PartDesign +
      Default shortcut +
      None +
      See also +
      PartDesign Pocket +

      + +
      +


      +

      +

      Description

      +

      The Hole feature creates one or more holes from a selected sketch. Many parameters can be set such as threading and size, fit, hole type (countersink, counterbore, straight) and more. +

      available in version 0.17 +

      +
      Countersunk and counterbored holes cross-section1.png
      Countersunk (to the left) and counterbored (to the right) holes cross section. +


      +

      +

      How to use

      +
      1. Press the PartDesign Hole.png Hole button.
      2. +
      3. If an existing unused sketch is found, it will be automatically be used. If more than one sketch is found, a Select feature panel appears to make a selection. Alternatively, a sketch can be selected before launching the Hole command.
      4. +
      5. Define the Hole parameters. See Options.
      6. +
      7. Press OK.
      +

      Options

      +

      Depending on which selection is made, some fields will activate or stay disabled. +

      +
      PartDesign Hole parameters.png
      +

      Threading and size

      +
      • Profile: if set to None, no threading info is defined. ISO and UTS thread profiles enable the Direction, Size, Fit and Class fields.
      • +
      • Threaded: check will add threading data to the Hole feature and the hole minor diameter is used. If left unchecked, the hole is considered non-threaded, and the nominal major diameter with defined Fit is chosen.
      • +
      • Direction: sets the thread direction (Right Hand or Left hand) if Threaded is checked.
      • +
      • Size: Sets the thread size. Requires Profile to be set to one of the ISO or UTS profiles.
      • +
      • Fit: defines standard or close fit for threaded profiles.
      • +
      • Class: defines the tolerance class.
      • +
      • Diameter: defines the hole diameter if the Profile was set to None.
      • +
      • Depth: depth of the hole from the sketch plane. Dimension enables a field to type a value. Through All will cut the hole through the whole Body.
      +

      Hole cut

      +
      • Type: sets type of hole cut: None is a straight hole; other types are Counterbore, Countersink, Cheesehead, Countersink socket screw and Cap screw.
      • +
      • Diameter: sets the major diameter for all hole cut types except None. Value is non-editable if a thread profile was selected in Profile.
      • +
      • Depth: depth of the hole cut type from the sketch plane. Value is non-editable if a thread profile was selected in Profile.
      • +
      • Countersink angle: angle of the conical hole cut. Value is non-editable if a thread profile was selected in Profile.
      +

      Drill point

      +
      • Type: defines the ending of the hole if Depth is set to Dimension. Flat produces a flat bottom; Angled sets a conical point.
      +

      Misc

      +
      • Tapered: sets a taper angle to the hole. Value is calculated from the sketch plane normal. 90 degrees sets a straight hole. A value under 90 generates a smaller hole radius at the bottom; a value over 90 enlarges the hole radius at the bottom.
      +
      +

      Properties

      +

      Much of the Data properties are the same as those shown in Options. +

      +
      • DATALabel: name given to the object, this name can be changed at convenience.
      • +
      • DATAReversed: true or false. Reverses extrusion direction.
      • +
      • DATARefine: true or false. If set to true, cleans the solid from residual edges left by features. See Part RefineShape for more details.
      +

      Limitations

      +
      • The selected sketch must contain one or more circle(s). The radius of the circle(s) inside the sketch is not taken into account. The generated holes will be identical even if the circles in the sketch have varying radii.
      • +
      • By default, the hole feature extrudes below the sketch plane. If the solid lies on the XY_Plane, and the hole sketch is attached to the XY_Plane, it will try to extrude away from the solid and seemingly produce no result. In such a case, the Reversed property needs to be manually set to true; otherwise the sketch needs to be mapped to the bottom face of the solid.
      +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/PartDesign_Hole.svg b/localwiki/PartDesign_Hole.svg new file mode 100644 index 0000000..8d25b09 --- /dev/null +++ b/localwiki/PartDesign_Hole.svg @@ -0,0 +1,646 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + + + + + + + + + + + diff --git a/localwiki/PartDesign_Hole_parameters.png b/localwiki/PartDesign_Hole_parameters.png new file mode 100644 index 0000000..e6981c2 Binary files /dev/null and b/localwiki/PartDesign_Hole_parameters.png differ diff --git a/localwiki/PartDesign_InternalExternalGear.svg b/localwiki/PartDesign_InternalExternalGear.svg new file mode 100644 index 0000000..155c7bc --- /dev/null +++ b/localwiki/PartDesign_InternalExternalGear.svg @@ -0,0 +1,95 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [Aglef Kaiser] + + + PartDesign_InternalExternalGear + 2014-08-08 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/PartDesign/Gui/Resources/icons/PartDesign_InternalExternalGear.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/PartDesign_InvoluteGear.html b/localwiki/PartDesign_InvoluteGear.html new file mode 100644 index 0000000..140bbcc --- /dev/null +++ b/localwiki/PartDesign_InvoluteGear.html @@ -0,0 +1,98 @@ +PartDesign InvoluteGear

      PartDesign InvoluteGear

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      PartDesign InvoluteGear.png PartDesign InvoluteGear

      +
      Menu location +
      Part Design → Involute gear... +
      Workbenches +
      PartDesign +
      Default shortcut +
      None +
      See also +
      None +

      + +
      +


      +

      +

      Description

      +

      This tool allows you to create a 2D profile of an involute gear. This 2D profile is fully parametric, and can be padded with the PartDesign Pad feature. +

      +
      PartDesign Involute Gear 01.png
      +
      +


      +

      +

      How to use

      +
      1. Go to the Part Design → PartDesign InvoluteGear.png Involute gear... menu.
      2. +
      3. Set the Involute parameters.
      4. +
      5. Click OK.
      6. +
      7. The involute gear is created outside of the active body. Drag and drop it into a body for the application of further features like padding.
      +

      Parameters

      +

      Number of teeth

      +

      Sets the number of teeth. +

      +

      Modules

      +

      Pitch diameter divided by the number of teeth. +

      +

      Pressure angle

      +

      Acute angle between the line of action and a normal to the line connecting the gear centers. Default is 20 degrees. (More info) +

      +

      High precision

      +

      True or false +

      +

      External gear

      +

      True or false +

      +

      Bugs

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/PartDesign_InvoluteGear.svg b/localwiki/PartDesign_InvoluteGear.svg new file mode 100644 index 0000000..25c2201 --- /dev/null +++ b/localwiki/PartDesign_InvoluteGear.svg @@ -0,0 +1,50 @@ + + + + + + + + + + + image/svg+xml + + + + + [jriegel] + + + PartDesign_InvoluteGear + 2014-02-16 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/PartDesign/Gui/Resources/icons/PartDesign_InvoluteGear.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + Layer 1 + + + + + + diff --git a/localwiki/PartDesign_Involute_Gear_01.png b/localwiki/PartDesign_Involute_Gear_01.png new file mode 100644 index 0000000..2fd6ae2 Binary files /dev/null and b/localwiki/PartDesign_Involute_Gear_01.png differ diff --git a/localwiki/PartDesign_Legacy.html b/localwiki/PartDesign_Legacy.html new file mode 100644 index 0000000..0385eb6 --- /dev/null +++ b/localwiki/PartDesign_Legacy.html @@ -0,0 +1,266 @@ +PartDesign Legacy

      PartDesign Legacy

      + +
      This page is written for FreeCAD v0.16. The upcoming v0.17 release brings major changes to the PartDesign workbench. If you are using a development version of v0.17, please refer to the updated PartDesign Workbench page.
      +


      +The Part Design Workbench provides tools for modelling complex solid parts and is based on a Feature editing methodology to produce a single contiguous solid. It is intricately linked with the Sketcher Workbench. +

      What is a single contiguous solid? This is an item like a casting or something machined from a single block of metal. If the item involves nails, screws, glue or welding, it is not a single contiguous solid. As a practical example, PartDesign would not be used to model a wooden chair, but would be used to model the subcomponents (legs, slats, seat, etc). The subcomponents are combined using the Assembly, Part or Draft workbench. +


      +PartDesign Example.png +

      + + +

      Basic Workflow

      +

      The sketch is the building block for creating and editing solid parts. The workflow can be summarized by this: a sketch containing 2D geometry is created first, then a solid creation tool is used on the sketch. At the moment the available tools are: +

      +
      • PartDesign Pad.png Pad which extrudes a sketch
      • +
      • PartDesign Pocket.png Pocket which creates a pocket on an existing solid
      • +
      • PartDesign Revolution.png Revolution which creates a solid by revolving a sketch along an axis
      • +
      • PartDesign Groove.png Groove which creates a groove in an existing solid
      +

      More tools are planned in future releases. +

      A very important concept in the PartDesign Workbench is the sketch support. Sketches can be created on standard planes (XY, XZ, YZ and planes parallel to them) or on a planar face of an existing solid. For this last case, the existing solid becomes the support of the sketch. Several tools will only work with sketches that have a support, for example, Pocket - without a support there would be nothing to remove material from! +

      After solid geometry has been created it can be modified with chamfers and fillets or transformed, e.g. mirrored or patterned. +

      The PartDesign Workbench is meant to create a single, connected solid. Multiple solids will be possible with the Assembly workbench. +

      As we create a model in the Part Design Workbench, each feature takes the shape of the last one and adds or removes something, creating linear dependencies from feature to feature as the model is created. Hence a "Cut" feature is not only the cut hole itself, but the whole part with the cut. As a new feature is added to the model, FreeCAD turns off visibility of the old features. The user usually should only have the newest item (feature) in the model tree visible, because otherwise the other phases of the model overlay each other, and holes are filled in by the earlier model features that didn't yet have those holes. +

      To toggle visibility of an object on or off, select it in the hierarchy tree and press the Spacebar. Usually everything but the last item in the hierarchy tree should be greyed out and therefore not visible in the 3D view. +

      +

      The Tools

      +

      The Part Design tools are all located in the Part Design menu that appears when you load the Part Design module. +

      They include the Sketcher Workbench tools, since the Part Design module is so dependent on them. +

      +

      The Sketcher Tools

      +

      Sketcher Geometries

      +

      These are tools for creating objects. +

      +
      • Sketcher CreatePoint.png Point: Draws a point.
      • +
      • Sketcher Line.png Line by 2 point: Draws a line segment from 2 points.
      • +
      • Sketcher Arc.png Arc: Draws an arc segment from center, radius, start angle and end angle.
      • +
      • Sketcher CreateArc3Point.png Arc by 3 Point: Draws an arc segment from two endpoints and another point on the circumference.
      • +
      • Sketcher Circle.png Circle: Draws a circle from center and radius.
      • +
      • Sketcher CreateCircle3Point.png Circle by 3 Point : Draws a circle from three points on the circumference.
      • +
      • Sketcher Conics.png Conic sections: +
        • Sketcher CreateEllipse.png Ellipse by center : Draws an ellipse by center point, major radius point and minor radius point. (v0.15)
        • +
        • Sketcher CreateEllipse 3points.png Ellipse by 3 points : Draws an ellipse by major diameter (2 points) and minor radius point. (v0.15)
        • +
        • Sketcher Elliptical Arc.png Arc of ellipse : Draws an arc of ellipse by center point, major radius point, starting point and ending point. (v0.15)
        • +
        • Sketcher Hyperbolic Arc.png Arc of hyperbola: Draws an arc of hyperbola. (v0.17)
        • +
        • Sketcher Parabolic Arc.png Arc of parabola: Draws an arc of parabola. (v0.17)
      • +
      • Sketcher CreatePolyline.png Polyline (multiple-point line): Draws a line made of multiple line segments. Pressing the M key while drawing a Polyline toggles between the different polyline modes.
      • +
      • Sketcher CreateRectangle.png Rectangle: Draws a rectangle from 2 opposite points.
      • +
      • Sketcher CreateTriangle.png Triangle: Draws a regular triangle inscribed in a construction geometry circle. (v0.15)
      • +
      • Sketcher CreateSquare.png Square: Draws a regular square inscribed in a construction geometry circle. (v0.15)
      • +
      • Sketcher CreatePentagon.png Pentagon: Draws a regular pentagon inscribed in a construction geometry circle. (v0.15)
      • +
      • Sketcher CreateHexagon.png Hexagon: Draws a regular hexagon inscribed in a construction geometry circle. (v0.15)
      • +
      • Sketcher CreateHeptagon.png Heptagon: Draws a regular heptagon inscribed in a construction geometry circle. (v0.15)
      • +
      • Sketcher CreateOctagon.png Octagon: Draws a regular octagon inscribed in a construction geometry circle. (v0.15)
      • +
      • Sketcher CreateSlot.png Slot: Draws an oval by selecting the center of one semicircle and an endpoint of the other semicircle.
      • +
      • Sketcher CreateFillet.png Fillet: Makes a fillet between two lines joined at one point. Select both lines or click on the corner point, then activate the tool.
      • +
      • Sketcher Trimming.png Trimming: Trims a line, circle or arc with respect to the clicked point.
      • +
      • Sketcher External.png External Geometry: Creates an edge linked to external geometry.
      • +
      • Sketcher ToggleConstruction.png Construction Mode: A construction object will be shown in blue and will not be used in a 3D geometry operation. It is only visible while editing the Sketch that contains it. Selecting existing Sketcher geometry and then clicking this tool toggles that geometry between regular and construction mode. Selecting this tool when no Sketcher geometry is selected changes the mode (regular vs. construction) in which future objects will be created.
      +

      Sketcher Constraints

      +

      Constraints are used to define lengths, set rules between sketch elements, and to lock the sketch along the vertical and horizontal axes. Some constraints require the Helper constraints +

      Not associated with numeric data +

      +
      • Constraint PointOnPoint.png Coincident: Affixes a point onto (coincident with) one or more other points.
      • +
      • Constraint PointOnObject.png Point On Object: Affixes a point onto another object such as a line, arc, or axis.
      • +
      • Constraint Vertical.png Vertical: Constrains the selected lines or polyline elements to a true vertical orientation. More than one object can be selected before applying this constraint.
      • +
      • Constraint Horizontal.png Horizontal: Constrains the selected lines or polyline elements to a true horizontal orientation. More than one object can be selected before applying this constraint.
      • +
      • Constraint Parallel.png Parallel: Constrains two or more lines parallel to one another.
      • +
      • Constraint Perpendicular.png Perpendicular: Constrains two lines perpendicular to one another, or constrains a line perpendicular to an arc endpoint.
      • +
      • Constraint Tangent.png Tangent: Creates a tangent constraint between two selected entities, or a co-linear constraint between two line segments. A line segment does not have to lie directly on an arc or circle to be constrained tangent to that arc or circle.
      • +
      • Constraint EqualLength.png Equal Length: Constrains two selected entities equal to one another. If used on circles or arcs their radii will be set equal.
      • +
      • Constraint Symmetric.png Symmetric: Constrains two points symmetrically about a line, or constrains the first two selected points symmetrically about a third selected point.
      • +
      • Sketcher ConstrainBlock.png Constrain Block: v 0.17 Basically allows to block a geometric element in place with a single constraint. I should be particularly useful to work with B-Splines. See https://forum.freecadweb.org/viewtopic.php?f=9&t=26572
      +

      Associated with numeric data +

      For these constraints you can use the expressions. The data may be taken from a spreadsheet. +

      +
      • Sketcher ConstrainLock.png Lock: Constrains the selected item by setting vertical and horizontal distances relative to the origin, thereby locking the location of that item. These constraint distances can be edited later.
      • +
      • Constraint HorizontalDistance.png Horizontal Distance: Fixes the horizontal distance between two points or line endpoints. If only one item is selected, the distance is set to the origin.
      • +
      • Constraint VerticalDistance.png Vertical Distance: Fixes the vertical distance between 2 points or line endpoints. If only one item is selected, the distance is set to the origin.
      • +
      • Constraint Length.png Length: Defines the distance of a selected line by constraining its length, or defines the distance between two points by constraining the distance between them.
      • +
      • Constraint Radius.png Radius: Defines the radius of a selected arc or circle by constraining the radius.
      • +
      • Constraint InternalAngle.png Internal Angle: Defines the internal angle between two selected lines.
      • +
      • Constraint SnellsLaw.png Snell's Law: Constrains two lines to obey a refraction law to simulate the light going through an interface. (v 0.15)
      • +
      • Constraint InternalAlignment.png Internal Alignment: Aligns selected elements to selected shape (e.g. a line to become major axis of an ellipse).
      +


      +

      +
      • Sketcher ToggleConstraint.png Toggle Constraint: Toggles the toolbar or the selected constraints to/from reference mode. v0.16
      +

      Other

      +
      • Sketcher NewSketch.png New sketch: Creates‎ a new sketch on a selected face or plane. If no face is selected while this tool is executed the user is prompted to select a plane from a pop-up window.
      + + +
      • Sketcher ViewSketch.png View sketch: Sets the model view perpendicular to the sketch plane.
      + + +
      • Validate sketch: It allows you to check if there are in the tolerance of different points and to match them.
      + +
      • Sketcher MirrorSketch.png Mirror sketch: Mirror a sketch along the x-axis, the y-axis or the origin [v 0.16]
      +


      +

      +
      • Sketcher CloseShape.png Close Shape: Creates a closed shape by applying coincident constraints to endpoints [v 0.15]
      +
      • Sketcher ConnectLines.png Connect Edges: Connect sketcher elements by applying coincident constraints to endpoints [v 0.15]
      + + + + + + + +
      • Sketcher Element Ellipse All.png Show/Hide internal geometry: Recreates missing/deletes unneeded geometry aligned to internal geometry of a selected element (applicable only to ellipse so far). [v 0.15]
      +
      • Sketcher Symmetry.png Symmetry: Copies a sketcher element symmetrical to a chosen line [v 0.16]
      +
      • Sketcher Clone.png Clone: Clones a sketcher element [v 0.16]
      +
      • Sketcher Copy.png Copy: Copies a sketcher element [v 0.16]
      + + +

      Preferences

      + +


      +

      +

      The Part Design Tools

      +

      Construction tools

      +

      These are tools for creating solid objects or removing material from an existing solid object. +

      +
      • PartDesign Pad.png Pad: Extrudes a solid object from a selected sketch.
      • +
      • PartDesign Pocket.png Pocket: Creates a pocket from a selected sketch. The sketch must be mapped to an existing solid object's face.
      • +
      • PartDesign Revolution.png Revolution: Creates a solid by revolving a sketch around an axis. The sketch must be a closed profile to get a solid object.
      • +
      • PartDesign Groove.png Groove: Creates a groove by revolving a sketch around an axis. The sketch must be mapped to an existing solid object's face.
      +

      Modification tools

      +

      These are tools for modifying existing objects. They will allow you to choose which object to modify. +

      +
      • PartDesign Fillet.png Fillet: Fillets (rounds) edges of an object.
      • +
      • PartDesign Chamfer.png Chamfer: Chamfers edges of an object.
      • +
      • PartDesign Draft.png Draft: Applies angular draft to faces of an object.
      +

      Transformation tools

      +

      These are tools for transforming existing features. They will allow you to choose which features to transform. +

      +
      • PartDesign Mirrored.png Mirrored: Mirrors features on a plane or face.
      • +
      • PartDesign LinearPattern.png Linear Pattern: Creates a linear pattern of features.
      • +
      • PartDesign PolarPattern.png Polar Pattern: Creates a polar pattern of features.
      • +
      • PartDesign Scaled.png Scaled: Scales features to a different size.
      • +
      • PartDesign MultiTransform.png MultiTransform: Allows creating a pattern with any combination of the other transformations.
      +

      Boolean tools

      +

      These are tools for create boolean operation with two or more bodies +

      +
      • PartDesign Boolean.png Boolean: Creates boolean operation with two or more bodies
      +


      +

      +

      Extras

      +

      Some optional functionality that has been created for the PartDesign Workbench: +

      +
      • PartDesign WizardShaft.png Shaft design wizard: Generates a shaft from a table of values and allows to analyze forces and moments
      + +


      +


      +

      +

      Feature properties

      +

      Properties

      +

      There are two types of feature properties, accessible through tabs at the bottom of the Property editor: +

      +
      VIEWView :properties related to the visual display of the object.
      +
      DATAData : properties related to the physical parameters of an object.
      +

      View

      +
      PartDesign Revolution en 03.png
      +

      Base +

      +
      • VIEWBounding Box : To view the occupation, and, overall, of the object dimensions in space. Value False, or True (Default, False).
      +
      • VIEWControl Point : Value False, or True (Default, False).
      +
      • VIEWDeviation : Sets the accuracy of the polygonal representation of the model in 3d view (tessellation). Lower values = better quality. The value is in percent of object's size (deviation in mm = (w+h+d)/3*valueInPercent/100, where w,h,d are sizes of bounding box).
      +
      • VIEWDisplay Mode :Display mode of the form, Flat lines, Shaded, Wireframe, Points Vue DisplayModePartDesign fr 00.png. (Default, Flat lines).
      +
      • VIEWLighting : Lighting One side, Two side Vue Lighting fr 00.png. (Default, Two side).
      +
      • VIEWLine Color : Gives the color of the line (edges) (Default, 25, 25, 25).
      +
      • VIEWLine Width : Gives the thickness of the line (edges) (Default, 2).
      +
      • VIEWPoint Color : Gives the color of the points (ends of the form) (Default, 25, 25, 25).
      +
      • VIEWPoint Size : Gives the size of the points (Default, 2).
      +
      • VIEWSelectable : Allows the selection of the form. Value False, ou True (Default, True).
      +
      • VIEWShape Color : Give the color shape (default, 204, 204, 204).
      +
      • VIEWTransparency : Sets the degree of transparency in the form of 0 to 100 (Default, 0).
      +
      • VIEWVisibility : Determines the visibility of the form (like the bar SPACE). Value False, or True (Default, True).
      +
      +


      +


      +

      +
      +


      +

      +

      Data

      +
      PartDesign Revolution en 04.png
      +

      Base +DATAAngle : The argument Angle, indicates the angle that will be used with the option Axis (below). Here, an angle is defined. The angle on the axis is set with the option Axis.
      The object takes the specified angle around the specified axis.
      An example, if you create an object with a required revolution should be rotate functionality of a certain amount, in order to enable it to take the same angle that another element existing. +

      DATAAxis : This option specifies the axis/axes to rotate the created object. The exact value of rotation comes from the angle (see above) option.
      This option takes three arguments, these arguments, are transmitted in the form of numbers, x, y or z. Adding a value, more of an axis, will the rotation to each specified axis angle.
      For example, with a Angle of 15 ° : specifying, 1.0 for x and 2.0 for y, will rotate 15 ° and 30 ° in the y-axis and the x-axis (final position), +

      DATABase : This option specifies the offset in either axes x, y, or z, and accept any number as the argument for each field. +

      DATALabel : The Label is the name given to the operation, this name can be changed at convenience. +

      DATAPlacement : [(0.00 0.00 1.00);0.00;(0.00 0.00 0.00)] Summary below data. +Every feature has a placement that can be controlled through the Data Properties table. It controls the placement of the part with respect to the coordinate system. NOTE: The placement options do not affect the physical dimensions of the feature, but merely its position in space!
      If you select the title Placement Options Placement, a button with three small points appears, clicking this button ..., you have access to the options window Tasks_Placement. +

      DATAAngle : +The Angle argument specifies the angle to be used with the axis option (below). An angle is set here, and the axis that the angle acts upon is set with the axis option. +The feature is rotated by the specified angle, about the specified axis. +A usage example might be if you created a revolution feature as required, but then needed to rotate the whole feature by some amount, in order to allow it to line-up with another pre-existing feature. +

      DATAAxis : +This option specifies the axis/axes about which the created feature is to be rotated. The exact value of rotation comes from the angle option (above). +This option takes three arguments, which are passed as numbers to either the x, y, or z boxes in the tool. Adding a value to more than one of the axes will cause the part to be rotated by the angle in each axis. +For example, with an angle of 15° set, specifying a value of 1.0 for x, and 2.0 for y will cause the finished part to be rotated 15° in the x-axis AND 30° in the y-axis. +

      DATAPosition : +This option specifies the base point to which all dimensions refer. This option takes three arguments, which are passed as numbers to either the x, y, or z boxes in the tool. Adding a value to more than one of the boxes will cause the part to be translated by the number of units along the corresponding axis. +

      +
      +

      PS: The displayed properties can vary, depending on the tool used. +


      +

      +

      Tutorials

      +

      Only for a development version of FreeCAD that is not currently available as a binary or installer: +

      + + + +


      +

      + +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/PartDesign_Line.html b/localwiki/PartDesign_Line.html new file mode 100644 index 0000000..42f25a0 --- /dev/null +++ b/localwiki/PartDesign_Line.html @@ -0,0 +1,85 @@ +PartDesign Line

      PartDesign Line

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      PartDesign Line.png PartDesign Line

      +
      Menu location +
      Part Design → Create a datum line +
      Workbenches +
      PartDesign +
      Default shortcut +
      None +
      See also +
      PartDesign Point, PartDesign Plane +

      + +
      +


      +

      +

      Description

      +

      Creates a datum line which can be used as reference for sketches, other datum geometry or features. For example it can be used as revolution axis for Revolution and Groove features. +

      available in version 0.17 +

      +
      Datum line.png
      +

      Two Datum lines through opposite corners of the cube meet at the center of mass. +

      +

      How to use

      +
      1. Press the PartDesign Line.png Create a datum line button.
      2. +
      3. Define Line parameters. Select a first reference in the 3D view to filter the available attachment modes.
      4. +
      5. Depending on the selected reference, there may be one or more attachment modes available in the the list. The most likely one will automatically be selected and shown in bold in the list. The text Attached with mode along with the attachment mode name will appear in green at the top of the Parameters panel.
      6. +
      7. To add an additional reference, press the next Reference button. Once pressed its label changes to Selecting... until a selection is made.
      8. +
      9. Select an attachment mode in the list.
      10. +
      11. Define Attachment Offset values.
      12. +
      13. Press OK.
      +

      Options

      +

      Double-click the DatumLine label in the Model tree or right-click and select Edit datum in the contextual menu to edit its parameters. For more details about Attachment mode and Attachment offset, see Attachment. +

      +

      Properties

      +
      • DATAMapMode: lists the attachment mode used.
      • +
      • DATAAttachment Offset: applies a transformation (translation and rotation) in reference to the attachment placement.
      • +
      • DATALabel: name given to the object, this name can be changed at convenience.
      +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/PartDesign_Line.svg b/localwiki/PartDesign_Line.svg new file mode 100644 index 0000000..55576ad --- /dev/null +++ b/localwiki/PartDesign_Line.svg @@ -0,0 +1,91 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [jrheinlaender] + + + PartDesign_Line + 2013-05-22 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/PartDesign/Gui/Resources/icons/PartDesign_Line.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/PartDesign_LinearPattern.html b/localwiki/PartDesign_LinearPattern.html new file mode 100644 index 0000000..d706b8e --- /dev/null +++ b/localwiki/PartDesign_LinearPattern.html @@ -0,0 +1,128 @@ +PartDesign LinearPattern

      PartDesign LinearPattern

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      PartDesign LinearPattern.png PartDesign LinearPattern

      +
      Menu location +
      PartDesign → LinearPattern +
      Workbenches +
      PartDesign, Complete +
      Default shortcut +
      None +
      See also +
      None +

      + +
      +


      +

      +

      Description

      +

      The Linear pattern tool creates evenly spaced copies of a feature in a linear direction. Starting with v0.17, it can pattern multiple features. +

      +
      PartDesign LinearPattern example.svg
      +

      Above: An L-shaped pad (B) made on top of a base pad (A, also referred to as support) is used for a linear pattern. The result (C) is shown on the right. +

      +

      How to use

      +
      1. Select the feature(s) to be patterned. Alternatively, the feature can be selected from a dialogue after step 2. +
        v0.16 and below Only a single feature can be selected, and it must be the last one at the bottom of the feature tree.
      2. +
      3. Press the PartDesign LinearPattern.png LinearPattern button.
      4. +
      5. v0.17 and above Press Add feature to add a feature to be patterned. The feature must be visible in the 3D view: +
        1. Switch to the Model tree;
        2. +
        3. Select in the tree the feature to be added and press spacebar to make it visible in the 3D view;
        4. +
        5. Switch back to the Tasks panel;
        6. +
        7. Select the feature in the 3D view; it will be added to the list.
        8. +
        9. Repeat to add other features.
      6. +
      7. v0.17 and above Press Remove feature to remove a feature from the list, or right-click on the feature in the list and select Remove.
      8. +
      9. Define the Direction. See Options.
      10. +
      11. Define the Length (distance) between the last copied occurrence and the original feature.
      12. +
      13. Set the number of occurrences.
      14. +
      15. Press OK .
      +

      Options

      +
      LinearPattern parameters in v0.16 and below.
      +
      LinearPattern parameters in v0.17 and above.
      +

      Direction

      +

      When creating a linear pattern feature, the LinearPattern parameters dialogue offers different ways of specifying the pattern direction. +

      +

      Horizontal sketch axis

      +

      Uses the horizontal axis of the sketch for direction. +

      +

      Vertical sketch axis

      +

      Uses the vertical axis of the sketch for direction. +

      +

      Normal sketch axis

      +

      v0.17 and above Uses the normal axis of the sketch for direction. +

      +

      Select reference...

      +

      Allows you to select an edge (such as an edge of the object) to use for direction. +

      +

      Custom Sketch Axis

      +

      If the sketch which defines the feature to be patterned also contains a construction line (or lines), then the drop down list will contain one custom sketch axis for each construction line. The first construction line will be labelled Sketch axis 0. +

      +

      Base (X/Y/Z) axis

      +

      v0.17 and above Select one of the Body Origin's standard axis (X, Y or Z) as direction. +

      +
      +


      +

      +

      Limitations

      +
      • Pattern shapes may not overlap one another except for the special case of only two occurrences (original plus one copy)
      • +
      • Any pattern shapes that do not overlap the original's support will be excluded. This ensures that a PartDesign feature always consists of a single, connected solid
      • +
      • For further limitations, see the mirrored feature
      +
      +


      +

      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/PartDesign_LinearPattern.svg b/localwiki/PartDesign_LinearPattern.svg new file mode 100644 index 0000000..1488e30 --- /dev/null +++ b/localwiki/PartDesign_LinearPattern.svg @@ -0,0 +1,1907 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [jrheinlaender] + + + PartDesign_LinearPattern + 2012-09-07 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/PartDesign/Gui/Resources/icons/PartDesign_LinearPattern.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/PartDesign_LinearPattern_example.svg b/localwiki/PartDesign_LinearPattern_example.svg new file mode 100644 index 0000000..7f83d58 --- /dev/null +++ b/localwiki/PartDesign_LinearPattern_example.svg @@ -0,0 +1,517 @@ + + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + + + + + + + (A) + (B) + (C) + + + + + + + diff --git a/localwiki/PartDesign_Migrate.html b/localwiki/PartDesign_Migrate.html new file mode 100644 index 0000000..bdd3e8e --- /dev/null +++ b/localwiki/PartDesign_Migrate.html @@ -0,0 +1,76 @@ +PartDesign Migrate

      PartDesign Migrate

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      PartDesign Migrate

      +
      Menu location +
      Part Design → Migrate +
      Workbenches +
      PartDesign +
      Default shortcut +
      None +
      See also +
      +

      + +
      +


      +

      +

      Description

      +

      The PartDesign workbench in FreeCAD v0.17 introduces new tools and elements that are not recognized by older FreeCAD versions (0.16 and older). FreeCAD documents created in older versions can still be opened and edited. To benefit from the new features, they must be migrated via the menu PartDesign → Migrate. +

      available in version 0.17 +


      +

      +

      How to use

      +
      1. Open an older FreeCAD (≤ 0.16) document.
      2. +
      3. Switch to the PartDesign workbench.
      4. +
      5. Go to the Part DesignMigrate menu.
      6. +
      7. If the migration works, a Std Part.png Part container will be created which will hold one or more PartDesign Body.png Bodies, each hosting a chain of features.
      +

      Limitations

      +
      • Before starting the migration process, check if the model was built with automatic refine options enabled (in Edit → Preferences → Part design → General), and set your preferences accordingly. This can be easily determined by successively toggling the visibility of the features in the Model tree. If no residual edges are left between features such as Pads and Pockets, the automatic refine options were disabled.
      • +
      • If a document to migrate only contains sketches and PartDesign features, the migration process may likely succeed. Some features such as chamfers and fillets may require rebuilding.
      • +
      • If the document to migrate has a mixed Part/Part Design/Draft work flow, the conversion will most likely fail or at best produce unexpected results, and will need to be migrated manually.
      +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/PartDesign_Mirrored.html b/localwiki/PartDesign_Mirrored.html new file mode 100644 index 0000000..e8b6153 --- /dev/null +++ b/localwiki/PartDesign_Mirrored.html @@ -0,0 +1,128 @@ +PartDesign Mirrored

      PartDesign Mirrored

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      PartDesign Mirrored.png PartDesign Mirrored

      +
      Menu location +
      PartDesign → Mirrored +
      Workbenches +
      PartDesign, Complete +
      Default shortcut +
      None +
      See also +
      None +

      + +
      +


      +

      +

      Description

      +

      The Mirrored tool mirrors one feature on a plane. Starting with v0.17, it can mirror multiple features . +

      PartDesign Mirrored example.svg +

      Above: a Pocket feature was created from a sketch containing a circle (A), the Pocket was subsequently used to create a Mirrored feature. The sketch vertical axis (B) was used as axis of symmetry. The result (C) is shown on the right. +

      +

      How to use

      +
      1. Select the feature(s) to be mirrored. Alternatively, the feature can be selected from a dialogue after step 2. +
        v0.16 and below Only a single feature can be selected, and it must be the last one at the bottom of the feature tree.
      2. +
      3. Press the PartDesign Mirrored.png Mirrored button.
      4. +
      5. v0.17 and above Press Add feature to add a feature to be mirrored. The feature must be visible in the 3D view: +
        1. Switch to the Model tree;
        2. +
        3. Select in the tree the feature to be added and press spacebar to make it visible in the 3D view;
        4. +
        5. Switch back to the Tasks panel;
        6. +
        7. Select the feature in the 3D view; it will be added to the list.
        8. +
        9. Repeat to add other features.
      6. +
      7. v0.17 and above Press Remove feature to remove a feature from the list, or right-click on the feature in the list and select Remove.
      8. +
      9. Define the mirror plane. See Options.
      10. +
      11. Press OK.
      +

      Options

      +
      Mirrored parameters in v0.16 and below.
      +
      Mirrored parameters in v0.17 and above.
      +

      Plane

      +

      When creating a mirrored feature, the Mirrored parameters dialogue offers different ways of specifying the mirror line or plane . +

      +

      Horizontal sketch axis

      +

      Uses the horizontal axis of the sketch as the axis of symmetry. +

      +

      Vertical sketch axis

      +

      Uses the vertical axis of the sketch as the axis of symmetry. +

      +

      Select reference...

      +

      Allows you to select a plane (such as a face of an object) to use as a mirror plane . +

      +

      Custom Sketch Axis

      +

      If the sketch which defines the feature to be mirrored also contains a construction line (or lines), then the drop down list will contain one custom sketch axis for each construction line. The first construction line will be labelled 'Sketch axis 0'. The image below is an example with the sketch in edit mode showing that it includes a construction line for use as the Mirrored axis. +

      +
      PartDesign Mirrored axis fromconstructionlines.jpg
      +

      Base (XY/XZ/YZ) plane

      +

      v0.17 and above Select one of the Body Origin's standard planes (XY, XZ or YZ) . +

      +

      Preview

      +

      The mirror result can be previewed in real time before clicking OK by checking "Update view" . +

      +
      +


      +

      +

      Limitations

      +
      • v0.16 and below Only the last feature in the feature tree can be used for the Mirrored feature; therefore, +
        • it is not possible to choose more than one feature to be mirrored;
        • +
        • it is not possible to select more features to add to the list view of original features .
      +
      • v0.16 and below Once the Mirrored feature has been started or been completed, it is not possible to replace the original feature for a different one .
      +
      • The Mirrored feature cannot mirror a whole solid body. For that, see Part Mirror .
      +
      • The mirrored feature must intersect the solid (also called support) it is based on, or the command will fail .
      +


      +

      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/PartDesign_Mirrored.svg b/localwiki/PartDesign_Mirrored.svg new file mode 100644 index 0000000..1246dbc --- /dev/null +++ b/localwiki/PartDesign_Mirrored.svg @@ -0,0 +1,2097 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [jrheinlaender] + + + PartDesign_Mirrored + 2012-09-07 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/PartDesign/Gui/Resources/icons/PartDesign_Mirrored.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/PartDesign_Mirrored_axis_fromconstructionlines.jpg b/localwiki/PartDesign_Mirrored_axis_fromconstructionlines.jpg new file mode 100644 index 0000000..59046a2 Binary files /dev/null and b/localwiki/PartDesign_Mirrored_axis_fromconstructionlines.jpg differ diff --git a/localwiki/PartDesign_Mirrored_example.svg b/localwiki/PartDesign_Mirrored_example.svg new file mode 100644 index 0000000..fb3a7ef --- /dev/null +++ b/localwiki/PartDesign_Mirrored_example.svg @@ -0,0 +1,483 @@ + + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + + + + + + + + + + (A) + (B) + + + (C) + + diff --git a/localwiki/PartDesign_MoveFeature.html b/localwiki/PartDesign_MoveFeature.html new file mode 100644 index 0000000..907a015 --- /dev/null +++ b/localwiki/PartDesign_MoveFeature.html @@ -0,0 +1,71 @@ +PartDesign MoveFeature

      PartDesign MoveFeature

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Official icon not found PartDesign MoveFeature

      +
      Menu location +
      Contextual menu → Move object to other body +
      Workbenches +
      PartDesign +
      Default shortcut +
      None +
      See also +
      Set tip, Move object after other object +

      + +
      +


      +

      +

      Description

      +

      Move object to other body, as this command is labeled in the contextual menu, allows moving objects under a Body to another Body. The moved object is placed right below the other Body's tip. Sketches, datum geometry and features are supported. +

      available in version 0.17 +


      +

      +

      How to use

      +
      1. In the Model tree, right-click on the object to be moved.
      2. +
      3. Select Move object to other body.
      4. +
      5. In the Select body dialog, select the Body to move the object to from the drop-down menu.
      6. +
      7. Press OK.
      +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/PartDesign_MoveFeatureInTree.html b/localwiki/PartDesign_MoveFeatureInTree.html new file mode 100644 index 0000000..19b313d --- /dev/null +++ b/localwiki/PartDesign_MoveFeatureInTree.html @@ -0,0 +1,76 @@ +PartDesign MoveFeatureInTree

      PartDesign MoveFeatureInTree

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      PartDesign MoveFeatureInTree

      +
      Menu location +
      Contextual menu → Move object after other object +
      Workbenches +
      PartDesign +
      Default shortcut +
      None +
      See also +
      Set tip, Move object to other body +

      + +
      +


      +

      +

      Description

      +

      Move object after other object, as this command is labeled in the contextual menu, allows reordering of objects under a Body. Sketches, datum geometry and features are supported. +

      available in version 0.17 +


      +

      +

      How to use

      +
      1. In the Model tree, select the object(s) to be moved then right-click to open the contextual menu.
      2. +
      3. Select Move object after other object.
      4. +
      5. In the Select feature dialog, select the object under which to move the object(s).
      6. +
      7. Press OK.
      +

      Example

      +

      The following three pictures show the same model with a pocket defined on a sketch attached to the datum plane. The features are reordered from one picture to the other. This has the effect that the pocket makes either no hole or make holes in different pads, depending on the order of the features in the model tree. +

      +
      PD move feature0.png
      +
      Hole Pad002.png
      +
      PD move feature2.png
      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/PartDesign_MoveTip.html b/localwiki/PartDesign_MoveTip.html new file mode 100644 index 0000000..0bfcbf5 --- /dev/null +++ b/localwiki/PartDesign_MoveTip.html @@ -0,0 +1,74 @@ +PartDesign MoveTip

      PartDesign MoveTip

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      PartDesign MoveTip.png PartDesign MoveTip

      +
      Menu location +
      Contextual menu → Set tip +
      Workbenches +
      PartDesign +
      Default shortcut +
      None +
      See also +
      Move object to other body, Move object after other object +

      + +
      +


      +

      +

      Description

      +

      Set tip as this command is labeled in the contextual menu redefines the tip, which is the feature exposed outside of the Body. By default, the tip is the last feature added to the Body; but sometimes it can be useful to temporarily set the tip to a feature earlier in the tree. This may be done to add a sketch, datum geometry or a feature which in retrospect should have been created earlier in the Body's history. +

      The tip is visually distinguished in the Model tree by a small white down arrow in a green circle overlayed on the feature's icon. +

      +
      PartDesign Body tree-04.png
      +

      available in version 0.17 +


      +

      +

      How to use

      +
      1. In the Model tree, right-click on the feature to set as tip.
      2. +
      3. Select PartDesign MoveTip.png Set tip.
      4. +
      5. The new tip is set to visible, and all elements below the tip are hidden from view. Elements newly created from that point will be placed under the tip, and above the other existing elements.
      +

      Note: it is important not to forget to set the tip again to the last feature at the bottom of the Body tree. +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/PartDesign_MoveTip.svg b/localwiki/PartDesign_MoveTip.svg new file mode 100644 index 0000000..abc2268 --- /dev/null +++ b/localwiki/PartDesign_MoveTip.svg @@ -0,0 +1,111 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [blobfish] + + + PartDesign_MoveTip + 2015-05-03 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/PartDesign/Gui/Resources/icons/PartDesign_MoveTip.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/PartDesign_MultiTransform.html b/localwiki/PartDesign_MultiTransform.html new file mode 100644 index 0000000..46a69a3 --- /dev/null +++ b/localwiki/PartDesign_MultiTransform.html @@ -0,0 +1,127 @@ +PartDesign MultiTransform

      PartDesign MultiTransform

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      PartDesign MultiTransform.png PartDesign MultiTransform

      +
      Menu location +
      PartDesign -> MultiTransform +
      Workbenches +
      PartDesign, Complete +
      Default shortcut +
      None +
      See also +
      None +

      + +
      +


      +

      +

      Introduction

      +

      'Make a pattern from combinations of transformations' - This tool takes a set of one or more selected features as its input (the 'originals'), and allows to apply several transformations in sequence to them. For example, to produce a flange with a double row of holes, the hole (the 'original') is first patterned in a linear pattern in the X direction, and then patterned eight times in a polar pattern around the Y axis. +

      +
      Multitransform example.png
      +
      +


      +

      +

      Options

      + + + +
      Multitransfrom parameters.png
      +
      +

      When creating a multitransform feature, the 'multitransform parameters' dialogue offers two different list views. +

      +

      Select originals

      +

      The list view shows the 'originals', the features that are to be patterned. Clicking on any feature will add it to the list. +

      +

      Select transformations

      +

      This list can be filled with a combination of the simple transformations mirrored, linear pattern, polar pattern and scaled. The transformations will be applied one after the other. +The context menu offers the following entries: +

      +

      Edit

      +

      Allows editing the parameters of a transformation in the list (double-clicking will have the same effect) +

      +

      Delete

      +

      Removes a transformation from the list +

      +

      Add transformation

      +

      Adds a transformation to the list +

      +

      Move Up/Down

      +

      Allows changing the order of transformations in the list +

      +
      +
      +


      +

      +

      Limitations

      +
      • A scaled transformation should not be the first in the list
      • +
      • The scaled transformation must have the same number of occurrences as the transformation immediately preceding it in the list
      • +
      • For further limitations, see the linear pattern feature
      +
      +


      +

      +

      Examples

      +
      c
      +

      The smallest pad was first patterned three times in X direction and then scaled to factor two (so the three occurrences have scaling factor 1.0, 1.5 and 2.0). Then a polar pattern was applied with 8 occurrences. +

      +
      c
      +

      The pocket was first mirrored on the YZ plane and then patterned with two linear patterns to give a rectangular pattern. +

      +
      +


      +

      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/PartDesign_MultiTransform.svg b/localwiki/PartDesign_MultiTransform.svg new file mode 100644 index 0000000..e10d766 --- /dev/null +++ b/localwiki/PartDesign_MultiTransform.svg @@ -0,0 +1,1965 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [jrheinlaender] + + + PartDesign_MultiTransform + 2012-09-07 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/PartDesign/Gui/Resources/icons/PartDesign_MultiTransform.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/PartDesign_NewSketch.html b/localwiki/PartDesign_NewSketch.html new file mode 100644 index 0000000..d8630f8 --- /dev/null +++ b/localwiki/PartDesign_NewSketch.html @@ -0,0 +1,82 @@ +PartDesign NewSketch

      PartDesign NewSketch

      + +
      +

      This documentation is not finished. Please help and contribute documentation. +

      See Draft ShapeString for good documented Command. Gui Command gives an overview over commands. And see List of Commands for other commands. +

      Go to Help FreeCAD to contribute. +

      +
      +


      +

      + + + + + + + + + + + + + + + + + + + + +
      +

      PartDesign NewSketch.png PartDesign NewSketch

      +
      Menu location +
      PartDesign → Create sketch +
      Workbenches +
      PartDesign, Complete +
      Default shortcut +
      +
      See also +
      +

      + +
      +


      +

      +

      Description

      +

      available in version 0.17 +


      +

      +

      Use

      +
      1. Click on PartDesign NewSketch.png in the toolbar, or choose PartDesignPartDesign NewSketch.png Create sketch from the main menu.
      +

      Options

      +

      Limitations

      +

      Scripts

      +

      Links

      +

      Notes

      +
      + + + +
      + +
      +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/PartDesign_NewSketch.png b/localwiki/PartDesign_NewSketch.png new file mode 100644 index 0000000..45ea178 Binary files /dev/null and b/localwiki/PartDesign_NewSketch.png differ diff --git a/localwiki/PartDesign_Pad.html b/localwiki/PartDesign_Pad.html new file mode 100644 index 0000000..8cb4c3b --- /dev/null +++ b/localwiki/PartDesign_Pad.html @@ -0,0 +1,133 @@ +PartDesign Pad

      PartDesign Pad

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      PartDesign Pad.png PartDesign Pad

      +
      Menu location +
      Part Design → Pad +
      Workbenches +
      PartDesign, Complete +
      Default shortcut +
      None +
      See also +
      None +

      + +
      +


      +

      +

      Description

      +

      The Pad tool extrudes a sketch into a solid in a direction normal to the sketch plane. Starting with v0.17, faces on the solid can also be used. +

      +
      PartDesign Pad example.svg
      +

      Sketch (A) shown on the left; end result after pad operation (B) on the right. +

      v0.16 and below If the selected sketch is mapped to the face of an existing solid or another Part Design feature, the pad will be fused to it. +

      +

      How to use

      +
      1. Select the sketch to be padded. In v0.17 and above, a face on the existing solid can alternatively be used.
      2. +
      3. Press the PartDesign Pad.png Pad button.
      4. +
      5. Set the Pad parameters (see next section).
      6. +
      7. Click OK.
      +

      Options

      +

      When creating a pad, the Combo view automatically switches to the Tasks pane, showing the Pad parameters dialogue. +

      +
      Pad parameters cropped.png
      +

      Type

      +

      Type offers five different ways of specifying the length to which the pad will be extruded. +

      +

      Dimension

      +

      Enter a numeric value for the length of the pad. The default direction for extrusion is away (outside of) the support, but it can be changed by ticking the Reversed option. Extrusions occur normal to the defining sketch plane. With the option Symmetric to plane the pad will extend half of the given length to either side of the sketch plane. Negative dimensions are not possible. Use the Reversed option instead. +

      +

      Two dimensions

      +

      This allows to enter a second length in which the pad should extend in the opposite direction (into the support). Again can be changed by ticking the Reversed option. +

      +

      To last

      +

      The pad will extrude up to the last face of the support in the extrusion direction. If there is no support, an error message will appear. +

      +

      To first

      +

      The pad will extrude up to the first face of the support in the extrusion direction. If there is no support, an error message will appear. +

      +

      Up to face

      +

      The pad will extrude up to a face in the support that can be chosen by clicking on it. If there is no support, no selections will be accepted. +

      +

      Length

      +

      Defines the length of the pad. Multiple units can be used independently of the user's units preferences (m, cm, mm, nm, ft or ', in or "). +

      +

      Symmetric to plane

      +

      Tick the checkbox to extend half of the given length to either side of the sketch plane. +

      +

      Reversed

      +

      Reverses the direction of the pad. +

      +

      Properties

      +
      • DATARefine: v0.17 and above true or false. Cleans up residual edges left after the operation. This property is initially set according to the user's settings (found in Preferences → Part design → General → Model settings). It can be manually changed afterwards. This property will be saved with the FreeCAD document.
      +

      Limitations

      +
      • Like all Part Design features, Pad creates a solid, thus the sketch must include a closed profile or it will fail with a Failed to validate broken face error. There can be multiple enclosed profiles inside a larger one, provided none intersect each other (for example, a rectangle with two circles inside it).
      • +
      • The algorithm used for To First and To Last is: +
        • Create a line through the centre of gravity of the sketch
        • +
        • Find all faces of the support cut by this line
        • +
        • Choose the face where the intersection point is nearest/furthest from the sketch
      +
      This means that the face that is found might not always be what you expected. If you run into this problem, use the Up to face type instead, and pick the face you want.
      +
      For the very special case of extrusion to a concave surface, where the sketch is larger than this surface, extrusion will fail. This is a unresolved bug.
      +
      • v0.16 and below There is no automatic cleanup, e.g. of adjacent planar surfaces into a single surface. You can fix this manually in the Part workbench with Refine shape (which creates an unlinked, non-parametric solid) or with the Refine shape feature from the OpenSCAD Workbench which creates a parametric feature.
      +
      +


      +

      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/PartDesign_Pad.svg b/localwiki/PartDesign_Pad.svg new file mode 100644 index 0000000..590eb48 --- /dev/null +++ b/localwiki/PartDesign_Pad.svg @@ -0,0 +1,151 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [wmayer] + + + PartDesign_Pad + 2011-10-10 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/PartDesign/Gui/Resources/icons/PartDesign_Pad.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + diff --git a/localwiki/PartDesign_Pad_example.svg b/localwiki/PartDesign_Pad_example.svg new file mode 100644 index 0000000..a518353 --- /dev/null +++ b/localwiki/PartDesign_Pad_example.svg @@ -0,0 +1,405 @@ + + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + + + + + + + + + + + (A) + + (B) + + + + diff --git a/localwiki/PartDesign_Plane.html b/localwiki/PartDesign_Plane.html new file mode 100644 index 0000000..a5beb1d --- /dev/null +++ b/localwiki/PartDesign_Plane.html @@ -0,0 +1,85 @@ +PartDesign Plane

      PartDesign Plane

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      PartDesign Plane.png PartDesign Plane

      +
      Menu location +
      PartDesign → Create a datum plane +
      Workbenches +
      PartDesign, Complete +
      Default shortcut +
      None +
      See also +
      PartDesign Point, PartDesign Line +

      + +
      +


      +

      +

      Description

      +

      Creates a datum plane which can be used as reference for sketches or other datum geometry. Sketches can be attached to datum planes. +

      available in version 0.17 +

      +
      Datum plane.png
      +

      Datum Plane crossing 3 corners of the Cube with a Cylinder sketched on it using the Datum Plane as its X-Y Plane. +

      +

      How to use

      +
      1. Press the PartDesign Plane.png Create a datum plane button.
      2. +
      3. Define Plane parameters. Select a first reference in the 3D view to filter the available attachment modes.
      4. +
      5. Depending on the selected reference, there may be one or more attachment modes available in the the list. The most likely one will automatically be selected and shown in bold in the list. The text Attached with mode along with the attachment mode name will appear in green at the top of the Parameters panel.
      6. +
      7. To add an additional reference, press the next Reference button. Once pressed its label changes to Selecting... until a selection is made.
      8. +
      9. Select an attachment mode in the list.
      10. +
      11. Define Attachment Offset values.
      12. +
      13. Press OK.
      +

      Options

      +

      Double-click the DatumPlane label in the Model tree or right-click and select Edit datum in the contextual menu to edit its parameters. For more details about Attachment mode and Attachment offset, see Attachment. +

      +

      Properties

      +
      • DATAMapMode: lists the attachment mode used.
      • +
      • DATAAttachment Offset: applies a transformation (translation and rotation) in reference to the attachment placement.
      • +
      • DATALabel: name given to the object, this name can be changed at convenience.
      +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/PartDesign_Plane.svg b/localwiki/PartDesign_Plane.svg new file mode 100644 index 0000000..be44c95 --- /dev/null +++ b/localwiki/PartDesign_Plane.svg @@ -0,0 +1,130 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [jrheinlaender] + + + PartDesign_Plane + 2013-05-22 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/PartDesign/Gui/Resources/icons/PartDesign_Plane.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/PartDesign_Pocket.html b/localwiki/PartDesign_Pocket.html new file mode 100644 index 0000000..92f2935 --- /dev/null +++ b/localwiki/PartDesign_Pocket.html @@ -0,0 +1,108 @@ +PartDesign Pocket

      PartDesign Pocket

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      PartDesign Pocket.png PartDesign Pocket

      +
      Menu location +
      PartDesign → Pocket +
      Workbenches +
      PartDesign, Complete +
      Default shortcut +
      None +
      See also +
      None +

      + +
      +


      +

      +

      Description

      +

      The Pocket tool cuts out a solid by extruding a sketch in a straight path and subtracting it from the solid. +

      +
      PartDesign Pocket example.svg
      +

      Sketch profile (A) was mapped to the top face of base solid (B); result after pocketing through on the right. +

      +

      How to use

      +
      1. Select the sketch to be pocketed. +
        v0.16 and below The sketch must be mapped to the planar face of an existing solid or Part Design feature, or an error message will appear.
      2. +
      3. Press the PartDesign Pocket.png Pocket button.
      4. +
      5. Set the Pocket parameters (see next section).
      6. +
      7. Click OK.
      +

      Options

      +
      Pocket options.png
      +

      When creating a pocket, the Pocket parameters dialogue offers five different ways of specifying the length (depth) to which the pocket will be extruded: +

      +

      Dimension

      +

      Enter a numeric value for the depth of the pocket. The default direction for extrusion is into the support. Extrusions occur normal to the defining sketch plane. Negative dimensions are not possible. Use the Reversed option instead. +

      +

      To first

      +

      The pocket will extrude up to the first face of the support in the extrusion direction. In other words, it will cut through all material until it reaches an empty space. +

      +

      Through all

      +

      The pocket will cut through all material in the extrusion direction. With the option Symmetric to plane the pad will cut through all material in both directions. +

      +

      Up to face

      +

      The pocket will extrude up to a face in the support that can be chosen by clicking on it. +

      +

      Two dimensions

      +

      v0.17 and above This allows to enter a second length in which the pad should extend in the opposite direction (into the support). Again can be changed by ticking the Reversed option. +


      +

      +

      Limitations

      +
      • Use the type Dimension or Through All wherever possible because the other types sometimes give trouble when they are being patterned
      • +
      • Otherwise, the pocket feature has the same limitations as the pad feature.
      +

      Useful links

      +

      An example with the practice on the forum. +


      +

      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/PartDesign_Pocket.svg b/localwiki/PartDesign_Pocket.svg new file mode 100644 index 0000000..553223b --- /dev/null +++ b/localwiki/PartDesign_Pocket.svg @@ -0,0 +1,172 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [wmayer] + + + PartDesign_Pocket + 2011-10-10 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/PartDesign/Gui/Resources/icons/PartDesign_Pocket.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/PartDesign_Pocket_example.svg b/localwiki/PartDesign_Pocket_example.svg new file mode 100644 index 0000000..7b4de9a --- /dev/null +++ b/localwiki/PartDesign_Pocket_example.svg @@ -0,0 +1,455 @@ + + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + + + + + + + + + + (A) + (B) + + + diff --git a/localwiki/PartDesign_Point.html b/localwiki/PartDesign_Point.html new file mode 100644 index 0000000..bd03027 --- /dev/null +++ b/localwiki/PartDesign_Point.html @@ -0,0 +1,89 @@ +PartDesign Point

      PartDesign Point

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      PartDesign Point.png PartDesign Point

      +
      Menu location +
      Part Design → Create a datum point +
      Workbenches +
      PartDesign +
      Default shortcut +
      None +
      See also +
      PartDesign Line, PartDesign Plane +

      + +
      +


      +

      +

      Description

      +

      Creates a datum point which can be used as reference for sketches or other datum geometry. +

      available in version 0.17 +


      +DatumPoint.png +

      A datum point attached to a sphere with an attachment offset in Z = 2 +


      +

      +

      How to use

      +
      1. Press the PartDesign Point.png Create a datum point button.
      2. +
      3. Define Point parameters. Select a first reference in the 3D view to filter the available attachment modes.
      4. +
      5. Depending on the selected reference, there may be one or more attachment modes available in the the list. The most likely one will automatically be selected and shown in bold in the list. The text Attached with mode along with the attachment mode name will appear in green at the top of the Parameters panel.
      6. +
      7. To add an additional reference, press the next Reference button. Once pressed its label changes to Selecting... until a selection is made.
      8. +
      9. Select an attachment mode in the list.
      10. +
      11. Define Attachment Offset values.
      12. +
      13. Press OK.
      +

      Options

      +

      Double-click the DatumPoint label in the Model tree or right-click and select Edit datum in the contextual menu to edit its parameters. For more details about Attachment mode and Attachment offset, see Attachment. +

      +

      Properties

      +
      • DATAMapMode: lists the attachment mode used.
      • +
      • DATAAttachment Offset: applies a transformation (translation and rotation) in reference to the attachment placement.
      • +
      • DATALabel: name given to the object, this name can be changed at convenience.
      +

      Limitations

      +
      • The datum point cannot be used as section for Pipe and Loft features.
      +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/PartDesign_Point.svg b/localwiki/PartDesign_Point.svg new file mode 100644 index 0000000..28184db --- /dev/null +++ b/localwiki/PartDesign_Point.svg @@ -0,0 +1,80 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [jrheinlaender] + + + PartDesign_Point + 2013-05-22 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/PartDesign/Gui/Resources/icons/PartDesign_Point.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + diff --git a/localwiki/PartDesign_PolarPattern.html b/localwiki/PartDesign_PolarPattern.html new file mode 100644 index 0000000..e4a3499 --- /dev/null +++ b/localwiki/PartDesign_PolarPattern.html @@ -0,0 +1,108 @@ +PartDesign PolarPattern

      PartDesign PolarPattern

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      PartDesign PolarPattern.png PartDesign PolarPattern

      +
      Menu location +
      PartDesign -> PolarPattern +
      Workbenches +
      PartDesign, Complete +
      Default shortcut +
      None +
      See also +
      None +

      + +
      +


      +

      +

      Introduction

      +

      'Make a polar pattern of features' - This tool takes a selected feature and creates a set of rotated (by a chosen axis) copies.
      +The resulting object is created as a new seperate object in the tree view.
      +For example: +

      +
      Polarpattern example.png
      +
      +


      +

      +

      Options

      +

      When creating a polar pattern feature, the 'polar pattern parameters' dialogue offers two different ways of specifying the pattern rotation axis. +

      +

      Normal sketch axis

      +

      An axis being normal to the sketch and starting in the origin of the sketch of the feature being used is taken as axis for the polar pattern.
      +The pattern direction can be reversed by ticking 'Reverse direction'. +

      +

      Select reference

      +

      Here you can select an edge as a reference.
      +If that option is chosen only the edge of a feature being used just before the polar pattern-operation is choosable. +So you are able to use this option by: +

      +
      • creating a helper feature (for example a pad) with on of the edges being the axis of the polar pattern
      • +
      • create feature (pad or pocket) to be patterned
      • +
      • select polar pattern feature and select edge as reference
      • +
      • use another helper feature (for example pocket) to remove your first helper feature.
      +

      The pattern direction can be reversed by ticking 'Reverse direction'. +

      PartDesign PolarPattern EdgeReference.gif +


      +

      +

      Angle and Occurrences

      +

      Specifies the angle to be covered by the pattern, and the total number of pattern shapes (including the original feature). For example, four occurrences in an angle of 180 degrees would give a spacing of 60 degrees between patterns. There is one exception: If the angle is 360 degrees, since first and last occurrence are identical, four occurrences will be spaced 90 degrees apart. +

      +

      Limitations

      + +
      +


      +

      +

      Examples

      +
      Polarpattern example2.jpg
      +
      +


      +

      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/PartDesign_PolarPattern.svg b/localwiki/PartDesign_PolarPattern.svg new file mode 100644 index 0000000..64c87cd --- /dev/null +++ b/localwiki/PartDesign_PolarPattern.svg @@ -0,0 +1,1702 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [jrheinlaender] + + + PartDesign_PolarPattern + 2012-09-07 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/PartDesign/Gui/Resources/icons/PartDesign_PolarPattern.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/PartDesign_PolarPattern_EdgeReference.gif b/localwiki/PartDesign_PolarPattern_EdgeReference.gif new file mode 100644 index 0000000..592301f Binary files /dev/null and b/localwiki/PartDesign_PolarPattern_EdgeReference.gif differ diff --git a/localwiki/PartDesign_Preferences.html b/localwiki/PartDesign_Preferences.html new file mode 100644 index 0000000..191585d --- /dev/null +++ b/localwiki/PartDesign_Preferences.html @@ -0,0 +1,27 @@ +PartDesign Preferences

      PartDesign Preferences

      + +

      The preferences screen of the PartDesign are found in the Preferences window (Menu Edit → Preferences → PartDesign). +

      +

      General

      +

      Preference Part Design Tab 01.png +

      +
      +

      Shape view

      +

      Preference Part Design Tab 02.png +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/PartDesign_Revolution.html b/localwiki/PartDesign_Revolution.html new file mode 100644 index 0000000..cf35a64 --- /dev/null +++ b/localwiki/PartDesign_Revolution.html @@ -0,0 +1,128 @@ +PartDesign Revolution

      PartDesign Revolution

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      PartDesign Revolution.png PartDesign Revolution

      +
      Menu location +
      PartDesign → Revolution +
      Workbenches +
      PartDesign, Complete +
      Default shortcut +
      None +
      See also +
      None +

      + +
      +


      +

      +

      Introduction

      +

      The Revolution tool creates a solid by revolving a selected sketch or 2D object about a given axis. +

      +
      PartDesign Revolution example.svg
      +

      Above: sketch (A) is revolved 270 degrees counter-clockwise around axis (B); resulting solid (C) is shown right. +

      +

      How to use

      +
      1. Select the sketch to be revolved. v0.17 and above A face on the existing solid can alternatively be used.
      2. +
      3. Press the PartDesign Revolution.png Revolution button.
      4. +
      5. Set the Revolution parameters (see next section).
      6. +
      7. Press OK.
      +

      Options

      +

      When creating a revolution, the Revolution parameters dialogue offers several parameters specifying how the sketch should be revolved. +

      + + + +
      Partdesign revolution parameters.png
      +
      +

      Axis

      +

      This option specifies the axis about which the sketch is to be revolved. +

      +
      • Vertical sketch axis: selects the vertical sketch axis.
      • +
      • Horizontal sketch axis: selects the horizontal sketch axis.
      • +
      • Sketch axis: v0.16 and below selects a construction line contained in the sketch used by the Revolution. The first construction line created in the sketch will be labelled Sketch axis 0. The drop down list will contain one custom sketch axis for each construction line.
      • +
      • Construction line: v0.17 and above selects a construction line contained in the sketch used by the Revolution. The drop down list will contain an entry for each construction line. The first construction line created in the sketch will be labelled Construction line 1.
      • +
      • Base (X/Y/Z) axis: v0.17 and above selects the X, Y or Z axis of the Body's Origin;
      • +
      • Select reference...: v0.17 and above allows selection in the 3D view of an edge on the Body, or a datum line.
      +

      Angle

      +

      This controls the angle through which the revolution is to be formed, e.g. 360° would be a full, contiguous revolution. +The images in the examples section demonstrate some of the possibilities with specifying different angles. It is not possible to specify negative angles (use the Reversed option instead) or angles greater than 360° . +

      +

      Symmetric to plane

      +

      If checked, the revolution will extend half of the specified angle in both directions from the sketch plane. +

      +

      Reversed

      +

      If checked, the direction of revolution is reversed from default clockwise to counterclockwise. +

      +
      +
      +


      +

      +

      Properties

      +

      Below are properties which can be defined after creation of the feature. Data properties Base and Axis are uneditable. +

      +
      • DATAAngle: angle of rotation. See Angle.
      • +
      • DATALabel: label given to the operation, can be changed at convenience.
      • +
      • DATAMidplane: true or false. See Symmetric to plane.
      • +
      • DATAReversed: true or false. See Reversed.
      • +
      • DATARefine: v0.17 and above true or false. If set to true, cleans the solid from residual edges left by features. See Part RefineShape for more details.
      +

      Examples

      +
      Example revolution using a construction line as the Revolution axis: In this image the angle is 75°, revolution is about the construction line (Sketch axis 0)
      +
      +


      +

      +

      Useful links

      +

      A detailed example of use on the forum. +


      +

      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/PartDesign_Revolution.svg b/localwiki/PartDesign_Revolution.svg new file mode 100644 index 0000000..8cc17c3 --- /dev/null +++ b/localwiki/PartDesign_Revolution.svg @@ -0,0 +1,125 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [wmayer] + + + PartDesign_Revolution + 2011-10-10 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/PartDesign/Gui/Resources/icons/PartDesign_Revolution.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + diff --git a/localwiki/PartDesign_Revolution_axis_fromconstructionlines1.jpg b/localwiki/PartDesign_Revolution_axis_fromconstructionlines1.jpg new file mode 100644 index 0000000..1b245bb Binary files /dev/null and b/localwiki/PartDesign_Revolution_axis_fromconstructionlines1.jpg differ diff --git a/localwiki/PartDesign_Revolution_example.svg b/localwiki/PartDesign_Revolution_example.svg new file mode 100644 index 0000000..6eb7246 --- /dev/null +++ b/localwiki/PartDesign_Revolution_example.svg @@ -0,0 +1,535 @@ + + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + + + + + + + + + + + (A) + (B) + (C) + + + + + + diff --git a/localwiki/PartDesign_Scaled.html b/localwiki/PartDesign_Scaled.html new file mode 100644 index 0000000..9a95f60 --- /dev/null +++ b/localwiki/PartDesign_Scaled.html @@ -0,0 +1,104 @@ +PartDesign Scaled

      PartDesign Scaled

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      PartDesign Scaled.png PartDesign Scaled

      +
      Menu location +
      PartDesign → MultiTransform +
      Workbenches +
      PartDesign, Complete +
      Default shortcut +
      None +
      See also +
      None +

      + +
      +


      +

      +

      Note

      +

      Since FreeCAD 0.15, this feature is not available directly, but is included as MultiTransform component +

      +

      Introduction

      +

      'Scale features' - This tool takes a set of one or more selected features as its input (the 'originals'), and scales them by a given factor. Since the scaling takes place around the centre of gravity of the selected features, they usually disappear inside the scaled versions. Therefore, normally it is only useful to use scaling as part of the MultiTransform feature. +

      +

      Options

      + + + +
      Scaled parameters.png
      +
      +

      When creating a scaled feature, the 'scaled parameters' dialogue offers the following options: +

      +

      Select originals

      +

      The list view shows the 'originals', the features that are to be scaled. Clicking on any feature will add it to the list. +

      +

      Factor and Occurrences

      +

      Specifies the maximum factor which the features are to be scaled to, and the total number of scaled shapes (including the original feature). +

      +
      +
      +


      +

      +

      Limitations

      +
      • Scaling always happens with the centre of gravity of the feature as the base point.
      • +
      • A scaled transformation should not be the first in the list
      • +
      • The scaled transformation must have the same number of occurrences as the transformation immediately preceding it in the list
      • +
      • See linear pattern feature for other limitations
      • +
      • See MultiTransform for more details
      +

      Examples

      +
      c
      +

      The smallest pad was first patterned three times in X direction and then scaled to factor two (so the three occurrences have scaling factor 1.0, 1.5 and 2.0). Then a polar pattern was applied with 8 occurrences. +

      Since the scaling is done with respect to the center of gravity, in the case of a pad, it is necessary that the pad penetrate also in the main body, otherwise the scaled objects are floating, detached from the body. To have a pad that intersects the main body can be used "two dimensions" type or "simmetric to plane" option. +

      +
      +


      +

      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/PartDesign_Scaled.svg b/localwiki/PartDesign_Scaled.svg new file mode 100644 index 0000000..3b9db05 --- /dev/null +++ b/localwiki/PartDesign_Scaled.svg @@ -0,0 +1,1504 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [jrheinlaender] + + + PartDesign_Scaled + 2012-09-07 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/PartDesign/Gui/Resources/icons/PartDesign_Scaled.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/PartDesign_ShapeBinder.html b/localwiki/PartDesign_ShapeBinder.html new file mode 100644 index 0000000..e719015 --- /dev/null +++ b/localwiki/PartDesign_ShapeBinder.html @@ -0,0 +1,93 @@ +PartDesign ShapeBinder

      PartDesign ShapeBinder

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      PartDesign ShapeBinder.png PartDesign ShapeBinder

      +
      Menu location +
      Part Design → Create a shape binder +
      Workbenches +
      PartDesign +
      Default shortcut +
      None +
      See also +
      PartDesign Clone +

      + +
      +


      +

      +

      Description

      +

      Creates a datum shape binder from a selected Body inside the active Body. A shape binder is a reference object that links to edges or faces from another Body. An example of use would be to build a box with fitting cover in two different bodies. The shape binder object displays as translucent yellow in the 3D view. +

      available in version 0.17 +

      Shapebinder tree.png +

      +
      Shapebinder flow.png
      +

      Two shapes from Body.Pad004 are selected and their datum objects are now available in Body001.Sketch005 as external geometry through Body001.ShapeBinder. +

      +

      How to use

      +
      1. Activate target body (body to receive shape binder object).
      2. +
      3. Press the PartDesign ShapeBinder.png Create a shape binder button.
      4. +
      5. Press either the Object button or the Add geometry button.
      6. +
      7. In the 3D view, select the object or geometry to copy. Object will select the whole body; Add geometry will select any element (vertex, edge, face).
      8. +
      9. To remove selected geometry, press the Remove geometry button and select the geometry in the 3D view. To cancel, press the button again.
      10. +
      11. Alternatively, the Body to copy can be selected before launching the Shape binder command.
      12. +
      13. Press OK.
      +

      Options

      +

      Double-click the ShapeBinder label in the Model tree or right-click and select Edit shape binder in the contextual menu to edit its parameters. +

      +

      Properties

      +
      • DATALabel: name given to the object, this name can be changed at convenience.
      +

      Limitations

      +
      • Multiple selection is not supported. The Add geometry and Remove geometry buttons need to be pressed for each single selection.
      +

      There is a workaround for multiple selection: If you select all the elements you want to have before creating the ShapeBinder, they appear in the initial list. +

      +
      • A shape binder cannot serve as base feature.
      • +
      • Selected geometry on a body must be contiguous.
      • +
      • If the body to be copied is selected first before launching the command, or if the Object button is used, it is no longer possible to only select specific geometry elements.
      • +
      • The relative placement of the target body and the copied body is not taken into account. The shape binder will adopt the same internal coordinates as the copied body.
      +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/PartDesign_ShapeBinder.svg b/localwiki/PartDesign_ShapeBinder.svg new file mode 100644 index 0000000..9056a83 --- /dev/null +++ b/localwiki/PartDesign_ShapeBinder.svg @@ -0,0 +1,111 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [Stefan Tröger] + + + PartDesign_ShapeBinder + 2015-07-18 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/PartDesign/Gui/Resources/icons/PartDesign_ShapeBinder.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/PartDesign_Sphere_Parameter_en.jpg b/localwiki/PartDesign_Sphere_Parameter_en.jpg new file mode 100644 index 0000000..4b1dafa Binary files /dev/null and b/localwiki/PartDesign_Sphere_Parameter_en.jpg differ diff --git a/localwiki/PartDesign_SubtractiveBox.html b/localwiki/PartDesign_SubtractiveBox.html new file mode 100644 index 0000000..c99313b --- /dev/null +++ b/localwiki/PartDesign_SubtractiveBox.html @@ -0,0 +1,87 @@ +PartDesign SubtractiveBox

      PartDesign SubtractiveBox

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      PartDesign SubtractiveBox.png PartDesign SubtractiveBox

      +
      Menu location +
      Part Design → Create a subtractive primitive → Subtractive box +
      Workbenches +
      PartDesign +
      Default shortcut +
      None +
      See also +
      PartDesign CompPrimitiveSubtractive +

      + +
      +


      +

      +

      Description

      +

      Inserts a subtractive box in the active Body. Its shape is subtracted from the existing solid. +

      available in version 0.17 +


      +

      +
      PartDesign SubtractiveBox example.png
      +

      On the left: active body (A) shown in grey and subtractive box (B) shown in transparent red; result on the right. +

      +

      How to use

      +
      1. Press the PartDesign SubtractiveBox.png Subtractive Box button. Note: the Subtractive Box is part of an icon menu labelled Create a subtractive primitive. After launching FreeCAD, the Subtractive Box is the one displayed in the toolbar. If a different primitive is displayed, click on the down arrow besides the icon and select Subtractive Box in the menu.
      2. +
      3. Set the Primitive parameters and Attachment.
      4. +
      5. Click OK.
      6. +
      7. A Box feature appears under the active Body.
      +

      Options

      +

      The Box can be edited after its creation in two ways: +

      +
      • Double-clicking it in the Model tree, or by right-clicking and selecting Edit primitive in the contextual menu; this brings up the Primitive parameters.
      • +
      • Via the Property editor.
      +

      Properties

      +
      • DATAAttachment: defines the attachment mode as well as the Attachment Offset. See Part Attachment.
      • +
      • DATALabel: Label given to the Box object. Change to suit your needs.
      • +
      • DATALength: the Box's dimension in the X-direction.
      • +
      • DATAWidth: the Box's dimension in the Y-direction.
      • +
      • DATAHeight: the Box's dimension in the Z-direction.
      +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/PartDesign_SubtractiveBox.png b/localwiki/PartDesign_SubtractiveBox.png new file mode 100644 index 0000000..721d08f Binary files /dev/null and b/localwiki/PartDesign_SubtractiveBox.png differ diff --git a/localwiki/PartDesign_SubtractiveBox_example.png b/localwiki/PartDesign_SubtractiveBox_example.png new file mode 100644 index 0000000..4013728 Binary files /dev/null and b/localwiki/PartDesign_SubtractiveBox_example.png differ diff --git a/localwiki/PartDesign_SubtractiveCone.html b/localwiki/PartDesign_SubtractiveCone.html new file mode 100644 index 0000000..f309715 --- /dev/null +++ b/localwiki/PartDesign_SubtractiveCone.html @@ -0,0 +1,88 @@ +PartDesign SubtractiveCone

      PartDesign SubtractiveCone

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      PartDesign SubtractiveCone.png PartDesign SubtractiveCone

      +
      Menu location +
      Part Design → Create a subtractive primitive → Subtractive Cone +
      Workbenches +
      PartDesign +
      Default shortcut +
      None +
      See also +
      PartDesign CompPrimitiveSubtractive +

      + +
      +


      +

      +

      Description

      +

      Inserts a subtractive cone in the active Body. Its shape is subtracted from the existing solid. +

      available in version 0.17 +


      +

      +
      PartDesign SubtractiveCone example.png
      +

      On the left: active body (A) shown in grey and subtractive cone (B) shown in transparent red; result on the right. +

      +

      How to use

      +
      1. Press the PartDesign SubtractiveCone.png Subtractive Cone button. Note: the Subtractive Cone is part of an icon menu labelled Create a subtractive primitive. After launching FreeCAD, the Subtractive Box is the one displayed in the toolbar. To get to the Cone button, click on the down arrow besides the visible icon and select Subtractive Cone in the menu.
      2. +
      3. Set the Primitive parameters and Attachment.
      4. +
      5. Click OK.
      6. +
      7. A Cone feature appears under the active Body.
      +

      Options

      +

      The Cone can be edited after its creation in two ways: +

      +
      • Double-clicking it in the Model tree, or by right-clicking and selecting Edit primitive in the contextual menu; this brings up the Primitive parameters.
      • +
      • Via the Property editor.
      +

      Properties

      +
      • DATAAttachment: defines the attachment mode as well as the Attachment Offset. See Part Attachment.
      • +
      • DATALabel: label given to the Cone object. Change to suit your needs.
      • +
      • DATARadius1: the radius value at the cone's base.
      • +
      • DATARadius2: the radius value at the cone's top. A non-zero value creates a truncated cone.
      • +
      • DATAHeight: the height of the cone along its axis.
      • +
      • DATAAngle: angle of rotation of the cross section (360 degrees in a full cone).
      +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/PartDesign_SubtractiveCone.png b/localwiki/PartDesign_SubtractiveCone.png new file mode 100644 index 0000000..90e6290 Binary files /dev/null and b/localwiki/PartDesign_SubtractiveCone.png differ diff --git a/localwiki/PartDesign_SubtractiveCone_example.png b/localwiki/PartDesign_SubtractiveCone_example.png new file mode 100644 index 0000000..0e46800 Binary files /dev/null and b/localwiki/PartDesign_SubtractiveCone_example.png differ diff --git a/localwiki/PartDesign_SubtractiveCylinder.html b/localwiki/PartDesign_SubtractiveCylinder.html new file mode 100644 index 0000000..f9663df --- /dev/null +++ b/localwiki/PartDesign_SubtractiveCylinder.html @@ -0,0 +1,87 @@ +PartDesign SubtractiveCylinder

      PartDesign SubtractiveCylinder

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      PartDesign SubtractiveCylinder.png PartDesign SubtractiveCylinder

      +
      Menu location +
      Part Design → Create a subtractive primitive → Subtractive Cylinder +
      Workbenches +
      PartDesign +
      Default shortcut +
      None +
      See also +
      PartDesign CompPrimitiveSubtractive +

      + +
      +


      +

      +

      Description

      +

      Inserts a subtractive cylinder in the active Body. Its shape is subtracted from the existing solid. +

      available in version 0.17 +


      +

      +
      PartDesign SubtractiveCylinder example.svg
      +

      On the left: active body (A) shown in grey and subtractive cylinder (B) shown in transparent red; result on the right. +

      +

      How to use

      +
      1. Press the PartDesign SubtractiveCylinder.png Subtractive Cylinder button. Note: the Subtractive Cylinder is part of an icon menu labelled Create an subtractive primitive. After launching FreeCAD, the Subtractive Box is the one displayed in the toolbar. To get to the Cylinder button, click on the down arrow besides the visible icon and select Subtractive cylinder in the menu.
      2. +
      3. Set the Primitive parameters and Attachment.
      4. +
      5. Click OK.
      6. +
      7. A Cylinder feature appears under the active Body.
      +

      Options

      +

      The Cylinder can be edited after its creation in two ways: +

      +
      • Double-clicking it in the Model tree, or by right-clicking and selecting Edit primitive in the contextual menu; this brings up the Primitive parameters.
      • +
      • Via the Property editor.
      +

      Properties

      +
      • DATAAttachment: defines the attachment mode as well as the Attachment Offset. See Part Attachment.
      • +
      • DATALabel: label given to the Cylinder object. Change to suit your needs.
      • +
      • DATARadius: the radius value of the cylinder.
      • +
      • DATAAngle: angle of rotation of the cross section (360 degrees forms a full cylinder).
      • +
      • DATAHeight: the length of the cylinder along its axis.
      +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/PartDesign_SubtractiveCylinder.png b/localwiki/PartDesign_SubtractiveCylinder.png new file mode 100644 index 0000000..62ffea0 Binary files /dev/null and b/localwiki/PartDesign_SubtractiveCylinder.png differ diff --git a/localwiki/PartDesign_SubtractiveCylinder_example.svg b/localwiki/PartDesign_SubtractiveCylinder_example.svg new file mode 100644 index 0000000..2a868c1 --- /dev/null +++ b/localwiki/PartDesign_SubtractiveCylinder_example.svg @@ -0,0 +1,478 @@ + + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + + + + + + + + + + (B) + (A) + + + diff --git a/localwiki/PartDesign_SubtractiveEllipsoid.html b/localwiki/PartDesign_SubtractiveEllipsoid.html new file mode 100644 index 0000000..4fa906e --- /dev/null +++ b/localwiki/PartDesign_SubtractiveEllipsoid.html @@ -0,0 +1,90 @@ +PartDesign SubtractiveEllipsoid

      PartDesign SubtractiveEllipsoid

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      PartDesign SubtractiveEllipsoid.png PartDesign SubtractiveEllipsoid

      +
      Menu location +
      Part Design → Create an subtractive primitive → Subtractive Ellipsoid +
      Workbenches +
      PartDesign +
      Default shortcut +
      None +
      See also +
      PartDesign CompPrimitiveSubtractive +

      + +
      +


      +

      +

      Description

      +

      Inserts a subtractive ellipsoid in the active Body. Its shape is subtracted from the existing solid. +

      available in version 0.17 +


      +

      +
      PartDesign SubtractiveEllipsoid example.svg
      +

      On the left: active body (A) shown in grey and subtractive ellipsoid (B) shown in transparent red; result on the right. +

      +

      How to use

      +
      1. Press the PartDesign SubtractiveEllipsoid.png Subtractive Ellipsoid button. Note: the Subtractive Ellipsoid is part of an icon menu labelled Create an subtractive primitive. After launching FreeCAD, the Subtractive Box is the one displayed in the toolbar. To get to the Ellipsoid button, click on the down arrow besides the visible icon and select Subtractive Ellipsoid in the menu.
      2. +
      3. Set the Primitive parameters and Attachment.
      4. +
      5. Click OK.
      6. +
      7. An Ellipsoid feature appears under the active Body.
      +

      Options

      +

      The Ellipsoid can be edited after its creation in two ways: +

      +
      • Double-clicking it in the Model tree, or by right-clicking and selecting Edit primitive in the contextual menu; this brings up the Primitive parameters.
      • +
      • Via the Property editor.
      +

      Properties

      +
      • DATAAttachment: defines the attachment mode as well as the Attachment Offset. See Part Attachment.
      • +
      • DATALabel: label given to the Ellipsoid object. Change to suit your needs.
      • +
      • DATARadius1: the radius value along the ellipsoid's vertical axis; by default, parallel to the Z-axis.
      • +
      • DATARadius2: the radius value along the ellipsoid's length; by default, parallel to the X-axis.
      • +
      • DATARadius2: the radius value along the ellipsoid's width; by default, parallel to the Y-axis. At the default value of zero, the ellipsoid forms an oblate spheroid.
      • +
      • DATAAngle1: (labelled V parameter in the Primitive parameters) lower truncation of the ellipsoid, parallel to the circular cross section (-90 degrees in a full spheroid)
      • +
      • DATAAngle2: (unlabelled in the Primitive parameters) upper truncation of the ellipsoid, parallel to the circular cross section (90 degrees in a full spheroid).
      • +
      • DATAAngle3: (labelled U parameter in the Primitive parameters) angle of rotation of the elliptical cross section (360 degrees in a full spheroid).
      +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/PartDesign_SubtractiveEllipsoid.png b/localwiki/PartDesign_SubtractiveEllipsoid.png new file mode 100644 index 0000000..98e7de7 Binary files /dev/null and b/localwiki/PartDesign_SubtractiveEllipsoid.png differ diff --git a/localwiki/PartDesign_SubtractiveEllipsoid_example.svg b/localwiki/PartDesign_SubtractiveEllipsoid_example.svg new file mode 100644 index 0000000..02fccd3 --- /dev/null +++ b/localwiki/PartDesign_SubtractiveEllipsoid_example.svg @@ -0,0 +1,794 @@ + + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + + + + + + + + (B) + (A) + + + + + diff --git a/localwiki/PartDesign_SubtractiveLoft.html b/localwiki/PartDesign_SubtractiveLoft.html new file mode 100644 index 0000000..7238aa6 --- /dev/null +++ b/localwiki/PartDesign_SubtractiveLoft.html @@ -0,0 +1,96 @@ +PartDesign SubtractiveLoft

      PartDesign SubtractiveLoft

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      PartDesign SubtractiveLoft.png PartDesign SubtractiveLoft

      +
      Menu location +
      Part Design → Subtractive loft +
      Workbenches +
      PartDesign +
      Default shortcut +
      None +
      See also +
      Additive loft, Subtractive pipe +

      + +
      +


      +

      +

      Description

      +

      Subtractive Loft creates a subtractive solid in the active Body by making a transition between two or more sketches (also referred to as cross-sections). Its shape is then subtracted from the existing solid. +

      available in version 0.17 +


      +

      +

      How to use

      +
      1. Press the PartDesign SubtractiveLoft.png Subtractive loft button.
      2. +
      3. In the Select feature dialog, select a sketch to be used as first cross-section and click OK. +
        • Alternatively, a single sketch can be selected prior to pressing the Subtractive loft button.
      4. +
      5. In the Loft parameters, press the Add Section button.
      6. +
      7. Select a sketch in the 3D view. Repeat to select more sketches.
      8. +
      9. Set options if needed and click OK.
      +

      Options

      +
      • Ruled surface: makes straight transitions between cross-sections. Dos not apply to a loft with two cross-sections. If not checked, transitions will be smooth.
      • +
      • Closed: makes a transition from the last cross-section to the first, creating a loop.
      • +
      • Press the Remove Section button to remove a sketch, by selecting it in the 3D view.
      +

      Properties

      +
      • DATALabel: name given to the operation, this name can be changed at convenience.
      • +
      • DATASections: lists the sections used.
      • +
      • DATARuled: see Options.
      • +
      • DATAClosed: see Options.
      • +
      • DATAMidplane: N/A
      • +
      • DATAReversed: N/A
      • +
      • DATARefine: true or false. If set to true, cleans the solid from residual edges left by features. See Part RefineShape for more details.
      +

      Limitations

      +
      • Sketches must form closed profiles.
      • +
      • It is not possible to loft to a vertex.
      • +
      • A cross-section cannot lie on the same plane as the one immediately preceding it.
      • +
      • To better control the shape of the loft, it is recommended that all the cross-sections have the same number of segments. For example, for a loft between a rectangle and a circle, the circle may be broken down into 4 connected arcs.
      +

      Links

      + +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/PartDesign_SubtractiveLoft.png b/localwiki/PartDesign_SubtractiveLoft.png new file mode 100644 index 0000000..aaebcb3 Binary files /dev/null and b/localwiki/PartDesign_SubtractiveLoft.png differ diff --git a/localwiki/PartDesign_SubtractivePipe.html b/localwiki/PartDesign_SubtractivePipe.html new file mode 100644 index 0000000..43a578d --- /dev/null +++ b/localwiki/PartDesign_SubtractivePipe.html @@ -0,0 +1,95 @@ +PartDesign SubtractivePipe

      PartDesign SubtractivePipe

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      PartDesign SubtractivePipe.png PartDesign SubtractivePipe

      +
      Menu location +
      Part Design → Subtractive pipe +
      Workbenches +
      PartDesign +
      Default shortcut +
      None +
      See also +
      Additive pipe, Subtractive loft +

      + +
      +


      +

      +

      Description

      +

      Subtractive Pipe creates a subtractive solid in the active Body by sweeping one or more sketches (also referred to as cross-sections) along an open or closed path. Its shape is then subtracted from the existing solid. +

      available in version 0.17 +


      +

      +

      How to use

      +
      1. Press the PartDesign SubtractivePipe.png Subtractive pipe button.
      2. +
      3. In the Select feature dialog, select a sketch to be used as first cross-section and click OK. +
        • Alternatively, a single sketch can be selected prior to pressing the Subtractive pipe button.
      4. +
      5. In the Pipe parameters under Profile, press the Object button.
      6. +
      7. Select the sketch to be used as path in the 3D view: +
        • Alternatively, edges of the body can be selected by pressing Add Edge and selecting edges in the 3D view.
      8. +
      9. To use more than one cross-section, under Section transformation set the Transform mode to Multisection; press Add Section then select a sketch in the 3D view. Repeat for each additional cross-section.
      10. +
      11. Set options if needed and click OK.
      +

      Options

      +

      Properties

      +
      • DATALabel: name given to the operation, this name can be changed at convenience.
      • +
      • DATARefine: true or false. If set to true, cleans the solid from residual edges left by features. See Part RefineShape for more details.
      • +
      • DATASections: lists the sections used.
      • +
      • DATASpine Tangent: true or false (default). True extends the path to include tangent edges.
      • +
      • DATAAuxiliary Spine Tangent: true or false (default). True extends the auxiliary path to include tangent edges.
      • +
      • DATAAuxiliary Curvelinear: true or false (default). True calculates normal between equidistant points on both spines.
      • +
      • DATAMode: profile mode. See Options.
      • +
      • DATABinormal: binormal vector for corresponding orientation mode.
      • +
      • DATATransition: transition mode. Options are Transformed, Right Corner or Round Corner.
      • +
      • DATATransformation: Constant uses a single cross-section. Multisection uses two or more cross-sections. Linear, S-shape and Interpolation are currently not functional.
      +

      Limitations

      +
      • Sketches used for cross-sections must form closed profiles.
      • +
      • It is not possible to use a vertex as cross-section.
      • +
      • A cross-section cannot lie on the same plane as the one immediately preceding it.
      • +
      • To better control the shape of the pipe, it is recommended that all the cross-sections have the same number of segments. For example, for a pipe between a rectangle and a circle, the circle may be broken down into 4 connected arcs.
      +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/PartDesign_SubtractivePipe.png b/localwiki/PartDesign_SubtractivePipe.png new file mode 100644 index 0000000..795a336 Binary files /dev/null and b/localwiki/PartDesign_SubtractivePipe.png differ diff --git a/localwiki/PartDesign_SubtractivePrism.html b/localwiki/PartDesign_SubtractivePrism.html new file mode 100644 index 0000000..def1f01 --- /dev/null +++ b/localwiki/PartDesign_SubtractivePrism.html @@ -0,0 +1,87 @@ +PartDesign SubtractivePrism

      PartDesign SubtractivePrism

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      PartDesign SubtractivePrism.png PartDesign SubtractivePrism

      +
      Menu location +
      Part Design → Create a subtractive primitive → Subtractive Prism +
      Workbenches +
      PartDesign +
      Default shortcut +
      None +
      See also +
      PartDesign CompPrimitiveSubtractive +

      + +
      +


      +

      +

      Description

      +

      Inserts a subtractive prism in the active Body. Its shape is subtracted from the existing solid. +

      available in version 0.17 +


      +

      +
      PartDesign SubtractivePrism example.svg
      +

      On the left: active body (A) shown in grey and subtractive prism (B) shown in transparent red; result on the right. +

      +

      How to use

      +
      1. Press the PartDesign SubtractivePrism.png Subtractive Prism button. Note: the Subtractive Prism is part of an icon menu labelled Create an subtractive primitive. After launching FreeCAD, the Subtractive Box is the one displayed in the toolbar. To get the Prism, click on the down arrow besides the visible icon and select Subtractive Prism in the menu.
      2. +
      3. Set the Primitive parameters and Attachment.
      4. +
      5. Click OK.
      6. +
      7. A Prism feature appears under the active Body.
      +

      Options

      +

      The Prism can be edited after its creation in two ways: +

      +
      • Double-clicking it in the Model tree, or by right-clicking and selecting Edit primitive in the contextual menu; this brings up the Primitive parameters.
      • +
      • Via the Property editor.
      +

      Properties

      +
      • DATAAttachment: defines the attachment mode as well as the Attachment Offset. See Part Attachment.
      • +
      • DATALabel: label given to the Prism object. Change to suit your needs.
      • +
      • DATAPolygon: number of sides in the polygon cross-section of the prism.
      • +
      • DATACircumradius: circumscribed radius of the polygon cross-section of the prism.
      • +
      • DATAHeight: height of the prism.
      +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/PartDesign_SubtractivePrism.png b/localwiki/PartDesign_SubtractivePrism.png new file mode 100644 index 0000000..e513aa3 Binary files /dev/null and b/localwiki/PartDesign_SubtractivePrism.png differ diff --git a/localwiki/PartDesign_SubtractivePrism_example.svg b/localwiki/PartDesign_SubtractivePrism_example.svg new file mode 100644 index 0000000..8ce20f2 --- /dev/null +++ b/localwiki/PartDesign_SubtractivePrism_example.svg @@ -0,0 +1,435 @@ + + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + + + + + + + + (B) + (A) + + + + + diff --git a/localwiki/PartDesign_SubtractiveSphere.html b/localwiki/PartDesign_SubtractiveSphere.html new file mode 100644 index 0000000..0285aff --- /dev/null +++ b/localwiki/PartDesign_SubtractiveSphere.html @@ -0,0 +1,88 @@ +PartDesign SubtractiveSphere

      PartDesign SubtractiveSphere

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      PartDesign SubtractiveSphere.png PartDesign SubtractiveSphere

      +
      Menu location +
      Part Design → Create a subtractive primitive → Subtractive Sphere +
      Workbenches +
      PartDesign +
      Default shortcut +
      None +
      See also +
      PartDesign CompPrimitiveSubtractive +

      + +
      +


      +

      +

      Description

      +

      Inserts a subtractive sphere in the active Body. Its shape is subtracted from the existing solid. +

      available in version 0.17 +


      +

      +
      PartDesign SubtractiveSphere example.svg
      +

      On the left: active body (A) shown in grey and subtractive sphere (B) shown in transparent red; result on the right. +

      +

      How to use

      +
      1. Press the PartDesign SubtractiveSphere.png Subtractive Sphere button. Note: the Subtractive Sphere is part of an icon menu labelled Create an additive primitive. After launching FreeCAD, the Subtractive Box is the one displayed in the toolbar. To get the Sphere, click on the down arrow besides the visible icon and select Subtractive Sphere in the menu.
      2. +
      3. Set the Primitive parameters and Attachment.
      4. +
      5. Click OK.
      6. +
      7. A Sphere feature appears under the active Body.
      +

      Options

      +

      The Sphere can be edited after its creation in two ways: +

      +
      • Double-clicking it in the Model tree, or by right-clicking and selecting Edit primitive in the contextual menu; this brings up the Primitive parameters.
      • +
      • Via the Property editor.
      +

      Properties

      +
      • DATAAttachment: defines the attachment mode as well as the Attachment Offset. See Part Attachment.
      • +
      • DATALabel: Label given to the Sphere object. Change to suit your needs.
      • +
      • DATARadius: Radius of the sphere.
      • +
      • DATAAngle1: (labelled V parameter in the Primitive parameters) lower truncation of the sphere, parallel to the circular cross section (-90 degrees in a full sphere)
      • +
      • DATAAngle2: (unlabelled in the Primitive parameters) upper truncation of the ellipsoid, parallel to the circular cross section (90 degrees in a full sphere).
      • +
      • DATAAngle3: (labelled U parameter in the Primitive parameters) angle of rotation of the cross section (360 degrees in a full sphere).
      +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/PartDesign_SubtractiveSphere.png b/localwiki/PartDesign_SubtractiveSphere.png new file mode 100644 index 0000000..1de971e Binary files /dev/null and b/localwiki/PartDesign_SubtractiveSphere.png differ diff --git a/localwiki/PartDesign_SubtractiveSphere_example.svg b/localwiki/PartDesign_SubtractiveSphere_example.svg new file mode 100644 index 0000000..2c4cb1e --- /dev/null +++ b/localwiki/PartDesign_SubtractiveSphere_example.svg @@ -0,0 +1,750 @@ + + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + + + + + + + + + + (B) + (A) + + + diff --git a/localwiki/PartDesign_SubtractiveTorus.html b/localwiki/PartDesign_SubtractiveTorus.html new file mode 100644 index 0000000..d30955d --- /dev/null +++ b/localwiki/PartDesign_SubtractiveTorus.html @@ -0,0 +1,89 @@ +PartDesign SubtractiveTorus

      PartDesign SubtractiveTorus

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      PartDesign SubtractiveTorus.png PartDesign SubtractiveTorus

      +
      Menu location +
      Part Design → Create a subtractive primitive → Subtractive Torus +
      Workbenches +
      PartDesign +
      Default shortcut +
      None +
      See also +
      PartDesign CompPrimitiveSubtractive +

      + +
      +


      +

      +

      Description

      +

      Inserts a subtractive torus in the active Body. Its shape is subtracted from the existing solid. +

      available in version 0.17 +


      +

      +
      PartDesign SubtractiveTorus example.svg
      +

      On the left: active body (A) shown in grey and subtractive torus (B) shown in transparent red; result on the right. +

      +

      How to use

      +
      1. Press the PartDesign SubtractiveTorus.png Subtractive Torus button. Note: the Subtractive Torus is part of an icon menu labelled Create an additive primitive. After launching FreeCAD, the Subtractive Box is the one displayed in the toolbar. To get the Torus, click on the down arrow besides the visible icon and select Subtractive Torus in the menu.
      2. +
      3. Set the Primitive parameters and Attachment.
      4. +
      5. Click OK.
      6. +
      7. A Torus feature appears under the active Body.
      +

      Options

      +

      The Torus can be edited after its creation in two ways: +

      +
      • Double-clicking it in the Model tree, or by right-clicking and selecting Edit primitive in the contextual menu; this brings up the Primitive parameters.
      • +
      • Via the Property editor.
      +

      Properties

      +
      • DATAAttachment: defines the attachment mode as well as the Attachment Offset. See Part Attachment.
      • +
      • DATALabel: Label given to the Torus object. Change to suit your needs.
      • +
      • DATARadius1: Radius of the imaginary orbit around which the circular cross-section revolves. (The distance between the center of the torus and the center of the revolving cross section)
      • +
      • DATARadius2: Radius of the circular cross-section defining the form of the torus.
      • +
      • DATAAngle1: (labelled V parameter in the Primitive parameters) lower truncation of the torus, parallel to the circular cross section (-180° in a full torus). A bug in the sources causes unexpected results at changing Angle1.
      • +
      • DATAAngle2: (unlabelled in the Primitive parameters) upper truncation of the ellipsoid, parallel to the circular cross section (180° in a full torus). A bug in the sources causes unexpected results at changing Angle2.
      • +
      • DATAAngle3: (labelled U parameter in the Primitive parameters) angle of rotation of the circular cross section (360° in a full torus).
      +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/PartDesign_SubtractiveTorus.png b/localwiki/PartDesign_SubtractiveTorus.png new file mode 100644 index 0000000..308d66c Binary files /dev/null and b/localwiki/PartDesign_SubtractiveTorus.png differ diff --git a/localwiki/PartDesign_SubtractiveTorus_example.svg b/localwiki/PartDesign_SubtractiveTorus_example.svg new file mode 100644 index 0000000..18645ad --- /dev/null +++ b/localwiki/PartDesign_SubtractiveTorus_example.svg @@ -0,0 +1,935 @@ + + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + + + + + + + + + + (B) + (A) + + + diff --git a/localwiki/PartDesign_SubtractiveWedge.html b/localwiki/PartDesign_SubtractiveWedge.html new file mode 100644 index 0000000..19832bf --- /dev/null +++ b/localwiki/PartDesign_SubtractiveWedge.html @@ -0,0 +1,89 @@ +PartDesign SubtractiveWedge

      PartDesign SubtractiveWedge

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      PartDesign SubtractiveWedge.png PartDesign SubtractiveWedge

      +
      Menu location +
      Part Design → Create a subtractive primitive → Subtractive Wedge +
      Workbenches +
      PartDesign +
      Default shortcut +
      None +
      See also +
      PartDesign CompPrimitiveSubtractive +

      + +
      +


      +

      +

      Description

      +

      Inserts a subtractive wedge in the active Body. Its shape is subtracted from the existing solid. +

      available in version 0.17 +


      +

      +
      PartDesign SubtractiveWedge example.svg
      +

      On the left: active body (A) shown in grey and subtractive wedge (B) shown in transparent red; result on the right. +

      +

      How to use

      +
      1. Press the PartDesign SubtractiveWedge.png Subtractive Wedge button. Note: the Subtractive Wedge is part of an icon menu labelled Create an additive primitive. After launching FreeCAD, the Subtractive Box is the one displayed in the toolbar. To get the Wedge, click on the down arrow besides the visible icon and select Subtractive Wedge in the menu.
      2. +
      3. Set the Primitive parameters and Attachment.
      4. +
      5. Click OK.
      6. +
      7. A Wedge feature appears under the active Body.
      +

      Options

      +

      The Wedge can be edited after its creation in two ways: +

      +
      • Double-clicking it in the Model tree, or by right-clicking and selecting Edit primitive in the contextual menu; this brings up the Primitive parameters.
      • +
      • Via the Property editor.
      +

      Properties

      +

      Using the default placement, the below inputs are: +

      +
      • DATAX min/max : Base face X axis span
      • +
      • DATAY min/max: Wedge height span
      • +
      • DATAZ min/max : Base face Z axis span
      • +
      • DATAX2 min/max : Top face X axis span
      • +
      • DATAZ2 min/max : Top face Z axis span
      +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/PartDesign_SubtractiveWedge.png b/localwiki/PartDesign_SubtractiveWedge.png new file mode 100644 index 0000000..2f9899b Binary files /dev/null and b/localwiki/PartDesign_SubtractiveWedge.png differ diff --git a/localwiki/PartDesign_SubtractiveWedge_example.svg b/localwiki/PartDesign_SubtractiveWedge_example.svg new file mode 100644 index 0000000..141ddc0 --- /dev/null +++ b/localwiki/PartDesign_SubtractiveWedge_example.svg @@ -0,0 +1,466 @@ + + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + + + + + + + + + + (B) + (A) + + + diff --git a/localwiki/PartDesign_Subtractive_Box.svg b/localwiki/PartDesign_Subtractive_Box.svg new file mode 100644 index 0000000..d760db9 --- /dev/null +++ b/localwiki/PartDesign_Subtractive_Box.svg @@ -0,0 +1,436 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [Stefan Tröger] + + + PartDesign_Subtractive_Box + 2015-05-18 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/PartDesign/Gui/Resources/icons/PartDesign_Subtractive_Box.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/PartDesign_Subtractive_Cone.svg b/localwiki/PartDesign_Subtractive_Cone.svg new file mode 100644 index 0000000..89a2841 --- /dev/null +++ b/localwiki/PartDesign_Subtractive_Cone.svg @@ -0,0 +1,270 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [Stefan Tröger] + + + PartDesign_Subtractive_Cone + 2015-05-20 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/PartDesign/Gui/Resources/icons/PartDesign_Subtractive_Cone.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/PartDesign_Subtractive_Cylinder.svg b/localwiki/PartDesign_Subtractive_Cylinder.svg new file mode 100644 index 0000000..6d451c1 --- /dev/null +++ b/localwiki/PartDesign_Subtractive_Cylinder.svg @@ -0,0 +1,317 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [Stefan Tröger] + + + PartDesign_Subtractive_Cylinder + 2015-05-18 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/PartDesign/Gui/Resources/icons/PartDesign_Subtractive_Cylinder.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/PartDesign_Subtractive_Ellipsoid.svg b/localwiki/PartDesign_Subtractive_Ellipsoid.svg new file mode 100644 index 0000000..4a9be51 --- /dev/null +++ b/localwiki/PartDesign_Subtractive_Ellipsoid.svg @@ -0,0 +1,283 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [Stefan Tröger] + + + PartDesign_Subtractive_Ellipsoid + 2015-05-20 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/PartDesign/Gui/Resources/icons/PartDesign_Subtractive_Ellipsoid.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/PartDesign_Subtractive_Loft.svg b/localwiki/PartDesign_Subtractive_Loft.svg new file mode 100644 index 0000000..3e53015 --- /dev/null +++ b/localwiki/PartDesign_Subtractive_Loft.svg @@ -0,0 +1,184 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [Stefan Tröger] + + + PartDesign_Subtractive_Loft + 2015-06-03 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/PartDesign/Gui/Resources/icons/PartDesign_Subtractive_Loft.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/PartDesign_Subtractive_Pipe.svg b/localwiki/PartDesign_Subtractive_Pipe.svg new file mode 100644 index 0000000..af40eb1 --- /dev/null +++ b/localwiki/PartDesign_Subtractive_Pipe.svg @@ -0,0 +1,103 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [Stefan Tröger] + + + PartDesign_Subtractive_Pipe + 2015-05-30 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/PartDesign/Gui/Resources/icons/PartDesign_Subtractive_Pipe.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/PartDesign_Subtractive_Prism.svg b/localwiki/PartDesign_Subtractive_Prism.svg new file mode 100644 index 0000000..d9edbed --- /dev/null +++ b/localwiki/PartDesign_Subtractive_Prism.svg @@ -0,0 +1,316 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [Stefan Tröger] + + + PartDesign_Subtractive_Prism + 2015-05-20 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/PartDesign/Gui/Resources/icons/PartDesign_Subtractive_Prism.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/PartDesign_Subtractive_Sphere.svg b/localwiki/PartDesign_Subtractive_Sphere.svg new file mode 100644 index 0000000..5fb0ed1 --- /dev/null +++ b/localwiki/PartDesign_Subtractive_Sphere.svg @@ -0,0 +1,206 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [Stefan Tröger] + + + PartDesign_Subtractive_Sphere + 2015-05-18 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/PartDesign/Gui/Resources/icons/PartDesign_Subtractive_Sphere.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/PartDesign_Subtractive_Torus.svg b/localwiki/PartDesign_Subtractive_Torus.svg new file mode 100644 index 0000000..0d2a4b2 --- /dev/null +++ b/localwiki/PartDesign_Subtractive_Torus.svg @@ -0,0 +1,332 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [Stefan Tröger] + + + PartDesign_Subtractive_Torus + 2015-05-20 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/PartDesign/Gui/Resources/icons/PartDesign_Subtractive_Torus.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/PartDesign_Subtractive_Wedge.svg b/localwiki/PartDesign_Subtractive_Wedge.svg new file mode 100644 index 0000000..1d176d3 --- /dev/null +++ b/localwiki/PartDesign_Subtractive_Wedge.svg @@ -0,0 +1,346 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [Stefan Tröger] + + + PartDesign_Subtractive_Wedge + 2015-05-20 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/PartDesign/Gui/Resources/icons/PartDesign_Subtractive_Wedge.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/PartDesign_Thickness.html b/localwiki/PartDesign_Thickness.html new file mode 100644 index 0000000..be24dd2 --- /dev/null +++ b/localwiki/PartDesign_Thickness.html @@ -0,0 +1,105 @@ +PartDesign Thickness

      PartDesign Thickness

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      PartDesign Thickness.png PartDesign Thickness

      +
      Menu location +
      Part Design → Thickness +
      Workbenches +
      PartDesign +
      Default shortcut +
      None +
      See also +
      Part Thickness +

      + +
      +


      +

      +

      Description

      +

      The Thickness tool works on a solid Body and transforms it into a thick-walled hollow object with at least one open face, giving to each of its remaining faces a uniform thickness. On some solids it allows you to significantly speed up the work, and avoids making extrusions and pockets. +

      available in version 0.17 +


      +

      +

      How to use

      +
      1. Select one or more face(s) on the active Body.
      2. +
      3. Press the PartDesign Thickness.png Thickness button.
      4. +
      5. Define the Thickness parameters (see Options).
      6. +
      7. To add more faces to open, press the Add face button and select a face in the 3D view.
      8. +
      9. To remove a previously select face, press the Remove face button and select a face in the 3D view, or right-click on the Face label in the list and select Remove.
      10. +
      11. Press OK.
      +

      Options

      +
      • Thickness: Wall thickness of the resulting object. Set the desired value.
      • +
      • Mode +
        • Skin: Select this option if you want to get an item like a vase, headless but with the bottom
        • +
        • Pipe: Select this option if you want to get an object like a pipe, headless and bottomless. In this case it may be convenient to select the faces to be deleted before you start the tool. Helping with predefined views buttons or use the numeric keys.
        • +
        • Recto Verso:
      • +
      • Join Type +
        • Arc: removes the outer edges and creates a fillet with a radius equal to the defined thickness.
        • +
        • Intersection: when faces are offset outward, sharp edges are kept between faces.
      • +
      • Make thickness inwards: when checked, faces are offset inward.
      +

      Limitations

      +
      • At least one face to be opened must be selected.
      • +
      • The thickness value may not exceed the smallest face height of the Body.
      • +
      • The command may fail with complex shapes.
      +

      Example

      +
      1. Create a Pad from the sketch
      2. +
      3. Create a second sketch on the XY plane
      4. +
      5. Create a second Pad from the second sketch
      +

      As in the following pictures: +

      Braga-primoPad.png +

      Braga-secondoschizzo.png +

      Braga-secondo Pad.png +

      Then +

      +
      1. Select a circular face
      2. +
      3. Select PartDesign Thickness.png Thickness
      4. +
      5. Add to the selection Face1, Face4 and Face5
      +

      Result: +

      Brga-spessore.png +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/PartDesign_Thickness.svg b/localwiki/PartDesign_Thickness.svg new file mode 100644 index 0000000..79efd9c --- /dev/null +++ b/localwiki/PartDesign_Thickness.svg @@ -0,0 +1,121 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [Stefan Tröger] + + + PartDesign_Thickness + 2015-05-21 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/PartDesign/Gui/Resources/icons/PartDesign_Thickness.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/PartDesign_WizardShaft.html b/localwiki/PartDesign_WizardShaft.html new file mode 100644 index 0000000..3fb2228 --- /dev/null +++ b/localwiki/PartDesign_WizardShaft.html @@ -0,0 +1,104 @@ +PartDesign WizardShaft

      PartDesign WizardShaft

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      PartDesign WizardShaft.png PartDesign WizardShaft

      +
      Menu location +
      Part Design → Shaft design wizard... +
      Workbenches +
      PartDesign, Complete +
      Default shortcut +
      None +
      See also +
      None +

      + +
      +


      +

      +

      Introduction

      +

      This tool allows you to create a shaft from a table of values, and to analyse forces and moments. You can start the wizard from the Part Design menu or by typing +

      +
      Gui.runCommand('PartDesign_WizardShaft') 
      +

      into the Python console of FreeCAD. The wizard will start and show a default table, the corresponding shaft part and force/moment graphs. +

      WizardShaft Part.jpg +

      The top of the window is taken up by the table. It is organized into numbered columns which correspond to segments of the shaft. A shaft segment is characterized by having certain length and diameter. The main window shows two tabs. One is the shaft part itself (a revolution feature), shown in the image above. The second tab shows graphs of the shear forces and moments created by the loads defined in the table. +

      Shaftwizard1.jpg +

      +
      +


      +

      +

      Prerequisites

      +

      The shaft design wizard depends on the matplotlib library to create and display the graphs of shear force and bending moment. On Debian/Ubuntu-based systems, it is available through the python-matplotlib package. +

      +

      Parameters

      +

      For each shaft segment, the following parameters can be defined +

      +
      • Length of the segment
      • +
      • Diameter of the segment
      • +
      • Load type. Note that you have to click on the desired entry in the menu after scrolling to it, otherwise it will not be selected! +
        • None: No load
        • +
        • Fixed: The end of the shaft is fixed (e.g. welded to another part). This load type can only be defined for the first or last segment.
        • +
        • Static: There is a static load on this shaft segment
      • +
      • Load on the shaft segment
      • +
      • Location where the load is applied to the segment. The location is counted from the left-hand edge of the segment
      +

      (Other rows and load types exist but no functionality has been implemented yet) +

      +

      Menus

      +

      To add a new shaft segment, right-click into the empty space to the right of the table, and choose "Add column". +

      +

      Limitations

      +
      • It is not possible to have adjacent shaft segments with the same diameter.
      +

      Planned functionality

      +
      • Table-driven chamfers and rounds on the shaft edges
      • +
      • Recognize a previously created shaft wizard part and initialize the table values from it
      • +
      • Shaft stress calculation
      • +
      • Visualization of loads on the shaft (can use the same functionality as for FEM module)
      • +
      • Definition of loads as a Document Object (can use the same functionality as for FEM module)
      • +
      • Material database
      • +
      • Allow loads in the Z-direction as well as in Y-direction (requires definition of loads as a Document Object, otherwise the table will become very long)
      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/PartDesign_Workbench.html b/localwiki/PartDesign_Workbench.html new file mode 100644 index 0000000..79c5334 --- /dev/null +++ b/localwiki/PartDesign_Workbench.html @@ -0,0 +1,210 @@ +PartDesign Workbench

      PartDesign Workbench

      + +
      With the release of FreeCAD version 0.17, the PartDesign workbench benefits from important changes. This documentation reflects this new version. For FreeCAD 0.16 users, please refer to the old PartDesign Legacy page.
      +


      +The Part Design Workbench provides advanced tools for modeling complex solid parts and is based on a feature-editing methodology. It is mostly focused on, but not limited to, creating mechanical parts. It is intricately linked with the Sketcher Workbench. +

      +
      PartDesign Example.png
      + + +

      Basic Concepts

      +

      Feature Editing Methodology

      +

      While the Part Workbench and other FreeCAD workbenches construct models by combining shapes together, the PartDesign workbench uses features. A feature is an operation that modifies the shape of a model. +

      The first feature is commonly called the base feature. As more features are added to the model, each feature takes the shape of the previous one and adds or removes matter, creating linear dependencies from one feature to the next. In effect, this methodology mimics a common manufacturing process: a block is cut on one side, then on another side, holes are added, then rounds, etc. +

      All features are listed sequentially in the Model tree and can be edited at any time, with the last feature at the bottom representing the final part. +

      Features can be sorted into different categories: +

      +
      • Profile-based: these features start from a profile to define the shape of the matter to be added or removed. The profile can be a sketch, a planar face on existing geometry (a profile will be extracted from its edges), a ShapeBinder or a Draft object that has been included in the active Body.
      +
      • Additive: adds matter to the existing model. Additive features show yellow icons.
      +
      • Subtractive: removes matter from the existing model. Subtractive features show red and blue icons.
      +
      • Primitive-based: based on geometric primitives (cube, cylinder, cone, torus…). They can be additive or subtractive.
      +
      • Transformation features: they apply a transformation to existing features (mirrored, linear pattern, polar pattern, multitransform).
      +
      • Dress-up: features that apply a treatment to edges or faces, such as fillets/rounds, chamfers and drafts.
      +
      • Procedural: can be said of features that are not based on sketches, like the transformation and dress-up features.
      +

      Body

      +

      The Body is a container that groups a sequence of features forming a single contiguous solid. +

      What is a single contiguous solid? It is an object like a casting or something machined from a single block of metal. If the object involves nails, screws, glue or welding, it is not a single contiguous solid. As a practical example, a wooden chair would be made of multiple bodies, with one for each of its sub-components (legs, slats, seat, etc). +

      Multiple bodies can be created in a FreeCAD document; they can also be combined to form a single contiguous solid. +

      When a model requires multiple bodies, like the previous wooden chair example, the general purpose Part container can be used to group them and move the whole as a unit. +

      +

      Body Visibility Management

      +

      A body will present by default its most recent feature to the outside. This feature is defined by default as the tip. A good analogy is the expression the tip of the iceberg: only the tip is visible above the water, most of the iceberg's mass (the other features) is hidden. As a new feature is added to the body, visibility of the previous feature is turned off, and the new feature becomes the tip. +

      There can only be one feature visible at a time. It is possible to toggle the visibility of any feature in the body, by selecting it in the Model tree and pressing the spacebar, in effect going back in the history of the body. +

      +

      Body Origin

      +

      The body has an Origin which consists of reference planes (XY, XZ, YZ) and axes (X, Y, Z) that can be used by sketches and features. Sketches can be attached to Origin planes, and they no longer need to be mapped to planar faces for features based on them to be added or subtracted from the model. +

      +

      Moving and Reordering Objects

      +

      It is possible to temporarily redefine the tip to a feature in the middle of the Body tree to insert new objects (features, sketches or datum geometry). It is also possible to reorder features under a Body, or to move them to a different Body. Select the object and right-click to get a contextual menu that will offer both options. The operation may be prevented if the object has dependencies in the source Body, such as being attached to a face. To move a sketch to another Body, it should not contain links to external geometry. +

      +

      Datum Geometry

      +

      Datum geometry consists of custom planes, lines, points or externally linked shapes. They can be created for use as reference by sketches and features. There is a multitude of attachment possibilities for datums. +

      +

      Cross-referencing

      +

      It is possible to cross-reference elements from a body in another body via datums. For example the datum shape binder allows to copy over faces from a body as reference in another one. This should make it easy to build a box with fitting cover in two different bodies. FreeCAD helps you to not accidentally link to other bodies and queries your intent. +

      +

      Attachment

      +

      Object attachment is not a specific PartDesign tool, but rather a Part utility introduced in v0.17 that can be found in the Part menu. It is heavily used in the PartDesign workbench to attach sketches and reference geometry to the standard planes and axes of the Body. Very extensive ways of creating datum points, lines and planes are available. Optional attachment offset parameters make this tool very versatile. +

      More info can be found in the Attachment page. +

      +

      Advice for creating stable models

      +

      The idea of parametric modeling implies that you can change the values of certain parameters and subsequent steps are changed according to the new values. However, when severe changes are made, the model can break. Compared to previous FreeCAD versions breaking can be minimized when you respect the following design principles: +

      +
      • Basically, you need to stop mapping sketches to faces - entirely! Place your sketches on standard planes, or on custom datum planes.
      • +
      • When creating datum geometry, do not base it on the part topology, base it on standard planes/axes and/or sketches.
      • +
      • Use a "master sketch". That is a preferably not too complicated sketch which contains basic geometric elements of your model. These elements can be referenced when modeling subsequent features. Such a master sketch will often be the first sketch in the Body but it doesn't have to be; in fact you don't even have to use it at all for anything else but being referenced.
      • +
      • If you inevitably have to reference an intermediate feature, e.g. the result of a thickness operation, use the first reference possible in the list of subsequent features where the referenced geometric element occurs. From FreeCAD 0.17 on you don't have to use the latest feature. If you take an early feature as reference, all changes to intermediate steps won't break your model. And again it is better to reference a sketch than edges and vertices of a solid
      +

      The Tools

      +

      The Part Design tools are all located in the Part Design menu and the PartDesign toolbar that appear when you load the Part Design workbench. +


      +

      +

      Structure tools

      +

      These are tools to organize the Model tree. +

      +
      • Std Part.png Part: adds a new Part container in the active document and makes it active.
      • +
      • Group.svg Group: adds a Group in the active document's Model tree.
      +


      +

      +

      Part Design Helper tools

      +
      • PartDesign Body.png Create body: Creates a Body in the active document and makes it active.
      +
      • PartDesign NewSketch.png Create sketch: creates‎ a new sketch on a selected face or plane. If no face is selected while this tool is executed, the user is prompted to select a plane from the Tasks panel. The interface then switches to the Sketcher_Workbench in sketch editing mode.
      + +
      • Sketcher MapSketch.png Map sketch to face: Maps a sketch to a previously selected plane or a face of the active body.
      +

      Part Design Modeling tools

      +

      Datum tools

      + + + + + +

      Additive tools

      +

      These are tools for creating base features or adding material to an existing solid body. +

      +
      • PartDesign Pad.png Pad: extrudes a solid from a selected sketch.
      +
      • PartDesign Revolution.png Revolution: creates a solid by revolving a sketch around an axis. The sketch must form a closed profile.
      +
      • PartDesign AdditiveLoft.png Additive loft: creates a solid by making a transition between two or more sketches.
      +
      • PartDesign AdditivePipe.png Additive pipe: creates a solid by sweeping one or more sketches along an open or closed path.
      + + + + + + + + + +

      Subtractive tools

      +

      These are tools for subtracting material from an existing body. +

      +
      • PartDesign Pocket.png Pocket: creates a pocket from a selected sketch.
      +
      • PartDesign Hole.png Hole: creates a hole feature from a selected sketch. The sketch must contain one or multiple circles.
      +
      • PartDesign Groove.png Groove: creates a groove by revolving a sketch around an axis.
      +
      • PartDesign SubtractiveLoft.png Subtractive loft: creates a solid shape by making a transition between two or more sketches and subtracts it from the active body.
      +
      • PartDesign SubtractivePipe.png Subtractive pipe: creates a solid shape by sweeping one or more sketches along an open or closed path and subtracts it from the active body.
      + + + + + + + + + +

      Transformation tools

      +

      These are tools for transforming existing features. They will allow you to choose which features to transform. +

      +
      • PartDesign Mirrored.png Mirrored: mirrors one or more features on a plane or face.
      +
      • PartDesign LinearPattern.png Linear Pattern: creates a linear pattern based on one or more features.
      + + +

      Dress-up tools

      +

      These tools apply a treatment to the selected edges or faces. +

      +
      • PartDesign Fillet.png Fillet: fillets (rounds) edges of the active body.
      +
      • PartDesign Chamfer.png Chamfer: chamfers edges of the active body.
      +
      • PartDesign Draft.png Draft: applies and angular draft to faces of the active body.
      +
      • PartDesign Thickness.png Thickness: creates a thick shell from the active body and opens selected face(s).
      +

      Boolean

      +
      • PartDesign Boolean.png Boolean operation: imports one or more Bodies or PartDesign Clones into the active body and applies a Boolean operation.
      +

      Extras

      +

      Some additional functionality found in the Part Design menu: +

      +
      • Migrate: migrates files created with older FreeCAD versions. If the file is pure PartDesign feature-based, migration should succeed. If the file contains mixed Part/Part Design/Draft objects, the conversion will most likely fail.
      +
      • PartDesign WizardShaft.png Shaft design wizard: Generates a shaft from a table of values and allows to analyze forces and moments. The shaft is made with a revolved sketch that can be edited.
      +
      • PartDesign InternalExternalGear.png Involute gear: creates an involute gear profile that can be used by a Pad.
      +

      Contextual Menu tools

      +
      • PartDesign MoveTip.png Set tip: redefines the tip, which is the feature exposed outside of the Body.
      + +
      • Move object after other object: allows reordering of the Body tree by moving the selected sketch, datum geometry or feature to another position in the list of features.
      +

      Preferences

      + +

      Tutorials

      + +

      Links

      + +


      +

      + +


      +

      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/PartDesign_project.html b/localwiki/PartDesign_project.html new file mode 100644 index 0000000..0fb9de7 --- /dev/null +++ b/localwiki/PartDesign_project.html @@ -0,0 +1,204 @@ +PartDesign project

      PartDesign project

      + +

      Here the project plan for the PartDesign as part of the Development roadmap. +


      +

      + + +

      Purpose and principles

      +

      This is a software development project aimed to implement a Part Design capabilities. Its about +implementing some core features into the CAD modules of FreeCAD, Part, PartDesign and Assembly. +

      The development steps are planed here and tracked in the Issue tracking system to get a well formed +change log: Issue tracker +

      +

      Outcome

      +

      Aim of the project is to enable FreeCAD accomplish a design task like the one at the right. +

      +
      Gripper.jpg
      +


      +This will be achived by using the Sketcher and the PartDesign to design +special part and Part to load standard part as STEP (like the linear bearing). +The Assembly puts it all together with constrains. +

      Also an important outcome is the Feature editing methodology. Which gives the +user an intuitive approach to instantiating and editing Features. This is importand +for all other Modules and Workbenches to be come, to comply to a consistent user +interface! +

      TaskPanel.jpg +

      CAD Modeling.gif +

      +

      Sketcher

      +

      A parametric sketcher with a geometrical constraints solver, for more details see the Sketcher project. +

      +

      PartDesign

      +

      Body feature

      +

      Since a history based modeling can have a lot of steps leading +to the final shape a bracket is needed. Thats the Body, which +holds the final outcome of the modeling and acts as a group to +all the features of the history tree. +


      +

      +

      Pad feature

      +

      A Pad feature extrude a Sketch (or any Part2DObject) in its normal direction. +Always guaranty a solid, or fail. +

      +

      Pocket feature

      +

      Imprint a sketch in a base solid either defined by depth or "Up to last | Up to first". +Also guaranty a solid. +

      +

      Bore feature

      +

      Very good bore parameter definition from the NaroCad specification: +

      + + + + + +
      NaroCAD Bore definitions +
      Counterbore settings.png + Counterbore settings2.png + Countersink settings.png +
      +

      Pattern

      +

      Replicate one of the above features +

      +
      RectangularPattern
      +

      Replicate one of the above features along an x,y pattern +

      +
      CircularPattern
      +

      Replicate one of the above features along a pattern in polar coordinates +

      +
      ScriptedPattern
      +

      Replicate one of the above features according to a general rule provided in form of a script. +

      +

      Brainstorming

      +

      What others do

      + +

      Pattern Implementation

      +

      The Pattern feature class can be implemented as a tabular pattern and serve as a base class for the Rectangular, Circular and Scripted Pattern features. These derived classes will only have to fill in the repetitions table of the base class. +

      Each line of the repetitions table of the base Pattern class has to hold at least a transformation matrix to applied to the Placement of the original feature to be replicated. Additionally we could have optional transformation rules like for example manipulating some parameter value the feature to be replicated (e.g. in order to create a pattern of holes with varying radius). +

      +

      Organizing

      +

      Modeling objects hierarchy

      +

      This UML chart shows the planed object hierarchy and its relationships. Yellow is a abstract base class, blue implemented and grey is planed. +

      PartDesign ModlingObjectsHirachy.png +

      +

      Tutorials

      +

      PartDesign Bearingholder Tutorial I +

      PartDesign Bearingholder Tutorial II +

      +

      Next actions

      +

      Next actions are defined in the Roadmap entry for PartDesign: +

      +

      Body

      +

      Since the parametric/associative nature of the PartDesign we need finally a "Body" which +groups and organizes a construction history. The Body itself holds the end result as a shape +and has grouped as children the PartDesign features. It also defines the actual head of the +modeling history. Its also related to the Assembly project since its the building block +for products and compounds. +

      +

      Additional features

      +

      The Pad and Pocket features are the first teaser for the PartDesign. There is still work to do +especially the visibility control and the visual manipulators. But then additional features are needed. +

      +

      Pattern

      +

      Pattern feature which repeatingly apply a Pad or Pocket feature according to a circular or rectangular patter. +An Example in IronCAD. Done [jrheinlaender] +

      +

      BoreHole

      +

      Classical bore hole with all parameters for threading and counter bore.... +

      +

      Sweep

      +

      Sweeps a Sketch along a curve and create a Solid. +

      +

      Revolve

      +

      Rotate a Sketch along one of its Axis and a certain angle. Done [jrheinlaender et al.] +

      +

      TODO List

      +
      1. Fillet/Chamfer Part +
        1. Apply fillet/chamfer operation to different selection types (face/faces pair/whole body)*
      2. +
      3. Pad Tool +
        1. Create 'up to next' mode DONE [mrlukeparry]
        2. +
        3. Create 'up to surface/face' mode [mrlukeparry]
        4. +
        5. Create draft property for pad DONE [mrlukeparry]
        6. +
        7. If pad is selected on face automatically create a sketch?
        8. +
        9. Create 'midplane' mode DONE [jrheinlaender]
      4. +
      5. Pocket Tool +
        1. Create 'up to first', 'up to last', 'through all', 'up to surface/face' modes DONE [jrheinlaender]
        2. +
        3. If pocket is selected on face automatically create a sketch?
      6. +
      7. Revolution Part +
        1. Allow a generic line segment/axis to be used for reference
        2. +
        3. Create 'midplane' mode DONE [jrheinlaender]
      8. +
      9. Hole Feature
      10. +
      11. Pattern Feature DONE [jrheinlaender]
      12. +
      13. Sweep Feature
      14. +
      15. Body Feature
      16. +
      17. Reference Geometry +
        1. Plane
      18. +
      19. Mirror Tool DONE [jrheinlaender]
      20. +
      21. Copy feature Tool
      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/PartDesign_tutorial.html b/localwiki/PartDesign_tutorial.html new file mode 100644 index 0000000..09082de --- /dev/null +++ b/localwiki/PartDesign_tutorial.html @@ -0,0 +1,156 @@ +PartDesign tutorial

      PartDesign tutorial

      + +
      + + + + + + + + + + + + + + + + + + + + + + + + + + + +
      +

      Base ExampleCommandModel.png Tutorial

      +
      Topic +
      Sketcher +
      Level +
      Beginner +
      Time to complete +
      15 minutes +
      Author +
      Drei +
      FreeCAD version +
      0.16 or above +
      Example File(s) +
      +

      + +
      +


      +

      +

      Introduction

      +

      This tutorial is meant to introduce the reader to the basic workflow of the PartDesign Workbench. +The reader will see how to create 3D objects based on Sketches, perform subtraction operations and how to replicate specific features in a pattern. +

      Sketcher tutorial result.png +

      +

      Requirements

      + +

      Procedure

      +

      Creating 3D geometry

      +

      The purpose of the PartDesign Workbench is to allow the user to create geometry in 3D space. As such, it is equipped with tools to make use of sketches and convert them to 3D objects. +

      To achieve this, two tools are exist: PartDesign Pad.png Pad and PartDesign Revolution.png Revolution. Alongside their subtractive counterparts (PartDesign Pocket.png Pocket and PartDesign Groove.png Groove) they make up most of the common actions used by this workbench. +

      +
      1. Switch to the PartDesign Workbench
      2. +
      3. Select the sketch that was created in the Sketcher tutorial
      4. +
      5. Select PartDesign Pad.png Pad
      6. +
      7. Set the distance to 5 mm
      8. +
      9. Select Ok
      +

      Another way to create 3D geometry is with the PartDesign Revolution.png Revolution tool. +

      PartDesign revolution exercise.png +

      +
      1. Create a sketch based on the image above
      2. +
      3. Select PartDesign Revolution.png Revolution
      4. +
      5. Set the "Axis" to the "Horizontal Sketch Axis"
      6. +
      7. Set the angle to 360°
      +

      Subtracting Features

      +

      We'll begin by creating a sketch with the shape we want to subtract. +

      +
      1. Select the top flat face of the "Revolution"
      2. +
      3. Select Sketcher NewSketch.png New sketch
      4. +
      5. Select Sketcher External.png External Geometry
      6. +
      7. Approach the edge of the pad. An arc should be highlighted
      8. +
      9. Select the arc. An arc of a different color should appear in the sketch
      10. +
      11. Create a hexagon centered on the same point as the arc and set the radius of the reference circle to 5 mm
      +
      External Geometry +

      When a 3D element has been created it is possible to create references to it within a sketch. +

      +
      1. Select Sketcher External.png External Geometry.
      2. +
      3. Approach the element that you wish to reference, the edge of a Pad for example.
      4. +
      5. Click on it
      6. +
      7. New elements of a different color should appear on the sketch in the location of the feature you wish to reference.
      +


      +PartDesign pocket exercise.png +

      Afterwards, we'll proceed to apply a Pocket feature. +

      +
      1. Select the sketch
      2. +
      3. Select PartDesign Pocket.png Pocket
      4. +
      5. Set the distance to Through all
      +

      Pattern Features

      +

      Recall the extruded profile that was created at the start of the tutorial. +

      +
      1. Select the top face of the object
      2. +
      3. Create a new Sketch
      4. +
      5. Create reference geometry linked to the top arm of the figure
      6. +
      7. Create a circle constrained to the center of the reference arc
      8. +
      9. Set its radius to 3 mm
      10. +
      11. Pocket the sketch through all the workpiece
      +

      Instead of creating a circle for each hole in the sketch, we will introduce the concept of Pattern Features. These tools operate by replicating a feature in the workpiece that has already been created and that we wish to reproduce in a linear or circular arrangement. +We will use a combination of Linear and Polar pattern features simulatneously to obtain the final workpiece. +

      +
      1. Select the Pockt feature that we just created in the Tree View
      2. +
      3. Select PartDesign MultiTransform.png MultiTransform
      +

      In the Combo View we are now asked to introduce the Transformations that we desire. Notice that in the MultiTransform parameters menu we see that FreeCAD has identified the Pocket as the Original feature and a second box requests us to Right click it to introduce the pattern features. +

      +
      1. Right click the box
      2. +
      3. Select Add Linear Pattern
      4. +
      5. Set the Direction to Vertical Sketch Axis
      6. +
      7. Set length to 10 mm
      8. +
      9. Leave occurrences at 2
      10. +
      11. Click OK
      12. +
      13. Right click the box again to add a Polar Pattern. Notice that the 3D view has now added the linear pattern.
      14. +
      15. Set occurrences to 5
      16. +
      17. Click OK twice
      +

      After completing this task you should have the following result. +

      PartDesign multitransform exercise.png +

      If not, re-edit the MultiTransform operation by double clicking on it in the Tree View. Check both pattern features to detect necessary modifications, such as the Axis and if the Direction needs to be reversed. +

      We are now finished with the basic workflow for the PartDesign Workbench. +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/PartFeature.svg b/localwiki/PartFeature.svg new file mode 100644 index 0000000..7e6ee10 --- /dev/null +++ b/localwiki/PartFeature.svg @@ -0,0 +1,48 @@ + + + + + + + + + + + image/svg+xml + + + + [wmayer] + + + PartFeature + 2011-10-10 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Part/Gui/Resources/icons/Part + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + diff --git a/localwiki/PartHelixPrimitivesOptions_en.png b/localwiki/PartHelixPrimitivesOptions_en.png new file mode 100644 index 0000000..fbaaafd Binary files /dev/null and b/localwiki/PartHelixPrimitivesOptions_en.png differ diff --git a/localwiki/PartHelixProperty_en.png b/localwiki/PartHelixProperty_en.png new file mode 100644 index 0000000..2afb0cf Binary files /dev/null and b/localwiki/PartHelixProperty_en.png differ diff --git a/localwiki/PartLinePrimitivesOptions_it.png b/localwiki/PartLinePrimitivesOptions_it.png new file mode 100644 index 0000000..a61f5d5 Binary files /dev/null and b/localwiki/PartLinePrimitivesOptions_it.png differ diff --git a/localwiki/PartLineProperty_it.png b/localwiki/PartLineProperty_it.png new file mode 100644 index 0000000..ef88b66 Binary files /dev/null and b/localwiki/PartLineProperty_it.png differ diff --git a/localwiki/PartOffset1_it.png b/localwiki/PartOffset1_it.png new file mode 100644 index 0000000..d65ccee Binary files /dev/null and b/localwiki/PartOffset1_it.png differ diff --git a/localwiki/PartOffset2_it.png b/localwiki/PartOffset2_it.png new file mode 100644 index 0000000..a29527c Binary files /dev/null and b/localwiki/PartOffset2_it.png differ diff --git a/localwiki/PartPlane.png b/localwiki/PartPlane.png new file mode 100644 index 0000000..4745ce8 Binary files /dev/null and b/localwiki/PartPlane.png differ diff --git a/localwiki/PartPlaneProperty.png b/localwiki/PartPlaneProperty.png new file mode 100644 index 0000000..558f894 Binary files /dev/null and b/localwiki/PartPlaneProperty.png differ diff --git a/localwiki/PartRefineShape_it.png b/localwiki/PartRefineShape_it.png new file mode 100644 index 0000000..d8acad5 Binary files /dev/null and b/localwiki/PartRefineShape_it.png differ diff --git a/localwiki/PartRuledSurface_it.png b/localwiki/PartRuledSurface_it.png new file mode 100644 index 0000000..2407dcf Binary files /dev/null and b/localwiki/PartRuledSurface_it.png differ diff --git a/localwiki/PartSection1_it.png b/localwiki/PartSection1_it.png new file mode 100644 index 0000000..a05dbd7 Binary files /dev/null and b/localwiki/PartSection1_it.png differ diff --git a/localwiki/PartToVRML.png b/localwiki/PartToVRML.png new file mode 100644 index 0000000..23691dd Binary files /dev/null and b/localwiki/PartToVRML.png differ diff --git a/localwiki/PartVertexPrimitivesOptions_it.png b/localwiki/PartVertexPrimitivesOptions_it.png new file mode 100644 index 0000000..2bf4c1c Binary files /dev/null and b/localwiki/PartVertexPrimitivesOptions_it.png differ diff --git a/localwiki/PartVertexProperty_it.png b/localwiki/PartVertexProperty_it.png new file mode 100644 index 0000000..f7b41bf Binary files /dev/null and b/localwiki/PartVertexProperty_it.png differ diff --git a/localwiki/PartWedgeProperty.png b/localwiki/PartWedgeProperty.png new file mode 100644 index 0000000..09b955f Binary files /dev/null and b/localwiki/PartWedgeProperty.png differ diff --git a/localwiki/PartWedgeProperty_Inputs.png b/localwiki/PartWedgeProperty_Inputs.png new file mode 100644 index 0000000..4a4e8bd Binary files /dev/null and b/localwiki/PartWedgeProperty_Inputs.png differ diff --git a/localwiki/Part_API.html b/localwiki/Part_API.html new file mode 100644 index 0000000..99eec24 --- /dev/null +++ b/localwiki/Part_API.html @@ -0,0 +1,293 @@ +Part API

      Part API

      + +

      The Part module is the direct connection between FreeCAD and the OpenCasCade kernel. It provides mainly TopoShapes which is the main object type used by OpenCascade. The Part module also contains a variety of convenience functions to create and manipulate topoShapes. Example: +

      +
      import Part
      +mycube = Part.makeBox(2,2,2)
      +Part.show(mycube) 
      +


      +

      +
      +
      Method.png __fromPythonOCC__ ( OCC.Object )
      +
      +

      Description: Helper method to convert a pythonocc shape to an internal shape +

      Returns: A Part.Shape +

      +
      +
      +


      +

      +
      +
      Method.png __sortEdges__ ( list of edges )
      +
      +

      Description: Helper method to sort an unsorted list of edges so that afterwards two adjacent edges share a common vertex +

      Returns: a list of edges +

      +
      +
      +


      +

      +
      +
      Method.png __toPythonOCC__ ( Part.Shape )
      +
      +

      Description: Helper method to convert an internal shape to pythonocc shape +

      Returns: an OCC.Shape +

      +
      +
      +


      +

      +
      +
      Method.png cast_to_shape ( Part.Shape )
      +
      +

      Description: Cast to the actual shape type +

      Returns: +

      +
      +
      +


      +

      +
      +
      Method.png export ( list,string )
      +
      +

      Description: Export a list of objects into a single file. +

      Returns: +

      +
      +
      +


      +

      +
      +
      Method.png getSortedClusters ( list of edges )
      +
      +

      Description: Helper method to sort and cluster a variety of edges +

      Returns: +

      +
      +
      +


      +

      +
      +
      Method.png insert ( string,string )
      +
      +

      Description: Insert the file (path given as first argument) into the given document (second argument). +

      Returns: +

      +
      +
      +


      +

      +
      +
      Method.png makeBox ( length,width,height,[pnt,dir] )
      +
      +

      Description: Makes a box located at pnt with the dimensions (length,width,height). By default pnt is Vector(0,0,0) and dir is Vector(0,0,1) +

      Returns: the created shape +

      +
      +
      +


      +

      +
      +
      Method.png makeCircle ( radius,[pnt,dir,angle1,angle2] )
      +
      +

      Description: Makes a circle with a given radius. By default pnt is Vector(0,0,0), dir is Vector(0,0,1), angle1 is 0 and angle2 is 360 +

      Returns: the created shape +

      +
      +
      +


      +

      +
      +
      Method.png makeCompound ( list )
      +
      +

      Description: Creates a compound out of a list of shapes. +

      Returns: the created shape +

      +
      +
      +


      +

      +
      +
      Method.png makeCone ( radius1,radius2,height,[pnt,dir,angle] )
      +
      +

      Description: Makes a cone with given radii and height. By default pnt is Vector(0,0,0), dir is Vector(0,0,1) and angle is 360 +

      Returns: the created shape +

      +
      +
      +


      +

      +
      +
      Method.png makeCylinder ( radius,height,[pnt,dir,angle] )
      +
      +

      Description: Makes a cylinder with a given radius and height. By default pnt is Vector(0,0,0),dir is Vector(0,0,1) and angle is 360 +

      Returns: the created shape +

      +
      +
      +


      +

      +
      +
      Method.png makeHelix ( pitch,height,radius,[angle,lefthand,heightstyle] )
      +
      +

      Description: Makes a helix shape with a given pitch, height and radius. Defaults to right-handed cylindrical helix. Non-zero angle parameter produces a conical helix. Lefthand True produces left handed helix. Heightstyle applies only to conical helices. Heightstyle False (default) will cause the height parameter to be interpreted as the length of the side of the underlying frustum. Heightstyle True will cause the height parameter to be interpreted as the vertical height of the helix. Pitch is "metric pitch" (advance/revolution). For conical helix, radius is the minor radius. +

      Returns: the created shape +

      +
      +
      +


      +

      +
      +
      Method.png makeLine ( (x1,y1,z1),(x2,y2,z2) )
      +
      +

      Description: Makes a line of two points +

      Returns: the created shape +

      +
      +
      +


      +

      +
      +
      Method.png makeLoft ( shapelist<profiles>,[boolean<solid>,boolean<ruled>] )
      +
      +

      Description: Creates a loft shape using the list of profiles. Optionally make result a solid (vs surface/shell) or make result a ruled surface. +

      Returns: the created shape +

      +
      +
      +


      +

      +
      +
      Method.png makePlane ( length,width,[pnt,dir] )
      +
      +

      Description: Makes a plane. By default pnt is Vector(0,0,0) and dir is Vector(0,0,1) +

      Returns: the created shape +

      +
      +
      +


      +

      +
      +
      Method.png makePolygon ( list )
      +
      +

      Description: Makes a polygon of a list of Vectors +

      Returns: the created shape +

      +
      +
      +


      +

      +
      +
      Method.png makeRevolution ( Curve,[vmin,vmax,angle,pnt,dir] )
      +
      +

      Description: Makes a revolved shape by rotating the curve or a portion of it around an axis given by (pnt,dir). By default vmin/vmax are set to bounds of the curve,angle is 360,pnt is Vector(0,0,0) and dir is Vector(0,0,1) +

      Returns: the created shape +

      +
      +
      +


      +

      +
      +
      Method.png makeRuledSurface ( Edge or Wire,Edge or Wire )
      +
      +

      Description: Creates a ruled surface out of two edges or wires. If wires are used then these must have the same number of edges. +

      Returns: the created shape +

      +
      +
      +


      +

      +
      +
      Method.png makeShell ( list )
      +
      +

      Description: Creates a shell out of a list of faces. Note: Resulting shell should be manifold. Non-manifold shells are not well supported. +

      Returns: the created shape +

      +
      +
      +


      +

      +
      +
      Method.png makeSolid ( Part.Shape )
      +
      +

      Description: Creates a solid out of the shells inside a shape. +

      Returns: the created shape +

      +
      +
      +


      +

      +
      +
      Method.png makeSphere ( radius,[pnt, dir, angle1,angle2,angle3] )
      +
      +

      Description: Makes a sphere with a given radius. By default pnt is Vector(0,0,0), dir is Vector(0,0,1), angle1 is 0, angle2 is 90 and angle3 is 360 +

      Returns: the created shape +

      +
      +
      +


      +

      +
      +
      Method.png makeTorus ( radius1,radius2,[pnt,dir,angle1,angle2,angle] )
      +
      +

      Description: Makes a torus with a given radii and angles. By default pnt is Vector(0,0,0),dir is Vector(0,0,1),angle1 is 0,angle2 is 360 and angle is 360 +

      Returns: the created shape +

      +
      +
      +


      +

      +
      +
      Method.png makeTube ( edge,float )
      +
      +

      Description: Creates a tube. +

      Returns: the created shape +

      +
      +
      +


      +

      +
      +
      Method.png open ( string )
      +
      +

      Description: Creates a new document and load the file into the document. +

      Returns: +

      +
      +
      +


      +

      +
      +
      Method.png read ( string )
      +
      +

      Description: Loads the file and return the shape. +

      Returns: a shape +

      +
      +
      +


      +

      +
      +
      Method.png show ( shape )
      +
      +

      Description: Adds the shape to the active document or create one if no document exists. +

      Returns: +

      +
      +
      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Part_Attachment.html b/localwiki/Part_Attachment.html new file mode 100644 index 0000000..ad2ea42 --- /dev/null +++ b/localwiki/Part_Attachment.html @@ -0,0 +1,321 @@ +Part Attachment

      Part Attachment

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Part Attachment

      +
      Menu location +
      Part → Attachment... +
      Workbenches +
      Part, PartDesign +
      Default shortcut +
      None +
      See also +
      Placement +

      + +
      +


      +

      +

      Description

      +

      Attachment is a utility to attach an object to another one. The attached object is linked to the other object, which means that if the latter's placement is changed afterwards, the attached object will update to its new position. +

      available in version 0.17 +


      +

      +

      How to use

      +
      1. Select the object to be attached.
      2. +
      3. Go to the Part → Attachment... menu. +
        Note: when working in PartDesign and creating sketches, datum geometry or primitives, steps 1 and 2 are unnecessary: the Attachment dialogue is brought up automatically.
      4. +
      5. Under Attachment parameters, Not attached can be read. The first button below is labeled Selecting… to indicate it is expecting a selection in the 3D view.
      6. +
      7. Select a topology element on the object to attach to: vertex, edge or face/plane. Datum geometry from Part containers are also selectable.
      8. +
      9. The first button's label now adopts the type of topology selected. In the white field to its right, the referenced object and its element is added. For example, if a face on a primitive cube is selected, the field will show Box:Face6.
      10. +
      11. Select an Attachment mode in the list. The available modes are filtered by the selected references. Attached with mode <mode description> will be displayed under the Attachment header. +
        For live information on the attachment modes, hover the mouse on top of one of the modes in the list for a tooltip to appear.
      12. +
      13. Optionally, add up to 3 more references by pressing the Reference2, Reference3, and Reference4 buttons and repeating step 4.
      14. +
      15. Optionally set an Attachment Offset.
      16. +
      17. Press OK.
      +

      Options

      +
      Part Offset Tasks.png
      +

      Attachment mode

      +

      Deactivated

      +

      Default, no reference selected . +

      +

      Normal to edge

      +

      Object is made perpendicular to edge. Optional vertex reference defines location . +

      +
      Reference combinations
      +
      +
      Edge
      +
      Edge, Vertex
      +
      Vertex, Edge
      +

      Align O-N-X

      +

      Matches object's origin with first referenced vertex, then aligns its normal and horizontal plane axis toward vertex/along line . +

      +
      Reference combinations
      +
      +
      Vertex, Vertex, Vertex
      +
      Vertex, Vertex, Edge
      +
      Vertex, Edge, Vertex
      +
      Vertex, Edge, Edge
      +
      Vertex, Vertex
      +
      Vertex, Edge
      +

      Align O-N-Y

      +

      Matches object's origin with first referenced vertex and aligns its normal and vertical plane axis toward vertex/along line . +

      +
      Reference combinations
      +
      +
      Vertex, Vertex, Vertex
      +
      Vertex, Vertex, Edge
      +
      Vertex, Edge, Vertex
      +
      Vertex, Edge, Edge
      +
      Vertex, Vertex
      +
      Vertex, Edge
      +

      Align O-X-Y

      +

      Matches object's origin with first referenced vertex and aligns its horizontal and vertical plane axes toward vertex/along line . +

      +
      Reference combinations
      +
      +
      Vertex, Vertex, Vertex
      +
      Vertex, Vertex, Edge
      +
      Vertex, Edge, Vertex
      +
      Vertex, Edge, Edge
      +
      Vertex, Vertex
      +
      Vertex, Edge
      +

      Align O-X-N

      +

      Matches object's origin with first referenced vertex and aligns its horizontal plane axis and normal toward vertex/along line . +

      +
      Reference combinations
      +
      +
      Vertex, Vertex, Vertex
      +
      Vertex, Vertex, Edge
      +
      Vertex, Edge, Vertex
      +
      Vertex, Edge, Edge
      +
      Vertex, Vertex
      +
      Vertex, Edge
      +

      Align O-Y-N

      +

      Matches object's origin with first referenced vertex and aligns its vertical plane axis and normal toward vertex/along line . +

      +
      Reference combinations
      +
      +
      Vertex, Vertex, Vertex
      +
      Vertex, Vertex, Edge
      +
      Vertex, Edge, Vertex
      +
      Vertex, Edge, Edge
      +
      Vertex, Vertex
      +
      Vertex, Edge
      +

      Align O-Y-X

      +

      Matches object's origin with first referenced vertex and aligns its vertical and horizontal plane axes toward vertex/along line . +

      +
      Reference combinations
      +
      +
      Vertex, Vertex, Vertex
      +
      Vertex, Vertex, Edge
      +
      Vertex, Edge, Vertex
      +
      Vertex, Edge, Edge
      +
      Vertex, Vertex
      +
      Vertex, Edge
      +

      Translate origin

      +

      Object's origin is aligned to matched vertex. Orientation is controlled by Placement property. +

      +
      Reference combinations
      +
      +
      Vertex.
      +

      Object's XY

      +

      Plane is aligned to XY local plane of linked object . +

      +
      Reference combinations
      +
      +
      Any, Conic.
      +

      Object's XZ

      +

      Plane is aligned to XZ local plane of linked object . +

      +
      Reference combinations
      +
      +
      Any, Conic.
      +

      Object's YZ

      +

      Plane is aligned to YZ local plane of linked object . +

      +
      Reference combinations
      +
      +
      Any, Conic
      +

      Plane face

      +

      Plane is aligned to coincide to planar face . +

      +
      Reference combinations
      +
      +
      Plane
      +

      Tangent to surface

      +

      Plane is made tangent to surface at vertex . +

      +
      Reference combinations
      +
      +
      Face, Vertex
      +
      Vertex, Face
      +

      Frenet NB

      +

      Plane is set to normal-binormal (NB) axes of Frenet-Serret coordinates at the point of the edge's curve that is closest to the vertex (or defined by MapPathParameter property, if vertex is not linked). The object's origin is translated to the vertex if the vertex is first, or kept at the curve if edge is first. This mode is similar to Normal to edge, except that X axis is well-defined. +

      +
      Reference combinations
      +
      +
      Curve
      +
      Curve, Vertex
      +
      Vertex, Curve
      +
      Attacher mode FrenetNB.png
      +

      Frenet TN

      +

      Plane is set to tangent-normal (TN) axes of Frenet-Serret coordinates at the point of the edge's curve that is closest to the vertex (or defined by MapPathParameter property, if vertex is not linked). The origin of sketch is translated to the vertex if the vertex is first, or kept at the curve if edge is first. Effectively, if the curve is planar, the sketching plane is the plane of the curve. +

      +
      Reference combinations
      +
      +
      Curve
      +
      Curve, Vertex
      +
      Vertex, Curve
      +
      Attacher mode FrenetTN.png
      +

      Frenet TB

      +

      Plane is set tangent-binormal (TB) axes of Frenet-Serret coordinates at the point of the edge's curve that is closest to the vertex (or defined by MapPathParameter property, if vertex is not linked). The origin of sketch is translated to the vertex if the vertex is first, or kept at the curve if edge is first. +

      +
      Reference combinations
      +
      +
      Curve
      +
      Curve, Vertex
      +
      Vertex, Curve
      +
      Attacher mode FrenetTB.png
      +

      Concentric

      +

      Aligns to plane to osculating circle of an edge. Optional Vertex link defines where . +

      +
      Reference combinations
      +
      +
      Curve
      +
      Circle
      +
      Curve, Vertex
      +
      Circle, Vertex
      +
      Vertex, Curve
      +
      Vertex, Circle
      +

      Revolution Section

      +

      Plane is perpendicular to edge, and Y axis is matched with axis of osculating circle. Optional Vertex link defines where . +

      +
      Reference combinations
      +
      +
      Curve
      +
      Circle
      +
      Curve, Vertex
      +
      Circle, Vertex
      +
      Vertex, Curve
      +
      Vertex, Circle
      +

      Plane by 3 points

      +

      Aligns XY plane to pass through three vertices . +

      +
      Reference combinations
      +
      +
      Vertex, Vertex, Vertex
      +
      Line, Vertex
      +
      Vertex, Line
      +
      Line, Line
      +

      Normal to 3 points

      +

      Aligns plane to pass through first two vertices, and perpendicular to plane that passes through 3 vertices . +

      +
      Reference combinations
      +
      +
      Vertex, Vertex, Vertex
      +
      Line, Vertex
      +
      Vertex, Line
      +
      Line, Line
      +

      Folding

      +

      Specialty mode for folding polyhedra. Select 4 edge in order: foldable edge, fold line, other fold line, other foldable edge. Plane will be aligned to folding the first edge. In the picture below, it is not required that both leafs to fold together be the same . +

      +
      Reference combinations
      +
      Line, Line, Line, Line
      +
      Attacher mode Folding.png
      +


      +

      +

      Inertia 2-3

      +

      Object will be attached to a plane passing through second and third principal axes of inertia (passes through center of mass) . +

      +
      Reference combinations
      +
      +
      Any
      +
      Any, Any
      +
      Any, Any, Any
      +
      Any, Any, Any, Any
      +

      Attachment Offset

      +

      Attachment Offset is used to apply a linear or rotary offset from the referenced object. It becomes active when an attachment mode other than Deactivated has been selected . +

      +
      • X: sets an offset distance in the X axis of the reference object .
      +
      • Y: sets an offset distance in the Y axis of the reference object .
      +
      • Z: sets an offset distance in the Z axis of the reference object .
      +
      • Yaw: rotates the attached object along the reference object's Z axis .
      +
      • Pitch: rotates the attached object along the reference object's Y axis .
      +
      • Roll: rotates the attached object along the reference object's X axis .
      +
      • Flip sides: if checked, the attached object is reversed from its XY plane .
      +

      Limitations

      +
      • Part and Body containers are not supported. While it's possible to use Attachment to align them, the attachment won't be parametrically linked .
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Part_Attachment.svg b/localwiki/Part_Attachment.svg new file mode 100644 index 0000000..b45a788 --- /dev/null +++ b/localwiki/Part_Attachment.svg @@ -0,0 +1,95 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [DeepSOIC] + + + Part_Attachment + 2016-05-17 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Part/Gui/Resources/icons/Part_Attachment.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Part_BooleanFragments.html b/localwiki/Part_BooleanFragments.html new file mode 100644 index 0000000..9c26cd5 --- /dev/null +++ b/localwiki/Part_BooleanFragments.html @@ -0,0 +1,116 @@ +Part BooleanFragments

      Part BooleanFragments

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Part BooleanFragments.png Part BooleanFragments

      +
      Menu location +
      Part → Split → Boolean Fragments +
      Workbenches +
      Part +
      Default shortcut +
      None +
      See also +
      Part Slice, Part XOR, Join features, Part Booleans +

      + +
      +


      +

      +

      Description

      +

      Tool to compute all fragments that can result from applying Boolean operations between input shapes. For example, for two intersecting spheres, three non-overlapping but touching solids are generated. +

      Part BooleanFragments Demo.png +

      (on the picture above, the pieces were moved apart manually afterwards, to reveal the slicing) +

      The output shape is always a compound. The content of the compound depends on input shape types and operation mode. That means, you don't immediately get access to individual pieces of the result - the pieces remain grouped together. The individual pieces can be extracted by exploding the compound (Draft Downgrade). +

      The tool has three modes: "Standard", "Split", and "CompSolid". +

      "Standard" and "Split" differ by the action of the tool on wires, shells and compsolids: if "Split", those are separated; if "Standard", they are kept together (get extra segments). +

      Compounding structure in "Standard" and "Split" modes follows the compounding structure of inputs. That is, if you feed in two compounds, each containing a sphere like on example above, the result will also contain two compounds, each containing the pieces of the originally contained sphere. That means, the common piece will be repeated twice in the result. Only if the input shperes are both not in compounds, the result will contain the common piece once. +

      In "CompSolid" mode, the solids are joined into a compsolid (compsolid is a set of solids connected by faces; they are related to solids like wires are related to edges, and shells are related to faces; the name is probably a shortened phrase "composite solid"). The output is a non-nested compound of compsolids +

      +

      How to use

      +
      1. Select objects to be intersected.
        The order of selection is not important, since the action of the tool is symmetric. It is enough to select one sub-shape of each object (e.g., faces). You can also select a compound containing all the shapes to be connected, e.g. Draft Array.
      2. +
      3. Invoke the Part BooleanFragments command.
      +

      A Boolean Fragments parametric object is created. Original objects are hidden, and the result of intersection is shown in 3D view. +

      +

      Properties

      +

      Boolean Fragments +

      +
      • DATAObjects: List of objects to be intersected. Generally, at least two objects are needed, but a single compound containing the shapes to intersect will do as well. (as of FreeCAD v0.17.8053, this property is not displayed in property editor, and can only be accessed via Python).
      • +
      • DATAMode: "Standard", "Split", or "CompSolid". "Standard" is default. Standard and Split differ by the action of the tool on aggregation type shapes: if Split, those are separated; otherwise they are kept together (get extra segments).
      • +
      • DATATolerance: "fuzziness" value. This is an extra tolerance to apply when searching for intersections, in addition to tolerances stored in the input shapes.
      +

      Implementation details

      +

      Boolean Fragments tool in "Standard mode" is OpenCascade's General Fuse Operator (GFA). It accepts a combination of probably all shape types, and the logic of output is quite convoluted. See OpenCascade user guide: Boolean operations. +

      For "Split" and "CompSolid" modes, extra post-processing is done by FreeCAD. +

      +

      Scripting

      +

      The tool can by used in macros and from the python console by using the following function: +

      +
      BOPTools.SplitFeatures.makeBooleanFragments(name)
      +
      +
      • Creates an empty BooleanFragments feature. The 'Objects' property must be assigned explicitly, afterwards.
      • +
      • Returns the newly created object.
      +

      BooleanFragments can also be applied to plain shapes, without the need to have a document object, via: +

      +
      Part.BOPTools.SplitAPI.booleanFragments(list_of_shapes, mode, tolerance = 0.0)
      +
      +# OR, for Standard mode:
      +
      +list_of_shapes = [App.ActiveDocument.Sphere.Shape, App.ActiveDocument.Sphere001.Shape]
      +pieces, map = list_of_shapes[0].generalFuse(list_of_shapes[1:], tolerance)
      +# pieces receives a compound of shapes; map receives a list of lists of shapes, defining list_of_shapes <--> pieces correspondence 
      +

      This can be useful for making custom Python scripted features. +


      +Example: +

      +
      import Part
      +j = Part.BOPTools.SplitFeatures.makeBooleanFragments(name= 'BooleanFragments')
      +j.Objects = FreeCADGui.Selection.getSelection() 
      +

      The tool itself is implemented in Python, see /Mod/Part/BOPTools/SplitFeatures.py under where FreeCAD is installed. +

      +

      Version

      +

      The tool was introduced in FreeCAD v0.17.8053. FreeCAD needs to be compiled with OCC 6.9.0 or later; otherwise, the tool is unavailable. +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Part_BooleanFragments.svg b/localwiki/Part_BooleanFragments.svg new file mode 100644 index 0000000..48c9665 --- /dev/null +++ b/localwiki/Part_BooleanFragments.svg @@ -0,0 +1,107 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [DeepSOIC] + + + Part_BooleanFragments + 2016-07-29 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Part/Gui/Resources/icons/Part_Boolean + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + diff --git a/localwiki/Part_Booleans.html b/localwiki/Part_Booleans.html new file mode 100644 index 0000000..4975731 --- /dev/null +++ b/localwiki/Part_Booleans.html @@ -0,0 +1,61 @@ +Part Booleans

      Part Booleans

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Part Booleans.png Part Booleans

      +
      Menu location +
      Part → Booleans +
      Workbenches +
      Part,Complete +
      Default shortcut +
      None +
      See also +
      Part Union, Part Common and Part Cut +

      Contents

      + +
      + +
      +


      +

      This command is a generic all-in-one boolean tool. It allows you to specify what operation to perform and what parameters to use via the dialog below. For quicker boolean operations, see also Part Union, Part Common and Part Cut. +

      PartBooleansDialog.png +

      See also Part → Refine Shape +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Part_Booleans.svg b/localwiki/Part_Booleans.svg new file mode 100644 index 0000000..3a960c4 --- /dev/null +++ b/localwiki/Part_Booleans.svg @@ -0,0 +1,69 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + [wmayer] + + + Part_Booleans + 2011-10-10 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Part/Gui/Resources/icons/Part_Booleans.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + diff --git a/localwiki/Part_Box-Properties.jpg b/localwiki/Part_Box-Properties.jpg new file mode 100644 index 0000000..3969d82 Binary files /dev/null and b/localwiki/Part_Box-Properties.jpg differ diff --git a/localwiki/Part_Box.html b/localwiki/Part_Box.html new file mode 100644 index 0000000..e388281 --- /dev/null +++ b/localwiki/Part_Box.html @@ -0,0 +1,107 @@ +Part Box

      Part Box

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Part Box.png Part Box

      +
      Menu location +
      Part → Primitives → Cube +
      Workbenches +
      Part, Complete +
      Default shortcut +
      None +
      See also +
      Part CreatePrimitives +

      + +
      +


      +

      +

      Description

      +

      The Box command from the Part Workbench inserts a parametric, rectangular cuboid, geometric primitive into the active document. By default, the Box command will insert a 10x10x10 mm cube, positioned at the origin, with the label "cube". These parameters may be modified after the object has been added. +

      Part_Box +

      +

      How to Use

      +
      • Click the cube icon Part Box.png from the Part Workbench.
      • +
      • Alternatively, you can select Part → Primitives → Cube from the menu bar.
      +

      Options

      +
      • Via the Property Editor: +
        • Length: Set the length distance for your Box object (default is 10 mm).
        • +
        • Width: Set the width distance for your Box object (default is 10 mm).
        • +
        • Height: Set the height distance for your Box object (default is 10 mm).
        • +
        • Placement: Specifies the orientation and position of the Box in the 3D space. See Placement. The reference point is the left front lower corner of the box.
        • +
        • Label: The Label is the name given to the operation. This name can be changed at your convenience.
      +

      Properties

      +

      Base +

      +
      • DATAPlacement: Specifies the orientation and position of the Box in the 3D space. See Placement. The reference point is the left front lower corner of the box.
      • +
      • DATALabel: Label given to the Box object. Change to suit your needs.
      +

      Box +

      +
      • DATALength: The length parameter is the Box's dimension in the x-direction.
      • +
      • DATAWidth: The width parameter is the Box's dimension in the y-direction.
      • +
      • DATAHeight: The height parameter is the Box's dimension in the z-direction.
      +

      Part_Box-Properties +

      +

      Scripting

      +

      The Box command can by used in macros and from the python console using the following function: +

      +
      FreeCAD.ActiveDocument.addObject("Part::Box", "myBox") 
      +
      • Where "myBox" is the label for the Box object.
      • +
      • Returns newly created object of type Box.
      +

      You can access and modify attributes of the Box object. For example, you may wish to modify the length, width and height parameters. +

      +
      FreeCAD.ActiveDocument.myBox.Length = 25
      +FreeCAD.ActiveDocument.myBox.Width = 15
      +FreeCAD.ActiveDocument.myBox.Height = 30 
      +

      You can change its placement with: +

      +
      FreeCAD.ActiveDocument.myBox.Placement = FreeCAD.Placement(FreeCAD.Vector(4, 6, 3), FreeCAD.Rotation(30, 45, 10)) 
      +

      FreeCAD - Version

      + +

      Beginning in FreeCAD version 0.14, a Part Box is referred to in the GUI elements as a Cube and the default label is "Cube". +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Part_Box.svg b/localwiki/Part_Box.svg new file mode 100644 index 0000000..72b4779 --- /dev/null +++ b/localwiki/Part_Box.svg @@ -0,0 +1,70 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [wmayer] + + + Part_Box + 2011-10-10 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Part/Gui/Resources/icons/Part_Box.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + diff --git a/localwiki/Part_Chamfer-Properties.png b/localwiki/Part_Chamfer-Properties.png new file mode 100644 index 0000000..bc68472 Binary files /dev/null and b/localwiki/Part_Chamfer-Properties.png differ diff --git a/localwiki/Part_Chamfer.html b/localwiki/Part_Chamfer.html new file mode 100644 index 0000000..942b84a --- /dev/null +++ b/localwiki/Part_Chamfer.html @@ -0,0 +1,146 @@ +Part Chamfer

      Part Chamfer

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Part Chamfer.png Part Chamfer

      +
      Menu location +
      Part → Chamfer +
      Workbenches +
      Part, Complete +
      Default shortcut +
      None +
      See also +
      +

      + +
      +


      +

      +

      Description

      +

      Chamfers the selected edge(s) of an object. A dialog allows you to choose which edge(s) to work on as well as modify various chamfer parameters. +

      Chamfer example +

      +

      How to Use

      +
      1. Press the Part Chamfer.svg button from the Part Workbench. Alternatively, you can select Part → Chamfer.
      2. +
      3. Select the shape to chamfer from the dialog.
      4. +
      5. Select edges to chamfer by checking the corresponding box in the chamfer dialog or by selecting them on the model directly.
      6. +
      7. Edit chamfer parameters.
      8. +
      9. Press OK to close the chamfer dialog and apply the chamfer.
      +

      Options

      +

      Dialog-chamfer +

      +
      • When selecting edges on the model, you have the option to select by edge or by face. Selecting by face will select all bordering edges of that face.
      • +
      • Constant length chamfer or variable length chamfer. +
        • A constant length chamfer will create a chamfer with edges equidistant to the original edge at the distance specified.
        • +
        • A variable length chamfer will have edges that may be set to different distances from the original edge, allowing you to create a chamfer at a variable angle.
      +

      Properties

      +
      Part_Chamfer Properties
      +


      +

      Base +

      +
      • DATABase: The shape onto which the chamfer is to be applied.
      • +
      • DATAPlacement: Specifies the orientation and position of the shape in the 3D space.
      • +
      • DATALabel: Label given to the object. Change to suit your needs.
      +
      +


      +

      +

      Scripting

      +

      The Chamfer tool can by used in macros and from the python console by adding a Chamfer object to the document. +

      Example Script: +

      +
      import Part
      +cube = FreeCAD.ActiveDocument.addObject("Part::Feature", "myCube")
      +cube.Shape = Part.makeBox(5, 5, 5)
      +chmfr = FreeCAD.ActiveDocument.addObject("Part::Chamfer", "myChamfer")
      +chmfr.Base = FreeCAD.ActiveDocument.myCube
      +myEdges = []
      +myEdges.append((1, 1.5, 1.25)) # (edge number, chamfer start length, chamfer end length)
      +myEdges.append((2, 1.5, 1.25))
      +myEdges.append((3, 1.5, 1.25))
      +myEdges.append((4, 1.5, 1.25))
      +myEdges.append((5, 1.5, 1.25))
      +myEdges.append((6, 1.5, 1.25))
      +myEdges.append((7, 1.5, 1.25))
      +myEdges.append((8, 1.5, 1.25))
      +myEdges.append((9, 1.5, 1.25))
      +myEdges.append((10, 1.5, 1.25))
      +myEdges.append((11, 1.5, 1.25))
      +myEdges.append((12, 1.5, 1.25))
      +chmfr.Edges = myEdges
      +FreeCADGui.ActiveDocument.myCube.Visibility = False
      +FreeCAD.ActiveDocument.recompute() 
      +

      Example Script Explanation: +

      +
      import Part
      +cube = FreeCAD.ActiveDocument.addObject("Part::Feature", "myCube")
      +cube.Shape = Part.makeBox(5, 5, 5) 
      +
      • Creates a 5 mm cube for us to apply chamfered edges to. See Part_API for an explanation of the makeBox method.
      +
      chmfr = FreeCAD.ActiveDocument.addObject("Part::Chamfer", "myChamfer") 
      +
      • Adds a new object to the document of type Chamfer (from the Part module) with label "myChamfer".
      +
      chmfr.Base = FreeCAD.ActiveDocument.myCube 
      +
      • Specifies that the base shape of the chamfer object should be "myCube".
      +
      myEdges = []
      +myEdges.append((1, 1.5, 1.25)) # (edge number, chamfer start length, chamfer end length)
      +myEdges.append((2, 1.5, 1.25))
      +myEdges.append((3, 1.5, 1.25))
      +myEdges.append((4, 1.5, 1.25))
      +myEdges.append((5, 1.5, 1.25))
      +myEdges.append((6, 1.5, 1.25))
      +myEdges.append((7, 1.5, 1.25))
      +myEdges.append((8, 1.5, 1.25))
      +myEdges.append((9, 1.5, 1.25))
      +myEdges.append((10, 1.5, 1.25))
      +myEdges.append((11, 1.5, 1.25))
      +myEdges.append((12, 1.5, 1.25)) 
      +
      • Creates an empty array "myEdges" and then appends the array with each edge's chamfer parameters.
      • +
      • Syntax for each item should be (edge#, chamfer start length, chamfer end length)
      +
      chmfr.Edges = myEdges 
      +
      • Sets the Edges attribute of our Chamfer object equal to the array we just created.
      +
      FreeCADGui.ActiveDocument.myCube.Visibility = False 
      +
      • This line simply hides "myCube" so that our newly created "myChamfer" object is the only one visible.
      +
      FreeCAD.ActiveDocument.recompute() 
      +
      • Recomputes all altered components on the screen and refreshes the display.
      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Part_Chamfer.svg b/localwiki/Part_Chamfer.svg new file mode 100644 index 0000000..c0e9847 --- /dev/null +++ b/localwiki/Part_Chamfer.svg @@ -0,0 +1,67 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [wmayer] + + + Part_Chamfer + 2011-10-10 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Part/Gui/Resources/icons/Part_Chamfer.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + diff --git a/localwiki/Part_CheckGeometry.html b/localwiki/Part_CheckGeometry.html new file mode 100644 index 0000000..9bc679c --- /dev/null +++ b/localwiki/Part_CheckGeometry.html @@ -0,0 +1,96 @@ +Part CheckGeometry

      Part CheckGeometry

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Part CheckGeometry.png Part CheckGeometry‏‎

      +
      Menu location +
      Part → Check geometry +
      Workbenches +
      Part +
      Default shortcut +
      None +
      See also +
      +

      + +
      +


      +

      +

      Introduction

      +

      The check geometry tool allows you to verify if you have a valid solid +

      +

      Usage

      +

      The tool is available in the Part workbench under Part menu or with the button in the Boolean toolbar. +Select a part (beware to select the whole part and not just a face to check for valid solid) then launch the tool. +You will see results in the Task panel. +

      +

      Activate extra BOP check

      +

      If you want to enable the extra BOP (BOP= Boolean OPerations) checks then follow these steps : +Tools menu > Edit Parameters > Preferences > Mod > Part > CheckGeometry +then in the right pane double click under Value for the RunBOPCheck parameter and set to true, then click Save to disk, close and restart. +See the screenshot below. +

      If the parameter or folder does not exist, you can create by +

      +
      • choosing "Tools > Edit Parameters ..." from the top menu
      • +
      • unfold the group "Preferences"
      • +
      • unfold the group "Mod"
      • +
      • unfold the group "Part"
      • +
      • right-cklick on part and choose "Add sub-group"
      • +
      • name the sub-group "CheckGeometry"
      • +
      • make sure the (just created) sub-group "CheckGeometry" is selected and right-click in the RIGHT (empty) window and choose "New Boolean Item"
      • +
      • name the new boolean item "RunBOPCheck" and make sure it is set to "true"
      +


      +PartCheckGeometry.png +

      +

      Run Check and interpret results

      +
      • select in the tree view one or more objects you like to check
      • +
      • click on Part CheckGeometry.png
      • +
      • you will get a report on the left side of the screen showing the result of the scan
      • +
      • if your scan turned up errors you may click in the report window on a specific error message and the corresponding geometric object (edge/face ...) will be highlighted in the 3D view
      • +
      • at the moment FreeCAD has no automatic repair methods for solids, so you need to look at the steps used in FreeCAD to model this specific geometry and try to fix the error yourself
      +

      GeometryCheck Errors.jpg +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Part_CheckGeometry.svg b/localwiki/Part_CheckGeometry.svg new file mode 100644 index 0000000..879128c --- /dev/null +++ b/localwiki/Part_CheckGeometry.svg @@ -0,0 +1,103 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + [tanderson] + + + Part_CheckGeometry + 2012-09-08 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Part/Gui/Resources/icons/Part_CheckGeometry.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + diff --git a/localwiki/Part_Circle.html b/localwiki/Part_Circle.html new file mode 100644 index 0000000..f67ef33 --- /dev/null +++ b/localwiki/Part_Circle.html @@ -0,0 +1,76 @@ +Part Circle

      Part Circle

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Part Circle.png Part Circle

      +
      Menu location +
      Part → Create Primitives → Circle +
      Workbenches +
      Part, OpenSCAD +
      Default shortcut +
      None +
      See also +
      .. +

      + +
      +


      +


      +

      +

      Description

      +

      A Circle geometric primitive is available from the Create Primitives dialogue in the Part workbench. +

      The Create Primitives dialogue can be accessed via the CreatePrimitives icon Part CreatePrimitives.png located in the Part menu or the Part toolbar, in the Part Workbench. +

      This command will create a circular curved edge. With the default values, the circular curved edge will be closed and therefore will be a circle. If the properties Angle 0 or Angle 1 are changed from their default values (0 and 360) the edge will be an open curve, an arc. +

      Alternatively a Part Circle can be initially defined from three points. Once created the circle will only contain the standard Part Circle properties and will no longer contain a reference to the creation points. +


      +

      +

      Properties

      +
      • Radius: the radius of the curved edge (arc or circle)
      • +
      • Angle 0: start of the curved edge, (degrees anti-clockwise), the default value is 0
      • +
      • Angle 1: end of the curved edge, (degrees anti-clockwise), the default value is 360
      +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Part_Circle_Parametric.svg b/localwiki/Part_Circle_Parametric.svg new file mode 100644 index 0000000..07b8a44 --- /dev/null +++ b/localwiki/Part_Circle_Parametric.svg @@ -0,0 +1,94 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [jmaustpc] + + + Part_Circle_Parametric + 2013-03-05 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Part/Gui/Resources/icons/Part_Circle_Parametric.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Part_Classes.jpg b/localwiki/Part_Classes.jpg new file mode 100644 index 0000000..4f71ffb Binary files /dev/null and b/localwiki/Part_Classes.jpg differ diff --git a/localwiki/Part_Common.html b/localwiki/Part_Common.html new file mode 100644 index 0000000..09d04e9 --- /dev/null +++ b/localwiki/Part_Common.html @@ -0,0 +1,66 @@ +Part Common

      Part Common

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Part Common.png Part Common

      +
      Menu location +
      Part → Common +
      Workbenches +
      Part,Complete +
      Default shortcut +
      None +
      See also +
      Part Union, Part Cut +

      + +
      +


      +

      Extracts the common part (intersection) between selected Part objects. This operation is fully parametric and the components can be modified and the result recomputed. +

      +

      How to use

      +
      1. Select two shapes
      2. +
      3. Press the Part Common.png Part Common button.
      +

      Supported inputs

      +

      Input objects must be OpenCascade shapes. Examples: stuff made with Part, PartDesign, Sketcher workbenches. Not meshes (unless those were converted to shapes) - for meshes, there are specific Boolean tools in MeshDesign workbench. +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Part_Common.svg b/localwiki/Part_Common.svg new file mode 100644 index 0000000..9e24184 --- /dev/null +++ b/localwiki/Part_Common.svg @@ -0,0 +1,81 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [wmayer] + + + Part_Common + 2011-10-10 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Part/Gui/Resources/icons/Part_Common.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + diff --git a/localwiki/Part_CompJoinFeatures.html b/localwiki/Part_CompJoinFeatures.html new file mode 100644 index 0000000..3fbf3e4 --- /dev/null +++ b/localwiki/Part_CompJoinFeatures.html @@ -0,0 +1,62 @@ +Part CompJoinFeatures

      Part CompJoinFeatures

      + +

      Under construction! +

      + + + + + + + + + + + + + + + + + + + + +
      +

      Part CompJoinFeatures.png Part CompJoinFeatures

      +
      Menu location +
      Part → Join +
      Workbenches +
      Part +
      Default shortcut +
      None +
      See also +
      Connect, Embed, Cutout, Part Booleans, Part Thickness +

      Contents

      + +
      + +
      +


      +

      This command is a dropdown toolbar button containing all the Join tools. See individual tool pages for more info.
      Connect, Embed, Cutout +

      JoinFeatures dropdownToolbarButton.png +

      JoinFeatures demo.png +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Part_CompoundFilter.svg b/localwiki/Part_CompoundFilter.svg new file mode 100644 index 0000000..09c2a81 --- /dev/null +++ b/localwiki/Part_CompoundFilter.svg @@ -0,0 +1,281 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Part_Cone.html b/localwiki/Part_Cone.html new file mode 100644 index 0000000..5dc8d32 --- /dev/null +++ b/localwiki/Part_Cone.html @@ -0,0 +1,85 @@ +Part Cone

      Part Cone

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Part Cone.png Part Cone

      +
      Menu location +
      Part -> Cone +
      Workbenches +
      Part, Complete +
      Default shortcut +
      None +
      See also +
      Part CreatePrimitives +

      + +
      +


      +

      +

      Description

      +

      A parametric truncated Part Cone primitive is available in the Part workbench from the Part tool bar, Part menu (primitives sub-menu) and the Create Primitives dialogue. +

      +

      How to use

      +

      In the workbench Part click on the cone icon Part Cone.png. +

      The default values create a truncated parametric cone, defined by radius1, radius2 height and angle, parameters. The default cone will be positioned at origin (point 0,0,0) on creation. The angle parameter permits the creation of a portion of cone (it is set to 360° by default), and the radius 1 and 2 correspond to base and top radius of the truncated cone. +

      +

      Options

      + + + +
      PartConeProperty en.png + +

      Cone +

      +
      • Radius 1 - radius of the arc or circle defining the lower face
      • +
      • Radius 2 - radius of the arc or circle defining the upper face
      • +
      • Height - the height of the Part Cone
      • +
      • Angle - the number of degrees of the arc or circles defining the upper and lower faces of the truncated cone. The default 360 creates circular faces, a lower value will create a portion of a cone as defined by upper and lower faces each with edges defined by an arc of the number of degrees and two radii.
      +
      +


      +The image below shows a Part Cone with the parameter "Angle" set to 270 degrees and all other parameters are at their default values. +

      Otherwisedefault270degree Part Cone.png +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Part_Cone.svg b/localwiki/Part_Cone.svg new file mode 100644 index 0000000..951289c --- /dev/null +++ b/localwiki/Part_Cone.svg @@ -0,0 +1,62 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + [wmayer] + + + Part_Cone + 2011-10-10 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Part/Gui/Resources/icons/Part_Cone.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + diff --git a/localwiki/Part_ConvertToSolid.html b/localwiki/Part_ConvertToSolid.html new file mode 100644 index 0000000..72c388b --- /dev/null +++ b/localwiki/Part_ConvertToSolid.html @@ -0,0 +1,76 @@ +Part ConvertToSolid

      Part ConvertToSolid

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Part ConvertToSolid.png Part ConvertToSolid‏‎

      +
      Menu location +
      Part → Convert to solid +
      Workbenches +
      Part +
      Default shortcut +
      None +
      See also +
      +

      + +
      +


      +

      +

      Introduction

      +

      This command creates a solid from a shape object. +

      +

      Use

      +
      1. Select the shape object.
      2. +
      3. Choose PartConvert to solid from the top menu.
      4. +
      5. A solid from the shape object is created as a seperate new object.
      +

      Limitations

      +

      There will be no analyzing or validating of the shape object. +
      +It is recommended to use Part Refine Shape before converting to a solid. +

      +

      Notes

      +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Part_ConvertToSolid.png b/localwiki/Part_ConvertToSolid.png new file mode 100644 index 0000000..782eb4d Binary files /dev/null and b/localwiki/Part_ConvertToSolid.png differ diff --git a/localwiki/Part_CreatePrimitives.html b/localwiki/Part_CreatePrimitives.html new file mode 100644 index 0000000..b091625 --- /dev/null +++ b/localwiki/Part_CreatePrimitives.html @@ -0,0 +1,80 @@ +Part CreatePrimitives

      Part CreatePrimitives

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Part CreatePrimitives.png Part CreatePrimitives

      +
      Menu location +
      Part -> CreatePrimitives... +
      Workbenches +
      Part +
      Default shortcut +
      None +
      See also +
      Part Shapebuilder +

      Contents

      + +
      + +
      +


      +

      A tool to create various parametric geometric primitives. +

      + +

      Part CreatePrimitives example FreeCAD 0 13.jpg +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Part_CreatePrimitives.svg b/localwiki/Part_CreatePrimitives.svg new file mode 100644 index 0000000..c31a408 --- /dev/null +++ b/localwiki/Part_CreatePrimitives.svg @@ -0,0 +1,124 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [wmayer] + + + Part_CreatePrimitives + 2011-10-21 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Part/Gui/Resources/icons/Part_CreatePrimitives.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Part_CreatePrimitives_example_FreeCAD_0_13.jpg b/localwiki/Part_CreatePrimitives_example_FreeCAD_0_13.jpg new file mode 100644 index 0000000..4a09a6a Binary files /dev/null and b/localwiki/Part_CreatePrimitives_example_FreeCAD_0_13.jpg differ diff --git a/localwiki/Part_CreateSimpleCopy.html b/localwiki/Part_CreateSimpleCopy.html new file mode 100644 index 0000000..7484edc --- /dev/null +++ b/localwiki/Part_CreateSimpleCopy.html @@ -0,0 +1,71 @@ +Part CreateSimpleCopy

      Part CreateSimpleCopy

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Part CreateSimpleCopy.png Part CreateSimpleCopy‏‎

      +
      Menu location +
      Part → Create simple copy +
      Workbenches +
      Part +
      Default shortcut +
      None +
      See also +
      Clone, Copy, Duplicate Selection +

      + +
      +


      +

      +

      Introduction

      +

      Removes the history of the part so that the different steps to create the part aren't accessible/editable any more +

      With Simple copy only a non-parametric simple solid is produced, so if you want to change anything you have to go back to your creation file or history fix the issue then create a new simple solid. +

      +

      Usage

      +

      Mark part of choice in the tree view and choose Part → Create simple copy. +

      +

      Links

      +


      +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Part_CreateSimpleCopy.png b/localwiki/Part_CreateSimpleCopy.png new file mode 100644 index 0000000..782eb4d Binary files /dev/null and b/localwiki/Part_CreateSimpleCopy.png differ diff --git a/localwiki/Part_Create_Primitives1.jpeg b/localwiki/Part_Create_Primitives1.jpeg new file mode 100644 index 0000000..44ebba8 Binary files /dev/null and b/localwiki/Part_Create_Primitives1.jpeg differ diff --git a/localwiki/Part_CrossSections.svg b/localwiki/Part_CrossSections.svg new file mode 100644 index 0000000..1ac3b48 --- /dev/null +++ b/localwiki/Part_CrossSections.svg @@ -0,0 +1,74 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [wmayer] + + + Part_CrossSections + 2012-12-03 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Part/Gui/Resources/icons/Part_CrossSections.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + diff --git a/localwiki/Part_Cut.html b/localwiki/Part_Cut.html new file mode 100644 index 0000000..59cf054 --- /dev/null +++ b/localwiki/Part_Cut.html @@ -0,0 +1,68 @@ +Part Cut

      Part Cut

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Part Cut.png Part Cut

      +
      Menu location +
      Part → Cut +
      Workbenches +
      Part, Complete +
      Default shortcut +
      None +
      See also +
      Part Union, Part Common +

      + +
      +


      +

      Cuts (subtracts) selected Part objects, the last one being subtracted from the first one. This operation is fully parametric and the components can be modified and the result recomputed. +

      +
      Part Cut
      +
      +

      How to use

      +
      1. Select two shapes
      2. +
      3. Press the Part Cut.png Part Cut button.
      +

      Supported inputs

      +

      Input objects must be OpenCascade shapes. Examples: stuff made with Part, PartDesign, Sketcher workbenches. Not meshes (unless those were converted to shapes) - for meshes, there are specific Boolean tools in MeshDesign workbench. +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Part_Cut.svg b/localwiki/Part_Cut.svg new file mode 100644 index 0000000..b10a376 --- /dev/null +++ b/localwiki/Part_Cut.svg @@ -0,0 +1,69 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [wmayer] + + + Part_Cut + 2011-10-10 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Part/Gui/Resources/icons/Part_Cut.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + diff --git a/localwiki/Part_Cylinder.html b/localwiki/Part_Cylinder.html new file mode 100644 index 0000000..fa07b3d --- /dev/null +++ b/localwiki/Part_Cylinder.html @@ -0,0 +1,80 @@ +Part Cylinder

      Part Cylinder

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Part Cylinder.png Part Cylinder

      +
      Menu location +
      Part → Cylinder +
      Workbenches +
      Part, Complete +
      Default shortcut +
      None +
      See also +
      Part CreatePrimitives +

      + +
      +


      +

      +

      Description

      +

      Creates a simple parametric cylinder, with position, angle, radius and height parameters. +

      +

      How to use

      +

      In the workbench Part click on the cube icon Part Cylinder.png. The default is for a full cylinder to be positioned, the centre of one circular face coincident with the global origin (point 0,0,0), with a radius of 2mm and height of 10mm. +

      +

      Options

      +

      The properties can later be edited in the data tab for the cylinder: +

      a cylinder created with the Cylinder tool +

      +

      Cylinder

      +
      • Angle: The angle parameter permits the creation of a portion of cylinder (it is set to 360° by default)
      • +
      • Height: The height is the distance in the z-axis
      • +
      • Radius: The radius defines a plane in x-y.
      +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Part_Cylinder.svg b/localwiki/Part_Cylinder.svg new file mode 100644 index 0000000..2e0eabd --- /dev/null +++ b/localwiki/Part_Cylinder.svg @@ -0,0 +1,65 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + [wmayer] + + + Part_Cylinder + 2011-10-10 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Part/Gui/Resources/icons/Part_Cylinder.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + diff --git a/localwiki/Part_Ellipse.html b/localwiki/Part_Ellipse.html new file mode 100644 index 0000000..c898564 --- /dev/null +++ b/localwiki/Part_Ellipse.html @@ -0,0 +1,70 @@ +Part Ellipse

      Part Ellipse

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Part Ellipse.png Part Ellipse

      +
      Menu location +
      Part → Create Primitives → Ellipse +
      Workbenches +
      Part, OpenSCAD +
      Default shortcut +
      None +
      See also +
      .. +

      + +
      +


      +


      +

      +

      Description

      +

      An Ellipse geometric primitive is available from the Create Primitives dialogue in the Part workbench. +

      The Create Primitives dialogue can be accessed via the CreatePrimitives icon Part CreatePrimitives.png located in the Part menu or the Part toolbar, in the Part Workbench. +

      This command will create a elliptical curved edge. With the default values, the elliptical curved edge will be closed and therefore will be an ellipse. If the properties Angle 1 or Angle 2 are changed from their default values (0 and 360) the edge will be an open curve. +

      +

      Properties

      +
      • Major radius: the major radius of the ellipse, the default value is 4
      • +
      • Minor radius: the minor radius of the ellipse, the default value is 2
      • +
      • Angle 1: start of the edge of the ellipse or elliptical curved edge, (degrees anti-clockwise), the default value is 0
      • +
      • Angle 2: end of the edge of the ellipse or elliptical curved edge, (degrees anti-clockwise), the default value is 360
      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Part_Ellipse_Parametric.svg b/localwiki/Part_Ellipse_Parametric.svg new file mode 100644 index 0000000..e22c29a --- /dev/null +++ b/localwiki/Part_Ellipse_Parametric.svg @@ -0,0 +1,118 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [jmaustpc] + + + Part_Ellipse_Parametric + 2013-03-05 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Part/Gui/Resources/icons/Part_Ellipse_Parametric.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Part_Ellipsoid.html b/localwiki/Part_Ellipsoid.html new file mode 100644 index 0000000..5f449d8 --- /dev/null +++ b/localwiki/Part_Ellipsoid.html @@ -0,0 +1,76 @@ +Part Ellipsoid

      Part Ellipsoid

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Part Ellipsoid.png Part Ellipsoid

      +
      Menu location +
      Part → Create Primitives → Ellipsoid +
      Workbenches +
      Part, OpenSCAD +
      Default shortcut +
      None +
      See also +
      .. +

      + +
      +


      +

      +

      Description

      +

      A parametric Ellipsoid solid is available from the Create Primitives dialogue in the Part workbench. +

      The Create Primitives dialogue can be accessed via the CreatePrimitives icon Part CreatePrimitives.png located in the Part menu or the Part toolbar, in the Part Workbench. +

      The shape produced is limited in FreeCAD to being a solid (optionally truncated) spheroid, the shape you would create by rotating an ellipse around one of its axis. By default it is a oblate_spheroid, the shape you would create by rotating an ellipse around its minor axis. The parameters can be changed to form a prolate_spheroid. +

      The default spheroid in FreeCAD will have a circle for any cross section parallel to the xy plane. The cross section parallel to the other two planes will be an ellipse. +

      In mathematics, an Ellipsoid would have an elliptical cross section in all three planes. +

      +

      Properties

      +
      • Radius 1, by default the minor radius parallel to the Z-axis,
      • +
      • Radius 2, by default the major radius parallel to the XY plane, it is also the maximum radius of the circular cross section
      • +
      • Angle 1, lower truncation of the ellipsoid, parallel to the circular cross section (-90 degrees in a full spheroid)
      • +
      • Angle 2, upper truncation of the ellipsoid, parallel to the circular cross section (90 degrees in a full spheroid)
      • +
      • Angle 3, angle of rotation of the elliptical cross section (360 degrees in a full spheroid)
      +
      +


      +Part Ellipsoid screenshot.jpg +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Part_Ellipsoid_screenshot.jpg b/localwiki/Part_Ellipsoid_screenshot.jpg new file mode 100644 index 0000000..02a3440 Binary files /dev/null and b/localwiki/Part_Ellipsoid_screenshot.jpg differ diff --git a/localwiki/Part_Export.svg b/localwiki/Part_Export.svg new file mode 100644 index 0000000..0ec045b --- /dev/null +++ b/localwiki/Part_Export.svg @@ -0,0 +1,80 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [jmaustpc] + + + Part_Export + 2013-03-22 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Part/Gui/Resources/icons/Part_Export.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Part_ExportCAD.html b/localwiki/Part_ExportCAD.html new file mode 100644 index 0000000..0f8ef97 --- /dev/null +++ b/localwiki/Part_ExportCAD.html @@ -0,0 +1,73 @@ +Part ExportCAD

      Part ExportCAD

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Part ExportCAD.png Part ExportCAD‏‎

      +
      Menu location +
      Part → Export CAD +
      Workbenches +
      Part +
      Default shortcut +
      None +
      See also +
      Std Export +

      + +
      +


      +

      +

      Introduction

      +

      It allows you to export a part object in a *.IGES, *.STEP, *.BREP file +

      +

      Use

      +
      1. Select shapes in tree view or in 3D view
      2. +
      3. Click on PartPart ExportCAD.png ExportCAD from the top menu.
      4. +
      5. Select file format and path
      +

      Links

      +

      Preferences-import-export.svg Preference ... Import Export +


      +
      +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Part_Extrude.html b/localwiki/Part_Extrude.html new file mode 100644 index 0000000..ca46a81 --- /dev/null +++ b/localwiki/Part_Extrude.html @@ -0,0 +1,125 @@ +Part Extrude

      Part Extrude

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Part Extrude.png Part Extrude

      +
      Menu location +
      Part → Extrude +
      Workbenches +
      Part +
      Default shortcut +
      None +
      See also +
      +

      + +
      +


      +

      Part Extrude demo.png +

      +

      Description

      +

      Part Extrude extends a shape by a specified distance, in a specified direction. The output shape type will vary depending on the input shape type and the options selected. +

      In most common scenarios, the following lists the expected output shape type from a given input shape type, +

      +
      • Extrude a Vertex (point), will produce a lineal Edge (Line)
      • +
      • Extrude a open edge (e.g. line, arc), will produce a open face (e.g. plane)
      • +
      • Extrude a closed edge (e.g. circle), will optionally produce a closed face (e.g. an open ended cylinder) or if the parameter "solid" is "true" will produce a solid (e.g. a closed solid cylinder)
      • +
      • Extrude a open Wire (e.g. a Draft Wire), will produce a open shell (several joined faces)
      • +
      • Extrude a closed Wire (e.g. a Draft Wire), will optionally produce a shell (several joined faces) or if the parameter "solid" is "true" will produce a solid
      • +
      • Extrude a face (e.g. plane), will produce a solid (e.g. Cuboid)
      • +
      • Extrude a Draft Shape String, will produce a compound of solids (the string is a compound of the letters which are each a solid)
      • +
      • Extrude a shell of faces, will produce a Compsolid.
      +

      How to use

      +
      1. Select the shape(s) in the 3D view or in the Model tree
      2. +
      3. Click on the Part Extrude.png Extrude icon in the toolbar, or go to the Part → Extrude menu
      4. +
      5. Set the direction and length and optionally other parameters (see the following Parameters section for more details).
      6. +
      7. Click OK.
      +

      Alternatively, the selection can be done after launching the tool, by selecting one or more shape from the list in the Tasks panel. +

      The Model tree will list as many Extrude objects as there were selected shapes. Each input shape is placed underneath its Extrude object. +

      +

      Parameters

      +

      The Extrude shape is defined by the following parameters, which can be edited after its creation in the Data tab. +

      +
      • Base: the input shape (the shape upon which the Part Extrude was applied)
      +
      • Dir: the direction to extend the shape. If Dir Mode is 'Custom', you can edit Dir. Otherwise, Dir is read-only, and computed from the linked shape.
      +
      • Dir Link: parametric link to a edge (line) that sets the direction of extrusion. As of v0.17, this property is not supported by property editor.
      +
      • Dir Mode: sets how Dir is controlled. 'Custom' meand Dir is editable. 'Edge' means Dir is obtained from an edge (line) linked by Dir Link. 'Normal' means Dir is perpendicular to plane of the input shape.
      +
      • Length Fwd: The distance to extrude by. If both Length Fwd and Length Rev are zero, the length of Dir vector is used.
      +
      • Length Rev: Additional length to extrude against Dir.
      +
      • Solid: if True, extruding a closed edge or a closed wire will yield a solid. If False, a shell will result.
      +
      • Reversed: reverses the extrusion to go against Dir.
      +
      • Symmetric: if True, extrusion is centered at the input shape, and total length is Length Fwd. Length Rev is ignored.
      +
      • Taper Angle and Taper Angle Rev: applies an angle to the extrusion, so that sides of the extrusion are drafted by the specified angle. Positive angle means the cross-section expands. Taper Angle Rev sets the taper for the reversed part of the extrusion (the part from Length Rev). As of v0.17, tapered extrusion is only supported for wires with no holes.
      +
      • Face Maker Class: sets C++ class name of face making code, which is used when making solids from wires. This property is here mainly for maintaining backward compatibility. Do not touch, unless you know what you are doing.
      + +
      • Label: label to be shown in the Model tree (not available on Extrude creation)
      +

      Task dialog

      +
      Part Extrude dialog.png
      +
      • OK: creates the extrusion, and closes the dialog.
      +
      • Close: closes dialog, without doing anything.
      +
      • Apply: creates the extrusion, but does not close the dialog. You can then select another shape in the list on the bottom, and create more extrusions. Clicking Apply may times creates many extrusions.
      +
      • 'Direction' radio buttons: set the way extrusion direction is computed.
      +
      • 'Select' button: click it, and then pick an edge in 3D view. That edge will appear in text field next to the button, in format "ObjectName:EdgeN". You can also type the link manually. Values X,Y,Z will be filled according to the edge direction.
      +
      • X, Y, Z buttons: click X button to set extrusion direction to +X axis. Click it again to set -X axis.
      +
      • X,Y,Z input fields: set or display the direction vector of extrusion. If both lengths are zero, the length of this vector sets the length of extrusion, and values are always in mm, regardless of unit preferences.
      +
      • Length fields: set length of extrusion. These input fields have unit support.
      +
      • Symmetric: spreads out the extrusion into both directions, so that the profile remains in the middle.
      +
      • Taper Outward Angle: positive angle means profile is expanded at other end of extrusion.
      +
      • Create Solid checkbox: if checked, extruding a closed wire or edge will yield a solid. It is checked by default, if a closed wire was preselected before invoking Part Extrude.
      +
      • Shape list: here you select, what shapes to extrude. If multiple objects are selected, multiple Extrude objects are created.
      +

      Gotchas

      +

      Part Extrude dialog does not offer a preview, yet. 'Apply' will create an extrusion object every time you click it, which can be useful as preview; however, they will remain and yet another one will be created as you click OK. Undo can be useful to clean them up before clicking OK. +

      Since v0.17, a sketch created from within PartDesign cannot be used for Part Extrude, if it is within a Body ("Links go out of allowed scope" error). In order to Part-Extrude a sketch, you should create the sketch from Sketcher workbench. Or you can just drag a PartDesign one out of a Body. +

      Extrusion with taper angle does not support holes. It also may give bogus results if the number of segments in the profile changes as a result of taper. +

      +

      Comparison with PartDesign Pad

      +

      PartDesign Pad is also an extrusion feature, but there are important differences. +

      Part Extrude always creates a standalone shape. PartDesign Pad fuses the extrusion result to the rest of the Body. +

      Part Extrude doesn't care where it is in model tree. PartDesign Pad can only live inside a PartDesign Body. +

      Part Extrude can extrude any object that has Part Geometry (OCC shape), except for solids and compsolids. And it can't extrude individual faces of other objects. PartDesign Pad will only accept a Sketch as a profile (and a small selection of other object types), or a face of a solid. +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Part_Extrude.svg b/localwiki/Part_Extrude.svg new file mode 100644 index 0000000..4aa2c10 --- /dev/null +++ b/localwiki/Part_Extrude.svg @@ -0,0 +1,83 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + [wmayer] + + + Part_Extrude + 2011-10-10 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Part/Gui/Resources/icons/Part_Extrude.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Part_Fillet.html b/localwiki/Part_Fillet.html new file mode 100644 index 0000000..b71875b --- /dev/null +++ b/localwiki/Part_Fillet.html @@ -0,0 +1,89 @@ +Part Fillet

      Part Fillet

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Part Fillet.png Part Fillet

      +
      Menu location +
      Part → Fillet +
      Workbenches +
      Part, Complete +
      Default shortcut +
      None +
      See also +
      Part Chamfer +

      + +
      +


      +

      +

      Description

      +

      This tool creates a fillet (round) on the selected edges of an object. A dialog allows you to choose which objects and which edges to work on. +

      +

      Usage

      +
      • Start the tool from the Part toolbar or from the menu. You can either select the object before or after starting the tool.
      • +
      • If the shape was not selected prior to starting the tool, select it in the Shape drop down list in the TaskPanel.
      • +
      • Select the fillet type, either constant radius (default) or variable radius.
      • +
      • Select the edges either in the 3D model view, or by ticking them in the edge list in TaskPanel.
      • +
      • Set the radius value.
      • +
      • Click OK to validate.
      +


      +Dialog-fillet.jpg +

      +

      Part Fillet VS. PartDesign Fillet

      +

      There is another fillet tool in the PartDesign workbench. Please note that their operation is quite different. Check out the PartDesign Fillet reference page for more details on their differences. +


      +

      +

      Notes on application of Part Fillet

      +

      The fillet tool sometimes fails when trying to fillet complex objects. +A common cause of this may be that the shape being filleted is not geometrically correct. This may be the result of lines/planes etc not being removed after previous operations used to construct the shape ( e.g. Cut/Intersection/Fusion). A number of steps can be used to minimize problems: +

      +
      • Where possible leave filleting a part until the part is completely generated. This will minimize interaction of fillets with subsequent Boolean operations;
      • +
      • Use the Part->Check Geometry to check for any errors in the shape geometry and correct;
      • +
      • Use Part->Refine shape to remove any artifacts introduced by previous Boolean operations before filleting (and in some cases between filleting operations in sequence);
      • +
      • Consider using Edit->Preferences->PartDesign to enable automatic checking and refining of the model after Boolean and sketch based operations (performance may be affected if these options are left switched on).
      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Part_Fillet.svg b/localwiki/Part_Fillet.svg new file mode 100644 index 0000000..37a6cbd --- /dev/null +++ b/localwiki/Part_Fillet.svg @@ -0,0 +1,67 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [wmayer] + + + Part_Fillet + 2011-10-10 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Part/Gui/Resources/icons/Part_ + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + diff --git a/localwiki/Part_Fuse.svg b/localwiki/Part_Fuse.svg new file mode 100644 index 0000000..19a5730 --- /dev/null +++ b/localwiki/Part_Fuse.svg @@ -0,0 +1,73 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [wmayer] + + + Part_Fuse + 2011-10-10 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Part/Gui/Resources/icons/Part_ + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + diff --git a/localwiki/Part_Helix.html b/localwiki/Part_Helix.html new file mode 100644 index 0000000..4aab291 --- /dev/null +++ b/localwiki/Part_Helix.html @@ -0,0 +1,108 @@ +Part Helix

      Part Helix

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Part Helix.png Part Helix

      +
      Menu location +
      Part → Create Primitives → Helix +
      Workbenches +
      Part, OpenSCAD +
      Default shortcut +
      None +
      See also +
      .. +

      + +
      +


      +


      +

      +

      Description

      +

      A Helix geometric primitive is available from the Create Primitives dialogue in the Part workbench. +

      The Create Primitives dialogue can be accessed via the CreatePrimitives icon Part CreatePrimitives.png located in the Part menu or the Part toolbar, in the Part Workbench. A common usage for the Helix is for threads in conjunction with the sweep operation. +

      +

      How to use

      + + + +
      PartHelixPrimitivesOptions en.png + +

      Parameter

      +
      • Pitch:The pitch corresponds to the space between two consecutive "turns" of the helix measured along the main axis of the helix.
      • +
      • Height: The height corresponds to the overall height of the helix measured along the main axis of the helix.
      • +
      • Radius: The radius corresponds to the radius of the circle built by the helix by viewing the helix from the top / bottom.
      • +
      • Angle: Per default the helix is built on a imaginary cylinder. With this option it is possible to build the helix on a imaginay conus. This angle corresponds to the angle of the conus. The value must be comprised between -90 deg and +90 deg.
      • +
      • Right-handed or Left-handed: This parameter specifies the handedness of the helix.
      +

      Location

      +
      • X: The main axis of the helix will be translated along the x axis of the value you indicate in this field.
      • +
      • Y: The main axis of the helix will be translated along the y axis of the value you indicate in this field.
      • +
      • Z: The main axis of the helix will be translated along the z axis of the value you indicate in this field.
      • +
      • Direction: Per default the main axis of the helix is the z axis. Here you have the possibility to edit the main axis of the helix. If you select the parameter "user defined..." , you will be invited to indicate the main axis of the helix by entering the coordinates of its vector.
      • +
      • 3D View: allows you select center in the 3D view
      +
      +

      Options

      +

      Properties

      +

      Once you have created the helix you have the possibility to edit its parameters. +

      + + + +
      PartHelixProperty en.png + +

      The parameters in this menu are similar to those described above.
      +Base
      +

      +
      • Placement: allows you to move or rotate the helix
      • +
      • Angle:
      +
      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Part_Helix_Parametric.svg b/localwiki/Part_Helix_Parametric.svg new file mode 100644 index 0000000..30ac43f --- /dev/null +++ b/localwiki/Part_Helix_Parametric.svg @@ -0,0 +1,133 @@ + + + + + + image/svg+xml + + + + + [jmaustpc] + + + Part_Helix_Parametric + 2013-03-05 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Part/Gui/Resources/icons/Part_Helix_Parametric.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Part_Import.svg b/localwiki/Part_Import.svg new file mode 100644 index 0000000..c04ca1c --- /dev/null +++ b/localwiki/Part_Import.svg @@ -0,0 +1,79 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + [wmayer] + + + Part_Import + 2011-10-10 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Part/Gui/Resources/icons/Part_Import.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Part_ImportCAD.html b/localwiki/Part_ImportCAD.html new file mode 100644 index 0000000..ce5e022 --- /dev/null +++ b/localwiki/Part_ImportCAD.html @@ -0,0 +1,72 @@ +Part ImportCAD

      Part ImportCAD

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Part ImportCAD.png Part ImportCAD‏‎

      +
      Menu location +
      Part → Import CAD +
      Workbenches +
      Part +
      Default shortcut +
      None +
      See also +
      Std Import +

      + +
      +


      +

      +

      Introduction

      +

      This tool allows you to add a file *.IGES, *.STEP, *.BREP to the current document. +

      +

      Use

      +
      1. Click on PartPart ImportCAD.png ImportCAD from the top menu.
      2. +
      3. Select the file to be imported
      +

      Links

      +

      Preferences-import-export.svg Preference ... Import Export +


      +
      +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Part_JoinBypass.svg b/localwiki/Part_JoinBypass.svg new file mode 100644 index 0000000..8d5b92e --- /dev/null +++ b/localwiki/Part_JoinBypass.svg @@ -0,0 +1,93 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [DeepSOIC] + + + Part_JoinBypass + 2015-06-04 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Part/Gui/Resources/icons/Part_JoinBypass.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Part_JoinConnect.html b/localwiki/Part_JoinConnect.html new file mode 100644 index 0000000..9a915c1 --- /dev/null +++ b/localwiki/Part_JoinConnect.html @@ -0,0 +1,122 @@ +Part JoinConnect

      Part JoinConnect

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Part JoinConnect.png Part JoinConnect

      +
      Menu location +
      Part → Join → Connect objects +
      Workbenches +
      Part +
      Default shortcut +
      None +
      See also +
      Connect, Embed, Cutout, Part Booleans, Part Thickness +

      + +
      +


      +

      +

      Description

      +

      Connect tool connects interiors of two walled objects (e.g., pipes). It can also join shells and wires. +

      JoinFeatures Connect.png +

      +

      How to use

      +
      1. Select objects to be connected.
        The order of selection is not important, since the action of the tool is symmetric. It is enough to select one sub-shape of each object (e.g., faces). You can also select a compound containing all the shapes to be connected, e.g. Draft Array.
      2. +
      3. Invoke the Part JoinConnect command.
      +

      A Connect parametric object is created. Original objects are hidden, and the result of conecting is shown in 3D view. +

      +

      Properties

      +

      Connect +

      +
      • DATAObjects: List of objects to be connected. Generally, at least two objects are needed, but a single compound containing the shapes to connect will do as well. (as of FreeCAD v0.17.8053, this property is not displayed in property editor, and can only be accessed via Python).
      • +
      • DATARefine: Sets whether to apply Refine operation or not, to the final shape. The default value is determined by a 'Automatically refine shape after boolean operation' checkbox in PartDesign preferences.
      • +
      • DATATolerance: "fuzziness" value. This is an extra tolerance to apply when searching for intersections, in addition to tolerances stored in the input shapes.
      +

      Example

      +
      1. Create a pipe by applying thickness to a cylinder:
        JoinFeatures Example step1.png
      2. +
      3. Create another, smaller diameter pipe, and place it so that it pierces the wall of the first pipe:
        JoinFeatures Example step2.png
      4. +
      5. Select the first pipe and the second pipe, and click the 'Connect objects' option from the Join tools dropdown toolbar button.
        JoinFeatures Example step3 Connect.png
      6. +
      7. Use some cross-section tool (Clipping plane, Arch Section Plane, Arch Cut Plane) to reveal internals. On the picture below, Arch Section Plane is used.
        JoinFeatures Example step4 Connect.png
      +

      Algorithm

      +

      The algorithms behind Join tools are quite simple, and understanding them is important to use the tools correctly. The algorithm of Connect, in particular, is quite a bit more complex than others, but it's generally enough to think of it as a symmetric variant of Embed algorithm +

      1. Each object is split into pieces by intersections with other objects. (see Part BooleanFragments) +

      2. From the pieces of an object, only the largest one is kept; all the rest are thrown away. +

      3. Intersection pieces that touch at least two objects are added to result. Then, the pieces are joined together to form the result of Connect. +

      +

      Notes

      +
      • If at step 1 each object remains in one piece, the result of Connect will be equivalent to union of Objects.
      • +
      • Now, all compounds supplied are exploded prior to connecting. This means that self-intersecting compounds, which are invalid for all other Boolean operations, are valid for Connect. (This may be changed in the future.)
      • +
      • The "largest" piece is the one that has largest mass. That is, for solids, volumes are compared; for shells and faces, areas are compared, and so on.
      • +
      • Since FreeCAD v0.17.8053, and if OCC version is 6.9.0 and above, Connect is almost as fast as all other Boolean operations. For older versions, Connect is approximately 5 times slower than a regular Boolean operation, and works only on solids.
      +

      Scripting

      +

      The Join tools can by used in macros and from the python console by using the following function: +

      +
      BOPTools.JoinFeatures.makeConnect(name)
      +
      +
      • Creates an empty Connect feature. The 'Objects' property must be assigned explicitly, afterwards.
      • +
      • Returns the newly created object.
      +

      Connect can also be applied to plain shapes, without the need to have a document object, via: +

      +
      Part.BOPTools.JoinAPI.connect(list_of_shapes, tolerance = 0.0)
      +
      +

      This can be useful for making custom Python scripted features. +

      Example: +

      +
      import Part
      +j = Part.BOPTools.JoinFeatures.makeConnect(name= 'Connect')
      +j.Objects = FreeCADGui.Selection.getSelection() 
      +

      The tool itself is implemented in Python, see /Mod/Part/BOPTools/JoinFeatures.py under where FreeCAD is installed. +

      +

      Version

      +

      The tool was introduced in FreeCAD v0.16.5069 +

      The tool was re-implemented to work via generalFuse in FreeCAD v0.17.8053 +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Part_JoinConnect.svg b/localwiki/Part_JoinConnect.svg new file mode 100644 index 0000000..e3d8785 --- /dev/null +++ b/localwiki/Part_JoinConnect.svg @@ -0,0 +1,72 @@ + + + + + + image/svg+xml + + + + + [DeepSOIC] + + + Part_JoinConnect + 2015-06-04 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Part/Gui/Resources/icons/Part_JoinConnect.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Part_JoinCutout.html b/localwiki/Part_JoinCutout.html new file mode 100644 index 0000000..cfb11b2 --- /dev/null +++ b/localwiki/Part_JoinCutout.html @@ -0,0 +1,119 @@ +Part JoinCutout

      Part JoinCutout

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Part JoinCutout.png Part JoinCutout

      +
      Menu location +
      Part → Join → Cutout for Object +
      Workbenches +
      Part +
      Default shortcut +
      None +
      See also +
      Connect, Embed, Cutout, Part Booleans, Part Thickness +

      + +
      +


      +

      +

      Description

      +

      Coutout tool creates a cutout in a walled object (e.g., a pipe) to fit another walled object. +


      +JoinFeatures Cutout.png +


      +

      +

      How to use

      +
      1. Select the base object first, then the object to define the cutout.
        The order of selection is important. It is enough to select one sub-shape of each object (e.g., faces).
      2. +
      3. Invoke the Part JoinCutout command.
      +

      A Part JoinFeature object is created, with Mode set to 'Cutout'. Original objects are hidden, and the result of cutting is shown in 3D view. +

      +

      Properties

      +

      Base +

      +
      • DATABase: Reference to base object (the one to make the cutout in). The object should be a single solid.
      • +
      • DATATool: Reference to tool object (the object that is to fit into the cutout). The object can be a single solid, or a valid compound of solids.
      • +
      • DATAMode: The mode of operation, equals 'Cutout' (Changing that will transform the tool into another Part_JoinXXX). The value of 'bypass' can be used to temporarily disable the long computations (a compound of Base and Tool will be created, which is a fast operation).
      • +
      • DATARefine: Sets whether to apply Refine operation or not, to the final shape. The default value is determined by a 'Automatically refine shape after boolean operation' checkbox in PartDesign preferences. When Mode property is 'bypass', Refine is ignored (never applied).
      +

      Example

      +
      1. Create a pipe by applying thickness to a cylinder:
        JoinFeatures Example step1.png
      2. +
      3. Create another, smaller diameter pipe, and place it so that it pierces the wall of the first pipe:
        JoinFeatures Example step2.png
      4. +
      5. Select the first pipe, then the second pipe (order of selection is important), and click the 'Cutout for object' option from the Join tools dropdown toolbar button.
        JoinFeatures Example step3 Cutout.png
      +

      Algorithm

      +

      The algorithms behind Join tools are quite simple, and understanding them is important to use the tools correctly. +

      1. Base object is boolean-cut with Tool object. The resulting shape is a set (compound) of non-intersecting solids (typically, two). +

      2. The resulting compound is filtered: only the largest solid is kept. +

      3. If Refine property is true, the resulting shape is refined. +

      JoinFeatures-Algo-Cutout.png +

      +

      Notes

      +
      • If after step 1, the object remains in one piece, the result of Cutout will be equivalent to boolean cut of Base with Tool.
      • +
      • Now, the tool will produce unexpected result, if a compound is supplied as Base. This may be changed in the future.
      • +
      • Because the largest piece is determined by comparing volumes of pieces, the tool can only work with solids. This may be changed in the future.
      +

      Scripting

      +

      The Join tools can by used in macros and from the python console by using the following function: +

      +
      JoinFeatures.makePartJoinFeature(name = 'Cutout', mode = 'Cutout')
      +
      +
      • Creates an empty Cutout feature (or other Join feature, depending on mode passed). The properties Base and Tool must be assigned explicitly, afterwards.
      • +
      • Returns the newly created object.
      +

      Example: +

      +
      import JoinFeatures
      +j = JoinFeatures.makePartJoinFeature(name = 'Cutout', mode = 'Cutout' )
      +j.Base = FreeCADGui.Selection.getSelection()[0]
      +j.Tool = FreeCADGui.Selection.getSelection()[1] 
      +

      The tool itself is implemented in Python, see /Mod/Part/JoinFeatures.py under where FreeCAD is installed. +

      +

      Version

      +

      The tool was introduced in FreeCAD v0.16.5069 +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Part_JoinCutout.svg b/localwiki/Part_JoinCutout.svg new file mode 100644 index 0000000..42bafbc --- /dev/null +++ b/localwiki/Part_JoinCutout.svg @@ -0,0 +1,70 @@ + + + + + + image/svg+xml + + + + + [DeepSOIC] + + + Part_JoinCutout + 2015-06-04 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Part/Gui/Resources/icons/Part_JoinCutout.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Part_JoinEmbed.html b/localwiki/Part_JoinEmbed.html new file mode 100644 index 0000000..8576b1b --- /dev/null +++ b/localwiki/Part_JoinEmbed.html @@ -0,0 +1,119 @@ +Part JoinEmbed

      Part JoinEmbed

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Part JoinEmbed.png Part JoinEmbed

      +
      Menu location +
      Part → Join → Embed Object +
      Workbenches +
      Part +
      Default shortcut +
      None +
      See also +
      Connect, Embed, Cutout, Part Booleans, Part Thickness +

      + +
      +


      +

      +

      Description

      +

      Embed tool embeds a walled object (e.g., a pipe) into another walled object. +

      JoinFeatures Embed.png +

      +

      How to use

      +
      1. Select the base object first, then the object to be embedded. The order of selection is important. It is enough to select one sub-shape of each object (e.g., faces).
      2. +
      3. Invoke the Part JoinEmbed command.
      +

      A Part JoinFeature object is created, with Mode set to 'Embed'. Original objects are hidden, and the result of embedding is shown in 3D view. +

      +

      Properties

      +

      Base +

      +
      • DATABase: Reference to base object (the one the other object is to be embedded into). The object should be a single solid.
      • +
      • DATATool: Reference to tool object (the object to be embedded). The object can be a single solid, or a valid compound of solids.
      • +
      • DATAMode: The mode of operation, equals 'Embed' (Changing that will transform the tool into another Part_JoinXXX). The value of 'bypass' can be used to temporarily disable the long computations (a compound of Base and Tool will be created, which is a fast operation).
      • +
      • DATARefine: Sets whether to apply Refine operation or not, to the final shape. The default value is determined by a 'Automatically refine shape after boolean operation' checkbox in PartDesign preferences. When Mode property is 'bypass', Refine is ignored (never applied).
      +

      Example

      +
      1. Create a pipe by applying thickness to a cylinder:
        JoinFeatures Example step1.png
      2. +
      3. Create another, smaller diameter pipe, and place it so that it pierces the wall of the first pipe:
        JoinFeatures Example step2.png
      4. +
      5. Select the first pipe, then the second pipe (order of selection is important), and click the 'Embed object' option from the Join tools dropdown toolbar button.
        JoinFeatures Example step3 Embed.png
      6. +
      7. Use some cross-section tool (Clipping plane, Arch Section Plane, Arch Cut Plane) to reveal internals. On the picture below, Arch Section Plane is used.
        JoinFeatures Example step4 Embed.png
      +

      Algorithm

      +

      The algorithms behind Join tools are quite simple, and understanding them is important to use the tools correctly. +

      1. Base object is boolean-cut with Tool object. The resulting shape is a set (compound) of non-intersecting solids (typically, two). +

      2. The resulting compound is filtered: only the largest solid is kept. +

      3. That largest solid is boolean-fused with Tool object. +

      4. If Refine property is true, the resulting shape is refined. +

      JoinFeatures-Algo-Embed.png +

      +

      Notes

      +
      • If after step 1, the object remains in one piece, the result of Embed will be equivalent to union of Base and Tool, but taking longer to compute.
      • +
      • Now, the tool will produce unexpected result, if a compound is supplied as Base. This may be changed in the future.
      • +
      • Because the largest piece is determined by comparing volumes of pieces, the tool can only work with solids. This may be changed in the future.
      +

      Scripting

      +

      The Join tools can by used in macros and from the python console by using the following function: +

      +
      JoinFeatures.makePartJoinFeature(name = 'Embed', mode = 'Embed')
      +
      +
      • Creates an empty Embed feature (or other Join feature, depending on mode passed). The properties Base and Tool must be assigned explicitly, afterwards.
      • +
      • Returns the newly created object.
      +

      Example: +

      +
      import JoinFeatures
      +j = JoinFeatures.makePartJoinFeature(name = 'Embed', mode = 'Embed' )
      +j.Base = FreeCADGui.Selection.getSelection()[0]
      +j.Tool = FreeCADGui.Selection.getSelection()[1] 
      +

      The tool itself is implemented in Python, see /Mod/Part/JoinFeatures.py under where FreeCAD is installed. +

      +

      Version

      +

      The tool was introduced in FreeCAD v0.16.5069 +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Part_JoinEmbed.svg b/localwiki/Part_JoinEmbed.svg new file mode 100644 index 0000000..8fa7f97 --- /dev/null +++ b/localwiki/Part_JoinEmbed.svg @@ -0,0 +1,75 @@ + + + + + + image/svg+xml + + + + + [DeepSOIC] + + + Part_JoinEmbed + 2015-06-04 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Part/Gui/Resources/icons/Part_JoinEmbed.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Part_Line.html b/localwiki/Part_Line.html new file mode 100644 index 0000000..bfbcbad --- /dev/null +++ b/localwiki/Part_Line.html @@ -0,0 +1,114 @@ +Part Line

      Part Line

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Part Line.png Part Line

      +
      Menu location +
      Part → Create Primitives → Line +
      Workbenches +
      Part, OpenSCAD +
      Default shortcut +
      None +
      See also +
      .. +

      + +
      +


      +


      +

      +

      Geometric Primitives

      + + + +
      PartLinePrimitivesOptions it.png + +

      Line +

      +

      Parameter

      +
      +
      • Start point
      • +
      • End point
      +

      Location

      +
      • +
      +
      +

      Property

      + + + +
      PartLineProperty it.png + +

      View

      +

      .. +

      +

      Data

      +

      Base
      +

      + +

      Vertex 1 Start
      +

      +
      • DATAX1 :
      • +
      • DATAX1 :
      • +
      • DATAX1 :
      +

      Vertex 2 Finish
      +

      +
      • DATAX2 :
      • +
      • DATAX2 :
      • +
      • DATAX2 :
      +
      +
      +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Part_Line_Parametric.svg b/localwiki/Part_Line_Parametric.svg new file mode 100644 index 0000000..b5c82e8 --- /dev/null +++ b/localwiki/Part_Line_Parametric.svg @@ -0,0 +1,91 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [jmaustpc] + + + Part_Line_Parametric + 2013-03-05 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Part/Gui/Resources/icons/Part_Line_Parametric.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Part_Loft.html b/localwiki/Part_Loft.html new file mode 100644 index 0000000..cbbcde3 --- /dev/null +++ b/localwiki/Part_Loft.html @@ -0,0 +1,139 @@ +Part Loft

      Part Loft

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Part Loft.png Part Loft

      +
      Menu location +
      Part → Loft... +
      Workbenches +
      Part +
      Default shortcut +
      None +
      See also +
      Part Sweep +

      + +
      +


      +


      +

      +

      Overview

      +

      The FreeCAD Loft tool (Part Workbench), is used to create a face, shell or a solid shape from two or more profiles. The profiles can be a point (vertex), line (Edge), wire or face. Edges and wires may be either open or closed. There are various limitations and complications, see below, however the profiles may come from the Part Workbench primitives, Draft Workbench features and a Sketch. +

      The Loft has three parameters, "Ruled","Solid" and "Closed" each with a value of either "true" or "false". +

      If "Ruled" is "true" FreeCAD creates a face, faces or a solid from ruled surfaces. Ruled surface page on Wikipedia. +

      If "Solid" is "true" FreeCAD creates a solid if the profiles are of closed geometry, if "false" FreeCAD creates a face or (if more than one face) a shell for either open or closed profiles. +

      If "Closed" is "true" FreeCAD attempts to loft the last profile to the first profile to create a closed figure. +

      For more info on how the profiles are joined together, refer Part Loft Technical Details page. +

      +
      Part_Loft. From three profiles which are two Part_Circles and one Part_Ellipse. Parameters are Solid "True" and Ruled "True"
      +

      Limitations and complications

      +
      • A vertex or point +
        • vertex or point may only be used as the first and/or last profile in the list of profiles. +
          • For example +
            • you cannot loft from a circle to a point, to an ellipse.
            • +
            • However you could Loft from a point to a circle to an ellipse to another point.
      • +
      • Open or closed geometry profiles can not be mixed in one single Loft +
        • In one Loft, all profiles (lines wires etc.) must be either open or closed. +
          • For example +
            • FreeCAD can not Loft between one Part Circle and one default Part Line.
      • +
      • Draft Workbench features +
        • Draft Workbench features can be directly used as a profile in FreeCAD 0.14 or later. +
          • For example the following Draft features can be used as profiles in a Part Loft +
            • Draft Polygon.
            • +
            • Draft Point, Line, wire,
            • +
            • Draft B-spline, Bezier Curve
            • +
            • Draft Circle, Ellipse, Rectangle
      • +
      • PartDesign Sketches +
        • The profile may be created with a sketch. However only a valid sketch will be shown in the list to be available for selection.
        • +
        • The sketch must contain only one open or closed wire or line (can be multiple lines, if those lines are all connected as they are then a single wire)
      • +
      • Part Workbench +
        • the profile can be a valid Part geometric primitive which can be created with the Part CreatePrimitives tool +
          • For example the following Part geometric primitives can be a valid profile +
            • Point (Vertex), Line (Edge)
            • +
            • Helix, Spiral
            • +
            • Circle, Ellipse
            • +
            • Regular Polygon
            • +
            • Plane (Face)
      +
      • Closed Lofts +
        • The results of closed lofts may be unexpected - the loft may develop twists or kinks. Lofting is very sensitive to the Placement of the profiles and the complexity of the curves required to connect the corresponding Vertices in all the profiles.
      +

      An example Loft

      +

      The Loft tool is in the Part Workbench, menu Part -> Loft... or via the icon in the tool bar. +

      Part Loft Ikon Ballon Hilfe.png +

      In the "Tasks" will be two lists: "node / wire" and "free form". +

      Part Loft Liste3.png +

      +

      Selection of the elements

      +

      In the "node / wire" the available items are displayed. Two elements must be selected one after the first in this list. +

      Part Loft Liste Auswahl 3b.png +


      +Thereafter, with the blue arrow that item is added to the list of "free form". +

      Part Loft Liste Auswahl 3c.png +

      The selected items must be of the same type. +

      Tip: the active / selected items in the list are displayed in the 3D area as active / selected. +

      +

      Command complete

      +

      If both elements are selected, the command can be completed with "OK". +

      Part Loft Liste Auswahl 3d.png +

      +

      Result

      +

      From closed lines we get surfaces which might be taken as a superficial look for solids. +

      Part Loft geschlossen.png +

      If indeed a solid needs to be created, used the button "Create Solid" or after creating the Loft switch to its properties tab data and set the switch "Solid" to true. +

      The procedure is the same as described above with open polylines. +

      +

      FreeCAD Version

      +
      • added Version 0.13
      • +
      • "closed" property added Version 0.14
      • +
      • Ability to use a face as a profile added Version 0.14
      +


      +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Part_Loft.svg b/localwiki/Part_Loft.svg new file mode 100644 index 0000000..75513fd --- /dev/null +++ b/localwiki/Part_Loft.svg @@ -0,0 +1,94 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + [wmayer] + + + Part_Loft + 2012-06-10 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Part/Gui/Resources/icons/Part_Loft.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Part_Loft_Ikon_Ballon_Hilfe.png b/localwiki/Part_Loft_Ikon_Ballon_Hilfe.png new file mode 100644 index 0000000..308e71b Binary files /dev/null and b/localwiki/Part_Loft_Ikon_Ballon_Hilfe.png differ diff --git a/localwiki/Part_Loft_Liste3.png b/localwiki/Part_Loft_Liste3.png new file mode 100644 index 0000000..ce6d600 Binary files /dev/null and b/localwiki/Part_Loft_Liste3.png differ diff --git a/localwiki/Part_Loft_Liste_Auswahl_3b.png b/localwiki/Part_Loft_Liste_Auswahl_3b.png new file mode 100644 index 0000000..da8a3b2 Binary files /dev/null and b/localwiki/Part_Loft_Liste_Auswahl_3b.png differ diff --git a/localwiki/Part_Loft_Liste_Auswahl_3c.png b/localwiki/Part_Loft_Liste_Auswahl_3c.png new file mode 100644 index 0000000..dfc7e92 Binary files /dev/null and b/localwiki/Part_Loft_Liste_Auswahl_3c.png differ diff --git a/localwiki/Part_Loft_Liste_Auswahl_3d.png b/localwiki/Part_Loft_Liste_Auswahl_3d.png new file mode 100644 index 0000000..d6867f4 Binary files /dev/null and b/localwiki/Part_Loft_Liste_Auswahl_3d.png differ diff --git a/localwiki/Part_Loft_Technical_Details.html b/localwiki/Part_Loft_Technical_Details.html new file mode 100644 index 0000000..5ec60a6 --- /dev/null +++ b/localwiki/Part_Loft_Technical_Details.html @@ -0,0 +1,94 @@ +Part Loft Technical Details

      Part Loft Technical Details

      + +

      This page explains the details of how the Loft surface is created. This is also relevant to Part Sweep done along a straight path, although there are differences. +

      The information provided is implementation specific, and may change. Current state is relevant to FreeCAD 0.15.4119, OCC version: 6.7.0. +

      + + +

      Stages of the Loft creation

      +

      To explain the process of loft, it is convenient to divide it into stages: +

      +
      1. make number of segments in the profiles equal (if they are not already)
      2. +
      3. establish correspondence between segments
      4. +
      5. make the loft surface
      +

      Step 1. Making numbers of segment in profiles match

      +

      The Loft needs the number of segments to match in order to create surfaces between corresponding segments. If the numbers of segments match in all profiles, this step is skipped. +

      If at least one of the profiles has a different number of segments, the following procedure is applied. The procedure is explained here for the case of only two profiles for simplicity. +

      +
      1. the profiles are temporarily aligned so that they are coplanar and their centers of masses* match.
      2. +
      3. (see the picture) for every vertex in one profile, the second profile is sliced at the same polar angle (the polar center is the center of mass). If there is more than one slice possible or no slice possible at all (it can happen on very convex profiles), the Loft typically fails.
      4. +
      5. the same is done in the opposite direction.
      +

      The operation is extended to all profiles, to yield the equal number of segments. The total number of segments in each profile would be equal to the sum of all numbers of segments of all profiles (provided none of the vertices happen to be at the same polar angle). +

      + + + +
      The process of slicing profile2 (white crescent-like shape) to create joints corresponding to vertices of profile1 (purple pentagon). The inserted joints are marked by yellow arrows.
      +
      The result of loft relevant to the picture on the left.
      +
      +

      Step 2. Establishing correspondence between segments

      +
      Demonstration of Loft keeping the number of segments in profiles when they match. Note how 3 edges of the top square "collapse" into a small polygonal piece of the bottom profile.
      +

      In case numbers of segments in all profiles were not equal, slicing was done in Step 1, and the correspondence is trivial. +In case numbers of segments in all profiles were equal, existing segments are used (see the picture), and this is when the correspondence must be established. +

      The exact algorithm to find corresponding segments is complex, but generally it tends to minimize the twisting of the resulting Loft. This means that if one is doing a loft between two squares, the maximum twist possible is <45°. Further rotation of one of the squares will cause the Loft to jump to other vertices. +

      The correspondence between neighboring profiles is made independently. This means that additional twisting can be obtained by adding more profiles. +

      Another thing to note is that when numbers of segments in profiles are equal, the resulting Loft is substantially more robust with respect to complex profiles, especially for non-convex ones. +

      +
      +

      Step 3. Making the loft surface.

      +
      A spline interpolation curve (red) that follows the loft surface. The points to interpolate through are shown as red squares.
      +

      If there are only two profiles, the surfaces created are ruled surfaces between corresponding segments of the profiles. Straight edges are created to connect corresponding vertices of the profiles. +

      If there are more than two profiles, the surfaces are made of splines in the same manner as straight lines form ruled surfaces. The imaginary splines the surface is "made of" are drawn through corresponding points of the corresponding segments of the profiles. +

      The splines are B-spline interpolation. +

      +
      • If the number of profiles is below 10, interpolation is done with by a B-spline with a maximum possible degree (i.e. degree = number_of_profiles - 1).
      • +
      • If the number of profiles exceeds 10, the interpolation is switched to 3rd degree B-splines.
      +

      The knotting method used is "approximate chord length". Approximate stands for the fact that the knot vector is exactly the same for every spline in a loft. For more info on what is B-spline interpolation, knot vector, chord length method, see, for example, cs.mtu.edu Curve Global Interpolation . +

      Note that Loft has a "Ruled" property. If it is set to true, ruled surfaces are made between neighboring profiles even when there's more than one profile. That is, B-spline interpolation is replaced by piecewise linear interpolation. +

      +
      +

      The essence

      +
      • The loft is doing B-spline interpolation between the provided profiles. The interpolation is switched to piecewise linear when "Ruled" property is set to true.
      • +
      • When number of profiles exceeds 9, interpolation degree is dropped to 3. This switchover can substantially reduce wiggling.
      • +
      • Matching the number of segments (aka number of vertices) in the profiles allows one to give the loft a slight twist, and typically permits using more complex profiles.
      • +
      • When numbers of segments are not matched, it's best to keep the profiles to be representable by a proper r(phi) function in polar coordinates.
      +

      Additional remarks

      +
      • It is not required that the profiles are parallel (see a picture below).
      • +
      • For Loft, it is not required that the profiles are separated (see a picture below). They can be coplanar, but they should not intersect.
      • +
      • When "closed" property of the Loft is "true", there is a cusp joint in all the splines forming the Loft (see a picture below). There is no reliable way to close the loft smoothly now.
      + + + + +
      It is not required that the profiles are parallel.
      +
      In Loft, the profiles can be coplanar. In this example, two of three profiles are coplanar.
      +
      An example of a closed loft between three pentagonal profiles (white). Note the non-smooth joint at the outermost profile. This is the first profile in the closed loft.
      +
      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Part_Loft_geschlossen.png b/localwiki/Part_Loft_geschlossen.png new file mode 100644 index 0000000..b433db2 Binary files /dev/null and b/localwiki/Part_Loft_geschlossen.png differ diff --git a/localwiki/Part_Loft_solid_ruled_from3profiles_example_FreeCAD_0_13.jpg b/localwiki/Part_Loft_solid_ruled_from3profiles_example_FreeCAD_0_13.jpg new file mode 100644 index 0000000..c7243d0 Binary files /dev/null and b/localwiki/Part_Loft_solid_ruled_from3profiles_example_FreeCAD_0_13.jpg differ diff --git a/localwiki/Part_MakeCompound.html b/localwiki/Part_MakeCompound.html new file mode 100644 index 0000000..005d611 --- /dev/null +++ b/localwiki/Part_MakeCompound.html @@ -0,0 +1,73 @@ +Part MakeCompound

      Part MakeCompound

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Part MakeCompound.png Part MakeCompound‏‎

      +
      Menu location +
      Part → Make compound +
      Workbenches +
      Part +
      Default shortcut +
      None +
      See also +
      +

      + +
      +


      +

      +

      Introduction

      +

      This command creates a compound of any kind of topological shapes. +These can be solids or meshes or any other kind of topological shapes. +

      A compound is a set of shapes grouped into one object. +

      +

      Usage

      +

      Mark the topological shapes to be added to the compound in the tree view and choose Part > Make Compound +

      +

      Notes

      +

      Warning
      +A compound containing pieces that intersect or touch is invalid for Boolean operations. Because of performance issues, checking if the pieces intersect is not done. Automatic geometry check (available for Boolean operations) is disabled for part compound as well. +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Part_MakeCompound.png b/localwiki/Part_MakeCompound.png new file mode 100644 index 0000000..782eb4d Binary files /dev/null and b/localwiki/Part_MakeCompound.png differ diff --git a/localwiki/Part_Measure_Angular.svg b/localwiki/Part_Measure_Angular.svg new file mode 100644 index 0000000..467daf3 --- /dev/null +++ b/localwiki/Part_Measure_Angular.svg @@ -0,0 +1,215 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [blobfish] + + + Part_Measure_Angular + 2013-12-17 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Part/Gui/Resources/icons/Part_Measure_Angular.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Part_Measure_Clear_All.svg b/localwiki/Part_Measure_Clear_All.svg new file mode 100644 index 0000000..5b4dfb6 --- /dev/null +++ b/localwiki/Part_Measure_Clear_All.svg @@ -0,0 +1,628 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Part_Measure_Linear.svg b/localwiki/Part_Measure_Linear.svg new file mode 100644 index 0000000..1a93973 --- /dev/null +++ b/localwiki/Part_Measure_Linear.svg @@ -0,0 +1,135 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [blobfish] + + + Part_Measure_Linear + 2013-12-17 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Part/Gui/Resources/icons/Part_Measure_Linear.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Part_Measure_Step_Active.svg b/localwiki/Part_Measure_Step_Active.svg new file mode 100644 index 0000000..49df765 --- /dev/null +++ b/localwiki/Part_Measure_Step_Active.svg @@ -0,0 +1,128 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [blobfish] + + + Part_Measure_Step_Active + 2013-12-17 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Part/Gui/Resources/icons/Part_Measure_Step_Active.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + diff --git a/localwiki/Part_Measure_Step_Done.svg b/localwiki/Part_Measure_Step_Done.svg new file mode 100644 index 0000000..a3326c3 --- /dev/null +++ b/localwiki/Part_Measure_Step_Done.svg @@ -0,0 +1,113 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [blobfish] + + + Part_Measure_Step_Done + 2013-12-17 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Part/Gui/Resources/icons/Part_Measure_Step_Done.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + diff --git a/localwiki/Part_Measure_Toggle_3d.svg b/localwiki/Part_Measure_Toggle_3d.svg new file mode 100644 index 0000000..c05b15f --- /dev/null +++ b/localwiki/Part_Measure_Toggle_3d.svg @@ -0,0 +1,150 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [blobfish] + + + Part_Measure_Toggle_3d + 2013-12-17 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Part/Gui/Resources/icons/Part_Measure_Toggle_3d.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Part_Measure_Toggle_All.svg b/localwiki/Part_Measure_Toggle_All.svg new file mode 100644 index 0000000..e0a2778 --- /dev/null +++ b/localwiki/Part_Measure_Toggle_All.svg @@ -0,0 +1,478 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Part_Measure_Toggle_Delta.svg b/localwiki/Part_Measure_Toggle_Delta.svg new file mode 100644 index 0000000..82618c1 --- /dev/null +++ b/localwiki/Part_Measure_Toggle_Delta.svg @@ -0,0 +1,143 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [blobfish] + + + Part_Measure_Toggle_Delta + 2013-12-17 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Part/Gui/Resources/icons/Part_Measure_Toggle_Delta.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Part_Mirror.html b/localwiki/Part_Mirror.html new file mode 100644 index 0000000..c5033fa --- /dev/null +++ b/localwiki/Part_Mirror.html @@ -0,0 +1,120 @@ +Part Mirror

      Part Mirror

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Part Mirror.png Part Mirror

      +
      Menu location +
      Part -> Mirror +
      Workbenches +
      Part, Complete +
      Default shortcut +
      None +
      See also +
      --- +

      + +
      +


      +

      +

      Introduction

      +

      'Mirror Object' - This tool creates a new object (image) which is a reflection of the original object (source). The image object is created behind a mirror plane. The mirror plane may be standard plane (XY, YZ, or XZ), or any plane parallel to a standard plane. +

      An example: +

      +
      Before
      +


      +

      +
      After (mirrored through YZ plane)
      +
      +


      +

      +

      Usage

      +
      PARTMirrorDialogv11.png
      +

      Select the source object from the list. +Select a standard Mirror plane from the dropbox. +Press OK to create the image object. +


      +

      +

      Options

      +

      The Base point boxes can be used to move the mirror plane parallel to the selected standard miror plane. Only one of the X, Y, or Z boxes is effective for a given standard plane. +

      + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
      Standard PlaneBase Point BoxEffect +
      XYZMove mirror plane along Z axis. +
      XYX, YNo effect. +
      XZYMove mirror plane along Y axis. +
      XZX, ZNo effect. +
      YZXMove mirror plane along X axis. +
      YZY, ZNo effect. +
      +

      Limitations

      +
      • Arbitrary mirror planes (ie not parallel to a standard plane) are not supported (as of FC version 0.13).
      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Part_Mirror.svg b/localwiki/Part_Mirror.svg new file mode 100644 index 0000000..2b9df9e --- /dev/null +++ b/localwiki/Part_Mirror.svg @@ -0,0 +1,138 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [wmayer] + + + Part_Mirror + 2011-10-10 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Part/Gui/Resources/icons/Part_Mirror.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Part_Module.html b/localwiki/Part_Module.html new file mode 100644 index 0000000..82ac524 --- /dev/null +++ b/localwiki/Part_Module.html @@ -0,0 +1,160 @@ +Part Module

      Part Module

      + +

      The CAD capabilities of FreeCAD are based on the OpenCasCade kernel. The Part module allows FreeCAD to access and use the OpenCasCade objects and functions. OpenCascade is a professional-level CAD kernel, that features advanced 3D geometry manipulation and objects. The Part objects, unlike Mesh Module objects, are much more complex, and therefore permit much more advanced operations, like coherent boolean operations, modifications history and parametric behaviour. +

      Part example.jpg +

      Example of Part shapes in FreeCAD +

      + + +

      The tools

      +

      The Part module tools are all located in the Part menu that appears when you load the Part module. +

      +

      Primitives

      +

      These are tools for creating primitive objects. +

      +
      • Part Box.png Box: Draws a box by specifying its dimensions
      • +
      • Part Cone.png Cone: Draws a cone by specifying its dimensions
      • +
      • Part Cylinder.png Cylinder: Draws a cylinder by specifying its dimensions
      • +
      • Part Sphere.png Sphere: Draws a sphere by specifying its dimensions
      • +
      • Part Torus.png Torus: Draws a torus (ring) by specifying its dimensions
      • +
      • Part CreatePrimitives.png CreatePrimitives: A tool to create various parametric geometric primitives
      • +
      • Part Shapebuilder.png Shapebuilder: A tool to create more complex shapes from various parametric geometric primitives
      +

      Modifying objects

      +

      These are tools for modifying existing objects. They will allow you to choose which object to modify. +

      +
      • Part Booleans.png Booleans: Performs boolean operations on objects
      • +
      • Part Union.png Union: Fuses (unions) two objects
      • +
      • Part Common.png Common: Extracts the common (intersection) part of two objects
      • +
      • Part Cut.png Cut: Cuts (subtracts) one object from another
      • +
      • Part JoinConnect.png Join features: smart booleans for walled objects (e.g., pipes) (v0.16) +
        • Part JoinConnect.png Connect: Connects interiors of objects (v0.16)
        • +
        • Part JoinEmbed.png Embed: Embeds a walled object into another walled object (v0.16)
        • +
        • Part JoinCutout.png Cutout: Creates a cutout in a wall of an object for another walled object (v0.16)
      • +
      • Splitting tools: (v0.17) +
        • Part BooleanFragments.png Boolean fragments: makes all the pieces that can be obtained by Boolean operations between objects (v0.17)
        • +
        • Part Slice.png Slice: Splits an object into pieces by intersections with another object (v0.17)
        • +
        • Part XOR.png XOR: removes space shared by even number of objects (symmetric version of Cut) (v0.17)
      • +
      • Part Extrude.png Extrude: Extrudes planar faces of an object
      • +
      • Part Fillet.png Fillet: Fillets (rounds) edges of an object
      • +
      • Part Revolve.png Revolve: Creates a solid by revolving another object (not solid) around an axis
      • +
      • Part Section.png Section: Creates a section by intersecting an object with a section plane
      • +
      • Part SectionCross.png Cross sections...:
      • +
      • Part Chamfer.png Chamfer: Chamfers edges of an object
      • +
      • Part Mirror.png Mirror: Mirrors the selected object on a given mirror plane
      • +
      • Part RuledSurface.png Ruled Surface:
      • +
      • Part Sweep.png Sweep: Sweeps one or more profiles along a path
      • +
      • Part Loft.png Loft: Lofts from one profile to another
      • +
      • Offset tools: +
        • Part Offset.png 3D Offset: Constructs a parallel shape at a certain distance from original.
        • +
        • Part Offset2D.png 2D Offset: Constructs a parallel wire at certain distance from original, or enlarges/shrinks a planar face. (v0.17)
        • +
        • Part Thickness.png Thickness: Hollows out a solid, leaving openings next to select faces.
      +

      Other tools

      +
      • Part ImportCAD.png Import CAD: This tool allows you to add a file *.IGES, *.STEP, *.BREP to the current document.
      • +
      • Part ExportCAD.png Export CAD: This tool allows you to export a part object in a *.IGES, *.STEP, *.BREP file.
      • +
      • Part ShapeFromMesh.png Shape from Mesh: Creates a shape object from a mesh object.
      • +
      • Convert to solid: Converts a shape object to a solid object.
      • +
      • Reverse shapes: Flips the normals of all faces of the selected object.
      • +
      • Create simple copy: Creates a simple copy of the selected object.
      • +
      • Make compound: Creates a compound from the selected objects.
      • +
      • Part RefineShape.png Refine shape: Cleans faces by removing unnecessary lines.
      • +
      • Part CheckGeometry.png Check geometry: Checks the geometry of selected objects for errors.
      • +
      • Measure: Allows linear and angular measurement between points/edges/faces.
      +


      +

      + +


      +

      +

      Boolean Operations

      +
      An example of union (Fuse), intersection (Common) and difference (Cut)
      +
      +


      +An example of union (Fuse), intersection (Common) and difference (Cut) +

      +

      Explaining the concepts

      +

      In OpenCasCade terminology, we distinguish between geometric primitives and (topological) shapes. A geometric primitive can be a point, a line, a circle, a plane, etc. or even some more complex types like a B-Spline curve or surface. A shape can be a vertex, an edge, a wire, a face, a solid or a compound of other shapes. The geometric primitives are not made to be directly displayed on the 3D scene, but rather to be used as building geometry for shapes. For example, an edge can be constructed from a line or from a portion of a circle. +

      We could say, to resume, that geometry primitive are "shapeless" building blocks, and shapes are the real spatial geometry built on it. +

      To get a complete list of all of them refer to the OCC documentation (Alternative: sourcearchive.com) and search for Geom_* (for geometry) and TopoDS_* (for shapes). There you can also read more about the differences between geometric objects and shapes. Please note that unfortunately the official OCC documentation is not available online (you must download an archive) and is mostly aimed at programmers, not at end-users. But hopefully you'll find enough information to get started here. +

      The geometric types actually can be divided into two major groups: curves and surfaces. Out of the curves (line, circle, ...) you can directly build an edge, out of the surfaces (plane, cylinder, ...) a face can be built. For example, the geometric primitive line is unlimited, i.e. it is defined by a base vector and a direction vector while its shape representation must be something limited by a start and end point. And a box -- a solid -- can be created by six limited planes. +

      From an edge or face you can also go back to its geometric primitive counterpart. +

      Thus, out of shapes you can build very complex parts or, the other way round, extract all sub-shapes a more complex shape is made of. +

      +

      Scripting

      +

      The main data structure used in the Part module is the BRep data type from OpenCascade. +Almost all contents and object types of the Part module are now available to python scripting. This includes geometric primitives, such as Line and Circle (or Arc), and the whole range of TopoShapes, like Vertexes, Edges, Wires, Faces, Solids and Compounds. For each of those objects, several creation methods exist, and for some of them, especially the TopoShapes, advanced operations like boolean union/difference/intersection are also available. Explore the contents of the Part module, as described in the FreeCAD Scripting Basics page, to know more. +

      +

      Examples

      +

      To create a line element switch to the Python console and type in: +

      +
      import Part,PartGui 
      +doc=App.newDocument()  
      +l=Part.Line()
      +l.StartPoint=(0.0,0.0,0.0)
      +l.EndPoint=(1.0,1.0,1.0)
      +doc.addObject("Part::Feature","Line").Shape=l.toShape() 
      +doc.recompute() 
      +

      Let's go through the above python example step by step: +

      +
      import Part,PartGui
      +doc=App.newDocument() 
      +

      loads the Part module and creates a new document +

      +
      l=Part.Line()
      +l.StartPoint=(0.0,0.0,0.0)
      +l.EndPoint=(1.0,1.0,1.0) 
      +

      Line is actually a line segment, hence the start and endpoint. +

      +
      doc.addObject("Part::Feature","Line").Shape=l.toShape() 
      +

      This adds a Part object type to the document and assigns the shape representation of the line segment to the 'Shape' property of the added object. It is important to understand here that we used a geometric primitive (the Part.Line) to create a TopoShape out of it (the toShape() method). Only Shapes can be added to the document. In FreeCAD, geometry primitives are used as "building structures" for Shapes. +

      +
      doc.recompute() 
      +

      Updates the document. This also prepares the visual representation of the new part object. +

      Note that a Line can be created by specifying its start and endpoint directly in the constructor, for example Part.Line(point1,point2), or we can create a default line and set its properties afterwards, as we did here. +

      A circle can be created in a similar way: +

      +
      import Part
      +doc = App.activeDocument()
      +c = Part.Circle() 
      +c.Radius=10.0  
      +f = doc.addObject("Part::Feature", "Circle")
      +f.Shape = c.toShape()
      +doc.recompute() 
      +

      Note again, we used the circle (geometry primitive) to construct a shape out of it. We can of course still access our construction geometry afterwards, by doing: +

      +
      s = f.Shape
      +e = s.Edges[0]
      +c = e.Curve 
      +

      Here we take the shape of our object f, then we take its list of edges. In this case there will be only one because we made the whole shape out of a single circle, so we take only the first item of the Edges list, and we takes its curve. Every Edge has a Curve, which is the geometry primitive it is based on. +

      Head to the Topological data scripting page if you would like to know more. +

      +

      Tutorials

      + + +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Part_Offset.html b/localwiki/Part_Offset.html new file mode 100644 index 0000000..2652055 --- /dev/null +++ b/localwiki/Part_Offset.html @@ -0,0 +1,80 @@ +Part Offset

      Part Offset

      + +
      +

      This documentation is not finished. Please help and contribute documentation. +

      See Draft ShapeString for good documented Command. Gui Command gives an overview over commands. And see List of Commands for other commands. +

      Go to Help FreeCAD to contribute. +

      +
      +


      +

      + + + + + + + + + + + + + + + + + + + + +
      +

      Part Offset.png Part Offset

      +
      Menu location +
      Part → 3D Offset +
      Workbenches +
      Part, Complete +
      Default shortcut +
      None +
      See also +
      Thickness, Part 2D Offset +

      + +
      +


      +


      +

      +

      Description

      +

      The Part 3D Offset tool creates copies of a selected shape at a certain distance from the base shape. +

      +

      How to use

      +

      ToDo +

      +

      Example

      +
      PartOffset1 it.png
      +
      +
      PartOffset2 it.png
      +
      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Part_Offset.svg b/localwiki/Part_Offset.svg new file mode 100644 index 0000000..48496e3 --- /dev/null +++ b/localwiki/Part_Offset.svg @@ -0,0 +1,76 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + [wmayer] + + + Part_Offset + 2012-11-25 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Part/Gui/Resources/icons/Part_Offset.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + diff --git a/localwiki/Part_Offset2D.html b/localwiki/Part_Offset2D.html new file mode 100644 index 0000000..a239872 --- /dev/null +++ b/localwiki/Part_Offset2D.html @@ -0,0 +1,134 @@ +Part Offset2D

      Part Offset2D

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Part Offset2D.png Part Offset2D

      +
      Menu location +
      Part → 2D Offset +
      Workbenches +
      Part +
      Default shortcut +
      None +
      See also +
      Part Offset 3D, Part Thickness, Draft Offset +

      + +
      +


      +

      Part Offset2D Demo.png +

      +

      Description

      +

      Part 2D Offset constructs a wire, parallel to the original wire, at a certain distance from it. Or enlarges/shrinks a planar face, similarly. +

      The wire/face must be planar. There can be multiple wires in one object, not necessarily coplanar. +

      +

      How to use

      +
      1. Select an object to offset
      2. +
      3. Invoke Part Offset2D command.
      4. +
      5. Set up the offset in Task Panel, and accept the dialog.
      +

      A 2D Offset parametric object is created. Original objects are switched to wireframe display mode. +

      +

      Properties

      +

      Offset +

      +
      • DATASource: Link to original shape
      +
      • DATAValue The distance to enlarge the wire/face by. If negative, the wire/face is shrunk instead.
      +
      • DATAMode ("Pipe" or "Skin"): sets how non-closed wires are processed. If "Pipe", the wire is outlined as if it was an extremely thin closed contour. If "Skin", an open wire is created.
      +

      Part Offset2D Mode.png +

      +
      • DATAJoin ("Arc", "Tangent", "Intersection"): sets the behavior around kinks. If "Arc", offset segments are connected with an arc of circle, centered at the vertex. "Tangent" is unsupported on OCC7.0.0. "Intersection": offset segments are extended till they intersect.
      +

      Part Offset2D Join.png +

      +
      • DATAIntersection ("false", "true"): sets if multiple wires are treated collectively or independently. If "false", wires are offset independently, intersections between resulting wires are ignored. If "true", the wires are offset in collective manner.
      +

      Part Offset2D Intersection.png +

      Only wires within a compound are coupled. For example, if the structure is like compound(wire1, wire2, compound(wire3, wire4)), wire1 and wire2 will be treated collectively, but independently from wire3 and wire4. Likewise, wire3 and wire4 are treated collectively, but independently of wire1+wire2. +

      Also, in collective mode, directions of wires are important, and influence direction of offset. This is in tight relationship with how holes in faces are treated. +

      Wires being treated collectively must be coplanar. Wires being offset independently don't have to be coplanar. +

      +
      • DATAFill ("false", "true"): if "true", the space between original wire/face and the offset is filled with a face.
      +

      Part Offset2D Fill.png +

      +

      Known issues

      +
      • Using the tool can crash FreeCAD (see next point). On Windows, these crashes are converted to exceptions and don't generally cause FreeCAD to close; on other OS'es it is not the case. So, it is advised to save project before attempting to use the tool.
      +
      • Enlarging faces with circular holes by an amount large enough to cause holes to close up, a crash occurs (OCC 7.0.0). The problem seems to be specific to circles; other shapes seem to close out properly.
      +
      • when offsetting circles that have non-zero Placement, the result is placed wrongly. (OCC 7.0.0)
      +
      • when offsetting circles, sometimes they are offset in unexpected direction (e.g. inward instead of outward). (OCC 7.0.0)
      +
      • Fill="true" doesn't work when collectively offsetting open wires in "Skin" mode
      +
      • "Tangent" join mode doesn't work (OCC 7.0.0)
      +
      • Offsetting wires made of single line segment is not supported (because line segment doesn't define a plane). Single line segments cannot participate in collective offset either.
      +

      Scripting

      +

      The tool can by used in macros and from the python console by using the following function: +

      +
      f = App.ActiveDocument.addObject("Part::Offset2D", "Offset2D")
      +f.Source =  #some object
      +f.Value = 10.0 
      +

      2D offset is also available as a method of Part.Shape. Example: +

      +
      import Part
      +circle = Part.Circle().toShape()
      +enlarged_circle = circle.makeOffset2D(10.0)
      +Part.show(circle)
      +Part.show(enlarged_circle)
      +# makeOffset2D(offset, join = 0, fill = False, openResult = false, intersection = false)
      +# 
      +# * offset: distance to expand the shape by. 
      +# 
      +# * join: method of offsetting non-tangent joints. 0 = arcs, 1 = tangent, 2 =
      +# intersection
      +# 
      +# * fill: if true, the output is a face filling the space covered by offset. If
      +# false, the output is a wire/face.
      +# 
      +# * openResult: True for "Skin" mode; False for Pipe mode. 
      +# 
      +# * intersection: collective offset
      +# 
      +# Returns: result of offsetting (wire or face or compound of those). Compounding
      +# structure follows that of source shape. 
      +

      Version

      +

      The tool was introduced in FreeCAD v0.17.8350. Most of non-default modes will only work with OCC 7.0.0 or later. +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Part_Offset2D.svg b/localwiki/Part_Offset2D.svg new file mode 100644 index 0000000..e89e94b --- /dev/null +++ b/localwiki/Part_Offset2D.svg @@ -0,0 +1,68 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [DeepSOIC] + + + Part_Offset2D + 2016-09-02 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Part/Gui/Resources/icons/Part_Offset2D.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + diff --git a/localwiki/Part_Offset_Tasks.png b/localwiki/Part_Offset_Tasks.png new file mode 100644 index 0000000..c6f6a2b Binary files /dev/null and b/localwiki/Part_Offset_Tasks.png differ diff --git a/localwiki/Part_Plane.html b/localwiki/Part_Plane.html new file mode 100644 index 0000000..ab48670 --- /dev/null +++ b/localwiki/Part_Plane.html @@ -0,0 +1,101 @@ +Part Plane

      Part Plane

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Part CreatePrimitives.png Part CreatePrimitives

      +
      Menu location +
      PartCreate Primitives → Plane +
      Workbenches +
      Part, OpenSCAD +
      Default shortcut +
      None +
      See also +
      Create Primitives +

      + +
      +


      +

      +

      Description

      +

      Create a simple parametric plane 10 x 10 mm, with the parameters of position, length, and width. +By default, the plane is positioned at the origin (0,0,0). +

      +
      PartPlane.png
      +
      +


      +

      +

      How to use

      +

      The standard plane is created with its lower left corner at the origin point 0,0,0. +To change these parameters, open the Location section and enter the desired values ​​in the respective input fields, or click on the 3D view and select a point, the point coordinates are taken from the fields. +In the Direction menu you can also define a standard vector (X, Y or Z) normal to the plane, or click User Defined ... to open the dialog box that allows you to set a different carrier (eg direction 1.0 , -1 creates a plane inclined 45 ° with respect to X and Z). +

      The properties can be changed later in the Combined View → Data, after selecting the item. +

      +

      Option

      + + + +
      PartPlaneProperty.png + +

      View

      +

      You have the standard properties view. +

      +

      Data

      +

      Base - Object placement data
      +

      +
      • DATALabel : String name of the object, defaults to 'Plane'. User may rename it.
      • +
      • DATAPlacement: Placement of feature is defined by below angle, axis and position.
      • +
      • DATAAngle : Angle of rotation relative to the below axis.
      • +
      • DATAAxis : Defines the axis of rotation plane: X, Y, or Z. Defaults to Z axis, Z = 1
      • +
      • DATAPosition : Position X, Y, Z, relative to the origin 0, 0, 0.
      +

      Plane - Plane Specific Parameters
      +

      +
      • DATALength : Length is the dimension along the X axis The default value is 10 mm
      • +
      • DATAWidth : Width is the size of the Y-axis The default value is 10 mm
      +
      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Part_Point.html b/localwiki/Part_Point.html new file mode 100644 index 0000000..e2b4306 --- /dev/null +++ b/localwiki/Part_Point.html @@ -0,0 +1,117 @@ +Part Point

      Part Point

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Part Point.png Part Point

      +
      Menu location +
      Part → Create Primitives → Point +
      Workbenches +
      Part, OpenSCAD +
      Default shortcut +
      None +
      See also +
      .. +

      + +
      +


      +


      +

      +

      Description

      +

      A Point (vertex) geometric primitive is available from the Create Primitives dialogue in the Part workbench. +

      The Create Primitives dialogue can be accessed via the CreatePrimitives icon Part CreatePrimitives.png located in the Part menu or the Part toolbar, in the Part Workbench. +


      +

      +

      Geometric Primitives

      + + + +
      PartVertexPrimitivesOptions it.png + +

      Point +

      +

      Parameter

      +
      • X
      • +
      • Y
      • +
      • Z
      +

      Location

      +
      • +
      • +
      +
      +

      Property

      + + + +
      PartVertexProperty it.png
      +
      +

      View

      +

      .. +

      +

      Data

      +

      Base
      +

      +
      • DatiLabel:
      • +
      • DatiPlacement: placement
      • +
      • DatiX :
      • +
      • DatiY :
      • +
      • DatiZ :
      +
      +
      +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Part_Point_Parametric.svg b/localwiki/Part_Point_Parametric.svg new file mode 100644 index 0000000..7dd72b4 --- /dev/null +++ b/localwiki/Part_Point_Parametric.svg @@ -0,0 +1,84 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [jmaustpc] + + + Part_Point_Parametric + 2013-03-05 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Part/Gui/Resources/icons/Part_Point_Parametric.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + diff --git a/localwiki/Part_Polygon_Parametric.svg b/localwiki/Part_Polygon_Parametric.svg new file mode 100644 index 0000000..eeab7af --- /dev/null +++ b/localwiki/Part_Polygon_Parametric.svg @@ -0,0 +1,142 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [Abdullah Tahiri] + + + Sketcher_CreateHexagon_Constr + 2015-05-24 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Sketcher/Gui/Resources/icons/Sketcher_CreateHexagon_Constr.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson, [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Part_Prism.html b/localwiki/Part_Prism.html new file mode 100644 index 0000000..8be01ec --- /dev/null +++ b/localwiki/Part_Prism.html @@ -0,0 +1,71 @@ +Part Prism

      Part Prism

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Part Prism.png Part Prism

      +
      Menu location +
      Part → Create Primitives → Prism +
      Workbenches +
      Part, OpenSCAD +
      Default shortcut +
      None +
      See also +
      Part → Primitives → Box +

      + +
      +


      +

      +

      Description

      +

      A Part Prism is available from the Create Primitives dialogue in the Part workbench. A Part Prism is a solid defined by a regular polygon cross section and a height. +

      The Create Primitives dialogue can be accessed via the CreatePrimitives icon Part CreatePrimitives.png located in the Part menu or the Part toolbar, in the Part Workbench. +


      +

      +

      Parameters

      +
      • Polygon - the number of sides of the polygon which describes the cross section of the Part Prism
      • +
      • cirumradius - the circumradius is the distance from the centre of the polygon to a vertex.
      • +
      • Height - the height of the Part Prism
      +

      available in version 0.14 +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Part_Prism_Apothem.svg b/localwiki/Part_Prism_Apothem.svg new file mode 100644 index 0000000..5b24c9f --- /dev/null +++ b/localwiki/Part_Prism_Apothem.svg @@ -0,0 +1,314 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + diff --git a/localwiki/Part_RefineShape.html b/localwiki/Part_RefineShape.html new file mode 100644 index 0000000..afa1b7b --- /dev/null +++ b/localwiki/Part_RefineShape.html @@ -0,0 +1,88 @@ +Part RefineShape

      Part RefineShape

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Part RefineShape.png Part RefineShape

      +
      Menu location +
      Part → Refine Shape +
      Workbenches +
      Part +
      Default shortcut +
      None +
      See also +
      OpenSCAD Refine Shape Feature +

      + +
      +


      +


      +

      +

      Description

      +

      Cleans unnecessary lines. After a Boolean operation some lines defining the previous form remain visible, this tool creates a totally cleaned copy of the original. +

      PartRefineShape it.png +

      +

      Use

      +
      1. Select the shape to be cleaned.
      2. +
      3. Click the Part → Refine shape menu.
      +
      • A copy of the object is created and totally cleaned, the original object is rendered hidden.
      • +
      • The newly created copy is independent of the original.
      +

      Limitations

      +
      • The refinement algorithm only works on shells. Therefore it iterates over the shells of the input shape and then for each shell it creates a new shell with joined faces wherever possible. This means if your input shape is only a face, wire, edge or vertex then the algorithm does nothing.
      • +
      • Opposed to RefineShapeFeature in OpenSCAD workbench, this feature won't update when the preceding shapes are changed.
      +

      Scripting

      +

      The Python command for refining a shape is the following: +

      +
      shape.removeSplitter() 
      +

      Notes

      +
      • the function does not modify the existing shape, but returns a new shape
      • +
      • the function is normally used as last step in the modelling history
      • +
      • the function can help to get difficult fillets to work
      • +
      • the function is intended to stop 3D printers from printing unwanted edges
      • +
      • the function can be used after converting a mesh to shape to clean up the residual edges on planar faces.
      +


      +
      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Part_Refine_Shape.svg b/localwiki/Part_Refine_Shape.svg new file mode 100644 index 0000000..86ca791 --- /dev/null +++ b/localwiki/Part_Refine_Shape.svg @@ -0,0 +1,145 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [wmayer] + + + Part_Refine_Shape + 2013-12-23 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Part/Gui/Resources/icons/Part_Refine_Shape.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Part_RegularPolygon.html b/localwiki/Part_RegularPolygon.html new file mode 100644 index 0000000..083895d --- /dev/null +++ b/localwiki/Part_RegularPolygon.html @@ -0,0 +1,71 @@ +Part RegularPolygon

      Part RegularPolygon

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Part RegularPolygon.png Part RegularPolygon

      +
      Menu location +
      Part → Create Primitives → Regular Polygon +
      Workbenches +
      Part, OpenSCAD +
      Default shortcut +
      None +
      See also +
      .. +

      + +
      +


      +

      +

      Description

      +

      A RegularPolygon geometric primitive is available from the Create Primitives dialogue in the Part workbench. +

      The Create Primitives dialogue can be accessed via the CreatePrimitives icon Part CreatePrimitives.png located in the Part menu or the Part toolbar, in the Part Workbench. +


      +

      +

      Parameters

      +
      • Polygon - the number of sides of the polygon which describes the cross section of the Part Prism
      • +
      • cirumradius - the circumradius is the distance from the centre of the polygon to a vertex.
      +


      +available in version 0.14 +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Part_ReverseShapes.html b/localwiki/Part_ReverseShapes.html new file mode 100644 index 0000000..131cd50 --- /dev/null +++ b/localwiki/Part_ReverseShapes.html @@ -0,0 +1,84 @@ +Part ReverseShapes

      Part ReverseShapes

      + +


      +


      +

      + + + + + + + + + + + + + + + + + + + + +
      +

      Part ReverseShapes.png Part ReverseShapes‏‎

      +
      Menu location +
      Part → Reverse Shapes +
      Workbenches +
      Part +
      Default shortcut +
      None +
      See also +
      +

      + +
      +


      +

      +

      Introduction

      +

      Flips the normals of all faces of the selected object. +

      +

      Usage

      +
      1. Select shape.
      2. +
      3. Choose PartReverse shapes from the top menu.
      4. +
      5. A reversed shape is created as a new seperate object.
      +

      Limitations

      +

      Notes

      +

      By executing this command, FreeCAD flips the normals of all faces of the shape/solid. +
      +You can verify this by +

      +
      1. making all other objects but the reversed shape/solid invisible
      2. +
      3. selecting the reversed shape/solid
      4. +
      5. change "lighting" in the "View"-tab from "Two side" to "One side"
      6. +
      7. the shape/solid will turn black → you are looking at the back of the faces
      +


      +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Part_ReverseShapes.png b/localwiki/Part_ReverseShapes.png new file mode 100644 index 0000000..782eb4d Binary files /dev/null and b/localwiki/Part_ReverseShapes.png differ diff --git a/localwiki/Part_Revolve.html b/localwiki/Part_Revolve.html new file mode 100644 index 0000000..69047d8 --- /dev/null +++ b/localwiki/Part_Revolve.html @@ -0,0 +1,109 @@ +Part Revolve

      Part Revolve

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Part Revolve.png Part Revolve

      +
      Menu location +
      Part → Revolve +
      Workbenches +
      Part, Complete +
      Default shortcut +
      None +
      See also +
      +

      Contents

      + +
      + +
      +


      +


      +Revolves the selected object around a given axis. The following shape types +are allowed, and lead to the listed output shapes (See Notes for exceptions): +

      + + + + + + + + + + + + + + + + + + + +
      Input shape + Output shape +
      Vertex + Edge +
      Edge + Face +
      Wire + Shell +
      Face + Solid +
      Shell + Compound solid (Compsolid) +
      +

      Solids or compound solids are not allowed as input shapes. Normal compounds +are currently not allowed, too. Future versions will check the actual shape +type of compound objects. +

      Dialog-revolve.png +

      The Angle argument specifies how far the object is to be turned. The +coordinates move the origin of the axis of revolving, relative to the origin +of the coordinate system. +

      If you select a user defined axis, the numbers define the direction of the +revolving axis with respect to the coordinate system: If the Z coordinate is +0 and the Y and X coordinate are non-zero, then the axis will lie in the +X-Y-plane. Its angle is such that its tangent is the ratio of the given +X and Y coordinates. +

      +

      Notes

      +
      • If your version of FreeCAD has a check box for Solid in the Revolve dialog, you can make Solids from closed Wires and Edges.
      • +
      • If Revolve is performed using an axis that intersects the face to rotate, and you want to create a solid, the result might be invalid. This can happen for various reasons, self-intersection, direction, etc.
      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Part_Revolve.svg b/localwiki/Part_Revolve.svg new file mode 100644 index 0000000..ca0c5cd --- /dev/null +++ b/localwiki/Part_Revolve.svg @@ -0,0 +1,82 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + [wmayer] + + + Part_Revolve + 2011-10-10 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Part/Gui/Resources/icons/Part_Revolve.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + diff --git a/localwiki/Part_RuledSurface.html b/localwiki/Part_RuledSurface.html new file mode 100644 index 0000000..9a43e4f --- /dev/null +++ b/localwiki/Part_RuledSurface.html @@ -0,0 +1,65 @@ +Part RuledSurface

      Part RuledSurface

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Part RuledSurface.png Part RuledSurface

      +
      Menu location +
      Part → RuledSurface +
      Workbenches +
      Part, Complete +
      Default shortcut +
      None +
      See also +
      +

      + +
      +


      +

      +

      Description

      +
      PartRuledSurface it.png
      +
      +


      +

      +

      How to use

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Part_RuledSurface.svg b/localwiki/Part_RuledSurface.svg new file mode 100644 index 0000000..be88bb2 --- /dev/null +++ b/localwiki/Part_RuledSurface.svg @@ -0,0 +1,121 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [wmayer] + + + Part_RuledSurface + 2011-10-21 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Part/Gui/Resources/icons/Part_RuledSurface.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + diff --git a/localwiki/Part_Section.html b/localwiki/Part_Section.html new file mode 100644 index 0000000..8253c39 --- /dev/null +++ b/localwiki/Part_Section.html @@ -0,0 +1,84 @@ +Part Section

      Part Section

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Part Section.png Part Section

      +
      Menu location +
      Part → Section +
      Workbenches +
      Part, Complete +
      Default shortcut +
      None +
      See also +
      Cross-sections +

      + +
      +


      +

      +

      Introduction

      +

      Extracts a section from the intersection of two selected shapes, the second one being used as a section plane. This operation is fully parametric and the components can be modified and the result recomputed. +


      +In this example, a cube is sectioned with a cylinder: +

      + + + +
      PartSection1 it.png + +
      • Base: base object, the Box
      • +
      • Tool: Section tool, the cylinder
      +
      +
      +


      +

      +

      Use

      +
      1. Select the base object
      2. +
      3. Select the Section tool
      4. +
      5. Click on PartPart Section.png Section from the top menu.
      +

      Links

      +

      To create sections with a section plane see Cross-sections. +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Part_Section.svg b/localwiki/Part_Section.svg new file mode 100644 index 0000000..ee070dc --- /dev/null +++ b/localwiki/Part_Section.svg @@ -0,0 +1,96 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + [wmayer] + + + Part_Section + 2011-10-10 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Part/Gui/Resources/icons/Part_Section.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Part_SectionCross.html b/localwiki/Part_SectionCross.html new file mode 100644 index 0000000..f55caab --- /dev/null +++ b/localwiki/Part_SectionCross.html @@ -0,0 +1,81 @@ +Part SectionCross

      Part SectionCross

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Part SectionCross.png Part SectionCross

      +
      Menu location +
      Part → Cross-sections... +
      Workbenches +
      Part +
      Default shortcut +
      None +
      See also +
      Part Section +

      + +
      +


      +

      +

      Description

      +

      The Cross-sections utility creates one or more cross-sections through the selected shape. +

      +

      How to use

      +
      1. Select a shape.
      2. +
      3. Press the Part SectionCross.png Cross-sections button.
      4. +
      5. Define the guiding plane.
      6. +
      7. Define the position (height of the cross-section).
      8. +
      9. Optionally, check Sections to create more than one cross-section: +
        • Checking On both sides will distribute the cross-sections on each side of the guiding plane location.
        • +
        • Set the count.
      10. +
      11. Press OK.
      +

      Limitations

      +
      • The resulting object is not parametric, that is it is not linked to the original shape.
      • +
      • A single object is created, even with more than one cross-section.
      +

      Example

      +

      Select an object +

      Dialog window +

      Result +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Part_ShapeFromMesh.html b/localwiki/Part_ShapeFromMesh.html new file mode 100644 index 0000000..621d772 --- /dev/null +++ b/localwiki/Part_ShapeFromMesh.html @@ -0,0 +1,81 @@ +Part ShapeFromMesh

      Part ShapeFromMesh

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Part ShapeFromMesh.png Part ShapeFromMesh‏‎

      +
      Menu location +
      Part → Create shape from mesh... +
      Workbenches +
      Part +
      Default shortcut +
      None +
      See also +
      Part ConvertToSolid, Part RefineShape +

      + +
      +


      +

      +

      Introduction

      +

      This command creates a shape from a mesh object. Mesh objects have limited editing capabilities in FreeCAD, converting them to shapes will allow their use with many more tools in FreeCAD (also see Notes). +

      +

      Use

      +
      1. Select the mesh object.
      2. +
      3. Choose PartPart ShapeFromMesh.png Create shape from mesh ... from the top menu.
      4. +
      5. A popup-menu will ask for the tolerance for sewing shape (default value: 0,1)
      6. +
      7. A shape from the mesh object is created as a seperate new object.
      +

      Limitations

      +

      There will be no analyzing or validating of the mesh object. +
      +Analyzing and repairing of the mesh (if needed) should be done manually before conversion. +
      +Appropriate tools are available in the Mesh Workbench. +

      +

      Notes

      +

      After creation of a shape, it may be useful to use Convert to solid (necessary for Boolean operations) and Refine shape tools. +


      +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Part_ShapeInfo.svg b/localwiki/Part_ShapeInfo.svg new file mode 100644 index 0000000..ad565f8 --- /dev/null +++ b/localwiki/Part_ShapeInfo.svg @@ -0,0 +1,95 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [wmayer] + + + Part_ShapeInfo + 2011-10-21 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Part/Gui/Resources/icons/Part_ShapeInfo.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Part_Shape_from_Mesh.svg b/localwiki/Part_Shape_from_Mesh.svg new file mode 100644 index 0000000..1dc3951 --- /dev/null +++ b/localwiki/Part_Shape_from_Mesh.svg @@ -0,0 +1,112 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [jmaustpc] + + + Part_Shape_from_Mesh + 2013-12-13 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Part/Gui/Resources/icons/Part_Shape_from_Mesh.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Part_Shapebuilder.html b/localwiki/Part_Shapebuilder.html new file mode 100644 index 0000000..3b5f0d1 --- /dev/null +++ b/localwiki/Part_Shapebuilder.html @@ -0,0 +1,98 @@ +Part Shapebuilder

      Part Shapebuilder

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Part Shapebuilder.png Part Shapebuilder

      +
      Menu location +
      Part -> Shapebuilder... +
      Workbenches +
      Part +
      Default shortcut +
      None +
      See also +
      Part CreatePrimitives +

      + +
      +


      +

      +

      Description

      +

      A tool to create more complex shapes from various parametric geometric primitives. +

      +

      Use

      +

      This tool will let you create shapes by creating +

      +
      1. Edge from two vertices
      2. +
      3. Face from vertices +
        1. Select vertices bounding the face in the 3D view
        2. +
        3. Select if face should be planar
        4. +
        5. Click on Create
        6. +
        7. Object will be created in 3D view and will be listed in tree view
      4. +
      5. Face from edges +
        1. Select a closed set of vertices bounding the face in the 3D view
        2. +
        3. Select if face should be planar
        4. +
        5. Click on Create
        6. +
        7. Object will be created in 3D view and will be listed in tree view
      6. +
      7. Shell from faces +
        1. Select faces in the 3D view
        2. +
        3. Select if the shape should be refined
        4. +
        5. Select if all faces should be included in shell
        6. +
        7. Click on Create
        8. +
        9. Object will be created in 3D view and will be listed in tree view
      8. +
      9. Solid from shell +
        1. Select if the shape should be refined
        2. +
        3. Click on Create
        4. +
        5. Object will be created in 3D view and will be listed in tree view
      +

      Limitations

      +


      +

      +

      Notes

      +

      A possible workflow could be: +

      +
      • Draw a wireframe-model of your shape using the tools in the draft-workbench (for example line and dwire)
      • +
      • Create all faces with "face from edges"
      • +
      • Create a "shell from faces"
      • +
      • Create a "solid from shell"
      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Part_Shapebuilder.svg b/localwiki/Part_Shapebuilder.svg new file mode 100644 index 0000000..3fab28f --- /dev/null +++ b/localwiki/Part_Shapebuilder.svg @@ -0,0 +1,141 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [wmayer] + + + Part_Shapebuilder + 2011-10-24 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Part/Gui/Resources/icons/Part_Shapebuilder.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Part_Slice.html b/localwiki/Part_Slice.html new file mode 100644 index 0000000..64da0b5 --- /dev/null +++ b/localwiki/Part_Slice.html @@ -0,0 +1,117 @@ +Part Slice

      Part Slice

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Part Slice.png Part Slice

      +
      Menu location +
      Part → Split → Slice +
      Workbenches +
      Part +
      Default shortcut +
      None +
      See also +
      Part Boolean Fragments, Part XOR, Join features, Part Booleans +

      + +
      +


      +

      +

      Description

      +

      Tool to split shapes by intersection with other shapes. For example, for a box and a plane, a compound of two solids is created. +

      Part Slice Demo.png +

      (on the picture above, the pieces were moved apart manually afterwards, to reveal the slicing) +

      The output shape occupies the same space as the original. But it is split where it intersects with other shapes. The split pieces are put into a compound (or compsolid), so the object appears to remain in one piece. You need to explode the compound to get the individual pieces. Use, for example, Draft Downgrade for the purpose. +

      The tool has three modes: "Standard", "Split", and "CompSolid". +

      "Standard" and "Split" differ by the action of the tool on wires, shells and compsolids: if "Split", those are separated; if "Standard", they are kept together (get extra segments). +

      Compounding structure in "Standard" and "Split" modes follows the compounding structure of shape being sliced. +

      In "CompSolid" mode, the output is a compsolid (or a compound of compsolids, if the resulting solids form more than one island of connectedness). Compsolid is a set of solids connected by faces; they are related to solids like wires are related to edges, and shells are related to faces; the name is probably a shortened phrase "composite solid". +

      The overall action of the tool is very similar to Boolean Fragments, except only the pieces from the first shape are in the result. +

      +

      How to use

      +
      1. Select the object to be sliced, first, and then some objects to slice with.
        The order of selection is important. Compounds with self-intersections are not allowed (self-intersections sometimes can be accounted for by passing the compound through BooleanFragments)
      2. +
      3. Invoke the Part Slice command.
      +

      A Slice parametric object is created. Original objects are hidden, and the result of intersection is shown in 3D view. +

      +

      Properties

      +

      Slice +

      +
      • DATABase: Object to be sliced.
      • +
      • DATATools: List of objects to slice with. (as of FreeCAD v0.17.8053, this property is not displayed in property editor, and can only be accessed via Python).
      • +
      • DATAMode: "Standard", "Split", or "CompSolid". "Split" is default. Standard and Split differ by the action of the tool on aggregation type shapes: if Split, those are separated; otherwise they are kept together (get extra segments).
      • +
      • DATATolerance: "fuzziness" value. This is an extra tolerance to apply when searching for intersections, in addition to tolerances stored in the input shapes.
      +

      Example: making puzzle

      +
      1. Switch to Sketcher Workbench, create an new sketch. Draw a rectangle that will outline the overall shape of the puzzle. Close the sketch.
        Slice example step1.png
      2. +
      3. Switch to Part workbench. Select the sketch, and pick Part->Create face from sketch (in menu).
        Slice example step2.png
      4. +
      5. Switch to Sketcher workbench, and create another sketch on the same plane. Using polyline tool, draw the lines that will split the puzzle into pieces.
        Slice example step3.png
      6. +
      7. Switch to Part workbench. Select the splitter sketch, and apply Part Boolean Fragments. This will insert vertices where lines of splitter sketch intersect. Having them is essential for the next step to work.
        Slice example step4.png
      8. +
      9. Select the rectangular face, and the BooleanFragments of splitter sketch, and apply Part Split.
        Slice example step5.png
      10. +
      11. Switch to Draft workbench, and apply Draft Downgrade to the result. You should get all the pieces as "Face00X" in document tree, that can be moved independently. Done!
        Slice example step6.png
      +

      Scripting

      +

      The tool can by used in macros and from the python console by using the following function: +

      +
      BOPTools.SplitFeatures.makeSlice(name)
      +
      +
      • Creates an empty Slice feature. The 'Base' and 'Tools' properties must be assigned explicitly, afterwards.
      • +
      • Returns the newly created object.
      +

      Slice can also be applied to plain shapes, without the need to have a document object, via: +

      +
      Part.BOPTools.SplitAPI.slice(base_shape, tool_shapes, mode, tolerance = 0.0)
      +
      +

      This can be useful for making custom Python scripted features. +


      +Example: +

      +
      import Part
      +j = Part.BOPTools.SplitFeatures.makeSlice(name= 'Slice')
      +j.Base = FreeCADGui.Selection.getSelection()[0]
      +j.Tools = FreeCADGui.Selection.getSelection()[1:] 
      +

      The tool itself is implemented in Python, see /Mod/Part/BOPTools/SplitFeatures.py under where FreeCAD is installed. +

      +

      Version

      +

      The tool was introduced in FreeCAD v0.17.8053. FreeCAD needs to be compiled with OCC 6.9.0 or later; otherwise, the tool is unavailable. +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Part_Slice.svg b/localwiki/Part_Slice.svg new file mode 100644 index 0000000..8ac35b9 --- /dev/null +++ b/localwiki/Part_Slice.svg @@ -0,0 +1,78 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [DeepSOIC] + + + Part_Slice + 2016-07-29 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Part/Gui/Resources/icons/Part_Slice.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + diff --git a/localwiki/Part_Sphere.html b/localwiki/Part_Sphere.html new file mode 100644 index 0000000..8e8faeb --- /dev/null +++ b/localwiki/Part_Sphere.html @@ -0,0 +1,91 @@ +Part Sphere

      Part Sphere

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Part Sphere.png Part Sphere

      +
      Menu location +
      Part -> Sphere +
      Workbenches +
      Part Module,Complete +
      Default shortcut +
      None +
      See also +
      Part CreatePrimitives +

      + +
      +


      +

      +

      Description

      +

      Creates a simple parametric sphere, with position, angle1, angle2, angle3 and radius parameters. +

      SimpleSphere.jpg +

      +

      How to use

      +

      In the workbench Part click on the sphere icon Part Sphere.png. The sphere will be positioned at origin (point 0,0,0) on creation. The angle parameters permit to make a portion of sphere instead of a full sphere (they are set to 360° by default). +

      +

      Options

      +

      The parametric sphere is defined by the following parameters: +

      +
      • Radius
      • +
      • Angle 1
      • +
      • Angle 2
      • +
      • Angle 3
      • +
      • as well as the standard set of placement parameters
      +

      The picture below gives an overview of a parametric sphere with parameters different from the default value. +

      PartDesign Sphere Parameter en.jpg +

      +

      Parameter

      +
      • Radius: Radius of the sphere
      • +
      • Angle 1: 1nd angle to cut / define the sphere
      • +
      • Angle 2: 2nd angle to cut / define the sphere
      • +
      • Angle 3: 3rd angle to cut / define the sphere
      +

      Because it is quite difficult to explain the meaning of the parameters angle 1, angle 2, angle 3, the picture below gives an explanation about these parameters with following values: angle 1 = -45°, angle 2 = 45° and angle 3= 90°. +

      SphereCutThreeAngles.jpg +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Part_Sphere.svg b/localwiki/Part_Sphere.svg new file mode 100644 index 0000000..43b927a --- /dev/null +++ b/localwiki/Part_Sphere.svg @@ -0,0 +1,71 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [wmayer] + + + Part_Sphere + 2011-10-10 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Part/Gui/Resources/icons/Part_Sphere.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + diff --git a/localwiki/Part_Spiral.html b/localwiki/Part_Spiral.html new file mode 100644 index 0000000..c69aae4 --- /dev/null +++ b/localwiki/Part_Spiral.html @@ -0,0 +1,70 @@ +Part Spiral

      Part Spiral

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Part Spiral.png Part Spiral

      +
      Menu location +
      PartCreate Primitives → Spiral +
      Workbenches +
      Part, OpenSCAD +
      Default shortcut +
      None +
      See also +
      Create Primitives +

      Contents

      + +
      + +
      +


      +


      +

      +

      Description

      +

      A Spiral geometric primitive is available from the Create Primitives dialogue in the Part workbench. +

      The Create Primitives dialogue can be accessed via the CreatePrimitives icon Part CreatePrimitives.png located in the Part menu or the Part toolbar, in the Part Workbench. +


      +SpiralDefault it.png +

      Spiral x45 it.png +

      Spiral y45 it.png +


      +available in version 0.14 +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Part_Spiral_Parametric.svg b/localwiki/Part_Spiral_Parametric.svg new file mode 100644 index 0000000..72f092f --- /dev/null +++ b/localwiki/Part_Spiral_Parametric.svg @@ -0,0 +1,90 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [wmayer] + + + Part_Spiral_Parametric + 2013-10-30 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Part/Gui/Resources/icons/Part_Spiral_Parametric.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Part_Spline_Parametric.svg b/localwiki/Part_Spline_Parametric.svg new file mode 100644 index 0000000..2b8cd11 --- /dev/null +++ b/localwiki/Part_Spline_Parametric.svg @@ -0,0 +1,112 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [jmaustpc] + + + Part_Spline_Parametric + 2013-11-11 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Part/Gui/Resources/icons/Part_Spline_Parametric.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Part_Sweep.html b/localwiki/Part_Sweep.html new file mode 100644 index 0000000..ebc9fcc --- /dev/null +++ b/localwiki/Part_Sweep.html @@ -0,0 +1,138 @@ +Part Sweep

      Part Sweep

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Part Sweep.png Part Sweep

      +
      Menu location +
      Part → Sweep... +
      Workbenches +
      Part +
      Default shortcut +
      None +
      See also +
      Part Loft +

      + +
      +


      +

      +

      Description

      +

      The Part Sweep tool is used to create a face, a shell or a solid shape from one or more profiles (cross-sections) projected along a path. +

      The Part Sweep tool is similar to Part Loft with the addition of a path to define the projection between profiles. +

      +
      Part Sweep simple.png
      +

      A solid sweep generated from a single profile (A) projected along a path (B). +

      +

      How to use

      +
      1. Press the Part Sweep.png Sweep button. This opens the Sweep parameters in the Tasks pane.
      2. +
      3. In the Available Profiles left column (previously Vertex/Edge/Wire/Face in v0.16), click on the element to be used as sweep profile, then click on the right arrow to place it in the Selected profiles right column (previously Sweep in v0.16). Repeat if more than one profile is desired. Use the up and down arrows to reorder the selected profiles.
      4. +
      5. Click on the Sweep Path button, then choose either mode of selection: +
        • Single segment selection: select one or more contiguous edges in the 3D view (press CTRL for multiple selection) and click Done. The sweep will only be generated along the selected edges.
        • +
        • Complete path selection: switch to the Model tab, select the 2D object to be used as path in the tree, switch back to the Tasks pane and click Done. The sweep will be generated along all the contiguous edges found in the 2D object.
      6. +
      7. Define options Solid and Frenet.
      8. +
      9. Click OK.
      +

      Accepted geometry

      +
      • Profiles: can be a point (vertex), line (Edge), wire or face. Edges and wires may be either open or closed. There are various profile limitations and complications, see below, however the profiles may come from the Part Workbench primitives, Draft Workbench features and Sketches.
      +
      • Path: can be a line (Edge) or series of connecting lines, wire or various Part Workbench primitives, Draft Workbench features or a Sketch. The path is often selected directly from the main model window, however it can also be selected from the Tree View (Model Tab of Combo View). The path can either be an entire appropriate shape or an appropriate sub-component of a more advance shape (for example, an edge of a Part Cube could be selected as the path). The path may be either open or closed and will thus create either an open or closed Sweep. A closed path such as a Part Circle will result in a closed Sweep. For example a Sweep of a smaller circle around a path of a larger circle will create a torus.
      +


      +

      +

      Properties

      +

      Solid

      +

      If "Solid" is set to "true", FreeCAD creates a solid, provided the profiles are of closed geometry; if set to "false", FreeCAD creates a face or (if more than one face) a shell for either open or closed profiles. +

      +

      Frenet

      +
      Sweep-frenet-comp.png
      +

      The "Frenet" property controls how the profile orientation changes as it follows along the sweep path. If "Frenet" is "false", the orientation of the profile is kept consistent from point to point. The resulting shape has the minimum possible twisting. Unintuitively, when a profile is swept along a helix, this results in the orientation of the profile slowly creep (rotate) as it follows the helix. Setting "Frenet" to true prevents such a creep. +

      If "Frenet" is "true" the orientation of the profile is computed basing on local curvature and tangency vectors of the path. This keeps the orientation of the profile consistent when sweeping along a helix (because curvature vector of a straight helix is always pointing to its axis). However, when path is not a helix, the resulting shape can have strange looking twists sometimes. For more information, see Frenet Serret formulas. +

      +

      Transition

      +

      "Transition" sets the transition style of the Sweep at a joint in the path, if the path does not define the corner transition (for example where the path is a wire). The property is not exposed in the Tasks pane and can be found in properties after the Sweep has been created. +

      +

      Profile limitations and complications

      +
      • A vertex or point +
        • vertex or point may only be used as the first and/or last profile in the list of profiles. +
          • For example +
            • you can not Sweep from a circle to a point, to a ellipse.
            • +
            • However you could Sweep from a point to a circle to an ellipse to another point.
      • +
      • Open or closed geometry profiles can not be mixed in one single Sweep +
        • In one Sweep, all profiles (lines wires etc.) must be either open or closed. +
          • For example +
            • FreeCAD can not Sweep between one Part Circle and one default Part Line.
      • +
      • Draft Workbench features +
        • Draft Workbench features can be directly used as a profile in FreeCAD 0.14 or later. +
          • For example the following Draft features can be used as profiles in a Part Sweep +
            • Draft Polygon.
            • +
            • Draft Point, Line, wire,
            • +
            • Draft B-spline, Bezier Curve
            • +
            • Draft Circle, Ellipse, Rectangle
      • +
      • PartDesign Sketches +
        • The profile may be created with a sketch. However only a valid sketch will be shown in the list to be available for selection.
        • +
        • The sketch must contain only one open or closed wire or line (can be multiple lines, if those lines are all connected as they are then a single wire)
      • +
      • Part Workbench +
        • the profile can be a valid Part geometric primitive which can be created with the Part CreatePrimitives tool +
          • For example the following Part geometric primitives can be a valid profile +
            • Point (Vertex), Line (Edge)
            • +
            • Helix, Spiral
            • +
            • Circle, Ellipse
            • +
            • Regular Polygon
            • +
            • Plane (Face)
      +


      +

      +

      Links

      + +


      +


      +

      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Part_Sweep.svg b/localwiki/Part_Sweep.svg new file mode 100644 index 0000000..bd7de87 --- /dev/null +++ b/localwiki/Part_Sweep.svg @@ -0,0 +1,90 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [wmayer] + + + Part_Sweep + 2012-06-10 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Part/Gui/Resources/icons/Part_Sweep.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Part_Sweep_simple.png b/localwiki/Part_Sweep_simple.png new file mode 100644 index 0000000..06c29bd Binary files /dev/null and b/localwiki/Part_Sweep_simple.png differ diff --git a/localwiki/Part_Thickness.html b/localwiki/Part_Thickness.html new file mode 100644 index 0000000..1cf16f5 --- /dev/null +++ b/localwiki/Part_Thickness.html @@ -0,0 +1,105 @@ +Part Thickness

      Part Thickness

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Part Thickness.png Part Thickness

      +
      Menu location +
      Part → Thickness +
      Workbenches +
      Part, Complete +
      Default shortcut +
      None +
      See also +
      Offset +

      + +
      +


      +


      +

      +

      Description

      +

      The Thickness tool works on a solid shape and transforms it into a hollow object, giving to each of its faces a defined thickness. +On some solids it allows you to significantly speed up the work, and avoids making extrusions and pockets. +

      +

      Use

      +
      1. Create a solid
      2. +
      3. Select one or more faces
      4. +
      5. Click on the Part Thickness.png Part Thickness tool
      6. +
      7. Set the parameters (see Options)
      8. +
      9. Click OK to confirm, create the operation and exit the function
      10. +
      11. In the Properties table adjust the parameters if necessary.
      +

      Options

      +
      • Thickness: Wall thickness of the resulting object, set the desired value +
        • A positive value will offset the faces outward
        • +
        • A negative value will offset the faces inward
      • +
      • Mode +
        • Skin: Select this option if you want to get an item like a vase, headless but with the bottom
        • +
        • Pipe: Select this option if you want to get an object like a pipe, headless and bottomless. In this case it may be convenient to select the faces to be deleted before you start the tool. Helping with predefined views buttons or use the numeric keys.
        • +
        • RectoVerso:
      • +
      • Join Type +
        • Arc: removes the outer edges and create a fillet with a radius equal to the thickness defined
        • +
        • Tangent:
        • +
        • Intersection:
      • +
      • Intersection:
      • +
      • Self-intersection: Enables self-intersection
      • +
      • Face / Done: Select the faces to be removed, then click Done
      • +
      • Update view: Automatically updates the view in real time
      +

      Limitations

      +

      Sometimes, on some shape produce bizarre results. Save your work before applying Thickness on complex objects +

      +

      Links

      +

      A good example on how to use this tool on the forum: Re: Help designing a simple enclosure +

      +

      Examples

      +

      ThicknessEsempio1.png +

      ThicknessEsempio2.png +

      ThicknessEsempio3.png +

      ThicknessEsempio4.png +


      +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Part_Thickness.svg b/localwiki/Part_Thickness.svg new file mode 100644 index 0000000..bf57035 --- /dev/null +++ b/localwiki/Part_Thickness.svg @@ -0,0 +1,65 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [wmayer] + + + Part_Thickness + 2012-11-26 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Part/Gui/Resources/icons/Part_Thickness.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + diff --git a/localwiki/Part_Torus.html b/localwiki/Part_Torus.html new file mode 100644 index 0000000..9f7f6bd --- /dev/null +++ b/localwiki/Part_Torus.html @@ -0,0 +1,91 @@ +Part Torus

      Part Torus

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Part Torus.png Part Torus

      +
      Menu location +
      Part → Torus +
      Workbenches +
      Part, Complete +
      Default shortcut +
      None +
      See also +
      Part CreatePrimitives +

      + +
      +


      +

      +

      Description

      +

      Creates a simple parametric torus, with position, angle1, angle2, angle3, radius1 and radius2 as parameters. +

      SimpleTorus.jpg +

      +

      How to use

      +

      In the Part workbench click on the torus icon Part Torus.png. The torus will be positioned at origin (point 0,0,0) on creation. +The angle parameters (angle1, angle2, angle3), as well as the radius parameter (radius1 , radius2) parameters permit to parametrize the torus, see next paragraph. +

      +

      Option

      +

      TorusExampleOverviewParameters.jpg +

      Parameter +

      A torus can be assimilated to a small disc that makes a circular orbit around an imaginary axe. Thus the parametric torus is defined by the following parameters: +

      +
      • Radius1: Radius of the circle around which the disc circulate
      • +
      • Radius2: Radius of the disc defining the form of the torus
      • +
      • Angle1: 1st angle to cut / define the disc of the torus
      • +
      • Angle2: 2nd angle to cut / define the disc of the torus
      • +
      • Angle3: 3rd angle to define the circumference of the torus.
      +

      as well as the standard set of placement parameters. The pictures below give a visual overview of the parameters antecedently mentioned: +

      TorusExampleRadius1.jpg +The parameter Radius1 has a value of 20 mm. +

      TorusExampleRadius2.jpg +The parameter Radius2 has a value of 2 mm. +

      TorusExampleAngle1.jpg +The parameter Angle1 has a value of -90°. Notice that, the "angle measure" tool cannot display negative angle. Considered the displayed value in picture as "-90°". +

      TorusExampleAngle2.jpg +The parameter Angle2 has a value of 90°. +

      TorusExampleAngle3.jpg +The parameter Angle3 has a value of 90°. +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Part_Torus.svg b/localwiki/Part_Torus.svg new file mode 100644 index 0000000..837094b --- /dev/null +++ b/localwiki/Part_Torus.svg @@ -0,0 +1,104 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [wmayer] + + + Part_Torus + 2011-10-10 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Part/Gui/Resources/icons/Part_Torus.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + diff --git a/localwiki/Part_Union.html b/localwiki/Part_Union.html new file mode 100644 index 0000000..73a6b23 --- /dev/null +++ b/localwiki/Part_Union.html @@ -0,0 +1,77 @@ +Part Union

      Part Union

      + +

      + + + + + + + + + + + + + + + + + + + +
      +

      Part Fuse.png Part Fuse

      +
      Menu location +
      Part → Union +
      Workbenches +
      Part, Complete +
      Default shortcut +
      None +
      See also +
      Part Cut, Part Common +

      + +
      +


      +

      Unites (fuses) selected Part objects into one. This operation is fully parametric and the components can be modified and the result recomputed. +

      This command allows you to perform quickly this Boolean operation. +

      +

      How to use

      +
      1. Select two or more shapes
      2. +
      3. Press the Part Fuse.png Part Union button.
      +

      Supported inputs

      +

      Input objects must be OpenCascade shapes. Examples: stuff made with Part, PartDesign, Sketcher workbenches. Not meshes (unless those were converted to shapes) - for meshes, there are specific Boolean tools in MeshDesign workbench. +

      +
      • Solid + Solid: the result is a solid that occupies all the volume covered by the inputs
      +
      • Shell + Shell, Shell + Face, Face + Face: the result is a shell. Where faces intersect, they are split. Shells can be non-manifold. After fusion, faces can be united by Refining the result.
      +
      • Wire + Wire, Edge + Wire, Edge + Edge: the result is a wire. Edges are split where they intersect.
      +

      Compounds are supported; however, it is assumed that shapes packed into a compound do not touch or intersect. If they actually do, Fusion will likely fail, or produce an incorrect result. +

      +

      Options

      +

      Items can be added and removed from the fuse, by dragging them in or out of the fuse feature in the treeview with the mouse. A manual recompute (press F5 key or click on the recompute icon) is required to see the results. +

      After this operation it may be necessary to clean the shape with RefineShape. +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Part_Wedge.html b/localwiki/Part_Wedge.html new file mode 100644 index 0000000..d337476 --- /dev/null +++ b/localwiki/Part_Wedge.html @@ -0,0 +1,98 @@ +Part Wedge

      Part Wedge

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Part Wedge.png Part Wedge

      +
      Menu location +
      Part -> Part CreatePrimitives -> Wedge +
      Workbenches +
      Part +
      Default shortcut +
      None +
      See also +
      Part CreatePrimitives +

      + +
      +


      +

      Create a parametric Wedge object. This Wedge defaults to a larger square base and a smaller square top. +

      +

      Default Size and Placement

      +

      Placement: +The default orientation places the base in the XZ plane and the top outward in the Y axis direction. The default base corner is the 0,0,0 origin. +

      Base Face: +

      +
      • X : 10 mm
      • +
      • Z : 10 mm
      +

      Height: +

      +
      • Y : 0-10 mm
      +

      Top Face: +

      +
      • X : 2-8 mm
      • +
      • Z : 2-8 mm
      +


      +

      +
      PartWedgeProperty.png
      +
      +


      +

      +

      Parametric Inputs

      + + + +
      PartWedgeProperty Inputs.png + +

      Using the default placement, the below inputs are: +

      +
      • DATAX min/max : Base face X axis span
      • +
      • DATAY min/max: Wedge height span
      • +
      • DATAZ min/max : Base face Z axis span
      • +
      • DATAX2 min/max : Top face X axis span
      • +
      • DATAZ2 min/max : Top face Z axis span
      +
      +

      More examples for wedges

      +

      Wedge examples.png +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Part_Workbench.html b/localwiki/Part_Workbench.html new file mode 100644 index 0000000..c581bd8 --- /dev/null +++ b/localwiki/Part_Workbench.html @@ -0,0 +1,160 @@ +Part Workbench

      Part Workbench

      (Redirected from Part Workbench)
      + +

      The CAD capabilities of FreeCAD are based on the OpenCasCade kernel. The Part module allows FreeCAD to access and use the OpenCasCade objects and functions. OpenCascade is a professional-level CAD kernel, that features advanced 3D geometry manipulation and objects. The Part objects, unlike Mesh Module objects, are much more complex, and therefore permit much more advanced operations, like coherent boolean operations, modifications history and parametric behaviour. +

      Part example.jpg +

      Example of Part shapes in FreeCAD +

      + + +

      The tools

      +

      The Part module tools are all located in the Part menu that appears when you load the Part module. +

      +

      Primitives

      +

      These are tools for creating primitive objects. +

      +
      • Part Box.png Box: Draws a box by specifying its dimensions
      • +
      • Part Cone.png Cone: Draws a cone by specifying its dimensions
      • +
      • Part Cylinder.png Cylinder: Draws a cylinder by specifying its dimensions
      • +
      • Part Sphere.png Sphere: Draws a sphere by specifying its dimensions
      • +
      • Part Torus.png Torus: Draws a torus (ring) by specifying its dimensions
      • +
      • Part CreatePrimitives.png CreatePrimitives: A tool to create various parametric geometric primitives
      • +
      • Part Shapebuilder.png Shapebuilder: A tool to create more complex shapes from various parametric geometric primitives
      +

      Modifying objects

      +

      These are tools for modifying existing objects. They will allow you to choose which object to modify. +

      +
      • Part Booleans.png Booleans: Performs boolean operations on objects
      • +
      • Part Union.png Union: Fuses (unions) two objects
      • +
      • Part Common.png Common: Extracts the common (intersection) part of two objects
      • +
      • Part Cut.png Cut: Cuts (subtracts) one object from another
      • +
      • Part JoinConnect.png Join features: smart booleans for walled objects (e.g., pipes) (v0.16) +
        • Part JoinConnect.png Connect: Connects interiors of objects (v0.16)
        • +
        • Part JoinEmbed.png Embed: Embeds a walled object into another walled object (v0.16)
        • +
        • Part JoinCutout.png Cutout: Creates a cutout in a wall of an object for another walled object (v0.16)
      • +
      • Splitting tools: (v0.17) +
        • Part BooleanFragments.png Boolean fragments: makes all the pieces that can be obtained by Boolean operations between objects (v0.17)
        • +
        • Part Slice.png Slice: Splits an object into pieces by intersections with another object (v0.17)
        • +
        • Part XOR.png XOR: removes space shared by even number of objects (symmetric version of Cut) (v0.17)
      • +
      • Part Extrude.png Extrude: Extrudes planar faces of an object
      • +
      • Part Fillet.png Fillet: Fillets (rounds) edges of an object
      • +
      • Part Revolve.png Revolve: Creates a solid by revolving another object (not solid) around an axis
      • +
      • Part Section.png Section: Creates a section by intersecting an object with a section plane
      • +
      • Part SectionCross.png Cross sections...:
      • +
      • Part Chamfer.png Chamfer: Chamfers edges of an object
      • +
      • Part Mirror.png Mirror: Mirrors the selected object on a given mirror plane
      • +
      • Part RuledSurface.png Ruled Surface:
      • +
      • Part Sweep.png Sweep: Sweeps one or more profiles along a path
      • +
      • Part Loft.png Loft: Lofts from one profile to another
      • +
      • Offset tools: +
        • Part Offset.png 3D Offset: Constructs a parallel shape at a certain distance from original.
        • +
        • Part Offset2D.png 2D Offset: Constructs a parallel wire at certain distance from original, or enlarges/shrinks a planar face. (v0.17)
        • +
        • Part Thickness.png Thickness: Hollows out a solid, leaving openings next to select faces.
      +

      Other tools

      +
      • Part ImportCAD.png Import CAD: This tool allows you to add a file *.IGES, *.STEP, *.BREP to the current document.
      • +
      • Part ExportCAD.png Export CAD: This tool allows you to export a part object in a *.IGES, *.STEP, *.BREP file.
      • +
      • Part ShapeFromMesh.png Shape from Mesh: Creates a shape object from a mesh object.
      • +
      • Convert to solid: Converts a shape object to a solid object.
      • +
      • Reverse shapes: Flips the normals of all faces of the selected object.
      • +
      • Create simple copy: Creates a simple copy of the selected object.
      • +
      • Make compound: Creates a compound from the selected objects.
      • +
      • Part RefineShape.png Refine shape: Cleans faces by removing unnecessary lines.
      • +
      • Part CheckGeometry.png Check geometry: Checks the geometry of selected objects for errors.
      • +
      • Measure: Allows linear and angular measurement between points/edges/faces.
      +


      +

      + +


      +

      +

      Boolean Operations

      +
      An example of union (Fuse), intersection (Common) and difference (Cut)
      +
      +


      +An example of union (Fuse), intersection (Common) and difference (Cut) +

      +

      Explaining the concepts

      +

      In OpenCasCade terminology, we distinguish between geometric primitives and (topological) shapes. A geometric primitive can be a point, a line, a circle, a plane, etc. or even some more complex types like a B-Spline curve or surface. A shape can be a vertex, an edge, a wire, a face, a solid or a compound of other shapes. The geometric primitives are not made to be directly displayed on the 3D scene, but rather to be used as building geometry for shapes. For example, an edge can be constructed from a line or from a portion of a circle. +

      We could say, to resume, that geometry primitive are "shapeless" building blocks, and shapes are the real spatial geometry built on it. +

      To get a complete list of all of them refer to the OCC documentation (Alternative: sourcearchive.com) and search for Geom_* (for geometry) and TopoDS_* (for shapes). There you can also read more about the differences between geometric objects and shapes. Please note that unfortunately the official OCC documentation is not available online (you must download an archive) and is mostly aimed at programmers, not at end-users. But hopefully you'll find enough information to get started here. +

      The geometric types actually can be divided into two major groups: curves and surfaces. Out of the curves (line, circle, ...) you can directly build an edge, out of the surfaces (plane, cylinder, ...) a face can be built. For example, the geometric primitive line is unlimited, i.e. it is defined by a base vector and a direction vector while its shape representation must be something limited by a start and end point. And a box -- a solid -- can be created by six limited planes. +

      From an edge or face you can also go back to its geometric primitive counterpart. +

      Thus, out of shapes you can build very complex parts or, the other way round, extract all sub-shapes a more complex shape is made of. +

      +

      Scripting

      +

      The main data structure used in the Part module is the BRep data type from OpenCascade. +Almost all contents and object types of the Part module are now available to python scripting. This includes geometric primitives, such as Line and Circle (or Arc), and the whole range of TopoShapes, like Vertexes, Edges, Wires, Faces, Solids and Compounds. For each of those objects, several creation methods exist, and for some of them, especially the TopoShapes, advanced operations like boolean union/difference/intersection are also available. Explore the contents of the Part module, as described in the FreeCAD Scripting Basics page, to know more. +

      +

      Examples

      +

      To create a line element switch to the Python console and type in: +

      +
      import Part,PartGui 
      +doc=App.newDocument()  
      +l=Part.Line()
      +l.StartPoint=(0.0,0.0,0.0)
      +l.EndPoint=(1.0,1.0,1.0)
      +doc.addObject("Part::Feature","Line").Shape=l.toShape() 
      +doc.recompute() 
      +

      Let's go through the above python example step by step: +

      +
      import Part,PartGui
      +doc=App.newDocument() 
      +

      loads the Part module and creates a new document +

      +
      l=Part.Line()
      +l.StartPoint=(0.0,0.0,0.0)
      +l.EndPoint=(1.0,1.0,1.0) 
      +

      Line is actually a line segment, hence the start and endpoint. +

      +
      doc.addObject("Part::Feature","Line").Shape=l.toShape() 
      +

      This adds a Part object type to the document and assigns the shape representation of the line segment to the 'Shape' property of the added object. It is important to understand here that we used a geometric primitive (the Part.Line) to create a TopoShape out of it (the toShape() method). Only Shapes can be added to the document. In FreeCAD, geometry primitives are used as "building structures" for Shapes. +

      +
      doc.recompute() 
      +

      Updates the document. This also prepares the visual representation of the new part object. +

      Note that a Line can be created by specifying its start and endpoint directly in the constructor, for example Part.Line(point1,point2), or we can create a default line and set its properties afterwards, as we did here. +

      A circle can be created in a similar way: +

      +
      import Part
      +doc = App.activeDocument()
      +c = Part.Circle() 
      +c.Radius=10.0  
      +f = doc.addObject("Part::Feature", "Circle")
      +f.Shape = c.toShape()
      +doc.recompute() 
      +

      Note again, we used the circle (geometry primitive) to construct a shape out of it. We can of course still access our construction geometry afterwards, by doing: +

      +
      s = f.Shape
      +e = s.Edges[0]
      +c = e.Curve 
      +

      Here we take the shape of our object f, then we take its list of edges. In this case there will be only one because we made the whole shape out of a single circle, so we take only the first item of the Edges list, and we takes its curve. Every Edge has a Curve, which is the geometry primitive it is based on. +

      Head to the Topological data scripting page if you would like to know more. +

      +

      Tutorials

      + + +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Part_Workbench.svg b/localwiki/Part_Workbench.svg new file mode 100644 index 0000000..f94d8ae --- /dev/null +++ b/localwiki/Part_Workbench.svg @@ -0,0 +1,70 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + [triplus] + + + PartWorkbench + 2016-02-26 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Part/Gui/Resources/icons/PartWorkbench.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + diff --git a/localwiki/Part_XOR.svg b/localwiki/Part_XOR.svg new file mode 100644 index 0000000..6864650 --- /dev/null +++ b/localwiki/Part_XOR.svg @@ -0,0 +1,102 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [DeepSOIC] + + + Part_XOR + 2016-07-29 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Part/Gui/Resources/icons/Part_XOR.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + diff --git a/localwiki/Part_example.jpg b/localwiki/Part_example.jpg new file mode 100644 index 0000000..2e82123 Binary files /dev/null and b/localwiki/Part_example.jpg differ diff --git a/localwiki/Partdesign_groove_parameters.png b/localwiki/Partdesign_groove_parameters.png new file mode 100644 index 0000000..8ddd4ca Binary files /dev/null and b/localwiki/Partdesign_groove_parameters.png differ diff --git a/localwiki/Partdesign_revolution_parameters.png b/localwiki/Partdesign_revolution_parameters.png new file mode 100644 index 0000000..7b0e773 Binary files /dev/null and b/localwiki/Partdesign_revolution_parameters.png differ diff --git a/localwiki/Path-3DPocket.svg b/localwiki/Path-3DPocket.svg new file mode 100644 index 0000000..4c85acb --- /dev/null +++ b/localwiki/Path-3DPocket.svg @@ -0,0 +1,269 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + Path-3DSurface + 2016-05-15 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Path/Gui/Resources/icons/Path-3DSurface.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Path-3DSurface.svg b/localwiki/Path-3DSurface.svg new file mode 100644 index 0000000..17d2d4a --- /dev/null +++ b/localwiki/Path-3DSurface.svg @@ -0,0 +1,85 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + Path-3DSurface + 2016-05-15 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Path/Gui/Resources/icons/Path-3DSurface.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Path-Area-View.svg b/localwiki/Path-Area-View.svg new file mode 100644 index 0000000..504106d --- /dev/null +++ b/localwiki/Path-Area-View.svg @@ -0,0 +1,657 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + Path-FaceProfile + 2016-01-19 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Path/Gui/Resources/icons/Path- + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + diff --git a/localwiki/Path-Area-Workplane.svg b/localwiki/Path-Area-Workplane.svg new file mode 100644 index 0000000..1498ef3 --- /dev/null +++ b/localwiki/Path-Area-Workplane.svg @@ -0,0 +1,676 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + Path-FaceProfile + 2016-01-19 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Path/Gui/Resources/icons/Path- + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + diff --git a/localwiki/Path-Area.svg b/localwiki/Path-Area.svg new file mode 100644 index 0000000..a620c23 --- /dev/null +++ b/localwiki/Path-Area.svg @@ -0,0 +1,648 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + Path-FaceProfile + 2016-01-19 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Path/Gui/Resources/icons/Path- + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + diff --git a/localwiki/Path-Array.svg b/localwiki/Path-Array.svg new file mode 100644 index 0000000..a5da4e0 --- /dev/null +++ b/localwiki/Path-Array.svg @@ -0,0 +1,154 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + Path-Array + 2016-01-19 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Path/Gui/Resources/icons/Path-Array.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Path-Axis.svg b/localwiki/Path-Axis.svg new file mode 100644 index 0000000..f5f13fa --- /dev/null +++ b/localwiki/Path-Axis.svg @@ -0,0 +1,88 @@ + + + + + + + + + + + image/svg+xml + + + Path-Axis + 2015-07-04 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Path/Gui/Resources/icons/Path-Axis.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Path-BFastForward.svg b/localwiki/Path-BFastForward.svg new file mode 100644 index 0000000..17ecb90 --- /dev/null +++ b/localwiki/Path-BFastForward.svg @@ -0,0 +1,118 @@ + + + + + + + + + + + + + + + + + image/svg+xml + + + + + + + + + + + + diff --git a/localwiki/Path-BPause.svg b/localwiki/Path-BPause.svg new file mode 100644 index 0000000..439edcd --- /dev/null +++ b/localwiki/Path-BPause.svg @@ -0,0 +1,121 @@ + + + + + + + + + + + + + + + + + image/svg+xml + + + + + + + + + + + + diff --git a/localwiki/Path-BPlay.svg b/localwiki/Path-BPlay.svg new file mode 100644 index 0000000..6cf1536 --- /dev/null +++ b/localwiki/Path-BPlay.svg @@ -0,0 +1,60 @@ + + + + + + + + + + + + + image/svg+xml + + + + + + + + + + diff --git a/localwiki/Path-BStep.svg b/localwiki/Path-BStep.svg new file mode 100644 index 0000000..898b343 --- /dev/null +++ b/localwiki/Path-BStep.svg @@ -0,0 +1,118 @@ + + + + + + + + + + + + + + + + + image/svg+xml + + + + + + + + + + + + diff --git a/localwiki/Path-BStop.svg b/localwiki/Path-BStop.svg new file mode 100644 index 0000000..8ae4161 --- /dev/null +++ b/localwiki/Path-BStop.svg @@ -0,0 +1,97 @@ + + + + + + + + + + + + + + + + image/svg+xml + + + + + + + + + + diff --git a/localwiki/Path-BaseGeometry.svg b/localwiki/Path-BaseGeometry.svg new file mode 100644 index 0000000..bb3143c --- /dev/null +++ b/localwiki/Path-BaseGeometry.svg @@ -0,0 +1,52 @@ + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + Path-BaseGeometry + 2016-05-15 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Path/Gui/Resources/icons/Path-BaseGeometry.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + diff --git a/localwiki/Path-Comment.svg b/localwiki/Path-Comment.svg new file mode 100644 index 0000000..35a1aef --- /dev/null +++ b/localwiki/Path-Comment.svg @@ -0,0 +1,152 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + Path-Comment + 2015-07-04 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Path/Gui/Resources/icons/Path-Comment.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Path-Compound.svg b/localwiki/Path-Compound.svg new file mode 100644 index 0000000..7040fc4 --- /dev/null +++ b/localwiki/Path-Compound.svg @@ -0,0 +1,215 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + Path-Compound + 2015-07-04 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Path/Gui/Resources/icons/Path-Compound.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Path-Contour.svg b/localwiki/Path-Contour.svg new file mode 100644 index 0000000..43a62e4 --- /dev/null +++ b/localwiki/Path-Contour.svg @@ -0,0 +1,193 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + Path-Contour + 2016-08-16 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Path/Gui/Resources/icons/Path-Contour.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Path-Copy.svg b/localwiki/Path-Copy.svg new file mode 100644 index 0000000..5f07ebd --- /dev/null +++ b/localwiki/Path-Copy.svg @@ -0,0 +1,170 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + Path-Copy + 2015-07-04 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Path/Gui/Resources/icons/Path-Copy.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Path-Custom.svg b/localwiki/Path-Custom.svg new file mode 100644 index 0000000..e0f4816 --- /dev/null +++ b/localwiki/Path-Custom.svg @@ -0,0 +1,140 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + Path-Custom + 2016-01-19 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Path/Gui/Resources/icons/Path-Custom.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Path-Datums.svg b/localwiki/Path-Datums.svg new file mode 100644 index 0000000..9dcae29 --- /dev/null +++ b/localwiki/Path-Datums.svg @@ -0,0 +1,92 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + Path-Datums + 2015-07-04 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Path/Gui/Resources/icons/Path-Datums.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Path-Depths.svg b/localwiki/Path-Depths.svg new file mode 100644 index 0000000..efcaa8b --- /dev/null +++ b/localwiki/Path-Depths.svg @@ -0,0 +1,87 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + Path-Depths + 2016-05-15 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Path/Gui/Resources/icons/Path-Depths.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Path-Dressup.svg b/localwiki/Path-Dressup.svg new file mode 100644 index 0000000..07e2305 --- /dev/null +++ b/localwiki/Path-Dressup.svg @@ -0,0 +1,178 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + Path-Dressup + 2015-07-04 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Path/Gui/Resources/icons/Path-Dressup.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Path-Drilling.svg b/localwiki/Path-Drilling.svg new file mode 100644 index 0000000..c611584 --- /dev/null +++ b/localwiki/Path-Drilling.svg @@ -0,0 +1,156 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + Path-Drilling + 2015-07-04 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Path/Gui/Resources/icons/Path-Drilling.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Path-EditTool-Dialog.PNG b/localwiki/Path-EditTool-Dialog.PNG new file mode 100644 index 0000000..a73e864 Binary files /dev/null and b/localwiki/Path-EditTool-Dialog.PNG differ diff --git a/localwiki/Path-Engrave.svg b/localwiki/Path-Engrave.svg new file mode 100644 index 0000000..c0b7bee --- /dev/null +++ b/localwiki/Path-Engrave.svg @@ -0,0 +1,161 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + Path-Engrave + 2016-02-24 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Path/Gui/Resources/icons/Path-Engrave.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Path-ExportTemplate.svg b/localwiki/Path-ExportTemplate.svg new file mode 100644 index 0000000..9536887 --- /dev/null +++ b/localwiki/Path-ExportTemplate.svg @@ -0,0 +1,1192 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + Path-Job + 2016-06-27 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Path/Gui/Resources/icons/Path-Job.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Path-Face.svg b/localwiki/Path-Face.svg new file mode 100644 index 0000000..a8837f5 --- /dev/null +++ b/localwiki/Path-Face.svg @@ -0,0 +1,212 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + Path-Face + 2016-11-07 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Path/Gui/Resources/icons/Path- + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Path-FacePocket.svg b/localwiki/Path-FacePocket.svg new file mode 100644 index 0000000..ded548f --- /dev/null +++ b/localwiki/Path-FacePocket.svg @@ -0,0 +1,165 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + Path-FacePocket + 2016-01-19 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Path/Gui/Resources/icons/Path- + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Path-FaceProfile.svg b/localwiki/Path-FaceProfile.svg new file mode 100644 index 0000000..74907b5 --- /dev/null +++ b/localwiki/Path-FaceProfile.svg @@ -0,0 +1,162 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + Path-FaceProfile + 2016-01-19 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Path/Gui/Resources/icons/Path- + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Path-Heights.svg b/localwiki/Path-Heights.svg new file mode 100644 index 0000000..b4a4888 --- /dev/null +++ b/localwiki/Path-Heights.svg @@ -0,0 +1,73 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + Path-Heights + 2016-05-15 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Path/Gui/Resources/icons/Path-Heights.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Path-Helix.svg b/localwiki/Path-Helix.svg new file mode 100644 index 0000000..83bd5ba --- /dev/null +++ b/localwiki/Path-Helix.svg @@ -0,0 +1,1524 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [Lorenz Hüdepohl] + + + Path-Helix + 2016-05-10 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Path/Gui/Resources/icons/Path-Helix.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Path-Holding.svg b/localwiki/Path-Holding.svg new file mode 100644 index 0000000..436ec72 --- /dev/null +++ b/localwiki/Path-Holding.svg @@ -0,0 +1,171 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + Path-Holding + 2016-02-24 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Path/Gui/Resources/icons/Path-Holding.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Path-Hop.svg b/localwiki/Path-Hop.svg new file mode 100644 index 0000000..59394f0 --- /dev/null +++ b/localwiki/Path-Hop.svg @@ -0,0 +1,165 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + Path-Hop + 2015-07-04 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Path/Gui/Resources/icons/Path-Hop.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Path-Inspect.svg b/localwiki/Path-Inspect.svg new file mode 100644 index 0000000..ab468fc --- /dev/null +++ b/localwiki/Path-Inspect.svg @@ -0,0 +1,243 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + Path-Inspect + 2016-01-19 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Path/Gui/Resources/icons/Path-Inspect.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Path-InspectWindow.gif b/localwiki/Path-InspectWindow.gif new file mode 100644 index 0000000..6496030 Binary files /dev/null and b/localwiki/Path-InspectWindow.gif differ diff --git a/localwiki/Path-Job.svg b/localwiki/Path-Job.svg new file mode 100644 index 0000000..50a0609 --- /dev/null +++ b/localwiki/Path-Job.svg @@ -0,0 +1,1248 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + Path-Job + 2016-06-27 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Path/Gui/Resources/icons/Path-Job.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Path-JobCreationDialog.png b/localwiki/Path-JobCreationDialog.png new file mode 100644 index 0000000..f555a16 Binary files /dev/null and b/localwiki/Path-JobCreationDialog.png differ diff --git a/localwiki/Path-JobOutput.png b/localwiki/Path-JobOutput.png new file mode 100644 index 0000000..6e879b2 Binary files /dev/null and b/localwiki/Path-JobOutput.png differ diff --git a/localwiki/Path-JobTools.png b/localwiki/Path-JobTools.png new file mode 100644 index 0000000..ed2c6c1 Binary files /dev/null and b/localwiki/Path-JobTools.png differ diff --git a/localwiki/Path-Kurve.svg b/localwiki/Path-Kurve.svg new file mode 100644 index 0000000..81d192c --- /dev/null +++ b/localwiki/Path-Kurve.svg @@ -0,0 +1,45 @@ + + + + + + + + + + + image/svg+xml + + + Path-Kurve + 2015-07-04 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Path/Gui/Resources/icons/Path-Kurve.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + diff --git a/localwiki/Path-LengthOffset.svg b/localwiki/Path-LengthOffset.svg new file mode 100644 index 0000000..15c692c --- /dev/null +++ b/localwiki/Path-LengthOffset.svg @@ -0,0 +1,136 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + Path-LengthOffset + 2015-07-04 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Path/Gui/Resources/icons/Path-LengthOffset.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Path-Machine-test1.svg b/localwiki/Path-Machine-test1.svg new file mode 100644 index 0000000..9636963 --- /dev/null +++ b/localwiki/Path-Machine-test1.svg @@ -0,0 +1,223 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + Path-Machine-test1 + 2016-05-15 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Path/Gui/Resources/icons/Path-Machine-test1.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Path-Machine.svg b/localwiki/Path-Machine.svg new file mode 100644 index 0000000..b4a9e10 --- /dev/null +++ b/localwiki/Path-Machine.svg @@ -0,0 +1,160 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + Path-Machine + 2015-07-04 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Path/Gui/Resources/icons/Path-Machine.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Path-MachineLathe.svg b/localwiki/Path-MachineLathe.svg new file mode 100644 index 0000000..a26922a --- /dev/null +++ b/localwiki/Path-MachineLathe.svg @@ -0,0 +1,103 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + Path-MachineLathe + 2016-05-15 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Path/Gui/Resources/icons/Path-MachineLathe.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Path-MachineMill.svg b/localwiki/Path-MachineMill.svg new file mode 100644 index 0000000..78d375a --- /dev/null +++ b/localwiki/Path-MachineMill.svg @@ -0,0 +1,76 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + Path-MachineMill + 2016-05-15 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Path/Gui/Resources/icons/Path-MachineMill.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Path-OpCopy.svg b/localwiki/Path-OpCopy.svg new file mode 100644 index 0000000..0079645 --- /dev/null +++ b/localwiki/Path-OpCopy.svg @@ -0,0 +1,704 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + Path-FaceProfile + 2016-01-19 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Path/Gui/Resources/icons/Path- + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Path-OperationA.svg b/localwiki/Path-OperationA.svg new file mode 100644 index 0000000..0e9b56e --- /dev/null +++ b/localwiki/Path-OperationA.svg @@ -0,0 +1,147 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + Mon Mar 12 17:20:03 2012 -0300 + + + [Yorik van Havre] + + + + + FreeCAD LGPL2+ + + + + + FreeCAD + + + FreeCAD/src/Mod/Draft/Resources/icons/Snap_Extension.svg + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + [agryson] Alexander Gryson, [agryson] Alexander Gryson + + + Three dots or circles in a horizontal sequence simiar to an ellipsis + + + circle + circles + dot + dots + ellipsis + + + Path-OperationA + https://www.gnu.org/copyleft/lesser.html + + + + diff --git a/localwiki/Path-OperationB.svg b/localwiki/Path-OperationB.svg new file mode 100644 index 0000000..8a0dba4 --- /dev/null +++ b/localwiki/Path-OperationB.svg @@ -0,0 +1,101 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + Path-OperationB + 2016-05-15 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Path/Gui/Resources/icons/Path-OperationB.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Path-Plane.svg b/localwiki/Path-Plane.svg new file mode 100644 index 0000000..2cd1fbc --- /dev/null +++ b/localwiki/Path-Plane.svg @@ -0,0 +1,74 @@ + + + + + + + + + + + image/svg+xml + + + Path-Plane + 2015-07-04 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Path/Gui/Resources/icons/Path-Plane.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Path-Pocket.svg b/localwiki/Path-Pocket.svg new file mode 100644 index 0000000..816cf71 --- /dev/null +++ b/localwiki/Path-Pocket.svg @@ -0,0 +1,177 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + Path-Pocket + 2015-07-04 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Path/Gui/Resources/icons/Path-Pocket.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Path-PocketOperation.gif b/localwiki/Path-PocketOperation.gif new file mode 100644 index 0000000..4074300 Binary files /dev/null and b/localwiki/Path-PocketOperation.gif differ diff --git a/localwiki/Path-Post.svg b/localwiki/Path-Post.svg new file mode 100644 index 0000000..7bdfd13 --- /dev/null +++ b/localwiki/Path-Post.svg @@ -0,0 +1,253 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + Path-Job + 2016-06-27 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Path/Gui/Resources/icons/Path-Job.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Path-PostOutput.gif b/localwiki/Path-PostOutput.gif new file mode 100644 index 0000000..2a0db4f Binary files /dev/null and b/localwiki/Path-PostOutput.gif differ diff --git a/localwiki/Path-Profile-Edges.svg b/localwiki/Path-Profile-Edges.svg new file mode 100644 index 0000000..a1fba1e --- /dev/null +++ b/localwiki/Path-Profile-Edges.svg @@ -0,0 +1,199 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + Path-Profile-Edges + 2016-10-19 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Path/Gui/Resources/icons/Path-Profile-Edges.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Path-Profile-Face.svg b/localwiki/Path-Profile-Face.svg new file mode 100644 index 0000000..5645f39 --- /dev/null +++ b/localwiki/Path-Profile-Face.svg @@ -0,0 +1,193 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + Path-Profile-Face + 2016-10-19 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Path/Gui/Resources/icons/Path-Profile- + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Path-Profile.svg b/localwiki/Path-Profile.svg new file mode 100644 index 0000000..ed9f61d --- /dev/null +++ b/localwiki/Path-Profile.svg @@ -0,0 +1,193 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + Path-Profile + 2015-07-04 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Path/Gui/Resources/icons/Path-Profile.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Path-Sanity.svg b/localwiki/Path-Sanity.svg new file mode 100644 index 0000000..9156910 --- /dev/null +++ b/localwiki/Path-Sanity.svg @@ -0,0 +1,166 @@ + + + + + + + image/svg+xml + + + Path-Sanity + 2016-05-15http://www.freecadweb.org/wiki/index.php?title=ArtworkFreeCADFreeCAD/src/Mod/Path/Gui/Resources/icons/Path-Sanity.svgFreeCAD LGPL2+https://www.gnu.org/copyleft/lesser.html[agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Path-SelectLoop.svg b/localwiki/Path-SelectLoop.svg new file mode 100644 index 0000000..1e865f2 --- /dev/null +++ b/localwiki/Path-SelectLoop.svg @@ -0,0 +1,154 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + Path-SelectLoop + 2016-10-19 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Path/Gui/Resources/icons/Path-SelectLoop.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Path-SetupSheet.svg b/localwiki/Path-SetupSheet.svg new file mode 100644 index 0000000..f15eab6 --- /dev/null +++ b/localwiki/Path-SetupSheet.svg @@ -0,0 +1,64 @@ + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [Eivind Kvedalen] + + + Spreadsheet + 2013-09-29 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Spreadsheet/Gui/Resources/icons/Spreadsheet.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + diff --git a/localwiki/Path-Shape.svg b/localwiki/Path-Shape.svg new file mode 100644 index 0000000..5f7a311 --- /dev/null +++ b/localwiki/Path-Shape.svg @@ -0,0 +1,164 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + Path-Shape + 2015-07-04 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Path/Gui/Resources/icons/Path-Shape.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Path-Simple_copy.svg b/localwiki/Path-Simple_copy.svg new file mode 100644 index 0000000..3b4d5ee --- /dev/null +++ b/localwiki/Path-Simple_copy.svg @@ -0,0 +1,147 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + Path-SimpleCopy + 2016-01-23 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Path/Gui/Resources/icons/Path-SimpleCopy.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + diff --git a/localwiki/Path-Simulation.gif b/localwiki/Path-Simulation.gif new file mode 100644 index 0000000..f053a01 Binary files /dev/null and b/localwiki/Path-Simulation.gif differ diff --git a/localwiki/Path-Simulator.svg b/localwiki/Path-Simulator.svg new file mode 100644 index 0000000..ed0b48d --- /dev/null +++ b/localwiki/Path-Simulator.svg @@ -0,0 +1,1459 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + Path-Machine + 2015-07-04 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Path/Gui/Resources/icons/Path-Machine.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Path-Speed.svg b/localwiki/Path-Speed.svg new file mode 100644 index 0000000..5fa8e09 --- /dev/null +++ b/localwiki/Path-Speed.svg @@ -0,0 +1,83 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + Path-Speed + 2016-05-15 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Path/Gui/Resources/icons/Path-Speed.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Path-SquarePocketModel.png b/localwiki/Path-SquarePocketModel.png new file mode 100644 index 0000000..ef594a2 Binary files /dev/null and b/localwiki/Path-SquarePocketModel.png differ diff --git a/localwiki/Path-Stock.svg b/localwiki/Path-Stock.svg new file mode 100644 index 0000000..1af7510 --- /dev/null +++ b/localwiki/Path-Stock.svg @@ -0,0 +1,65 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + Path-Stock + 2015-07-04 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Path/Gui/Resources/icons/Path-Stock.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + diff --git a/localwiki/Path-Stop.svg b/localwiki/Path-Stop.svg new file mode 100644 index 0000000..db9564a --- /dev/null +++ b/localwiki/Path-Stop.svg @@ -0,0 +1,50 @@ + + + + + + + + + + + + + + + + + image/svg+xml + + + Path-Stop + 2015-07-04 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Path/Gui/Resources/icons/Path-Stop.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + diff --git a/localwiki/Path-Tags.svg b/localwiki/Path-Tags.svg new file mode 100644 index 0000000..3569ac9 --- /dev/null +++ b/localwiki/Path-Tags.svg @@ -0,0 +1,171 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + Path-Tags + 2016-02-24 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Path/Gui/Resources/icons/Path-Tags.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Path-ToolAdd.gif b/localwiki/Path-ToolAdd.gif new file mode 100644 index 0000000..5dca3b2 Binary files /dev/null and b/localwiki/Path-ToolAdd.gif differ diff --git a/localwiki/Path-ToolChange.svg b/localwiki/Path-ToolChange.svg new file mode 100644 index 0000000..0a01c1f --- /dev/null +++ b/localwiki/Path-ToolChange.svg @@ -0,0 +1,203 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + Path-ToolChange + 2016-01-20 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Path/Gui/Resources/icons/Path-ToolChange.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Path-ToolConfig.gif b/localwiki/Path-ToolConfig.gif new file mode 100644 index 0000000..78c45b7 Binary files /dev/null and b/localwiki/Path-ToolConfig.gif differ diff --git a/localwiki/Path-ToolController.svg b/localwiki/Path-ToolController.svg new file mode 100644 index 0000000..83a8eba --- /dev/null +++ b/localwiki/Path-ToolController.svg @@ -0,0 +1,152 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + Path-LoadTool + 2015-07-04 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Path/Gui/Resources/icons/Path-LoadTool.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Path-ToolTable.svg b/localwiki/Path-ToolTable.svg new file mode 100644 index 0000000..73007f4 --- /dev/null +++ b/localwiki/Path-ToolTable.svg @@ -0,0 +1,232 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + Path-ToolTable + 2015-07-04 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Path/Gui/Resources/icons/Path-ToolTable.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Path-Toolpath.svg b/localwiki/Path-Toolpath.svg new file mode 100644 index 0000000..308bb57 --- /dev/null +++ b/localwiki/Path-Toolpath.svg @@ -0,0 +1,159 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + Path-Toolpath + 2015-07-04 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Path/Gui/Resources/icons/Path-Toolpath.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Path-Tooltable.png b/localwiki/Path-Tooltable.png new file mode 100644 index 0000000..2e27ff8 Binary files /dev/null and b/localwiki/Path-Tooltable.png differ diff --git a/localwiki/Path-TreeWithJob.png b/localwiki/Path-TreeWithJob.png new file mode 100644 index 0000000..1af3e1c Binary files /dev/null and b/localwiki/Path-TreeWithJob.png differ diff --git a/localwiki/Path-WalkThroughResult.gif b/localwiki/Path-WalkThroughResult.gif new file mode 100644 index 0000000..422a425 Binary files /dev/null and b/localwiki/Path-WalkThroughResult.gif differ diff --git a/localwiki/Path-Workbench.svg b/localwiki/Path-Workbench.svg new file mode 100644 index 0000000..75589dd --- /dev/null +++ b/localwiki/Path-Workbench.svg @@ -0,0 +1,161 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + PathWorkbench + 2016-02-26 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Path/Gui/Resources/icons/PathWorkbench.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Path_Area.html b/localwiki/Path_Area.html new file mode 100644 index 0000000..d6c70fe --- /dev/null +++ b/localwiki/Path_Area.html @@ -0,0 +1,25 @@ +Path Area

      Path Area

      + +
      This is an unfinished experimental feature. Enable Experimental Features
      +


      +

      +
      +

      This documentation is not finished. Please help and contribute documentation. +

      See Draft ShapeString for good documented Command. Gui Command gives an overview over commands. And see List of Commands for other commands. +

      Go to Help FreeCAD to contribute. +

      +
      + + + +
      + +
      +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Path_Area_Workplane.html b/localwiki/Path_Area_Workplane.html new file mode 100644 index 0000000..8acce9b --- /dev/null +++ b/localwiki/Path_Area_Workplane.html @@ -0,0 +1,25 @@ +Path Area Workplane

      Path Area Workplane

      + +
      This is an unfinished experimental feature. Enable Experimental Features
      +


      +

      +
      +

      This documentation is not finished. Please help and contribute documentation. +

      See Draft ShapeString for good documented Command. Gui Command gives an overview over commands. And see List of Commands for other commands. +

      Go to Help FreeCAD to contribute. +

      +
      + + + +
      + +
      +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Path_Array.html b/localwiki/Path_Array.html new file mode 100644 index 0000000..dd1947e --- /dev/null +++ b/localwiki/Path_Array.html @@ -0,0 +1,72 @@ +Path Array

      Path Array

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Path Array.png Path Array

      +
      Menu location +
      Path → Path Modification → Array +
      Workbenches +
      Path +
      Default shortcut +
      +
      See also +
      +

      + +
      +


      +

      +

      Description

      +

      This tool creates a new path by duplicating another path several times at a certain interval distance. +

      +

      Usage

      +
      1. Select one the path you want to repeat
      2. +
      3. Press the Path Array.png Array button
      4. +
      5. Apply
      6. +
      7. Adjust the desired properties at the data box
      +

      Properties

      +
      • DATAType: The type array (polar, linear one ore two directions)
      • +
      • DATAOffset: The spacing between the array copies for each direction
      • +
      • DATACopies: The number of copies for each direction
      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Path_Comment.html b/localwiki/Path_Comment.html new file mode 100644 index 0000000..d35f66a --- /dev/null +++ b/localwiki/Path_Comment.html @@ -0,0 +1,68 @@ +Path Comment

      Path Comment

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Path Comment.png Path Comment

      +
      Menu location +
      Path → Partial Commands → Comment +
      Workbenches +
      Path +
      Default shortcut +
      P,C +
      See also +
      +

      + +
      +


      +

      +

      Description

      +

      This tool inserts a comment. When exporting a project to G-code, the comments will be inserted in the G-code program, and can be read by people reading the file. Some machine controllers will also display comments on their display screens. +

      +

      Usage

      +
      1. Press the Path Comment.png Comment button
      2. +
      3. Write your comment in the Comment property
      +

      Properties

      +
      • DATAComment: The text of your comment
      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Path_Contour.html b/localwiki/Path_Contour.html new file mode 100644 index 0000000..756dafc --- /dev/null +++ b/localwiki/Path_Contour.html @@ -0,0 +1,97 @@ +Path Contour

      Path Contour

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Path Contour.png Path Contour

      +
      Menu location +
      Path → Contour +
      Workbenches +
      Path +
      Default shortcut +
      None +
      See also +
      +

      + +
      +


      +

      +

      Description

      +

      The Contour tool creates a simple external contour cut of complex 3D Part-based objects. The entire Job Model serves as the input for the Operation--regardless of whether any Body Geometry is selected when the Contour command is invoked. A Start point can be enabled from the Operation editor, using a location defined in the Property view->Start Points. +

      The Path Contour object is made to be part of a Path Job. +

      PathContourToolExample.png +

      +

      Usage

      +
      1. Press the Path Contour.png Contour button
      2. +
      3. Adjust the desired properties
      +


      +

      +

      Properties

      +

      Base Geometry

      +
      • Add, if not allready done, the elements which should be the base for the path +
        • you can also delete or change to other elements
      +

      Depth

      +
      • DATAStart Depth: Starting Depth of Tool- starting depth in Z
      • +
      • DATAFinal Depth: Final Depth of Tool- lowest cutting level in Z
      • +
      • DATAStep Down: Step Down of Tool- the amount of material which will be removed at once
      +

      Height

      +
      • DATASafe Height: The hight above the workpeace where rapid motions are allowed.
      • +
      • DATAClearance Height: The height needed to clear clamps and obstructions
      +

      Operation

      +
      • DATATool Controller: Defines the Tool controller used in the Operation
      • +
      • DATACut Side: Defines on which side the cut should be done
      • +
      • DATADirection: Specifies a CW or CCW move for the cut
      • +
      • DATAExtra Offset: Addet to the tool diameter to leave some material for a finish path
      • +
      • DATAUse Start Point: Set the start point of the path manualy (not implemented jet)
      • +
      • DATAUse Compensation: Creates a path with offset of the tool radius to respect the parts dimensions
      +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Path_Copy.html b/localwiki/Path_Copy.html new file mode 100644 index 0000000..c84c67f --- /dev/null +++ b/localwiki/Path_Copy.html @@ -0,0 +1,72 @@ +Path Copy

      Path Copy

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Path Copy.png Path Copy

      +
      Menu location +
      Path → Path Modification → Copy +
      Workbenches +
      Path +
      Default shortcut +
      P,Y +
      See also +
      +

      + +
      +


      +

      +

      Description

      +

      This tool creates a copy of a selected path +

      +

      Usage

      +
      1. Select a Path object
      2. +
      3. Press the Path Copy.png Copy button
      +

      Properties

      +
      • DATABase: The base path to be copied
      +

      Options

      +

      The copy stays linked with the original path. If the original changes, so does the copy. +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Path_Core_Concepts.html b/localwiki/Path_Core_Concepts.html new file mode 100644 index 0000000..704f177 --- /dev/null +++ b/localwiki/Path_Core_Concepts.html @@ -0,0 +1,86 @@ +Path Core Concepts

      Path Core Concepts

      + +
      + + + + + + + + + + + + + + + + + + + + + + + + + + + +
      +

      Base ExampleCommandModel.png Tutorial

      +
      Topic +
      Path Workbench +
      Level +
      +
      Time to complete +
      +
      Author +
      +
      FreeCAD version +
      +
      Example File(s) +
      +

      Contents

      + +
      + +
      +


      +

      Just a stub for now. +

      This page should talk about or link to relevant pages for: +

      Core Path Objects: +

      +
       Path
      + Command
      +
      +

      Libraries +

      +
       Path-Area
      + ClipperLib
      + OpenCamLib
      + OCC
      +
      +

      Link to Depths/Height page +Link to Dressup top level page. +

      +
        Discuss when writing a dressup is appropriate.  Dressups modify a base path to account for real-world issues (unusual tool requirements, work holding, tool limitations, material characteristics, etc.)   
      +
      +

      @mlampert may wish to contribute some content about the Operation inheritance structure +

      + + +
      + +
      +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Path_Custom.html b/localwiki/Path_Custom.html new file mode 100644 index 0000000..7d29a25 --- /dev/null +++ b/localwiki/Path_Custom.html @@ -0,0 +1,74 @@ +Path Custom

      Path Custom

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Path Custom.png Path Custom

      +
      Menu location +
      Path → Partial Commands → Custom +
      Workbenches +
      Path +
      Default shortcut +
      +
      See also +
      +

      + +
      +


      +

      +

      Description

      +

      This tool inserts a path object which is built from hand coded custom G-code. +

      Because the Custom G-Code command provides no link to a Tool Controller, if a Tool is used by the custom G-Code, the Tool index must be written, along with the Spindle Start M-Code, in order that it is passed to the Postprocessor. This ensures that Tool changes and starts will be properly generated. +

      For example, to convey to the Postprocessor that the Tool used in the Custom G-Code operation has Tool index 6, and a Spindle Speed of 10,000, insert the following code at the beginning of the Custom G-Code Operation: +

      (T6: 4mm Endmill) +

      M6 T6 +

      M3 S10000 +

      Note that Feed rates will be correctly generated by the Postprocessor, only if the Custom G-Code Feed rates are written in Units/second. +

      +

      Usage

      +
      1. Press the Path Custom.png Custom button
      2. +
      3. Write custom G-code in the G Code property of the newly created object. Refer to the Path scripting page for supported G-Code commands.
      +

      Properties

      +
      • DATAG Code: The custom G-Code commands to build the path on
      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Path_Customization.html b/localwiki/Path_Customization.html new file mode 100644 index 0000000..afc8c94 --- /dev/null +++ b/localwiki/Path_Customization.html @@ -0,0 +1,72 @@ +Path Customization

      Path Customization

      + +
      + + + + + + + + + + + + + + + + + + + + + + + + + + + +
      +

      Base ExampleCommandModel.png Tutorial

      +
      Topic +
      Path Workbench +
      Level +
      +
      Time to complete +
      +
      Author +
      +
      FreeCAD version +
      +
      Example File(s) +
      +

      Contents

      + +
      + +
      +


      +

      Just a page stub for now. +

      This page should talk about or link to at least these things: +

      The Path preferences (Edit->preferences (Path)) +

      Job Templates +

      SetupSheets +

      Post-Processor Arguments +

      + + +
      + +
      +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Path_DressupDogbone.html b/localwiki/Path_DressupDogbone.html new file mode 100644 index 0000000..62e6a98 --- /dev/null +++ b/localwiki/Path_DressupDogbone.html @@ -0,0 +1,75 @@ +Path DressupDogbone

      Path DressupDogbone

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Path DressupTag.png Path DressupTag

      +
      Menu location +
      Path → Path Dressup → Dogbone Dress-up +
      Workbenches +
      Path +
      Default shortcut +
      None +
      See also +
      Path_DressupTag, Path_DressupRampEntry, Path_DressupDragKnife +

      + +
      +


      +

      +

      Description

      +

      This tool dresses up an existing path to overcut corners on inside angles of a profile or contour operation. A cylindrical cutter cannot cut all the way into an acute corner without colliding with the model. In certain cases, it may be preferable to violate the model and ensure that the material at the corner is removed. This is especially necessary if parts are going to intersect/interlock with each other. +

      +

      Usage

      +
      1. Select a contour or profile path Path objects
      2. +
      3. click the Path Dressup.png Dogbone Dress-up menu item
      +

      Options

      +
      • Side - Which side of the path the modification will be added to.
      • +
      • Style - Style of overcut (Dogbone, T-Bone Horizontal, T-Bone Vertical, T-Bone Long Edge, T-Bone Short Edge).
      • +
      • incision - The Algorithm to use calculating the overcut length
      • +
      • Custom- If Incision is custom, the custom property is used to set the length.
      +

      Limitations

      +

      The dogbone dressup needs a straight path segement (G1) before and after the corner where the dressup should be inserted. +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Path_DressupDragKnife.html b/localwiki/Path_DressupDragKnife.html new file mode 100644 index 0000000..ede094b --- /dev/null +++ b/localwiki/Path_DressupDragKnife.html @@ -0,0 +1,71 @@ +Path DressupDragKnife

      Path DressupDragKnife

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Path DressupTag.png Path DressupTag

      +
      Menu location +
      Path → Path Dressup → Dragknife Dress-up +
      Workbenches +
      Path +
      Default shortcut +
      None +
      See also +
      Path DressupTag, Path DressupRampEntry, Path DressupDogbone +

      + +
      +


      +

      +

      Description

      +

      A drag knife uses a cutting edge on a pivot to cut sheet material like vinyl, cardboard, and leather. The cutting point is not aligned with the center of the spindle but rather follows it as the spindle moves. Because the cutting point is offset, the path must be modified to extend past the endpoint of each segment. Also, the dragknife is incapable of making extremely tight turns. To compensate, a pivot 'corner action' is inserted which momentarily lifts the blade slightly and then pivots into the new postion. +

      This tool dresses up an existing path to add corner actions and edge estensions for drag knife cutting. +

      +

      Usage

      +
      1. Select a contour or profile path Path objects
      2. +
      3. click the Path Dressup.png Dragknife Dress-up menu item
      +

      Options

      +
      • Filter Angle - Determines how acute an angle must be before a corner action is inserted.
      • +
      • Offset - Input how much the blade point is offset from the spindle center.
      • +
      • Pivot Height - Determines how high to lift the cutting blade during a corner action. This is material dependent and should be higher for thicker materials. Ideally, the point should remain in the material slightly.
      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Path_DressupRampEntry.html b/localwiki/Path_DressupRampEntry.html new file mode 100644 index 0000000..a652d67 --- /dev/null +++ b/localwiki/Path_DressupRampEntry.html @@ -0,0 +1,76 @@ +Path DressupRampEntry

      Path DressupRampEntry

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Path DressupTag.png Path DressupTag

      +
      Menu location +
      Path → Path Dressup → RampEntry Dress-up +
      Workbenches +
      Path +
      Default shortcut +
      None +
      See also +
      Path_DressupTag, Path_DressupDogbone , Path_DressupDragKnife +

      + +
      +


      +

      +

      Description

      +

      This tool dresses up an existing path to add a ramp entry +

      +

      Usage

      +
      1. Select a contour or profile path Path objects
      2. +
      3. click the Path Dressup.png RampEntry Dress-up menu item
      +

      Properties

      +
      • Ramp Feed Rate can either be the current vertical or horizontal feed rate or some other custom value
      • +
      • Angle of the ramp against the vertical axis. A smaller value makes the ramp steeper.
      • +
      • Method is used to select different modes of ramping: +
        • RampMethod1 goes down at the ramp angle and the moves horizontal to the target point
        • +
        • RampMethod2 goes horizontal first and then down at the ramp angle to the target point
        • +
        • RampMethod3 goes down in a zigzag way
        • +
        • Helix goes down spiraling
      • +
      • Dressup Start Depth is the distance above the target level where ramping starts
      • +
      • UseStartDepth indicates that the ramping does not start above the stock level. If it is not set to true the first ramp can be steeper than expected.
      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Path_DressupTag.html b/localwiki/Path_DressupTag.html new file mode 100644 index 0000000..ae30e3c --- /dev/null +++ b/localwiki/Path_DressupTag.html @@ -0,0 +1,72 @@ +Path DressupTag

      Path DressupTag

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Path DressupTag.png Path DressupTag

      +
      Menu location +
      Path → Path Dressup → Tag Dress-up +
      Workbenches +
      Path +
      Default shortcut +
      None +
      See also +
      Path_DressupRampEntry, Path_DressupDogbone , Path_DressupDragKnife +

      + +
      +


      +

      +

      Description

      +

      This tool dresses up an existing path to add holding tags +

      +

      Usage

      +
      1. Select a contour or profile path Path objects
      2. +
      3. click the Path Dressup.png Tag Dress-up menu item
      +

      Options

      +
      • Angle - Controls the angle of plunge and ascent when a tag is crated.
      • +
      • Height - Controls the height of the tag top from the bottom of the profile cut.
      • +
      • Radius - Radius of the fillet for the tag.
      • +
      • Segmentation Factor - Number of segments to approximate a rounded tag
      • +
      • width - Overall width of the tag
      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Path_DressupTag.png b/localwiki/Path_DressupTag.png new file mode 100644 index 0000000..ebec531 Binary files /dev/null and b/localwiki/Path_DressupTag.png differ diff --git a/localwiki/Path_Drilling.html b/localwiki/Path_Drilling.html new file mode 100644 index 0000000..b840ee9 --- /dev/null +++ b/localwiki/Path_Drilling.html @@ -0,0 +1,73 @@ +Path Drilling

      Path Drilling

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Path Drilling.png Path Drilling

      +
      Menu location +
      Path → Drilling +
      Workbenches +
      Path +
      Default shortcut +
      P,D +
      See also +
      +

      + +
      +


      +

      +

      Description

      +

      The Drilling command generates a drilling Operation in the Job. +

      +

      Usage

      +
      • Select the Drilling tool from the Path->menu, or the GUI Button, and press.
      • +
      • Choose a Tool controller from the pop-up selection dialogue window and confirm by pressing OK.
      • +
      • The holes available for processing with that Tool diameter will populate the list in the Base Geometry tab. Confirm that the list matches the holes that are intended for processing, and adjust add, enable, or disable, as necessary. Holes can be added by selecting the wall faces of the Holes.
      • +
      • Ensure the Depths, Final Depth is correct, and adjust if not.
      • +
      • Ensure the Heights, Safe and Clearance Heights are correct, and adjust if not.
      • +
      • In the Operation tab, specify the Retract Height, the Peck Depth, and the Dwell period in seconds. Enable Peck, Dwell, and Use Tip Length if needed.
      +

      Peck disabled generates (G81 canned drill cycles). +Peck enabled generates (G83 canned drill cycles). +Dwell enabled is currently unsupported, but is intended to generate (G82 canned drill cycles). +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Path_EditToolsTable.html b/localwiki/Path_EditToolsTable.html new file mode 100644 index 0000000..e0e9295 --- /dev/null +++ b/localwiki/Path_EditToolsTable.html @@ -0,0 +1,86 @@ +Path EditToolsTable

      Path EditToolsTable

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Official icon not found Path EditToolsTable

      +
      Menu location +
      Path → Tool Manager +
      Workbenches +
      Path +
      Default shortcut +
      P,T +
      See also +
      +

      + +
      +


      +

      +

      Description

      +

      The tooltable editor allows to edit the different tools of the tooltable contained in the machine object of a Path Job. This tooltable is used by the different operations contained in the project to obtain necessary informations about the current tool. +

      It serves for the selection of a tool which you want to use in your job as well. +

      Path-Tooltable.png +

      The handling is straight forward: +

      +
      • Import...: Imports a tooltable from an XML-file.
        Warning
      +

      This is currently partly broken and does not work if you have never had an xml file before. +

      +
      +
      • Export...: Exports the tooltable to an XML-file.
      • +
      • New Tool: opens a dialog where you can enter the parameters of your tool. See Path NewTool
      • +
      • Delete: deletes the currently selected lines.
        Warning
      +

      The tools are deleted from your tooltable even if you cancel the dialog +

      +
      +
      • Move up: You cannot edit the tool number, instead you can move the selected line up to decrease it's tool number
      • +
      • Move down: You can move the selected line down to increase it's tool number
      +
      • Create Tool Controller(s): If you check one or more of the checkboxes to the left in the tools list, this button becomes active. If you click it, the selected tools will be inserted in your current job.
      +

      Usage

      +
      1. Select a Path Job
      2. +
      3. Press the 16px Tool Manager button
      4. +
      5. Create new tools or adjust the properties of existing tools
      +

      Options

      +
      • The tools can be reordered by using the movre up/move down buttons
      • +
      • Complete tooltables can be imported from xml files (FreeCAD's own tooltable format) or from HeeksCAD tooltables
      +
      + + + + + + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Path_Engrave.html b/localwiki/Path_Engrave.html new file mode 100644 index 0000000..985db3b --- /dev/null +++ b/localwiki/Path_Engrave.html @@ -0,0 +1,63 @@ +Path Engrave

      Path Engrave

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Path Engrave.png Path Engrave

      +
      Menu location +
      Path → Engrave +
      Workbenches +
      Path +
      Default shortcut +
      None +
      See also +
      +

      + +
      +


      +

      +

      Description

      +

      Path Engrave is primarily for engraving a ShapeString onto a part. However, Engrave may be useful for other kinds of 2D +

      +

      Usage

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Path_Engrave.png b/localwiki/Path_Engrave.png new file mode 100644 index 0000000..2f595f0 Binary files /dev/null and b/localwiki/Path_Engrave.png differ diff --git a/localwiki/Path_ExportTemplate.html b/localwiki/Path_ExportTemplate.html new file mode 100644 index 0000000..4379da9 --- /dev/null +++ b/localwiki/Path_ExportTemplate.html @@ -0,0 +1,88 @@ +Path ExportTemplate

      Path ExportTemplate

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Path ExportTemplate.png Path ExportTemplate

      +
      Menu location +
      Path → Export Template +
      Workbenches +
      Path +
      Default shortcut +
      None +
      See also +
      Path SetupSheet +

      + +
      +


      +

      +

      Description

      +

      Exporting Job templates provides a convenient mechanism to save commonly used Job definitions from within an existing Job. This facilitates the setup of future Jobs, that are largely similar, by allowing Job template import during the Job creation process. +

      The Edit->Preferences...->Path->Job Preferences tab, Defaults->Template sets the default template. +

      +

      Usage

      +

      Creating a Template +

      +
      1. From within any configured Job, invoke the Path-ExportTemplate.png Export Template command from the Path->menu, or by right-clicking the Job node in the Combo view.
      2. +
      3. Select elements for inclusion from the Export Template configuration dialogue.
      4. +
      5. Click OK and save the template. The template name must follow the pattern of job_<template name>.json When shown in the selection combobox, the job_ prefix and extension will not be shown. Path workbench access requires saving the templates in the Macro directory or Path Directory, as configured in Path Preferences.
      +

      Options

      +

      Post Processing

      +
      • Postprocessor selection
      • +
      • Postprocessor arguments
      • +
      • Output file name
      +

      Stock

      +
      • Extent: Stock Size
      • +
      • Placement: Stock Location
      +

      Setup Sheet

      +
      • Operation Heights
      • +
      • Operation Depths
      • +
      • Tool Rapid Speeds
      +

      Tool controllers

      +
      • Selected Tool controllers.
      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Path_FAQ.html b/localwiki/Path_FAQ.html new file mode 100644 index 0000000..09a270a --- /dev/null +++ b/localwiki/Path_FAQ.html @@ -0,0 +1,176 @@ +Path FAQ

      Path FAQ

      + +

      Contents

      + +
      + +

      FAQ Path Workbench

      +

      How many axes can Path Workbench handle?

      +

      At the moment Path Workbench can handle up to 3 axis milling. +

      +

      Why does it seem that in some instances, Path workbench provides more than one way to specify an Operation?

      +

      Path workbench provides existing tools to meet many milling operations, more are in progress, and because FreeCAD is open source, there is nothing impeding any user from creating their own functionality. +

      As with 3D modeling, there are often multiple methods available that might be advantageous to use for different Job operations. In some cases, combinations of Operations are used to provide complete milling of the Stock. +

      One common example is that a Contour cut could be generated from Edges or Faces. In some cases there will be an advantage to one geometric input over another. +

      +

      Why does Dressing up an Operation change change the position in the Job Workflow shown in the Operations list?

      +

      All additions to the Job--including modifications, and Operation copies--are appended at the end of the Job Workflow. If that disrupts the correct Job sequence, it must be reordered in the Job editor->Workflow tab. +

      +

      What is the difference between Clearance Height and Safe Height?

      +

      More detailed information is available in Depths and Heights. +

      +

      What is the typical use of the SetupSheet?

      +

      The SetupSheet is a dedicated spreadsheet contained within a Job, modified in the Property view, accessible only from Path workbench. It provides a mechanism for more expert users to configure aspects of their Job by using Values and Expressions contained within the SetupSheet. +

      Current inputs for Depths, Heights, and Tool Controllers include: +

      +
      1. Final Depth Expression -- OpFinalDepth
      2. +
      3. Start Depth Expression -- OpStartDepth
      4. +
      5. Step Down Expression -- Defaults to OpToolDiameter. This expression is used for each Operation to calculate its default Step down value based on the diameter of the Tool defined in the associated Tool controller.
      6. +
      7. Clearance Height Expression -- StartDepth+SetupSheet.ClearanceHeightOffset
      8. +
      9. Clearance Height Offset Value -- Contains value used in Expressions
      10. +
      11. Safe Height Expression -- StartDepth+SetupSheet.SafeHeightOffset
      12. +
      13. Safe Height Offset Value -- Contains value used in Expressions
      14. +
      15. Horizontal Rapid Value -- Provides the default value used to initially populate the Horizontal Rapid Feed rate for all Tool controllers.
      16. +
      17. Vertical Rapid Value -- Provides the default value used to initially populate the Vertical Rapid Feed rate for all Tool controllers.
      +

      This provides flexibility. For example, default expressions are provided, but can be overwritten by the user. The modification can even reduce the default equation to a Value if that suits the user. +

      +

      What is the typical use of the Job Templates?

      +

      Job templates allow commonly used Job definitions to be saved from a Job for use on subsequent similarly configured Jobs. +

      +

      How many Base objects does Path workbench support?

      +

      Support exists only for a single Base object. To create paths for multiple solids in a single Job you can make a Compound out of them and use that as the base object for the Job. +

      +

      Why does an Operation not produce usable output?

      +

      A variety of reasons exist that may cause an individual Operation to generate no output. +

      One common reason is that the Tool geometry defined in the Tool controller selected for the Operation is too large to fit within the geometry selected on the 3D model for the Operation. +

      Be aware that this will typically exhibit as a Rapids movement to where the Operation beginning, completed by a Rapid Z movement to the geometry selected to define the Operation, and then a return to Rapid transit height. +

      Another common misunderstanding is that a Contour Operation is not outputting paths, when the Contour editor Operation->Cut Side is "Inside", the default, and toggling the 3D Model viability allows them to be seen. +

      +

      Can Path Workbench perform 3D surface milling?

      +

      Yes, Path provides for 3D surface milling Operations. It requires installation in the Macro file path of OpenCamLibrary--a 3rd party Open Source module. +

      OpenCamLibrary is not integrated into FreeCAD to ensure no licensing violations occur. +

      +

      What do I do if the default Operation strategies don't meet my needs?

      +

      For Pocket Operations, the Start Point defaults to XYZ = 000, and is always on, but it too can be configured in the Property view window. Pocket and Facing Operations provide explicit Climb versus Conventional Cut Mode specification in the Operation tab. +

      For Contour style Operations, the Operation tab has a "Direction" input that may be configured as CW, or CCW, which defines the cut direction. For reference: +

      +
      1. Cut Side = Outside, Cut Direction = CCW, Climb Cut
      2. +
      3. Cut Side = Outside, Cut Direction = CW, Conventional Cut
      4. +
      5. Cut Side = Inside, Cut Direction = CW, Conventional Cut
      +

      Cut Side = Inside, Cut Direction = CCW, Climb Cut +

      Start Points can be enabled--and configured in the Property view window. +

      In FaceMill Operations Material Allowance can be specified, allowing overcutting for positive values, and undercutting for negative values. +

      In Contour and Pocket Operations, the Extra Offset serves the same purpose. +

      These inputs are valuable, allowing functionality including: +

      +
      1. Defining Roughing Passes, in conjunction with the Depths input fields.
      2. +
      3. Specifying overcut for Facing operations
      4. +
      5. Features smaller than the Tool diameter, that must be faced, can benefit from specifying an Outside Contour cut with a negative Extra Offset value.
      +

      Judicious care should be exercised when specifying Material Allowances and Offsets, at the risk of undesired cuts into the Stock. +

      +

      What do I do if an Operation generates more Vertical movements than my Job can tolerate?

      +

      Operations such as 3D_Pocket, Pocket_Shape, and FaceMill, but not Contour Operations have a configuration option to keep the tool down, in the Data tab of the Property View. +

      +

      How can I leave tabs to clamp my milled work?

      +

      Path workbench provides a Tag dressup for just this purpose. +

      +

      What is a Postprocessor?

      +

      The Postprocessor is used to tailor output code to target CNC controllers for various machines, in their G-Code dialect. +

      +

      Can I modify an existing, or make my own Postprocessor?

      +

      Postprocessors are Python scripts, and are saved in the Macro file path. They are intended to be modified, or used as a template for further Postprocessor development. +

      +

      I only want to use one Postprocessor--can I make it the default, or hide other options?

      +

      Yes. +

      +

      How I can set metric/imperial units for my path object?

      +

      The 3D model units are defined in the Edit->Preferences...>General->Units tab's User System drop menu. +

      The Units setting configuring how the the target mill interprets the Job G-Code is set in the output Postprocessor, which inserts a G20, or a G21 G-Code command to indicate inches or millimeters, respectively. +

      The Postprocessor also is configured for Units/Second, or Units/Minute. If set for Units/Minute, the Path workbench internal G-Code dialect Feed rate is multiplied by 60. +

      Mismatches between the 3D model and Postprocessor settings are likely culprits for factor of 60 errors in Feed rate, and factors of 25.4 in distance. +

      +

      How I can simulate my milling strategies?

      +

      A volumetric simulator is provided to view the result of cutting the tool geometries included in the Job Operations against the Stock. +

      If the path lines obscure the simulation result, their visibility should be toggled off before simulation. +

      +

      What is the significance of the path line colors?

      +

      Path line colors are defined in the Edit->Preference...->Path->Path colors tab. +Default colors include: +

      +
      1. Green for normal paths.
      2. +
      3. Red for rapid paths.
      4. +
      5. Yellow for Probed paths.
      +

      How do I Enable/Disable visibility of path lines?

      +

      Path workbench allows control of the display of path lines by toggling the visibility of the Job by selecting it in the Combo View. The visibility of individual or groups of Operations are then toggled from the Combo View. +

      +

      How do I check that my G-Code sequence is correct?

      +

      By default, the Postprocessor output is displayed in a window before saving. This--along with the Path CAM simulator provide a means to examine the Job before processing it on a CNC machine. The G-Code inspection tool allows you to inspect the internal Path G-Code for each Operation, providing a means to trace whether the output of the Postprocessor reflects what is defined in the Operation. +

      The Operations list in the Combo View panel displays the sequence that the operations will be processed in the Job. If the Operations are correct, but not in the desired sequence, that can be adjusted by double clicking the Operations list and dragging the Operations to their proper location, or by double clicking the Job editor and selecting the Workflow tab, then using the Up/Down arrows on selected Operations to sort them. +

      +

      Why am I not getting correct G-Code output from my Postprocessor for Operations inserted using the Partial Command->Custom command?

      +

      Commonly, the Custom G-Code command because the format is always in Units/second, it can cause factor of 60 errors for CNC machine targets that operate in Units/minute. +

      +

      Why do changes to Placement values in the Property View not seem to work correctly in Path workbench?

      +

      "The Path feature also holds a Placement property. Changing the value of that placement will change the position of the Feature in the 3D view, although the Path information itself won't be modified. The transformation is purely visual. This allows you, for example, to create a Path around a face that has a particular orientation on your model, that is not the same orientation as your cutting material will have on the CNC machine. +

      However, Path Compounds can make use of the Placement of their children (see below)." +


      +[Path scripting ] +

      +

      Why does Path workbench on my computer seem to miss functionality that I see in other users forum posts?

      +

      By default, Experimental functionality is hidden in Path workbench. +

      +

      Why do Youtube videos posted by Path workbench developers appear out of synch with the Path workbench?

      +

      Path workbench shifted dramatically from FreeCAD v0.16 to v0.17, and any videos posted prior to January 1st, 2018, are very likely to contain information that is no longer in synch with v0.17 of FreeCAD Path workbench. +

      +

      Why are arcs not round, but are made of a set of straight lines?

      +

      This is only a matter of displaying the path. You can change this in the preferences: Load Path workbench. +

      +
      1. open Preferences->Path->Job Preferences
      2. +
      3. set the values for Default Geometry Tolerance and Default Curve Accuracy to small values but not to 0, e.g. to 0.01mm.
      4. +
      5. confirm the change
      6. +
      7. Restart FreeCAD.
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Path_Fixture.html b/localwiki/Path_Fixture.html new file mode 100644 index 0000000..7382df0 --- /dev/null +++ b/localwiki/Path_Fixture.html @@ -0,0 +1,75 @@ +Path Fixture

      Path Fixture

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Path Fixture.png Path Fixture

      +
      Menu location +
      Path → Partial Commands → Fixture +
      Workbenches +
      Path +
      Default shortcut +
      P,F +
      See also +
      +

      + +
      +


      +

      +

      Description

      +

      This tool sets the Work Offset Coordinate Fixture of the machine CNC controller. +

      Target Work Offset Coordinates typically include: Fixtures G53 to G59. The G-Code is simply the Fixture (G53, G54, etc...). The coordinate offset fixtures represent: +

      +
      • G53 -> Machine coordinate system.
      • +
      • G54 -> Scratchpad coordinate system.
      • +
      • G55 to G59.9 -> Coordinate fixtures allowing work offsets, relative to Homing switches located on the CNC machine, to be used.
      +

      The G59 Fixture is used to expand available fixtures. The degree of expansion implemented is CNC machine specific, and this command allows provides for G59.1 to G59.9. +

      +

      Usage

      +
      1. Press the Path Fixture.png Fixture button
      2. +
      3. Select the desired Work Offset Fixture from the drop-menu.
      +

      Properties

      +
      • DATAFixture: Sets the current fixture point
      • +
      • DATAActive: Defines if this command is active or not when inserted into a compound
      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Path_FromShapes.html b/localwiki/Path_FromShapes.html new file mode 100644 index 0000000..b1efdf7 --- /dev/null +++ b/localwiki/Path_FromShapes.html @@ -0,0 +1,82 @@ +Path FromShapes

      Path FromShapes

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Path FromShapes.png Path FromShapes

      +
      Menu location +
      Path → Partial commands → From Shape +
      Workbenches +
      Path +
      Default shortcut +
      +
      See also +
      +

      + +
      +


      +

      +

      Description

      +

      Path FromShapes dosn't match the current Path workflow. For that reason it's moved to the experimental features. +


      +This tool generates tool-paths from Path Object edges. +

      Tool-paths are uncompensated for tool radius. There is no Tool controller associated with the generated tool-paths . +

      FromShape image 0.png +

      +

      Usage

      +

      All edges associated with the 3D Model selection will be included. +

      +
      1. Select edges by selecting the entire object from the 3D view or document tree, or by selecting individual edges, or by Faces from the 3D view.
      2. +
      3. Press the Path GcodeFromShape.png From Shape button
      +

      The output tool-path is added outside the Path Job. +

      +

      Options

      +

      All Options provided are available only from the FromShape.Property.Data view, and include: +

      +
      • Retraction Axis
      • +
      • Retraction Height
      • +
      • Resume Height
      • +
      • Feed Rate
      • +
      • Feed Rate Vertical
      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Path_Helix.html b/localwiki/Path_Helix.html new file mode 100644 index 0000000..3af247d --- /dev/null +++ b/localwiki/Path_Helix.html @@ -0,0 +1,69 @@ +Path Helix

      Path Helix

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Path Helix.png Path Helix

      +
      Menu location +
      Path → Helix +
      Workbenches +
      Path +
      Default shortcut +
      +
      See also +
      +

      + +
      +


      +

      +

      Description

      +

      The Helix command appends a helical interpolation Operation to the Job. Clockwise Helix interpolation output (G2) G-Code commands. Counterclockwise output (G3) G-Code commands. Step Over percentage specifies the concentric step-over as a percentage of the Tool diameter. +

      +

      Usage

      +
      • Select the Helix tool from the Path->menu, or the GUI Button, and press.
      • +
      • Choose a Tool controller from the pop-up selection dialogue window and confirm by pressing OK.
      • +
      • All available holes in the Job Model will be available for processing, listed in the Base Geometry tab. Confirm that the list matches the holes that are intended for processing, and adjust add, enable, or disable, as necessary. Holes can be added by selecting the wall faces of the Holes.
      • +
      • Ensure the Depths, Final Depth is correct, and adjust if not.
      • +
      • Ensure the Heights, Safe and Clearance Heights are correct, and adjust if not.
      • +
      • In the Operation tab, specify the Start From, Direction, and the Step Over percentage.
      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Path_Inspect.html b/localwiki/Path_Inspect.html new file mode 100644 index 0000000..4528f09 --- /dev/null +++ b/localwiki/Path_Inspect.html @@ -0,0 +1,70 @@ +Path Inspect

      Path Inspect

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Path Inspect G-code.png Path Inspect G-code

      +
      Menu location +
      Path → Inspect G-code +
      Workbenches +
      Path +
      Default shortcut +
      +
      See also +
      +

      + +
      +


      +

      +

      Description

      +

      This tool allows inspection of the internal FreeCAD G-code dialect contents of a Path Operation object. +

      Path inspector.jpg +

      +

      Usage

      +
      1. Select a Path object
      2. +
      3. Press the Path Inspect.png Inspect G-code button
      +

      Options

      +
      • Alternatively, right-click a Path object → Inspect
      • +
      • The font and colors of the editor window follow the settings from Edit → Preferences → Editor
      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Path_Job.html b/localwiki/Path_Job.html new file mode 100644 index 0000000..b56172f --- /dev/null +++ b/localwiki/Path_Job.html @@ -0,0 +1,113 @@ +Path Job

      Path Job

      + +

      + + + + + + + + + + + + + + + + + + + +
      +

      Path Job.png Path Job

      +
      Menu location +
      Path → Job +
      Workbenches +
      Path +
      Default shortcut +
      P,F +
      See also +
      +

      + +
      +


      +

      +

      Description

      +

      The Job tool creates a new Job object in the active document. The Job object contains the following information: +

      +
      1. A list of Tool-Controller definitions, specifying the geometry, Feeds, and Speeds for the Path Operations Tools.
      2. +
      3. A Workflow sequential list of Path Operations.
      4. +
      5. A Base Body—a clone used for offset.
      6. +
      7. A Stock, representing the raw material that will be milled to Path Workbench.
      8. +
      9. A SetupSheet, containing inputs used by the Path Operations, including static values and formulas.
      10. +
      11. Configuration parameters specifying the output G-Code job's destination path, file name, and extension, and the Postprocessor—used to generate the appropriate dialect for the target CNC Controller, and customize Units, Tool Changes, Parking, etc...
      +

      Usage

      +
      1. Press the Path-Job.png Job button
      +

      The Job GUI has five horizontal aligned tabs, General, Output, Setup, Tools and Workplan. You can confirm or cancel the dialog. +

      +

      General

      +

      Job 1.jpg +

      +
      • Label: The label of the Job as displayed in the tree view.
      • +
      • Model: The Base Object which defines by its shape the paths of the job. If it is a Part Design object it is usually the Body which you select here. If you have an element selected in the tree before you click the "Add Job" icon that element is already entered here. You can change it by selecting a different element from the dropdown menue.
      • +
      • Description: You can add some notes to the job here. Notes are only for your information and have no effect on the path.
      +

      Output

      +

      Job 2.jpg +

      +
      • Output File: Set the name, extension, and the file path of the G-Code output. You can use the following placeholders: +
        •  %D directory of the active document
        • +
        •  %d name of the active document (without extension)
        • +
        •  %M user macro directory
        • +
        •  %j name of the job
      +
      • Processor: Select the postprocesser for your machine.
      • +
      • Arguments: Add arguments for the postprocessor as needed.
      +

      Setup

      +

      Job 3.jpg +

      +
      • Stock: set the size and shape of the raw material.
      • +
      • Orientation: Selected Edge or Face is used to orient Base or Stock accordingly.
      • +
      • Alignment: select a Vertex to set origin or move Base or Stock
      +


      +

      +

      Tools

      +

      Job 4.jpg +

      Add the tool(s) from your Tooltable which you need for the operations at this job. +

      After adding a tool, you can set/change the feedrate and spindle speed if you need a different feedrate in this job. +A change here dosn't change the parameters stored in the tooltable. +

      The default tool you can delete if you have a own tool added. +

      +

      Workplan

      +

      Job 5.jpg +

      If you have a job which contends more than one path operation, you can determine in which order the operations should be done. +To reorder, select a operation an push the up or down button. +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Path_MillFace.html b/localwiki/Path_MillFace.html new file mode 100644 index 0000000..73a82ba --- /dev/null +++ b/localwiki/Path_MillFace.html @@ -0,0 +1,62 @@ +Path MillFace

      Path MillFace

      + +
      +

      This documentation is not finished. Please help and contribute documentation. +

      See Draft ShapeString for good documented Command. Gui Command gives an overview over commands. And see List of Commands for other commands. +

      Go to Help FreeCAD to contribute. +

      +
      + + + + + + + + + + + + + + + + + + + + +
      +

      Path-Face.png Path-Face

      +
      Menu location +
      Path → Face +
      Workbenches +
      Path +
      Default shortcut +
      None +
      See also +
      +

      Contents

      + +
      + +
      +


      +

      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Path_NewTool.html b/localwiki/Path_NewTool.html new file mode 100644 index 0000000..5bb3bbb --- /dev/null +++ b/localwiki/Path_NewTool.html @@ -0,0 +1,36 @@ +Path NewTool

      Path NewTool

      + +

      New tools are added to the Edit Tools Table to represent the available tools on the CNC machine. +

      +

      Adding Tools

      +

      Path-EditTool-Dialog.PNG +

      +

      Tool Types

      +
      • Drill
      • +
      • Centerdrill
      • +
      • Countersink
      • +
      • Counterbore
      • +
      • Reamer
      • +
      • Tap
      • +
      • Endmill
      • +
      • Slotcutter
      • +
      • Ball Endmill
      • +
      • Chamfer Mill
      • +
      • Corner Round Endmill
      • +
      • Engraver
      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Path_Pocket_3D.html b/localwiki/Path_Pocket_3D.html new file mode 100644 index 0000000..d59de24 --- /dev/null +++ b/localwiki/Path_Pocket_3D.html @@ -0,0 +1,71 @@ +Path Pocket 3D

      Path Pocket 3D

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Path 3DPocket.png Path 3DPocket

      +
      Menu location +
      Path → 3D Pocket +
      Workbenches +
      Path +
      Default shortcut +
      +
      See also +
      +

      + +
      +


      +

      +

      Description

      +

      This tool creates a new 3D Pocket Operation. A 3D pocket takes into account the bottom surface of the pocket +


      +

      +

      Usage

      +
      1. Select the bottom of the pocket you want to mill
      2. +
      3. Press the Path-3DPocket.png 3D Pocket button
      4. +
      5. Select the tool controller you want to use
      6. +
      7. Adjust the desired properties
      8. +
      9. Apply
      +

      Properties

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Path_Pocket_Shape.html b/localwiki/Path_Pocket_Shape.html new file mode 100644 index 0000000..d6b09b5 --- /dev/null +++ b/localwiki/Path_Pocket_Shape.html @@ -0,0 +1,97 @@ +Path Pocket Shape

      Path Pocket Shape

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Path Pocket.png Path Pocket

      +
      Menu location +
      Path → Pocket Shape +
      Workbenches +
      Path +
      Default shortcut +
      P,O +
      See also +
      +

      + +
      +


      +

      +

      Description

      +

      This tool creates a pocketing operation from selected bottom faces or walls of one ore more pockets of the jobs base object. +

      The Path Pocket object is made to be part of a Path Job. +

      Path Pocket Shape.png +

      +

      Usage

      +
      1. Select the bottom or the wall(s) of a pocket. While it is usually easier to select the bottom, the walls have to be selected when a pocket goes through all.
      2. +
      3. Press the Path Pocket.png Pocket Shape button
      4. +
      5. Adjust the desired properties
      +

      Properties

      +

      Base Geometry

      +
      • Add, if not allready done, the elements which should be the base for the path +
        • you can also delete or change to other elements
      +

      Depth

      +
      • DATAStart Depth: Starting Depth of Tool- starting depth in Z
      • +
      • DATAFinal Depth: Final Depth of Tool- lowest cutting level in Z
      • +
      • DATAFinish Depth: The hight of the last cutting level- set for a better finish
      • +
      • DATAStep Down: Step Down of Tool- the amount of material which will be removed at once
      +

      Height

      +
      • DATASafe Height: The hight above the workpeace where rapid motions are allowed.
      • +
      • DATAClearance Height: The height needed to clear clamps and obstructions
      +

      Operation

      +
      • DATATool Controller: Defines the Tool controller used in the Operation
      • +
      • DATACut Mode: Specifies a CW or CCW move for the cut
      • +
      • DATAPattern: Select on which manner the horizontal movements should be done
      • +
      • DATAAngle: Select the path angle relativ to x axis
      • +
      • DATAStep Over Percent: Select the horizontal step over- 100% = tool diameter
      • +
      • DATAPass Extension:
      +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Path_Pocket_Shape.png b/localwiki/Path_Pocket_Shape.png new file mode 100644 index 0000000..28d0b34 Binary files /dev/null and b/localwiki/Path_Pocket_Shape.png differ diff --git a/localwiki/Path_Post.html b/localwiki/Path_Post.html new file mode 100644 index 0000000..65177d6 --- /dev/null +++ b/localwiki/Path_Post.html @@ -0,0 +1,138 @@ +Path Post

      Path Post

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Path PostProcess.png Path PostProcess

      +
      Menu location +
      Path → Post Process +
      Workbenches +
      Path +
      Default shortcut +
      P,P +
      See also +
      +

      + +
      +


      +

      +

      Description

      +

      This command exports the selected Job to a G-code file. +

      Each CNC Controller speaks a specific G-Code dialect, requiring a Dialect-correct Postprocessor to translate the final output from the agnostic internal FreeCAD G-Code dialect. +

      Typical functions of the Postprocessor include: +

      +
      • Using a correct Job output G-Code file extension.
      • +
      • Selecting the G-Code commands. CNC controllers typically support a subset of available G-Code commands. The super-set of G-Code commands contains powerful and specialized commands that otherwise must be processed using multiple simpler commands. Postprocessors are written to select the best G-Code for an Operation, available on the target.
      • +
      • Formatting the G-Code syntax by reordering the Feed, X, Y, Z, A, and B inputs, and the precision.
      • +
      • Inserting a Pre-amble to set units, units format, Work plane, coordinate system, etc...
      • +
      • Inserting a Post-amble to park the machine, stop it, process any arguments.
      • +
      • Inserting Tool changes, or suppressing them between subsequent operations using the same tool.
      • +
      • Formatting the Feed and Speed rate information to revolutions per minute, or per second.
      • +
      • Formatting Function Call Naming and Calling.
      +

      Several provided Postprocessors generate suitable code for many CNC controllers, or can be used as templates for modification +

      Postprocessors contain configuration flags and are designed to be tuned by adding G-Codes and M-Codes to provided definitions for: +

      +
      • Machine initialization
      • +
      • Job finalization
      • +
      • Tool-Changes
      • +
      • Cooling on /off
      • +
      • Etc...
      +


      +Postprocessors use the [Path Job Operations FreeCAD G-Code dialect ], in conjunction with the Postprocessor configuration definitions, to generate Dialect-Correct G-Code for target machines. This allows the Path workbench to generate correct G-Code to target various CNC machine controllers by invoking different Postprocessors. +

      CNC Machine Controller types include: +

      +
      • CNC mills
      • +
      • CNC lathes
      • +
      • 3D Printers
      • +
      • DragKnife Cutters
      • +
      • Laser Cutters
      • +
      • Engravers
      • +
      • Plasma Torch Cutters
      • +
      • Wire Benders
      • +
      • EDM Cutters
      • +
      • Etc...
      +

      If only one CNC machine is used, or if all CNC machines share a common Postprocesor, the Path workbench would need to include only a single Postprocessor. If a single Postprocessor is inadequate to output G-Code for all target CNC controllers, then multiple Postprocessors must be installed. +

      +

      Usage

      +
      1. Select the Job you wish to export
      2. +
      3. Press the Path PostProcess.png Post Process button
      4. +
      5. Confirm the Output File name and directory
      +

      Options

      +

      Output file and Postprocessor properties can be set in the Job, at any time, prior to invoking the Postprocessor. +


      +The provided Postprocessors are written with comments indicating areas containing Flags, Configuration Variables, and Sections of G-Codes and M-Codes that are to be used by the Postprocessor to configure the output. +

      Typical Configuration True/False Flags include: +

      +
      • OUTPUT_COMMENTS (True = Allow, False = Suppress), Used to insert Text Comments in the output G-Code file.
      • +
      • OUTPUT_HEADER (True = Allow, False = Suppress), Used to insert Text Headers in the output G-Code file.
      • +
      • OUTPUT_LINE_NUMBERS (True = Allow, False = Suppress), Used to insert Line Numbers in the output G-Code file.
      • +
      • SHOW_EDITOR (True = Allow, False = Suppress), Used to show the output G-Code in a Pop-up window when invoking the Postprocessor.
      • +
      • MODAL (True = Allow, False = Suppress), Used to reduce the number of output G-Code lines by stripping Mode information when the Mode is not changing.
      +

      Typical Configuration Variables include: +

      +
      • LINENR (Line Number), Used to Set the Line Number index.
      • +
      • UNITS (G20 or G21), Used to explicitly communicate to the target CNC controller what Units to use to interpret the final output file.
      • +
      • MACHINE_NAME (Name of Target CNC Mill), Used to Insert a machine name label in the final output file.
      • +
      • PRECISION, Used to Set the number of digits to include after the decimal place in final output file
      +

      Typical Configuration Sections include: +

      +
      • PREAMBLE (Code configuration inserted at beginning of the Job)
      • +
      • POSTAMBLE (Code configuration appended to the Job, providing for parking the machine, etc...)
      • +
      • TOOL_CHANGE (Code inserted with each tool change in the Job)
      +

      The Edit->Preferences...->Path->Job Preferences tab, Defaults->Path is used to set the default Postprocessor selected on Job creation. This allows Path workbench to be configured to only display desired Postprocessors, and to set a default. +

      Included Postprocessors are saved in the FreeCAD.Mod.Path.Pathscripts.Post by default: +

      +
      • centroid
      • +
      • comparams
      • +
      • dynapath
      • +
      • grbl
      • +
      • linuxcnc
      • +
      • opensbp
      • +
      • phillips
      • +
      • rml
      • +
      • smoothie
      +


      +Do not use the File->Export menu for export to G-code, it will produce damaged G-code! +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Path_Postprocessor_Customization.html b/localwiki/Path_Postprocessor_Customization.html new file mode 100644 index 0000000..fc0c348 --- /dev/null +++ b/localwiki/Path_Postprocessor_Customization.html @@ -0,0 +1,70 @@ +Path Postprocessor Customization

      Path Postprocessor Customization

      + +
      + + + + + + + + + + + + + + + + + + + + + + + + + + + +
      +

      Base ExampleCommandModel.png Tutorial

      +
      Topic +
      Path Workbench +
      Level +
      +
      Time to complete +
      +
      Author +
      +
      FreeCAD version +
      +
      Example File(s) +
      +

      Contents

      + +
      + +
      +


      +

      Just a page stub for now. +

      This page should mention: +

      Post processor naming requirements ie: <somename>_post.py +

      Post Processor location - Where do posts have to live to be seen in the GUI. +

      + + +
      + +
      +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Path_Preferences.html b/localwiki/Path_Preferences.html new file mode 100644 index 0000000..9300a61 --- /dev/null +++ b/localwiki/Path_Preferences.html @@ -0,0 +1,54 @@ +Path Preferences

      Path Preferences

      + +

      The preferences screen of the Path are found in the Preferences window (Menu Edit → Preferences → Path). +

      + + +

      Job preferences

      +

      Job preferences → General

      +

      Preference Path Tab 01 1.png +

      +
      +

      Job preferences → Post processor

      +

      Preference Path Tab 01 2.png +

      +
      +

      Job preferences → Setup

      +

      Preference Path Tab 01 3.png +

      +
      +

      Dressups

      +

      Preference Path Tab 02.png +

      +
      +

      Path colors

      +

      Preference Path Tab 03.png +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Path_Profile.html b/localwiki/Path_Profile.html new file mode 100644 index 0000000..1628297 --- /dev/null +++ b/localwiki/Path_Profile.html @@ -0,0 +1,115 @@ +Path Profile

      Path Profile

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Path Profile.png Path Profile

      +
      Menu location +
      Path → New Operation → Profile +
      Workbenches +
      Path +
      Default shortcut +
      P,P +
      See also +
      +

      + +
      +


      +

      +

      Description

      +

      The Contour tool creates a simple external contour cut of complex 3D Part-based objects. The entire Job Model serves as the input for the Operation--regardless of whether any Body Geometry is selected when the Contour command is invoked. A Start point can be enabled from the Operation editor, using a location defined in the Property view->Start Points. +

      Path profile example.jpg +

      +

      Usage

      +
      1. Select a face on a Part-based object. Alternatively, also select a starting edge on that face.
      2. +
      3. Press the Path Profile.png Profile button
      4. +
      5. Adjust the desired properties
      +

      Options

      +
      • The Path Profile object is made to be part of a Path Job. To correctly configure the profiling, a tool table must be present in the project's machine object, and a Tool Change command must be placed before the profile.
      +

      Properties

      +
      • DATAActive: Make False, to prevent operation from generating code
      • +
      • DATAUse Placements: make True, if using the profile operation placement properties to transform toolpath in post processor
      • +
      • DATATool Controller: The Tool controller specifies the index of the Tool to use
      +

      Depth Properties

      +
      • DATAStart Depth: Starting Depth of Tool- first cut depth in Z
      • +
      • DATAFinal Depth: Final Depth of Tool- lowest value in Z
      • +
      • DATAStep Down: Incremental Step Down of Tool
      +


      +

      +

      Height Properties

      +
      • DATASafe Height: The above which Rapid motions are allowed.
      • +
      • DATAClearance Height: The height needed to clear clamps and obstructions
      +


      +


      +

      +

      Operation Properties

      +
      • DATATool Controller: Defines the Tool controller used in the Operation
      • +
      • DATADirection: Specifies a CW or CCW path for the External contour cut
      • +
      • DATAUse Start Point: make True, if manually specifying a Start Point, then enter Start Points in the Property data Start Points field
      +

      Start Point Properties

      +
      • DATAStart Point: The start point of this path
      • +
      • DATAUse Start Point: make True, if specifying a Start Point
      • +
      • DATAExtend At Start: extra length of tool path before start of part edge
      • +
      • DATALeadIn Line Len: length of straight segment of toolpath that comes in at angle to first part edge
      +

      End Point Properties

      +
      • DATAUse End Point: make True, if specifying an End Point
      • +
      • DATAExtend At End: extra length of tool path after end of part edge
      • +
      • DATALeadOut LineLen: length of straight segment of toolpath that comes in at angle to last part edge
      • +
      • DATAEnd Point: The end point of this path
      +

      Profile Properties

      +
      • DATASide: Side of edge that tool should cut
      • +
      • DATADirection: The direction that the toolpath should go around the part ClockWise CW or CounterClockWise CCW
      • +
      • DATAOffsetExtra: Extra value to stay away from final profile- good for roughing toolpath
      • +
      • DATASegLen: Tesselation value for tool paths made from beziers, bsplines, and ellipses
      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Path_ProfileEdges.html b/localwiki/Path_ProfileEdges.html new file mode 100644 index 0000000..c430716 --- /dev/null +++ b/localwiki/Path_ProfileEdges.html @@ -0,0 +1,100 @@ +Path ProfileEdges

      Path ProfileEdges

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Path Profile Edges.png Path Profile Edges

      +
      Menu location +
      Path → Edge Profile +
      Workbenches +
      Path +
      Default shortcut +
      None +
      See also +
      +

      + +
      +


      +

      +

      Description

      +

      The Path ProfileEdges tool creates a simple contour path from selected edges. A Start point can be enabled from the Operation editor, using a location defined in the Property view->Start Points. +

      The Path ProfileEdge object is made to be part of a Path Job. +

      Path Profile by Edges.png +

      +

      Usage

      +
      1. Select a complete loop of edges
      2. +
      3. Press the Path-Profile-Edges.png Edge Profile button
      4. +
      5. Adjust the desired properties
      +


      +! Path ProfileEdge don't take care of other details of the object. You have to adjust the properties, especially the final depht, carefully, a mistake will destroy your workpeace +


      +

      +

      Properties

      +

      Base Geometry

      +
      • Add, if not allready done, the elements which should be the base for the path +
        • you can also delete or change to other elements
      +

      Depth

      +
      • DATAStart Depth: Starting Depth of Tool- starting depth in Z
      • +
      • DATAFinal Depth: Final Depth of Tool- lowest cutting level in Z
      • +
      • DATAStep Down: Step Down of Tool- the amount of material which will be removed at once
      +

      Height

      +
      • DATASafe Height: The hight above the workpeace where rapid motions are allowed.
      • +
      • DATAClearance Height: The height needed to clear clamps and obstructions
      +

      Operation

      +
      • DATATool Controller: Defines the Tool controller used in the Operation
      • +
      • DATACut Side: Defines on which side the cut should be done
      • +
      • DATADirection: Specifies a CW or CCW move for the cut
      • +
      • DATAExtra Offset: Addet to the tool diameter to leave some material for a finish path
      • +
      • DATAUse Start Point: Set the start point of the path manualy (not implemented jet)
      • +
      • DATAUse Compensation: Creates a path with offset of the tool radius to respect the parts dimensions
      +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Path_ProfileFace.html b/localwiki/Path_ProfileFace.html new file mode 100644 index 0000000..630ac4e --- /dev/null +++ b/localwiki/Path_ProfileFace.html @@ -0,0 +1,100 @@ +Path ProfileFace

      Path ProfileFace

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Path Profile Face.png Path Profile Face

      +
      Menu location +
      Path → Face Profile +
      Workbenches +
      Path +
      Default shortcut +
      None +
      See also +
      +

      + +
      +


      +

      +

      Description

      +

      The Path ProfileFace tool creates a simple contour path from one ore more selected faces of an object. A Start point can be enabled from the Operation editor, using a location defined in the Property view->Start Points. +

      The Path ProfileFace object is made to be part of a Path Job. +

      Path Profile by Faces.png +

      +

      Usage

      +
      1. Select the surface or surfaces you want to mill out
      2. +
      3. Press the Path-Profile-Face.png Face Profile button
      4. +
      5. Adjust the desired properties
      +


      +! Path ProfifileFace don't take care of other details of the object. You have to adjust the properties, especially the final depht, carefully, a mistake will destroy your workpeace +


      +

      +

      Properties

      +

      Base Geometry

      +
      • Add, if not allready done, the elements which should be the base for the path +
        • you can also delete or change to other elements
      +

      Depth

      +
      • DATAStart Depth: Starting Depth of Tool- starting depth in Z
      • +
      • DATAFinal Depth: Final Depth of Tool- lowest cutting level in Z
      • +
      • DATAStep Down: Step Down of Tool- the amount of material which will be removed at once
      +

      Height

      +
      • DATASafe Height: The hight above the workpeace where rapid motions are allowed.
      • +
      • DATAClearance Height: The height needed to clear clamps and obstructions
      +

      Operation

      +
      • DATATool Controller: Defines the Tool controller used in the Operation
      • +
      • DATACut Side: Defines on which side the cut should be done
      • +
      • DATADirection: Specifies a CW or CCW move for the cut
      • +
      • DATAExtra Offset: Addet to the tool diameter to leave some material for a finish path
      • +
      • DATAUse Start Point: Set the start point of the path manualy (not implemented jet)
      • +
      • DATAUse Compensation: Creates a path with offset of the tool radius to respect the parts dimensions
      +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Path_Profile_by_Edges.png b/localwiki/Path_Profile_by_Edges.png new file mode 100644 index 0000000..de81bd5 Binary files /dev/null and b/localwiki/Path_Profile_by_Edges.png differ diff --git a/localwiki/Path_Profile_by_Faces.png b/localwiki/Path_Profile_by_Faces.png new file mode 100644 index 0000000..a88b381 Binary files /dev/null and b/localwiki/Path_Profile_by_Faces.png differ diff --git a/localwiki/Path_Sanity.html b/localwiki/Path_Sanity.html new file mode 100644 index 0000000..de99c99 --- /dev/null +++ b/localwiki/Path_Sanity.html @@ -0,0 +1,19 @@ +Path Sanity

      Path Sanity

      + +
      This is an unfinished experimental feature. Enable Experimental Features
      +


      +Path Sanity documentation goes here +

      + + +
      + +
      +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Path_SelectLoop.html b/localwiki/Path_SelectLoop.html new file mode 100644 index 0000000..4ec08f2 --- /dev/null +++ b/localwiki/Path_SelectLoop.html @@ -0,0 +1,67 @@ +Path SelectLoop

      Path SelectLoop

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Path SelectLoop.png Path SelectLoop

      +
      Menu location +
      Path → Finish Selecting Loop +
      Workbenches +
      Path +
      Default shortcut +
      P,L +
      See also +
      +

      + +
      +


      +

      +

      Description

      +

      The SelectLoop command completes a selection of edges that form a loop. +

      +

      Usage

      +

      To use: select two edges that share a common vertex. Then execute the command. The remaining edges that form the loop will be automatically selected. This function is very useful in other workbenches to. +

      +

      Options

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Path_SetupSheet.html b/localwiki/Path_SetupSheet.html new file mode 100644 index 0000000..a57af34 --- /dev/null +++ b/localwiki/Path_SetupSheet.html @@ -0,0 +1,52 @@ +Path SetupSheet

      Path SetupSheet

      + +

      Description

      +

      Using a SetupSheet allows the user to customize how the various property values for operations will be calculated. The user always has the option to override the SetupSheet values with an explicit value or change the way SetupSheet values are calculated. +

      Since SetupSheets are part of the Path Job, values do not changes the default behavior of Path. Rather, they change only the behaviour within the context of the current job. +

      SetupSheets are particularly useful when saved with a Job Template. +

      +

      Properties

      +
      • DATAVertRapid: Sets the Vertical Rapid Rate in new Tool Controllers. (Used in post processors that support customizable Rapid rates)
      • +
      • DATAHorizRapid: Sets the Horizontal Rapid Rate in new Tool Controllers. (Used in post processors that support customizable Rapid rates)
      • +
      • DATASafeHeightOffset: The usage of this field depends on SafeHeightExpression (see below)
      • +
      • DATA SafeHeightExpression: The result of this expression will be used to set the Safe Height of operations.
      • +
      • DATAClearanceHeightOffset: The usage of this field depends on ClearanceHeightExpression (see below)
      • +
      • DATAClearanceHeightExpression: The result of this expression will be used to set the Clearance Height of operations.
      • +
      • DATAStartDepthExpression: The result of this expression will be used to set the StartDepth property of operations.
      • +
      • DATA FinalDepthExpression: The result of this expression will be used to set the FinalDepth property of operations.
      • +
      • DATAStepDownExpression: The result of this expression will be used to set the StepDown property of operations.
      +
        1. Operation Parameters
      +

      The following are pulled from +OpFinalDepth - The value of the FinalDepth property +OpStartDepth - The value of the FinalDepth property +OpToolDiameter - The value of the Tool Diameter property of the Tool Controller referenced by the operation. +


      +SetupSheet Values +

      Other values in the SetupSheet can be referenced directly: +

      +
      • SetupSheet.ClearanceHeightOffset
      • +
      • SetupSheet.SafeHeightOffset
      +
      • StartDepth
      • +
      • SafeHeightOffset
      • +
      • SafeHeightExpression
      • +
      • ClearanceHeightOffset
      • +
      • ClearanceHeightExpression
      • +
      • StartDepthExpression
      • +
      • FinalDepthExpression
      • +
      • StepDownExpression
      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Path_SimpleCopy.html b/localwiki/Path_SimpleCopy.html new file mode 100644 index 0000000..3f38535 --- /dev/null +++ b/localwiki/Path_SimpleCopy.html @@ -0,0 +1,68 @@ +Path SimpleCopy

      Path SimpleCopy

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Path SimpleCopy.png Path SimpleCopy

      +
      Menu location +
      Path → Path Modification → Simple Copy +
      Workbenches +
      Path +
      Default shortcut +
      +
      See also +
      +

      + +
      +


      +

      +

      Description

      +

      This tool creates a non-parametric copy of a given path. +

      +

      Usage

      +
      1. Select one Path object
      2. +
      3. Press the Path SimpleCopy.png Simple Copy button
      +

      Options

      +
      • The simple copy is not bound anymore to the path that was used to make the copy, and is not parametric. Therefore, when edited with the Path Inspect tool, any change made to its G-code will be retained.
      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Path_Simulator.html b/localwiki/Path_Simulator.html new file mode 100644 index 0000000..48fa51c --- /dev/null +++ b/localwiki/Path_Simulator.html @@ -0,0 +1,81 @@ +Path Simulator

      Path Simulator

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Path Simulator.png Path Simulator

      +
      Menu location +
      Path → CAM Simulator +
      Workbenches +
      Path +
      Default shortcut +
      None +
      See also +
      Path Inspect +

      + +
      +


      +

      +

      Description

      +

      This tool allows Simulation of the Path Job by sweeping 3D Models of the Tools used in each Operation, along the G-Code paths, subtracting material from the Stock, where the stock and tool overlap, providing visualization of the Job. This allows detection and isolation of errors prior to running the Job on a mill. +

      Path-Simulation.gif +

      +

      Usage

      +
      1. Press the Path Simulator.png CAM Simulator button
      2. +
      3. De-select any Operations that are not to be simulated
      4. +
      5. Tune the Speed and Accuracy settings.
      6. +
      7. Select the Job for simulation from the drop menu.
      8. +
      9. Press Play button to or play back an animation of the operations.
        Press the Fast Forward button to make it really fast even for complicated paths.
      10. +
      11. Pause, and Single-Step functionality is provided for resolving specific cuts or movements.
      12. +
      13. Clicking the Cancel button will remove the stock created for the simulation. If you click Ok this object will be kept in your Job.
      +

      Properties

      +
      1. need usage
      +
      • DATAPlayback Speed: The speed of the simulation playback, in G-Code lines/second
      • +
      • DATAAccuracy: The accuracy of the simulation expressed as a percentage indicating the simulations deviation from the Job. For interactive simulation, reducing accuracy to 0.3 works much faster.
      • +
      • DATAJob: The Job used as the basis of the simulation
      • +
      • DATAOperation List: The list of Operations selected for inclusion in the simulation.
      +


      +

      +
      • need options
      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Path_Stop.html b/localwiki/Path_Stop.html new file mode 100644 index 0000000..e179a6f --- /dev/null +++ b/localwiki/Path_Stop.html @@ -0,0 +1,68 @@ +Path Stop

      Path Stop

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Path Stop.png Path Stop

      +
      Menu location +
      Path → Partial Commands → Stop +
      Workbenches +
      Path +
      Default shortcut +
      +
      See also +
      +

      + +
      +


      +

      +

      Description

      +

      This tool inserts a Stop command (M1). This command will Pause a running program on the CNC controller, waiting for user interaction to continue. +

      Note this does not stop the spindle. +

      +

      Usage

      +
      1. Press the Path Stop.png Stop button
      +

      Properties

      +
      • DATAStop: Defines if the Stop is optional or mandatory.
      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Path_Surface.html b/localwiki/Path_Surface.html new file mode 100644 index 0000000..ffc28a8 --- /dev/null +++ b/localwiki/Path_Surface.html @@ -0,0 +1,20 @@ +Path Surface

      Path Surface

      + +
      This is an unfinished experimental feature. Enable Experimental Features
      +


      +

      information about installing opencamlib +

      information about the path surface operation +

      + + +
      + +
      +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Path_ToolLibraryEdit.html b/localwiki/Path_ToolLibraryEdit.html new file mode 100644 index 0000000..ac439dd --- /dev/null +++ b/localwiki/Path_ToolLibraryEdit.html @@ -0,0 +1,86 @@ +Path ToolLibraryEdit

      Path ToolLibraryEdit

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Path ToolLibraryEdit.png Path ToolLibraryEdit

      +
      Menu location +
      Path → Tool Manager +
      Workbenches +
      Path +
      Default shortcut +
      P,T +
      See also +
      +

      + +
      +


      +


      +

      +

      Description

      +

      The tooltable editor allows to edit the different tools of the tooltable contained in the machine object of a Path Job. This tooltable is used by the different operations contained in the project to obtain necessary informations about the current tool. +

      It serves for the selection of a tool which you want to use in your job as well. +

      Path-Tooltable.png +

      The handling is straight forward: +

      +
      • Import...: Imports a tooltable from an XML-file.
        Warning
      +

      This is currently partly broken and does not work if you have never had an xml file before. +

      +
      +
      • Export...: Exports the tooltable to an XML-file.
      • +
      • New Tool: opens a dialog where you can enter the parameters of your tool. See Path NewTool
      • +
      • Delete: deletes the currently selected lines.
        Warning
      +

      The tools are deleted from your tooltable even if you cancel the dialog +

      +
      +
      • Move up: You cannot edit the tool number, instead you can move the selected line up to decrease it's tool number
      • +
      • Move down: You can move the selected line down to increase it's tool number
      +
      • Create Tool Controller(s): If you check one or more of the checkboxes to the left in the tools list, this button becomes active. If you click it, the selected tools will be inserted in your current job.
      +

      Usage

      +
      1. Select a Path Job
      2. +
      3. Press the Path ToolLibraryEdit.png Tool Manager button
      4. +
      5. Create new tools or adjust the properties of existing tools.
        Set at least the diameter, FreeCAD needs it to calculate the radius compensation. As of version 0.17 this is the only value used for path creation. However, if you wish to use the simulation tool later, add cutting edge angle and cutting edge height as well.
        Path-ToolAdd.gif
      +

      Options

      +
      • The tools can be reordered by using the move up/move down buttons
      • +
      • Complete tooltables can be imported from xml files (FreeCAD's own tooltable format) or from HeeksCAD tooltables
      + + + + + + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Path_ToolNumberToLoad.html b/localwiki/Path_ToolNumberToLoad.html new file mode 100644 index 0000000..8357b71 --- /dev/null +++ b/localwiki/Path_ToolNumberToLoad.html @@ -0,0 +1,70 @@ +Path ToolNumberToLoad

      Path ToolNumberToLoad

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Path ToolNumberToLoad.png Path ToolNumberToLoad

      +
      Menu location +
      Path → Partial Commands → Tool number to load +
      Workbenches +
      Path +
      Default shortcut +
      +
      See also +
      +

      + +
      +


      +

      +

      Description

      +

      This command allows to change the tool number to be used by next operations +

      +

      Usage

      +
      1. Press the Path ToolNumberToLoad.png Tool number to load button
      2. +
      3. Set the desired values in the properties
      +

      Properties

      +
      • DATATool number: Sets the current tool
      • +
      • DATASpindle direction: Defines the rotation direction of the spindle
      • +
      • DATASpindle speed: Defines the speed of the spindle in rotations per minute
      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Path_Walkthrough_for_the_Impatient.html b/localwiki/Path_Walkthrough_for_the_Impatient.html new file mode 100644 index 0000000..a3ee0a4 --- /dev/null +++ b/localwiki/Path_Walkthrough_for_the_Impatient.html @@ -0,0 +1,143 @@ +Path Walkthrough for the Impatient

      Path Walkthrough for the Impatient

      + +
      + + + + + + + + + + + + + + + + + + + + + + + + + + + +
      +

      Base ExampleCommandModel.png Tutorial

      +
      Topic +
      Path Workbench +
      Level +
      +
      Time to complete +
      +
      Author +
      Chrisb +
      FreeCAD version +
      +
      Example File(s) +
      +

      + +
      +


      +

      Here is a demonstration showing the creation of a Path WB Job from a 3D Model, generating dialect-correct G-Code for a target CNC mill. +

      +

      The 3D Model

      +

      The Project begins with a simple FreeCAD model: a cube with a rectangular pocket, +

      Path-SquarePocketModel.png +

      created in the Part Design including a Body, a Box with a Pocket, based on a Sketch oriented in the XY plane. +

      With the 3D Model completed, the Path Workbench is selected. +

      +

      The Job

      +

      The Path-Job.png Job is created. +

      In the Job creation dialog click OK to accept the Body as the Base Model, with no Template. +

      +

      Job Setup

      +

      Path-JobCreationDialog.png +

      The Job Edit window opens in the Task window, and the model view Window shows the Stock as a wire frame cube surrounding the Base Body. The Setup Tab is selected. +

      +

      Job Output

      +

      The Output tab defines the output file path, name, and extension, and the Postprocessor. For advanced users, Post Processor Arguments can be defined—the mouse over hints show common arguments. +

      Path-JobOutput.png +


      +

      +

      Job Tools

      +

      Path-JobTools.png +

      We modify the Default tool by selecting it and clicking the Edit button. This opens the Tool Controller edit window. +

      Path-ToolConfig.gif +

      The name given to the tool and the tool number correspond with the tool number of the machine. Here it is tool Nr. 4. The tool controller is configured for horizontal and vertical feed rates of 2mm/s and a spindle speed of 2000 rpm. +

      Select the Tool subpanel of the tool controller. Set the diameter and - if you wish to use the simulation tool later - add a cutting edge angle and cutting edge height. +

      Path-ToolAdd.gif +

      The values are confirmed with OK. +

      For easy access all the tools can be predefined and selected from the Tool manager. +

      +

      Job Workplan

      +

      The Workplan tab begins empty, and is populated by the sequence of Job Operations, Partial Path Commands, and Path Dressups. The sequence of these items is ordered here. +


      +This tree is shown after the Job's configuration once the Path Job is unfolded: +

      Path-TreeWithJob.png +

      +

      The Path Operations

      +

      Two operations will be added to generate milling paths for this Path Job. The Contour operation creates a path around the box and the Pocket operation creates a path for the inner pocket. +

      For now we will keep it simple. The Path Profile.png Contour button opens the Contour panel. After confirming with OK using the default values, see the green path around the object is visible. +

      Selecting the bottom of the pocket and then the Path Pocket.png Pocket button opens the Pocket Shape window. The default values for Base Geometry, Depths, and Heights are used, and the Operation subpanel is selected, and the Step Over Percent is set at 50. +

      Path-PocketOperation.gif +

      The pattern is changed to "Offset" and the Job Operation is confirmed for the pocket configuration with OK. +

      The result is a model with two paths: +

      Path-WalkThroughResult.gif +

      +

      Verifying Paths

      +

      There are two ways to verify the created paths. The G-Code can be inspected, including highlighting the corresponding path segments. The milling process of the Path Job can also be simulated to demonstrate the idealized tool paths, required for the Tool geometries to mill the Stock. +

      To inspect the G-Code use the Path Inspect.png tool. Selecting the corresponding G-Code lines within the G-Code Inspection window highlights individual path segments. +

      Path-InspectWindow.gif +

      To start the simulation use the Path Simulator.png Path Simulator tool. +

      Adjust speed and accuracy and start the simulation with the play button. +

      Path-Simulation.gif +

      If you want to end the simulation click the Cancel button, it will remove the stock created for the simulation. If you click Ok this object will be kept in your Job. +

      +

      Postprocess the Job

      +

      The final step to generate G-Code for the target mill is to postprocess the Job. This outputs the G-Codes to a file that can be uploaded to the target CNC machine controller. To invoke the Postprocessor: +

      +
      • Select the Job object in the tree
      • +
      • Select the Path Postprocessing Path PostProcess.png tool to postprocess the file. This opens a G-Code window allowing inspection of the final output file before it is saved.
      +

      Path-PostOutput.gif +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Path_Workbench.html b/localwiki/Path_Workbench.html new file mode 100644 index 0000000..18afbda --- /dev/null +++ b/localwiki/Path_Workbench.html @@ -0,0 +1,146 @@ +Path Workbench

      Path Workbench

      + +
      + +

      Introduction

      +

      The Path workbench is used to produce machine instructions for CNC machines from a FreeCAD 3D model. These produce real-world 3D objects on CNC machines such as mills, lathes, lasercutters, or similar. Typically, instructions are a G-Code dialect. +


      +

      +
      Pathwb.png
      +


      +The FreeCAD Path Workbench workflow creates these machine instructions as follows: +

      +
      • A 3D model is the base object, typically created using one or more of the Part Design, Part or Draft Workbenches.
      • +
      • A Job is created in Path Workbench. This contains all the information required to generate the necessary G-Code to process the Job on a CNC mill: there is Stock material, the mill has a certain set of tools and it follows certain commands controlling speed and movements (usually G-Code).
      • +
      • Tools are selected as required by the Job Operations.
      • +
      • Milling paths are created using e.g. Contour and Pocket Operations. These Path objects use internal FreeCAD G-Code dialect, independent of the CNC machine.
      • +
      • Export the job with a g-code, matching to your machine.
      +


      +

      +

      Links for the impatient

      +

      Depending on your interest in the Path workbench there are different topics for further reading: +

      +
      • If you are a new new user trying to get familiar with Path, you might be interested in a fast walk-through tutorial.
      • +
      • If you have a special machine which cannot use one of the available postprocessors you may want to learn about post-processor customization
      • +
      • As an experienced user you may want to write a macro or automate a process might need to learn about scripting
      • +
      • Power users who want to streamline their workflow can learn about customization.
      • +
      • New developers who want to contribute to path might want to understand core concepts.
      +

      General concepts

      +

      The Path Workbench generates G-Code defining the paths required to mill the Project represented by the 3D model on the target mill—in [the Path Job Operations FreeCAD G-Code dialect ], which is later translated to the appropriate dialect for the target CNC controller by selecting the appropriate Postprocessor. +

      The G-Code is generated from directives and Operations contained in a Path Job. The Job Workflow lists these in the order they will be executed. The list is populated by adding Path Operations, Path Dressups, Path Partial Commands, and Path Modifications—from the Path Menu, or GUI buttons. +

      The Path Workbench provides a Tool Manager (Library, Tool-Table), and G-Code Inspection, and Simulation tools. It links the Postprocessor, and allows importing and exporting Job Templates. +

      The Path Workbench has external dependencies including: +

      +
      1. The FreeCAD 3D model units are defined in the Edit → Preference... → General → Units tab's Units settings. The Postprocessor configuration defines the final G-Code units.
      2. +
      3. The Macro file path, and Geometric tolerances, are defined in the Edit → Preferences... → Path → Job Preferences tab.
      4. +
      5. Colors are defined in the Edit → Preferences... → Path → Path colors tab.
      6. +
      7. Holding tag parameters are defined in the Edit → Preferences... → Path → Dressups tab.
      8. +
      9. That the Base 3D model quality supports the Path WB requirements—passes Check Geometry.
      +

      Units

      +

      Unit handling in Path can be confusing. There are several points to understand: +

      +
      1. FreeCAD base units for length and time are 'mm' and 's' respectively. Velocity is thus 'mm/s'. This is what FreeCAD stores internally regardless of anything else
      2. +
      3. The default unit schema uses the default units. If you're using the default schema and you enter a feed rate without a unit string, it will get entered as 'mm/s'
      4. +
      5. Most CNC machines expect feed rate in the form of either 'mm/min' or 'in/min'. Most post-processors will automatically convert the unit when generating gcode.
      +

      Schemas: +

      +
      1. Changing schema in preferences changes default unit string for the input fields. If you're a Path user and prefer to design in metric, it's highly recommended that you use the "Metric Small Parts & CNC" schema. If you design in US units, either the Imperial Decimal and Building US will work
      2. +
      3. Changing your preferred unit schema will have no effect on output but will help avoid input errors
      +

      Output: +

      +
      1. Generating the correct unit in output is the responsibility of the post-processor and is done only at that time
      2. +
      3. Machine output unit is completely unrelated to your selected unit schema
      4. +
      5. Post-processors produce either metric (G21) output, Imperial (G20) output or are configurable.
      6. +
      7. Configurable post-processors default to metric (G21)
      8. +
      9. If you want your configurable post-processor to output imperial gcode (G20), Set the correct argument in your job output configation (ie --inches for linuxcnc). This can be stored in a job template and set as your default template to make it automatic for all future jobs
      +

      Path Inspection: +

      +
      1. If you use the Path Inspect tool to look at g-code, you will see it in 'mm/s' because it is not being post-processed
      +

      Path Commands

      +

      These commands are used for seting up a CNC project and manage your templates. +

      +
      • Path-Job.png Job: Creates a new CNC job
      + + + +
      • Path Simulator.png Simulator: Shows the milling operation like it's done on the machine
      + + +
      • Path Contour.png Contour: Creates a path of the contour of the base object
      + + +
      • Path Pocket.png Pocket: Creates a pocketing operation from one ore more selected pocket(s)
      + + + +
      • Path-Helix.png Helix: Creates a helical path
      + +

      Path Dressup

      + + + + +
      • Path Dressup.png Tag Dressup: Adds a holding tag dressup modification to a selected path
      +

      Partial Commands

      +
      • Path Fixture.png Fixture: Changes the fixture position
      +
      • Path Comment.png Comment: Inserts a comment in the G-code of a path
      +
      • Path Stop.png Stop: Inserts a full stop of the machine
      +
      • Path Custom.png Custom: Inserts custom G-code
      + +

      Path Modification

      +
      • Path Copy.png Copy: Creates a parametric Copie of a selected path object
      +
      • Path Array.png Array: Creates an array by duplicating a selected path
      +
      • Path SimpleCopy.png Simple Copy: Creates a non-parametric copy of a selected path object
      +

      Other

      + + + +
      • Path Sanity.png Path Errors: Checks the selected Job for missing values
      +

      Preferences

      + +


      +

      +

      Scripting

      +

      The Path workbench offers a broad python scripting API. With it, you can create and modify paths from python scripts, or extend the available functionality of the workbench. +

      +

      FAQ

      +

      FAQ +

      The Path Workbench shares many concepts with other CAM software packages but has its own peculiarities. If something seems wrong, this might be a good place to start. +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Path_experimental.html b/localwiki/Path_experimental.html new file mode 100644 index 0000000..1e24eb0 --- /dev/null +++ b/localwiki/Path_experimental.html @@ -0,0 +1,25 @@ +Path experimental

      Path experimental

      + +

      By default, Experimental functionality is hidden in Path workbench. +

      To enable it to use and test requires the user: +

      Open 'Tools'->'Edit Parameters...->BaseApp->Preferences->Mod->Path' and create a new Boolean parameter EnableExperimentalFeatures, and set to True. Reopen FreeCAD. +


      +Path wb enable experimental features.PNG +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Path_inspector.jpg b/localwiki/Path_inspector.jpg new file mode 100644 index 0000000..331d900 Binary files /dev/null and b/localwiki/Path_inspector.jpg differ diff --git a/localwiki/Path_objects.html b/localwiki/Path_objects.html new file mode 100644 index 0000000..e09b74e --- /dev/null +++ b/localwiki/Path_objects.html @@ -0,0 +1,29 @@ +Path objects

      Path objects

      + +

      The basic object of the Path workbench is the Path object. A Path object describes the movement that a machine head must perform in order to cut through a block of material, in the case of CNC machines. Path objects can contain not only movement information, but also other instructions for the machine, such as the rotation speed that the cutter must have, or which tool must be used. +


      +Path objects can be created in many ways, by giving them manually the points through which they must pass, or deriving them from a wire-shaped FreeCAD object, or, more interestingly, by deriving them automatically from an existing 3D object, or parts of it. This is a complex task, and the tools below are there to do this, or part of this, in different ways. It requires some use to know them all, and choose which one is more suited to the particular task you need. Sometimes, you might also prefer to build your paths step-by-step, using partial tools, instead of using the more complex tools. +


      +Path objects can also be combined into Compounds or Arrays, allowing you to use different tools to do different parts of the whole cutting operation, and join them into one final path. +


      +Project objects, finally, allow you to manage different cutting operations that have to be performed by a same machine, and add machine-specific information such as a table of cutting tools available on the machine, with their characteristics. Some Path tools will then be able to refer to that table to obtain information like the diameter of a certain cutting tool. +


      +FreeCAD is also able to import G-Code files, for which a pre-processing script can also be used. +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Path_profile_example.jpg b/localwiki/Path_profile_example.jpg new file mode 100644 index 0000000..1b8e123 Binary files /dev/null and b/localwiki/Path_profile_example.jpg differ diff --git a/localwiki/Path_scripting.html b/localwiki/Path_scripting.html new file mode 100644 index 0000000..89dfb81 --- /dev/null +++ b/localwiki/Path_scripting.html @@ -0,0 +1,455 @@ +Path scripting

      Path scripting

      + +
      + + + + + + + + + + + + + + + + + + + + + + + + + + + +
      +

      Base ExampleCommandModel.png Tutorial

      +
      Topic +
      Path Workbench +
      Level +
      Intermediate +
      Time to complete +
      +
      Author +
      +
      FreeCAD version +
      +
      Example File(s) +
      +

      + +
      +


      +

      +

      Introduction

      +

      The Path workbench offers tools to import, create, manipulate and export machine toolpaths in FreeCAD. With it, the user is able to import, visualize and modify existing gcode programs, generate toolpaths from 3D shapes, and export these toolpaths to gcode. +

      In its current state, though, the Path workbench is still in pretty early stages of development, and will not offer you the very advanced functionality found in some commercial alternatives. However, its broad python scripting interface makes it easy to modify or develop more powerful tools, and is therefore at the moment more directed to users with some knowledge of python scripting than to end users. +

      Below you will find a more in-depth description of the python scripting API. +

      +

      Quickstart

      +

      FreeCAD's Path objects are made of a sequence of motion commands. A typical use is this: +

      +
          >>> import Path
      +    >>> c1 = Path.Command("g1x1")
      +    >>> c2 = Path.Command("g1y4")
      +    >>> c3 = Path.Command("g1 x2 y2") # spaces end newlines are not considered
      +    >>> p = Path.Path([c1,c2,c3])
      +    >>> o = App.ActiveDocument.addObject("Path::Feature","mypath")
      +    >>> o.Path = p
      +    >>> print p.toGCode()
      +

      FreeCAD's internal GCode format

      +

      A preliminary concept is important to grasp. Most of the implementation below relies heavily on motion commands that have the same names as GCode commands, but aren't meant to be close to a particular controller's implementation. We chose names such as 'G0' to represent 'rapid' move or 'G1' to represent 'feed' move for performance (efficient file saving) and to minimize the work needed to translate to/from other GCode formats. Since the CNC world speaks thousands of GCode dialects, we chose to stick with a very simplified subset of it. You could describe FreeCAD's GCode format as a "machine-agnostic" form of GCode. +

      Inside .FCStd files, Path data is saved directly into that GCode form. +

      All translations to/from dialects to FreeCAD GCode are done through pre and post scripts. That means that if you want to work with a machine that uses a specific LinuxCNC, Fanuc, Mitusubishi, or HAAS controller etc, you will have to use (or write if inexistant) a post processor for that particular control (see the "Importing and exporting GCode" section below). +

      +

      GCode reference

      +

      The following rules and guidelines define the GCode subset used internally in FreeCAD: +

      +
      • GCode data, inside FreeCAD Path objects, is separated into "Commands". A Command is defined by a command name, which must begin with G or M, and (optionally) arguments, which are in the form Letter = Float, for example X 0.02 or Y 3.5 or F 300. These are examples of typical GCode commands in FreeCAD:
      +
         G0 X2.5 Y0 (The command name is G0, the arguments are X=2.5 and Y=0)
      +
      +
         G1 X30 (The command name is G1, the only argument is X=30)
      +
      +
         G90 (The command name is G90, there are no arguments)
      +
      +
      • For the numeric part of a G or M command, both "G1" or "G01" forms are supported.
      • +
      • Only commands starting with G or M are supported at the moment.
      • +
      • Only millimeters are accepted at the moment. G20/G21 are not considered.
      • +
      • Arguments are always sorted alphabetically. This means that if you create a command with "G1 X2 Y4 F300", it will be stored as "G1 F300 X2 Y4"
      • +
      • Arguments cannot be repeated inside a same command. For example, "G1 X1 Y2 X2 Y3" will not work. You will need to split it into two commands, for example: "G1 X1 Y2, G1 X2 Y3"
      • +
      • X, Y, Z, A, B, C arguments are absolute or relative, depending on the current G90/G91 mode. Default (if not specified) is absolute.
      • +
      • I, J, K are always relative to the last point. K can be omitted.
      • +
      • X, Y, or Z (and A, B, C) can be omitted. In this case, the previous X, Y or Z coordinates are maintained.
      • +
      • Gcode commands other than the ones listed in the table below are supported, that is, they are saved inside the path data (as long as they comply to the rules above, of course), but they simply won't produce any visible result on screen. For example, you could add a G81 command, it will be stored, but not displayed.
      +

      List of currently supported GCode commands

      + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
      Command +Description +Supported Arguments +
      G0 +rapid move +X,Y,Z,A,B,C +
      G1 +normal move +X,Y,Z,A,B,C +
      G2 +clockwise arc +X,Y,Z,A,B,C,I,J,K +
      G3 +counterclockwise arc +X,Y,Z,A,B,C,I,J,K +
      G81, G82, G83 +drill +X,Y,Z,R,Q +
      G90 +absolute coordinates + +
      G91 +relative coordinates + +
      (Message) +comment + +
      +

      The Command object

      +

      The Command object represents a gcode command. It has three attributes: Name, Parameters and Placement, and two methods: toGCode() and setFromGCode(). Internally, it contains only a name and a dictionary of parameters. The rest (placement and gcode) is computed to/from this data. +

      +
          >>> import Path
      +    >>> c=Path.Command()
      +    >>> c
      +    Command  ( )
      +    >>> c.Name = "G1"
      +    >>> c
      +    Command G1 ( )
      +    >>> c.Parameters= {"X":1,"Y":0}
      +    >>> c
      +    Command G1 ( X:1 Y:0 )
      +    >>> c.Parameters
      +    {'Y': 0.0, 'X': 1.0}
      +    >>> c.Parameters= {"X":1,"Y":0.5}
      +    >>> c
      +    Command G1 ( X:1 Y:0.5 )
      +    >>> c.toGCode()
      +    'G1X1Y0.5'
      +    >>> c2=Path.Command("G2")
      +    >>> c2
      +    Command G2 ( )
      +    >>> c3=Path.Command("G1",{"X":34,"Y":1.2})
      +    >>> c3
      +    Command G1 ( X:34 Y:1.2 )
      +    >>> c3.Placement
      +    Placement [Pos=(34,1.2,0), Yaw-Pitch-Roll=(0,0,0)]
      +    >>> c3.toGCode()
      +    'G1X34Y1.2'
      +    >>> c3.setFromGCode("G1X1Y0")
      +    >>> c3
      +    Command G1 [ X:1 Y:0 ]
      +    >>> c4 = Path.Command("G1X4Y5")
      +    >>> c4
      +    Command G1 [ X:4 Y:5 ]
      +    >>> p1 = App.Placement()
      +    >>> p1.Base = App.Vector(3,2,1)
      +    >>> p1
      +    Placement [Pos=(3,2,1), Yaw-Pitch-Roll=(0,0,0)]
      +    >>> c5=Path.Command("g1",p1)
      +    >>> c5
      +    Command G1 [ X:3 Y:2 Z:1 ]
      +    >>> p2=App.Placement()
      +    >>> p2.Base = App.Vector(5,0,0)
      +    >>> c5
      +    Command G1 [ X:3 Y:2 Z:1 ]
      +    >>> c5.Placement=p2
      +    >>> c5
      +    Command G1 [ X:5 ]
      +    >>> c5.x
      +    5.0
      +    >>> c5.x=10
      +    >>> c5
      +    Command G1 [ X:10 ]
      +    >>> c5.y=2
      +    >>> c5
      +    Command G1 [ X:10 Y:2 ]
      +

      The Path object

      +

      The Path object holds a list of commands +

      +
          >>> import Path
      +    >>> c1=Path.Command("g1",{"x":1,"y":0})
      +    >>> c2=Path.Command("g1",{"x":0,"y":2})
      +    >>> p=Path.Path([c1,c2])
      +    >>> p
      +    Path [ size:2 length:3 ]
      +    >>> p.Commands
      +    [Command G1 [ X:1 Y:0 ], Command G1 [ X:0 Y:2 ]]
      +    >>> p.Length
      +    3.0
      +    >>> p.addCommands(c1)
      +    Path [ size:3 length:4 ]
      +    >>> p.toGCode()
      +    'G1X1G1Y2G1X1'
      +    
      +    lines = """
      +    G0X-0.5905Y-0.3937S3000M03
      +    G0Z0.125
      +    G1Z-0.004F3
      +    G1X0.9842Y-0.3937F14.17
      +    G1X0.9842Y0.433
      +    G1X-0.5905Y0.433
      +    G1X-0.5905Y-0.3937
      +    G0Z0.5
      +    """
      +    
      +    slines = lines.split('\n')
      +    p = Path.Path()
      +    for line in slines:
      +        p.addCommands(Path.Command(line))
      +    
      +    o = App.ActiveDocument.addObject("Path::Feature","mypath")
      +    o.Path = p
      +    
      +    # but you can also create a path directly form a piece of gcode.
      +    # The commands will be created automatically:
      +    
      +    p = Path.Path()
      +    p.setFromGCode(lines)
      +

      As a shortcut, a Path object can also be created directly from a full GCode sequence. It will be divided into a sequence of commands automatically. +

      +
          >>> p = Path.Path("G0 X2 Y2 G1 X0 Y2")
      +    >>> p
      +    Path [ size:2 length:2 ]
      +

      The Path feature

      +

      The Path feature is a FreeCAD document object, that holds a path, and represents it in the 3D view. +

      +
          >>> pf = App.ActiveDocument.addObject("Path::Feature","mypath")
      +    >>> pf
      +    <Document object>
      +    >>> pf.Path = p
      +    >>> pf.Path
      +    Path [ size:2 length:2 ]
      +

      The Path feature also holds a Placement property. Changing the value of that placement will change the position of the Feature in the 3D view, although the Path information itself won't be modified. The transformation is purely visual. This allows you, for example, to create a Path around a face that has a particular orientation on your model, that is not the same orientation as your cutting material will have on the CNC machine. +

      However, Path Compounds can make use of the Placement of their children (see below). +

      +

      The Tool and Tooltable objects

      +

      The Tool object contains the definitions of a CNC tool. The Tooltable object contains an ordered list of tools. Tooltables are attached as a property to Path Project features, and can also be edited via the GUI, by double-clicking a project in the tree view, and clicking the "Edit tooltable" button in the task views that opens. +

      From that dialog, tooltables can be imported from FreeCAD's .xml and HeeksCad's .tooltable formats, and exported to FreeCAD's .xml format. +

      +
          >>> import Path
      +    >>> t1=Path.Tool()
      +    >>> t1
      +    Tool Default tool
      +    >>> t1.Name = "12.7mm Drill Bit"
      +    >>> t1
      +    Tool 12.7mm Drill Bit
      +    >>> t1.ToolType
      +    'Undefined'
      +    >>> t1.ToolType = "Drill"
      +    >>> t1.Diameter= 12.7
      +    >>> t1.LengthOffset = 127
      +    >>> t1.CuttingEdgeAngle = 59
      +    >>> t1.CuttingEdgeHeight = 50.8
      +    >>> t2 = Path.Tool("my other tool",tooltype="EndMill",diameter=10)
      +    >>> t2
      +    Tool my other tool
      +    >>> t2.Diameter
      +    10.0
      +    >>> table = Path.Tooltable()
      +    >>> table
      +    Tooltable containing 0 tools
      +    >>> table.addTools(t1)
      +    Tooltable containing 1 tools
      +    >>> table.addTools(t2)
      +    Tooltable containing 2 tools
      +    >>> table.Tools
      +    {1: Tool 12.7mm Drill Bit, 2: Tool my other tool}
      +    >>>
      +

      Features

      +

      The Path Compound feature

      +

      The aim of this feature is to gather one or more toolpaths and associate it (them) with a tooltable. The Compound feature also behaves like a standard FreeCAD group, so you can add or remove objects to/from it directly from the tree view. You can also reorder items by double-clicking the Compound object in the Tree view, and reorder its elements in the Task view that opens. +

      +
          >>> import Path
      +    >>> p1 = Path.Path("G1X1")
      +    >>> o1 = App.ActiveDocument.addObject("Path::Feature","path1")
      +    >>> o1.Path=p1
      +    >>> p2 = Path.Path("G1Y1")
      +    >>> o2 = App.ActiveDocument.addObject("Path::Feature","path2")
      +    >>> o2.Path=p2
      +    >>> o3 = App.ActiveDocument.addObject("Path::FeatureCompound","compound")
      +    >>> o3.Group=[o1,o2]
      +

      An important feature of Path Compounds is the possibility to take into account the Placement of their child paths or not, by setting their UsePlacements property to True or False. If not, the Path data of their children will simply be added sequentially. If True, each command of the child paths, if containing position information (G0, G1, etc..) will first be transformed by the Placement before being added. +

      Creating a compound with just one child path allows you therefore to turn the child path's Placement "real" (it affects the Path data). +

      +

      The Path Project feature

      +

      The Path project is an extended kind of Compound, that has a couple of additional machine-related properties such as a tooltable. It is made mainly to be the main object type you'll want to export to gcode once your whole path setup is ready. The Project object is now coded in python, so its creation mechanism is a bit different: +

      +
          >>> from PathScripts import PathProject
      +    >>> o4 = App.ActiveDocument.addObject("Path::FeatureCompoundPython","prj")
      +    >>> PathProject.ObjectPathProject(o4)
      +    >>> o4.Group = [o3]
      +    >>> o4.Tooltable
      +    Tooltable containing 0 tools
      +

      The Path module also features a GUI tooltable editor that can be called from python, giving it an object that has a ToolTable property: +

      +
          >>> from PathScripts import TooltableEditor
      +    >>> TooltableEditor.edit(o4)
      +

      The Path Shape feature

      +

      This feature is a normal Path object with an additional Shape property. By giving that property a Wire shape, its path will be automatically calculated from the shape. Note that in this case the placement is automatically set to the first point of the wire, and the object is therefore not movable anymore by changing its placement. To move it, the underlying shape itself must be moved. +

      +
          >>> import Part
      +    >>> v1 = FreeCAD.Vector(0,0,0)
      +    >>> v2 = FreeCAD.Vector(0,2,0)
      +    >>> v3 = FreeCAD.Vector(2,2,0)
      +    >>> v4 = FreeCAD.Vector(3,3,0)
      +    >>> wire = Part.makePolygon([v1,v2,v3,v4])
      +    >>> o = FreeCAD.ActiveDocument.addObject("Path::FeatureShape","myPath2")
      +    >>> o.Shape = wire
      +    >>> FreeCAD.ActiveDocument.recompute()
      +

      Python features

      +

      Both Path::Feature and Path::FeatureShape features have a python version, respectively named Path::FeaturePython and Path::FeatureShapePython, that can be used in python code to create more advanced parametric objects derived from them. +

      +

      Importing and exporting GCode

      +

      Native format

      +

      GCode files can be directly imported and exported via the GUI, by using the "open", "insert" or "export" menu items. After the file name is acquired, a dialog pops up to ask which processing script must be used. It can also be done from python: +

      Path information is stored into Path objects using a subset of gcode described in the "FreeCAD's internal GCode format"section above. This subset can be imported or exported "as is", or converted to/from a particular version of GCode suited for your machine. +

      If you have a very simple and standard GCode program, that complies to the rules described in the "FreeCAD's internal GCode format" section above, for example the boomerang from http://www.cnccookbook.com/GWESampleFiles.html , it can be imported directly into a Path object, without translation (this is equivalent to using the "None" option of the GUI dialog): +

      +
          import Path
      +    f = open("/path/to/boomerangv4.ncc")
      +    s = f.read()
      +    p = Path.Path(s)
      +    o = App.ActiveDocument.addObject("Path::Feature","boomerang")
      +    o.Path = p
      +

      In the same manner, you can obtain the path information as "agnostic" gcode, and store it manually in a file: +

      +
          text = o.Path.toGCode()
      +    print text
      +    myfile = open("/path/to/newfile.ngc")
      +    myfile.write(text)
      +    myfile.close()
      +

      If you need a different output, though, you will need to convert this agnostic GCode into a format suited for your machine. That is the job of post-processing scripts. +

      +

      Using pre- and post-processing scripts

      +

      If you have a gcode file written for a particular machine, which doesn't comply to the internal rules used by FreeCAD, described in the "FreeCAD's internal GCode format" section above, it might fail to import and/or render properly in the 3D view. To remedy to this, you must use a pre-processing script, which will convert from your machine-specific format to the FreeCAD format. +

      If you know the name of the pre-processing script to use, you can import your file using it, from the python console like this: +

      +
          import example_pre
      +    example_pre.insert("/path/to/myfile.ncc","DocumentName")
      +

      In the same manner, you can output a path object to GCode, using a post_processor script like this: +

      +
          import example_post
      +    example_post.export (myObjectName,"/path/to/outputFile.ncc")
      +

      Writing processing scripts

      +

      Pre- and post-processing scripts behave like other common FreeCAD imports/exporters. When choosing a pre/post processing script from the dialog, the import/export process will be redirected to the specified given script. Preprocessing scripts must contain at least the following methods open(filename) and insert(filename,docname). Postprocessing scripts need to implement export(objectslist,filename). +

      Scripts are placed into either the Mod/Path/PathScripts folder or the user's macro path directory. You can give them any name you like but by convention, and to be picked by the GUI dialog, pre-processing scripts names must end with "_pre", post-processing scripts with "_post" (make sure to use the underscore, not the hyphen, otherwise python cannot import it). This is an example of a very, very simple preprocessor. More complex examples are found in the Mod/Path/PathScripts folder: +

      +
          def open(filename):
      +        gfile = __builtins__.open(filename)
      +        inputstring = gfile.read()
      +        # the whole gcode program will come in as one string,
      +        # for example: "G0 X1 Y1\nG1 X2 Y2"
      +        output = ""
      +        # we add a comment
      +        output += "(This is my first parsed output!)\n"
      +        # we split the input string by lines
      +        lines = inputstring.split("\n")
      +        for line in lines:
      +            output += line
      +            # we must insert the "end of line" character again
      +            # because the split removed it
      +            output += "\n"
      +        # another comment
      +        output += "(End of program)"
      +        import Path
      +        p = Path.Path(output)
      +        myPath = FreeCAD.ActiveDocument.addObject("Path::Feature","Import")
      +        myPath.Path = p
      +        FreeCAD.ActiveDocument.recompute()
      +

      Pre- and post-processors work exactly the same way. They just do the contrary: The pre scripts convert from specific GCode to FreeCAD's "agnostic" GCode, while post scripts convert from FreeCAD's "agnostic" GCode to machine-specific GCode. +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Path_wb_enable_experimental_features.PNG b/localwiki/Path_wb_enable_experimental_features.PNG new file mode 100644 index 0000000..7f78c19 Binary files /dev/null and b/localwiki/Path_wb_enable_experimental_features.PNG differ diff --git a/localwiki/Patharray_NoAlign.png b/localwiki/Patharray_NoAlign.png new file mode 100644 index 0000000..e383540 Binary files /dev/null and b/localwiki/Patharray_NoAlign.png differ diff --git a/localwiki/Pentaedres.gif b/localwiki/Pentaedres.gif new file mode 100644 index 0000000..d7d75e8 Binary files /dev/null and b/localwiki/Pentaedres.gif differ diff --git a/localwiki/Perpendicularity.svg b/localwiki/Perpendicularity.svg new file mode 100644 index 0000000..cdbdfe8 --- /dev/null +++ b/localwiki/Perpendicularity.svg @@ -0,0 +1,117 @@ + + + + + Perpendicularity + + + + + + image/svg+xml + + Perpendicularity + + + bavariaSHAPE + + + + + bavariaSHAPE + + + + + bavariaSHAPE + + + 15.10.2016 + Geometric dimensioning and tolerancing symbols +All symbols in this repository are licensed under CC-BY 3.0 + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Perspective.png b/localwiki/Perspective.png new file mode 100644 index 0000000..838b409 Binary files /dev/null and b/localwiki/Perspective.png differ diff --git a/localwiki/PianoTaglio6.png b/localwiki/PianoTaglio6.png new file mode 100644 index 0000000..0d53210 Binary files /dev/null and b/localwiki/PianoTaglio6.png differ diff --git a/localwiki/Pipeline.PNG b/localwiki/Pipeline.PNG new file mode 100644 index 0000000..1422486 Binary files /dev/null and b/localwiki/Pipeline.PNG differ diff --git a/localwiki/Pivy.html b/localwiki/Pivy.html new file mode 100644 index 0000000..19d238d --- /dev/null +++ b/localwiki/Pivy.html @@ -0,0 +1,90 @@ +Pivy

      Pivy

      + +

      Pivy is a python binding library for Coin3d, the 3D-rendering library used in FreeCAD. When imported in a running python interpreter, it allows to dialog directly with any running Coin3d scenegraphs, such as the FreeCAD 3D views, or even to create new ones. Pivy is bundled in standard FreeCAD installation. +

      The coin library is divided into several pieces, coin itself, for manipulating scenegraphs and bindings for several GUI systems, such as windows or, like in our case, qt. Those modules are available to pivy too, depending if they are present on the system. The coin module is always present, and it is what we will use anyway, since we won't need to care about anchoring our 3D display in any interface, it is already done by FreeCAD itself. All we need to do is this: +

      +
      from pivy import coin 
      +

      Accessing and modifying the scenegraph

      +

      We saw in the Scenegraph page how a typical Coin scene is organized. Everything that appears in a FreeCAD 3D view is a coin scenegraph, organized the same way. We have one root node, and all objects on the screen are its children. +

      FreeCAD has an easy way to access the root node of a 3D view scenegraph: +

      +
      sg = FreeCADGui.ActiveDocument.ActiveView.getSceneGraph()
      +print sg 
      +

      This will return the root node: +

      +
      <pivy.coin.SoSelection; proxy of <Swig Object of type 'SoSelection *' at 0x360cb60> > 
      +

      We can inspect the immediate children of our scene: +

      +
      for node in sg.getChildren():
      +    print node 
      +

      Some of those nodes, such as SoSeparators or SoGroups, can have children themselves. The complete list of the available coin objects can be found in the official coin documentation. +

      Let's try to add something to our scenegraph now. We'll add a nice red cube: +

      +
      col = coin.SoBaseColor()
      +col.rgb=(1,0,0)
      +cub = coin.SoCube()
      +myCustomNode = coin.SoSeparator()
      +myCustomNode.addChild(col)
      +myCustomNode.addChild(cub)
      +sg.addChild(myCustomNode) 
      +

      and here is our (nice) red cube. Now, let's try this: +

      +
      col.rgb=(1,1,0) 
      +

      See? everything is still accessible and modifiable on-the-fly. No need to recompute or redraw anything, coin takes care of everything. You can add stuff to your scenegraph, change properties, hide stuff, show temporary objects, anything. Of course, this only concerns the display in the 3D view. That display gets recomputed by FreeCAD on file open, and when an object needs recomputing. So, if you change the aspect of an existing FreeCAD object, those changes will be lost if the object gets recomputed or when you reopen the file. +

      A key to work with scenegraphs in your scripts is to be able to access certain properties of the nodes you added when needed. For example, if we wanted to move our cube, we would have added a SoTranslation node to our custom node, and it would have looked like this: +

      +
      col = coin.SoBaseColor()
      +col.rgb=(1,0,0)
      +trans = coin.SoTranslation()
      +trans.translation.setValue([0,0,0])
      +cub = coin.SoCube()
      +myCustomNode = coin.SoSeparator()
      +myCustomNode.addChild(col)
      +mtCustomNode.addChild(trans)
      +myCustomNode.addChild(cub)
      +sg.addChild(myCustomNode) 
      +

      Remember that in an openInventor scenegraph, the order is important. A node affects what comes next, so you can say something like: color red, cube, color yellow, sphere, and you will get a red cube and a yellow sphere. If we added the translation now to our existing custom node, it would come after the cube, and not affect it. If we had inserted it when creating it, like here above, we could now do: +

      +
      trans.translation.setValue([2,0,0]) 
      +

      And our cube would jump 2 units to the right. +Finally, removing something is done with: +

      +
      sg.removeChild(myCustomNode) 
      +

      Using callback mechanisms

      +

      A callback mechanism is a system that permits a library that you are using, such as our coin library, to call you back, that is, to call a certain function from your currently running python object. This is extremely useful, because that way coin can notify you if some specific event occurs in the scene. Coin can watch very different things, such as mouse position, clicks of a mouse button, keyboard keys being pressed, and many other things. +

      FreeCAD features an easy way to use such callbacks: +

      +
      class ButtonTest:
      +  def __init__(self):
      +    self.view = FreeCADGui.ActiveDocument.ActiveView
      +    self.callback = self.view.addEventCallbackPivy(SoMouseButtonEvent.getClassTypeId(),self.getMouseClick) 
      +  def getMouseClick(self,event_cb):
      +    event = event_cb.getEvent()
      +    if event.getState() == SoMouseButtonEvent.DOWN:
      +      print "Alert!!! A mouse button has been improperly clicked!!!"
      +      self.view.removeEventCallbackSWIG(SoMouseButtonEvent.getClassTypeId(),self.callback) 
      + 
      +ButtonTest() 
      +

      The callback has to be initiated from an object, because that object must still be running when the callback will occur. +See also a complete list of possible events and their parameters, or the official coin documentation. +

      +

      Documentation

      +

      Unfortunately pivy itself still doesn't have a proper documentation, but since it is an accurate translation of coin, you can safely use the coin documentation as reference, and use python style instead of c++ style (for example SoFile::getClassTypeId() would in pivy be SoFile.getClassId()) +

      + +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/PlacePyConv10.png b/localwiki/PlacePyConv10.png new file mode 100644 index 0000000..6bae6e8 Binary files /dev/null and b/localwiki/PlacePyConv10.png differ diff --git a/localwiki/Placement.html b/localwiki/Placement.html new file mode 100644 index 0000000..57e0dec --- /dev/null +++ b/localwiki/Placement.html @@ -0,0 +1,266 @@ +Placement

      Placement

      + +
      + +

      Overview

      +

      Placement is how FreeCAD specifies the location and attitude (orientation) of an object in space. Placement can be specified in multiple forms and manipulated via scripting, the Properties pane or the Placement dialog (Edit menu). +

      +

      Accessing the Placement Attribute

      +

      An object's Placement attributes can be accessed and modified in 3 ways: +

      +
      Placement in Properties panel
      +
      +


      +

      +
      Scripting Placement as y/p/r and Matrix and its API.
      +
      +


      +

      +
      Placement Dialog Rotation axis with angle
      +
      +


      +

      +

      Forms of Placement

      +

      The placement is stored internally as a position, and a rotation (rotation axis and angle transformed into a quaternion [1]). While there are several forms to specify a rotation, for instance with a rotation center, this is only used to affect the rotation computation and is not stored for later operations. Similarly, if a rotation axis of (1,1,1) is specified, it may be normalized when stored in the quaternion and appear as (0.58, 0.58, 0.58) when browsing the object later. +

      +

      Angle, Axis and Position

      +

      Placement = [Angle, Axis, Position] +

      The first form of Placement fixes an object's location in space with a Position, and describes its orientation as a single rotation about an axis. +

      Angle = r is a scalar indicating the amount of rotation of the object about Axis. Entered as degrees, but stored internally as radians. +

      Axis = (ax,ay,az) is a vector describing an axis of rotation (See Note about axis of rotation). Examples are: +

      +
         (1,0,0)       ==> about X axis
      +   (0,1,0)       ==> about Y axis
      +   (0,0,1)       ==> about Z axis
      +   (0.71,0.71,0) ==> about the line y=x
      +                                        
      +
      +

      Position = (x,y,z) is a Vector describing the point from which the object's geometry will be calculated (in effect, a "local origin" for the object). Note that in scripts, Placement.Base is used to denote the Position component of a placement. The Property Editor calls this value "Position" and the Placement dialog calls it "Translation". +

      +

      Position and Yaw, Pitch and Roll

      +
      Placement Dialog Euler angles
      +
      +

      Placement = [Position, Yaw-Pitch-Roll] +

      The second form of Placement fixes an object's location in space with a Position (as in the first form), but describes it's orientation using Yaw, Pitch and Roll angles (Yaw, Pitch, Roll). These angles are sometimes referred to as Euler angles or Tait-Bryan angles (Euler angles). Yaw, Pitch and Roll are common aviation terms for a body's orientation (or attitude). +

      Position = (x,y,z) is a Vector describing the point from which the object's geometry will be calculated (in effect, a "local origin" for the object). +

      Yaw-Pitch-Roll = (y,p,r) is a tuple that specifies the attitude of the object. Values for y,p,r specify degrees of rotation about each of the z,y,x axis (see note). +

      +
      +
      >>> App.getDocument("Sans_nom").Cylinder.Placement=App.Placement(App.Vector(0,0,0), App.Rotation(10,20,30), App.Vector(0,0,0)) 
      +

      App.Rotation(10,20,30) = Euler Angle +

      Yaw = 10 degrees (Z) +

      Pitch = 20 degrees (Y) +

      Roll = 30 degrees (X) +


      +

      +
      Tache Placement Lacet fr Mini.gif
      Yaw is the rotation about the Z axis, that is to say a rotation from left to right.
      (The yaw angle is the Psi ψ). +
      +


      +

      +
      Tache Placement Tangage fr Mini.gif
      Pitch is rotation about the Y axis, that is to say nose-up and nose-down.
      (The Pitch angle is the Phi φ). +
      +


      +

      +
      Tache Placement Roulis fr Mini.gif
      Roll is rotation about the X axis, that is to say wing up and down.
      (The Roll angle is the Thêta θ). +
      +


      +

      +

      Matrix

      +

      Placement = Matrix +

      The third form of Placement describes the object's position and orientation with a 4x4 affine transformation matrix (Affine Transformation). +

      Matrix = +

      +
        ((r11,r12,r13,t1),
      +   (r21,r22,r23,t2),
      +   (r31,r32,r33,t3),
      +   (0,0,0,1)) , with rij specifying rotation and ti specifying translation. 
      +
      +
      +


      +

      +

      The Placement Dialog

      +

      The Placement Dialog is invoked from the Edit menu. It is used to precisely rotate/translate objects. It is also used when we need to create a sketch on a "non standard" plane or change a sketch's orientation to a new plane. +

      The Translation section adjusts the object's location in space. +The Center section adjusts the rotational axis to one that does not pass through the object's reference point. +The Rotation section adjusts the rotational angle(s) and the method of specifying those angles. +

      The Apply incremental changes to object placement tick box is useful when translations/rotations are to be made relative the object's current position/attitude, rather than to the original position/attitude. Ticking this box resets the dialogue input fields to zero, but does not change the object's orientation or location. Subsequent entries do change the orientation/location, but are applied from the object's current position. +

      PS: since version 0.17 introduce new object Part, this object have his placement, and the Placement object created in the Part object is incremented with the Part Placement. available in version 0.17 +

      For obtain the Part Placement use this code +

      +
      import Draft, Part
      +sel = FreeCADGui.Selection.getSelection()
      +print sel[0].Placement
      +print sel[0].getGlobalPlacement()   # return the GlobalPlacement
      +print sel[0].getParentGeoFeatureGroup() # return the GeoFeatureGroup, ex:  Body or a Part.
      +print  "____________________" 
      +

      Examples

      +

      Rotations about a single axis: +

      +
      Before Rotation
      Before Rotation (top view)
      +


      +

      +
      After Rotation about Z
      After Rotation about Z (top view)
      +


      +

      +
      After Rotation about y=x
      After Rotation about y=x (right view)
      +


      +Rotation with offset centre point: +

      +
      Before Rotation
      Before Rotation (top view)
      +


      +

      +
      After Rotation about Z
      After Rotation about Z (top view)
      +


      +Rotation using Euler angles: +

      +
      Before Rotation
      Before Rotation
      +


      +

      +
      After Rotation
      After Rotation
      +


      +

      +

      Placement.Base vs Shape Definition

      +

      Placement is not the only way to position a shape in space. Note the Python console +in this image: +

      +
      2 Shapes with Same Placement
      +


      +Both cubes have the same value for Placement, but are in different locations! This is +because the 2 shapes are defined by different vertices (curves in more complex shapes). For the 2 shapes in the above illustration: +

      +
       >>> ev = App.ActiveDocument.Extrude.Shape.Vertexes
      + >>> for v in ev: print v.X,",",v.Y,",",v.Z
      + ... 
      + 30.0,30.0,0.0
      + 30.0,30.0,10.0
      + 40.0,30.0,0.0
      + 40.0,30.0,10.0
      + 40.0,40.0,0.0
      + 40.0,40.0,10.0
      + 30.0,40.0,0.0
      + 30.0,40.0,10.0
      + >>> e1v = App.ActiveDocument.Extrude001.Shape.Vertexes
      + >>> for v in e1v: print v.X,",",v.Y,",",v.Z
      + ... 
      + 0.0,10.0,0.0
      + 0.0,10.0,10.0
      + 10.0,10.0,0.0
      + 10.0,10.0,10.0
      + 10.0,0.0,0.0
      + 10.0,0.0,10.0
      + 0.0,0.0,0.0
      + 0.0,0.0,10.0
      + >>> 
      + 
      +
      +

      The Vertices (or Vectors) that define the shape use the Placement.Base attribute as +their origin. So if you want to move a shape 10 units along the X axis, you could +add 10 to the X coordinates of all the Vertices or you could set Placement.Base +to (10,0,0). +

      +

      Using "Center" to Control Axis of Rotation

      +

      By default, the axis of rotation isn't really the x/y/z axis. It is a line parallel to the selected axis, but passing through the reference point (Placement.Base) of the object to be rotated. This can be changed by using the Center fields in the Placement dialog or, in scripts, by using the Center parameter of the FreeCAD.Placement constructor. +

      For example, suppose we have a box (below) positioned at (20,20,10). +

      +
      Before Rotation
      +

      We wish to spin the box around it's own vertical centre line (ie local Z), while keeping it the same position. We can easily achieve this by specifying a Center value equal to the coordinates of the box's central point (25,25,15). +

      +
      After Rotation
      +


      +In a script, we would do: +

      +
      import FreeCAD
      +obj = App.ActiveDocument.Box                       # our box
      +rot = FreeCAD.Rotation(FreeCAD.Vector(0,0,1),45)   # 45° about Z
      +#rot = FreeCAD.Rotation(FreeCAD.Vector(1,0,1),45)   # 45° about X and 45° about Z
      +#rot = FreeCAD.Rotation(10,20,30)                   # here example with Euler angle Yaw = 10 degrees (Z), Pitch = 20 degrees (Y), Roll = 30 degrees (X) 
      +centre = FreeCAD.Vector(25,25,15)                  # central point of box 
      +pos = obj.Placement.Base                           # position point of box
      +newplace = FreeCAD.Placement(pos,rot,centre)       # make a new Placement object
      +obj.Placement = newplace                           # spin the box 
      +

      Same script with the file example RotateCoG2.fcstd (discussion on the forum) +

      +
      import FreeCAD
      +obj = App.ActiveDocument.Extrude                    # our box
      +rot = FreeCAD.Rotation(FreeCAD.Vector(0,0,1),45)    # 45 about Z
      +#rot = FreeCAD.Rotation(FreeCAD.Vector(1,0,1),45)    # 45° about X and 45° about Z
      +#rot = FreeCAD.Rotation(10,20,30)                    # here example with Euler angle Yaw = 10 degrees (Z), Pitch = 20 degrees (Y), Roll = 30 degrees (X) 
      +centre = FreeCAD.Vector(25,25,0)                    # "centre" of rotation (where local Z cuts XY)
      +pos = obj.Placement.Base                            # original placement of obj
      +newplace = FreeCAD.Placement(pos,rot,centre)        # make a new Placement object
      +obj.Placement = newplace                            # spin the box 
      +

      Notes

      +
      • Axis and Angle can also be expressed as a quaternion.
      • +
      • The reference point of an object varies depending on the object. Some examples for common objects:
      + + + + + + + + + + + + + + + + + + + + + +
      ObjectReference Point +
      Part.Box left (minx), front (miny), bottom (minz) vertex +
      Part.Spherecenter of the sphere (ie centre of bounding box) +
      Part.Cylindercenter of the bottom face +
      Part.Conecenter of bottom face (or apex if bottom radius is 0) +
      Part.Toruscenter of the torus +
      Features derived from Sketchesthe Feature inherits the Position of the underlying Sketch. Sketches always start with Position = (0,0,0). This position corresponds to the origin in the sketch. +
      +

      Issues

      +
      • As of version 0.13, update of Placement properties in the Data tab has been disabled for objects created with PartDesign, except for the initial sketch from which the solid will be created. Therefore the Placement of a solid created in PartDesign from a sketch can only be altered by adjusting Placement parameters of the initial construction sketch (the first sketch) from which the solid was created.
      • +
      • Placement functionality will eventually be handled in the Assembly workbench.
      +

      More

      +
      • This tutorial: Aeroplane covers the mechanics of changing an object's Placement extensively.
      • +
      • A step-by-step explanation of the Placement Dialog can be found here Tasks_Placement.
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/PlacementDialogv10.png b/localwiki/PlacementDialogv10.png new file mode 100644 index 0000000..35462bd Binary files /dev/null and b/localwiki/PlacementDialogv10.png differ diff --git a/localwiki/PlacementDialogv10b.png b/localwiki/PlacementDialogv10b.png new file mode 100644 index 0000000..fec1707 Binary files /dev/null and b/localwiki/PlacementDialogv10b.png differ diff --git a/localwiki/PlacementPropertiesv10-800x800.png b/localwiki/PlacementPropertiesv10-800x800.png new file mode 100644 index 0000000..bd01771 Binary files /dev/null and b/localwiki/PlacementPropertiesv10-800x800.png differ diff --git a/localwiki/Placement_API.html b/localwiki/Placement_API.html new file mode 100644 index 0000000..35a93db --- /dev/null +++ b/localwiki/Placement_API.html @@ -0,0 +1,102 @@ +Placement API

      Placement API

      + +

      In FreeCAD, Placement defines an object's position and rotation. The Placement concept is explained in detail here: Placement. +

      Example of setting a document object's Placement: +

      +
      myObj = FreeCAD.ActiveDocument.ActiveObject
      +pl = FreeCAD.Placement()
      +pl.move(FreeCAD.Vector(2,0,0))
      +myObj.Placement = pl 
      +


      +

      +
      +
      Class.png Placement ( ) or (Placement) or (Matrix) or (Base, Rotation) or (Base,Rotation,Center) or (Base,Axis,Angle )
      +
      +

      Description: Constructs a placement, empty or with the given arguments, or as a copy of the given placement. +

      +
      +
      +


      +

      +
      +
      Property.png Base
      +
      +

      Returns: a vector representing the Placement's position. +

      +
      +
      +


      +

      +
      +
      Property.png Rotation
      +
      +

      Returns: a quaternion representing the Placement's rotation. +

      +
      +
      +


      +

      +
      +
      Method.png inverse ( )
      +
      +

      Description: computes the inverse placement +

      Returns: a placement. +

      +
      +
      +


      +

      +
      +
      Method.png move ( Vector )
      +
      +

      Description: moves the Placement along the given vector +

      Returns: nothing +

      +
      +
      +


      +

      +
      +
      Method.png multVec ( Vector )
      +
      +

      Description: applies the Placement to the given vector +

      Returns: the resulting vector. +

      +
      +
      +


      +

      +
      +
      Method.png multiply ( Placement )
      +
      +

      Description: multiplies this placement with another one +

      Returns: the resulting placement. +

      +
      +
      +


      +

      +
      +
      Method.png toMatrix ( )
      +
      +

      Description: +

      Returns: a matrix representing the Placement's transformation. +

      +
      +
      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/PlotWorkbench.svg b/localwiki/PlotWorkbench.svg new file mode 100644 index 0000000..f6bf871 --- /dev/null +++ b/localwiki/PlotWorkbench.svg @@ -0,0 +1,148 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [triplus] + + + PlotWorkbench + 2016-02-26 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Plot/resources/icons/PlotWorkbench.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Plot_Axes.html b/localwiki/Plot_Axes.html new file mode 100644 index 0000000..2137ca5 --- /dev/null +++ b/localwiki/Plot_Axes.html @@ -0,0 +1,63 @@ +Plot Axes

      Plot Axes

      + +
      +

      This documentation is not finished. Please help and contribute documentation. +

      See Draft ShapeString for good documented Command. Gui Command gives an overview over commands. And see List of Commands for other commands. +

      Go to Help FreeCAD to contribute. +

      +
      +


      +

      + + + + + + + + + + + + + + + + + + + + +
      +

      Plot Axes.png Plot Axes

      +
      Menu location +
      Plot → Axes‏‎ +
      Workbenches +
      Plot +
      Default shortcut +
      +
      See also +
      +

      Contents

      + +
      + +
      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Plot_Axes.png b/localwiki/Plot_Axes.png new file mode 100644 index 0000000..3b4726a Binary files /dev/null and b/localwiki/Plot_Axes.png differ diff --git a/localwiki/Plot_Basic_tutorial.html b/localwiki/Plot_Basic_tutorial.html new file mode 100644 index 0000000..c46ad20 --- /dev/null +++ b/localwiki/Plot_Basic_tutorial.html @@ -0,0 +1,177 @@ +Plot Basic tutorial

      Plot Basic tutorial

      + +
      + + + + + + + + + + + + + + + + + + + + + + + + + + + +
      +

      Base ExampleCommandModel.png Tutorial

      +
      Topic +
      Plot Workbench +
      Level +
      Beginner +
      Time to complete +
      +
      Author +
      +
      FreeCAD version +
      +
      Example File(s) +
      +

      + +
      +


      +

      In this tutorial we will learn how to perform a basic plot using Plot module and Python console. You can learn more about Plot module here. +

      +
      Basic plot example
      +
      Basic plot example.
      +

      In previous image you can see the result that we aproximately will obtain. Following this tutorial you will learn: +

      +
      • How to create a Plot from Python Console.
      • +
      • How to plot some data from Python Console.
      • +
      • How to show the grid lines.
      • +
      • How to show the legend.
      • +
      • How to edit series labels, introducing text in LaTeX.
      • +
      • How to edit axes labels, introducing text in LaTeX.
      • +
      • How to edit series styles.
      • +
      • How to save your plot.
      +

      Plotting data

      +

      In order to plot data you don't need to create a new FreeCAD document, simply show the Python console and start sending commands, or use macros. +

      +

      Creating plot document

      +

      Plots are special documents that can be created manually in order to add data later, or allow the module creates one authomatically when you start plotting data. Create your own plot documents have 2 advantages: +

      +
      • You can set the document window label.
      • +
      • You can control easily on wich document you plot your data.
      +

      In order to create new plot document simply launch following commands: +

      +
      import Plot
      +Plot.figure("TrigonometricTest")
      +

      That will create a new tab on main windows called TrigonometricTest. The new created document already have a set of axes. Each plot document have at least one set of axes that can be removed without using fully matplotlib control. +

      +

      Drawing functions

      +

      You can start working here due to plot command will start a new document, but all plot commands that you execute will append series to created plot until you don't create a new document, so ussually is better options control the opened plot documents. First thing that we need to do is create the data for sine and cosine functions that we want to plot: +

      +
      import math
      +t = range(0,101)
      +t = [tt/100.0 for tt in t]
      +s = [math.sin(2.0*math.pi*tt) for tt in t]
      +c = [math.cos(2.0*math.pi*tt) for tt in t]
      +

      That will create 3 arrays of data (with 101 points): +

      +
      • t = Time in seconds.
      • +
      • s = Sine function.
      • +
      • c = Cosine function.
      +

      In order to plot both function we only need to launch next commands: +

      +
      Plot.plot(t,s)
      +Plot.plot(t,c)
      +

      That will plot our functions. plot command allows the series label as argument, but since we will edit it later using Plot module tools we don't pass this data yet. +

      +

      Configuring plot

      +

      Showing grid and legend

      +

      Change FreeCAD workbench to Plot module in View/Workbench menu. When module has been loaded use grid tool in order to show it. +

      +
      Show/hide grid tool icon
      +
      Show/hide grid tool icon.
      +

      You can repeat the action in order to hide it. Also you can show the legend with the tool provided. +

      +
      Show/hide legend tool icon
      +
      Show/hide legend tool icon.
      +

      As you can see, legend is empty because we have not set any series label yet. In Plot module series without label are not represented at legend, in order to allow you to draw auxiliar lines. +

      +

      Setting series labels

      +

      With the series tool you can edit some series parameters. +

      +
      Series configuration tool icon
      +
      Series configuration tool icon.
      +

      First for all select the line that you want to edit, for example we will start with the first one. Uncheck No label and set this label: +

      +
      $y = \sin \left( 2 \pi t \right)$
      +

      Since matplotlib supports LaTeX you can set all the labels or titles that you want using it. Set the following label to second serie: +

      +
      $y = \cos \left( 2 \pi t \right)$
      +

      Setting series style

      +

      Series allows you to set a lot of series properties. Try to set the properties shown at the example image, changing series colors and drawing style of the second one. +

      +

      Setting axes labels

      +

      With the labels tool you can set labels associated to all created axes. +

      +
      Labels tool icon
      +
      Labels tool icon.
      +

      Set this data: +

      +
      • Title = Trigonometric functions example
      • +
      • X Label = $t$
      • +
      • Y Label = $y = \mathrm{f} \left( t \right)$
      +

      Also change the size of all of them to 20. +

      +

      Saving plot

      +

      With saving plot tool you can save your plot as image file in several formats. +

      +
      Save tool icon
      +
      Save tool icon.
      +

      First for all select the path of the output file. You can use file selection dialog using the button at right of the path edition line. +

      You can set the output image size in inches, for example we can set 11.7x8.3 that is a DIN A4 paper size. DPI (Dots per inch) will control the image resolution, for example using 100 dpi you will get an image of 1170x830 pixels. +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Plot_Grid.html b/localwiki/Plot_Grid.html new file mode 100644 index 0000000..20e7a76 --- /dev/null +++ b/localwiki/Plot_Grid.html @@ -0,0 +1,63 @@ +Plot Grid

      Plot Grid

      + +
      +

      This documentation is not finished. Please help and contribute documentation. +

      See Draft ShapeString for good documented Command. Gui Command gives an overview over commands. And see List of Commands for other commands. +

      Go to Help FreeCAD to contribute. +

      +
      +


      +

      + + + + + + + + + + + + + + + + + + + + +
      +

      Plot Grid.png Plot Grid

      +
      Menu location +
      Plot → Grid‏‎ +
      Workbenches +
      Plot +
      Default shortcut +
      +
      See also +
      +

      Contents

      + +
      + +
      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Plot_Grid.png b/localwiki/Plot_Grid.png new file mode 100644 index 0000000..dcbaea9 Binary files /dev/null and b/localwiki/Plot_Grid.png differ diff --git a/localwiki/Plot_Labels.html b/localwiki/Plot_Labels.html new file mode 100644 index 0000000..b6a0736 --- /dev/null +++ b/localwiki/Plot_Labels.html @@ -0,0 +1,67 @@ +Plot Labels

      Plot Labels

      + +
      +

      This documentation is not finished. Please help and contribute documentation. +

      See Draft ShapeString for good documented Command. Gui Command gives an overview over commands. And see List of Commands for other commands. +

      Go to Help FreeCAD to contribute. +

      +
      +


      +

      + + + + + + + + + + + + + + + + + + + + +
      +

      Plot Labels.png Plot Labels

      +
      Menu location +
      Plot → Labels‏‎ +
      Workbenches +
      Plot +
      Default shortcut +
      +
      See also +
      +

      Contents

      + +
      + +
      +


      +


      +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Plot_Labels.png b/localwiki/Plot_Labels.png new file mode 100644 index 0000000..ea74f21 Binary files /dev/null and b/localwiki/Plot_Labels.png differ diff --git a/localwiki/Plot_Legend.html b/localwiki/Plot_Legend.html new file mode 100644 index 0000000..79d9ade --- /dev/null +++ b/localwiki/Plot_Legend.html @@ -0,0 +1,67 @@ +Plot Legend

      Plot Legend

      + +
      +

      This documentation is not finished. Please help and contribute documentation. +

      See Draft ShapeString for good documented Command. Gui Command gives an overview over commands. And see List of Commands for other commands. +

      Go to Help FreeCAD to contribute. +

      +
      +


      +

      + + + + + + + + + + + + + + + + + + + + +
      +

      Plot Legend.png Plot Legend

      +
      Menu location +
      Plot → Legend‏‎ +
      Workbenches +
      Plot +
      Default shortcut +
      +
      See also +
      +

      Contents

      + +
      + +
      +


      +


      +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Plot_Legend.png b/localwiki/Plot_Legend.png new file mode 100644 index 0000000..ac0b6da Binary files /dev/null and b/localwiki/Plot_Legend.png differ diff --git a/localwiki/Plot_Module.html b/localwiki/Plot_Module.html new file mode 100644 index 0000000..cec79de --- /dev/null +++ b/localwiki/Plot_Module.html @@ -0,0 +1,37 @@ +Plot Module

      Plot Module

      + +

      The Plot module allows to edit and save output plots created from other modules and tools. With plot module you can edit easily the working area, the axes, labels, titles, styles, etc. Plot module is an abstraction of matplotlib conveniently addapted to FreeCAD. +

      +

      Tools

      +

      These are tools availables. +

      +
      • Plot Save.png Save plot: Saves the plot in several formats. You can select the output size and resolution too.
      • +
      • Plot Axes.png Axes: Add, remove or edit plot axes.
      • +
      • Plot Series.png Series: Edit series title and styling.
      • +
      • Plot Grid.png Grid: Show/hide grid.
      • +
      • Plot Legend.png Legend: Show/hide legend.
      • +
      • Plot Labels.png Labels: Edit labels.
      • +
      • Plot Positions.png Positions: Set elements positions.
      +

      Scripting

      +

      Since Plot module is a layer over matplotlib, you are free to use all matplotlib commands over plot instances. See scripting examples section to see examples. +

      +

      Tutorial

      + + +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Plot_MultiAxes_tutorial.html b/localwiki/Plot_MultiAxes_tutorial.html new file mode 100644 index 0000000..eb735db --- /dev/null +++ b/localwiki/Plot_MultiAxes_tutorial.html @@ -0,0 +1,164 @@ +Plot MultiAxes tutorial

      Plot MultiAxes tutorial

      + +
      + + + + + + + + + + + + + + + + + + + + + + + + + + + +
      +

      Base ExampleCommandModel.png Tutorial

      +
      Topic +
      Plot workbench +
      Level +
      Intermediate +
      Time to complete +
      +
      Author +
      +
      FreeCAD version +
      +
      Example File(s) +
      +

      + +
      +


      +

      Ensure to visit basic tutorial before starting with this tutorial. In this tutorial we will learn how to create and edit a multiaxes plot. You can learn more about Plot module here. +

      +
      Multiaxes plot example
      +
      Multiaxes plot example.
      +

      In previous image you can see the result that we aproximately will obtain. Following this tutorial you will learn: +

      +
      • How to create a multiaxes Plot from Python Console.
      • +
      • How to edit axes properties.
      • +
      • How to control grid/legend when several axes is present.
      • +
      • How to edit labels, titles and legend positions.
      +

      Plotting data

      +

      As we did in previous tutorial we will use the Python console or macros in order to plot the data, with the difference that in this case we will plot the data in two different axes. +

      +

      Creating plot data

      +

      In this example we will plot 3 functions, the two ones used in previous tutorial, and another polynomial one. The fact is that the polynomial one will need new axes due to the variation range is different from all others. Next commands will create data arrays for us: +

      +
      import math
      +p = range(0,1001)
      +x = [2.0*xx/1000.0 for xx in p]
      +y = [xx**2.0 for xx in x]
      +t = [tt/1000.0 for tt in p]
      +s = [math.sin(math.pi*2.0*tt) for tt in t]
      +c = [math.cos(math.pi*2.0*tt) for tt in t]
      +

      As x moves from 0 to 2, y function has a maximum value of 4, so if we try to plot this function with trigonometrical ones, at least one function will be truncated or bad scaled, then we need a multiaxes plot. Multiaxes plot in FreeCAD is oriented to get a plot with multiple axes, not to get multiple plots in same document. +

      +

      Drawing functions, adding new axes

      +

      We will draw polynomial function at main axes. If all your axes will have same size then is not relevant what function is ploted in what axes, but if your plot has axes with other size (as in this example), main axes must be the biggest one (because this axes have the white background). In order to do it we only need to launch a command +

      +
      import Plot
      +Plot.plot(x,y,r"$x^2$")
      +

      In this example we pass directly the series label for the legend. Note that the label string has the r prefix in order to avoid Python try to interpret special characters (\ symbol is used frecuently in LaTeX syntax). +

      Now we can plot trigonometrical functions, creating new axes before. In FreeCAD Plot module when you create new axes this axes are selected as active ones, so new plots will be associated to this axes. +

      +
      Plot.addNewAxes()
      +Plot.plot(t,s,r"$\sin\left( 2 \pi t \right)$")
      +Plot.plot(t,c,r"$\cos\left( 2 \pi t \right)$")
      +

      As you can see you plot has gone crazy, with axes ticks overlaped, curves of same color, etc. Now we needs to use FreeCAD Plot module to fix this graph. +

      +

      Configuring plot

      +

      Configuring axes

      +

      FreeCAD Plot module provides a tool in order to modify the properties of each axes. +

      +
      Axes configuration tool icon
      +
      Axes configuration tool icon.
      +

      The first thing that you can find in axes tool is the active axes selector. Since the active axes are the last one, active axes is placed at one. The axes tool, as labels tool, allows to set the active axes, allowing you to plot more data in the axes that you want (including add/remove axes). For the moment we will work over the selected axes, that are the associated to trigonometrical functions. +

      In the dimensions sliders, we will move left horizontal and bottom vertical sliders (try to emulate example) in order to reduce axes size. Then we can set the axes alignement, changing it to top and right, and setting and small offset of two units. +

      +

      Configuring series

      +

      Set series properties as we did in previous tutorial. +

      +

      Showing grid and legend

      +

      Grid and legend is shown and hide with the same tools that used in previous tutorial, but in this case the behaviour is a little bit different due to the presence of two different axes. +

      Regarding grid lines, you can show lines for each axes set, for example, if you try to show grid now you will show only the grid of the trigonometrical functions, so in order to show the grid of polynomial function plot you needs to change active axes to 0 (using axes configuration tool) before using grid tool another time (Is possible that you need to press two times the tool). +

      Regarding legend, the legend will be the same for both axes, so you can choose the axes that you want in order to show the legend, but is strongly recommended to use the biggest ones (0 in this example) because position will be refered to this axes coordinates. If you show the legend you can see that is really bad placed, we will fix this problem later. +

      +

      Setting axes labels

      +

      You can set axes labels with same tool used in previous tutorial, with the difference that now you have more axes. Since axes labels is ussually set as one per axis, is not a significant difference, but FreeCAD Plot module allow you to set a title by axes too. In this case we only wants to set title to main axes, so set: +

      Axes 0: +

      +
      • Title = Multiaxes example
      • +
      • X Label = $x$
      • +
      • Y Label = $\mathrm{f} \left( x \right)$
      +

      Axes 1: +

      +
      • X Label = $t$
      • +
      • Y Label = $\mathrm{f} \left( t \right)$
      +

      Set also 20 to fontsize for all but title, that uses a fontsize of 24. As happens with legend, title is bad placed, interseting with second axes set, so we need to solve both problems. +

      +

      Setting elements position

      +

      FreeCAD Plot module provides a tool in order to set the position of several plot elements, as titles, labels or legend. +

      +
      Position editor icon
      +
      Position editor icon.
      +

      When you run the tool you see a list with all the editable elements. Title elements, as well as legend, can be moved in both directions, since axes labels can be moved only on the axes direction. Select title of axes 0 and move it to (0.24,1.01), then select legend and move it to a better position. You can increase legend labels fontsize too. +

      +

      Saving plot

      +

      Now you can save your work. See previous tutorial if you don't remeber how to do it. +


      +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Plot_Positions.html b/localwiki/Plot_Positions.html new file mode 100644 index 0000000..87e5537 --- /dev/null +++ b/localwiki/Plot_Positions.html @@ -0,0 +1,63 @@ +Plot Positions

      Plot Positions

      + +
      +

      This documentation is not finished. Please help and contribute documentation. +

      See Draft ShapeString for good documented Command. Gui Command gives an overview over commands. And see List of Commands for other commands. +

      Go to Help FreeCAD to contribute. +

      +
      +


      +

      + + + + + + + + + + + + + + + + + + + + +
      +

      Plot Positions.png Plot Positions

      +
      Menu location +
      Plot → Positions +
      Workbenches +
      Plot +
      Default shortcut +
      +
      See also +
      +

      Contents

      + +
      + +
      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Plot_Positions.png b/localwiki/Plot_Positions.png new file mode 100644 index 0000000..023d810 Binary files /dev/null and b/localwiki/Plot_Positions.png differ diff --git a/localwiki/Plot_Save.html b/localwiki/Plot_Save.html new file mode 100644 index 0000000..17082f9 --- /dev/null +++ b/localwiki/Plot_Save.html @@ -0,0 +1,83 @@ +Plot Save

      Plot Save

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Plot Save.png Plot Save

      +
      Menu location +
      Plot → Save plot +
      Workbenches +
      Plot +
      Default shortcut +
      None +
      See also +
      None +

      + +
      +


      +

      +

      Description

      +

      Plot save tool saves the active plot at desired location. With this tool you can also select the size and resolution of output image. +

      Plot Trigonometric Example.png +

      +

      How to use

      +

      Select the plot tab that you want to save, and run this tool. Use path selector button in order to show a file dialog where you can choose the output image place and format. +

      Path selection button +Path selection button +

      +

      Options

      +
      • File path: You can set the output image path (including format extension) inserting it at text line too.
      • +
      • Size: You can specify output image width and height (inches).
      • +
      • dpi: You can set the image resolution (Dots Per Inch). Final resolution (in pixels) will be the multiplication of width and height by dpi.
      +

      Scripting

      +

      Plot save tool can be used in macros and from Python console by using the following function: +

      save(str, (float, float), float) : Saves the plot at path, width the size specified in inches, and the resolution specified in Dots Per Inch. +

      Example: +

      +
      import Plot
      +Plot.save("~/example.pdf", (12.8, 9.6), 50) 
      +

      That will save a pdf image of 12.8x9.6 inches, with 640x480 pixels. +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Plot_Save.png b/localwiki/Plot_Save.png new file mode 100644 index 0000000..9e6eb18 Binary files /dev/null and b/localwiki/Plot_Save.png differ diff --git a/localwiki/Plot_Save_Path.png b/localwiki/Plot_Save_Path.png new file mode 100644 index 0000000..58a1090 Binary files /dev/null and b/localwiki/Plot_Save_Path.png differ diff --git a/localwiki/Plot_Series.html b/localwiki/Plot_Series.html new file mode 100644 index 0000000..7d1853b --- /dev/null +++ b/localwiki/Plot_Series.html @@ -0,0 +1,63 @@ +Plot Series

      Plot Series

      + +
      +

      This documentation is not finished. Please help and contribute documentation. +

      See Draft ShapeString for good documented Command. Gui Command gives an overview over commands. And see List of Commands for other commands. +

      Go to Help FreeCAD to contribute. +

      +
      +


      +

      + + + + + + + + + + + + + + + + + + + + +
      +

      Plot Series.png Plot Series

      +
      Menu location +
      Plot → Series‏‎ +
      Workbenches +
      Plot +
      Default shortcut +
      +
      See also +
      +

      Contents

      + +
      + +
      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Plot_Series.png b/localwiki/Plot_Series.png new file mode 100644 index 0000000..7575e39 Binary files /dev/null and b/localwiki/Plot_Series.png differ diff --git a/localwiki/Plus.svg b/localwiki/Plus.svg new file mode 100644 index 0000000..2ea4c15 --- /dev/null +++ b/localwiki/Plus.svg @@ -0,0 +1,153 @@ + + + + + + + + + + + + image/svg+xml + + + + + Pablo Gil + + + + + SVG + template + + + + + + + + + + + + + + + + diff --git a/localwiki/Pocket_options.png b/localwiki/Pocket_options.png new file mode 100644 index 0000000..c58de2a Binary files /dev/null and b/localwiki/Pocket_options.png differ diff --git a/localwiki/PointsWorkbench.svg b/localwiki/PointsWorkbench.svg new file mode 100644 index 0000000..24d5dd3 --- /dev/null +++ b/localwiki/PointsWorkbench.svg @@ -0,0 +1,151 @@ + + + + + + image/svg+xml + + + + $committer + + + + 2016-02-26 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Points/Gui/Resources/icons/PointsWorkbench.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Points_ExportPoints.html b/localwiki/Points_ExportPoints.html new file mode 100644 index 0000000..4200adb --- /dev/null +++ b/localwiki/Points_ExportPoints.html @@ -0,0 +1,73 @@ +Points ExportPoints

      Points ExportPoints

      + +
      +

      This documentation is not finished. Please help and contribute documentation. +

      See Draft ShapeString for good documented Command. Gui Command gives an overview over commands. And see List of Commands for other commands. +

      Go to Help FreeCAD to contribute. +

      +
      +


      +

      + + + + + + + + + + + + + + + + + + + + +
      +

      Points ExportPoints.png Points ExportPoints

      +
      Menu location +
      Points → Export points... +
      Workbenches +
      Points +
      Default shortcut +
      +
      See also +
      +

      + +
      +


      +


      +

      +

      Introduction

      +

      TODO +


      +

      +

      Tutorials

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Points_Export_Point_cloud.svg b/localwiki/Points_Export_Point_cloud.svg new file mode 100644 index 0000000..9873342 --- /dev/null +++ b/localwiki/Points_Export_Point_cloud.svg @@ -0,0 +1,1078 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [agryson] Alexander Gryson + + + + + + media + stop + playback + video + music + + + + + + [agryson] Alexander Gryson + + + [agryson] Alexander Gryson + + + Points_Export_Point_cloud + 2014-01-26 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Points/Gui/Resources/icons/Points_Export_Point_cloud.svg + + + FreeCAD LGPL2+ + + + + + [agryson] Alexander Gryson + + + http://agryson.net + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Points_ImportPoints.html b/localwiki/Points_ImportPoints.html new file mode 100644 index 0000000..25ae188 --- /dev/null +++ b/localwiki/Points_ImportPoints.html @@ -0,0 +1,83 @@ +Points ImportPoints

      Points ImportPoints

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Points ImportPoints.png Points ImportPoints

      +
      Menu location +
      Points → Import points... +
      Workbenches +
      Points +
      Default shortcut +
      +
      See also +
      +

      + +
      +


      +

      +

      Description

      +

      Imports points from a point cloud file. +

      +

      Use

      +

      Click on Points ImportPoints.png or choose PointsPoints ImportPoints.png Import points... from the top menu. +

      +

      Limitations

      +

      The coordinates of the points have to be stored in a text file.
      +The ending of the file has to be ".asc".
      +The coordinates have to use point (NOT comma) and have to be separated by a space. +

      Example point-cloud-file +

      +
      0 0 0
      +1.4562 -7.2354 12.2367
      +5.9423 3.1728 -17.6439 
      +

      Notes

      +

      For testing you can use a low poly version of the famous stanford bunny.
      +You can download the pre-prepared asc-file by clicking here. +

      After importing, your points will be selectable in the 3D view and for example endpoint snap in draft-workbench could be used on these points.
      +But oppsosite to points inserted with the Draft-Point-Tool the points will be shown in the tree view as one whole point cloud object. +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Points_Import_Point_cloud.svg b/localwiki/Points_Import_Point_cloud.svg new file mode 100644 index 0000000..cd4d9c0 --- /dev/null +++ b/localwiki/Points_Import_Point_cloud.svg @@ -0,0 +1,223 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [agryson] ALexadner Gryson + + + + + + media + stop + playback + video + music + + + + + + [agryson] Alexander Gryson + + + [agryson] Alexander Gryson + + + Points_Import_Point_cloud + 2014-01-26 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Points/Gui/Resources/icons/Points_Import_Point_cloud.svg + + + FreeCAD LGPL2+ + + + http://agryson.net + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Points_Module.html b/localwiki/Points_Module.html new file mode 100644 index 0000000..b82fee4 --- /dev/null +++ b/localwiki/Points_Module.html @@ -0,0 +1,33 @@ +Points Module

      Points Module

      + +

      The Points module is made to give you specific tools for working with point clouds. It is still in development. +

      These tools are already available: +

      + +

      At the moment, the points cloud workbench has no automatic routines to deal with the imported points.
      +But linking against the points cloud library (the windows version of FreeCAD already has that capability) you could
      +use python commands to further process your data, see discusion here and here (german sub-form).
      +Another interesting discussion here (english Help-Forum).
      +

      Of course you could also use the draft workbench within FreeCAD and connect the points using draft elements.
      +Using snap-mode "end-point" will ensure snapping to the points. +


      +

      + +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Polarpattern_example2.jpg b/localwiki/Polarpattern_example2.jpg new file mode 100644 index 0000000..32db30f Binary files /dev/null and b/localwiki/Polarpattern_example2.jpg differ diff --git a/localwiki/PolygonPick.svg b/localwiki/PolygonPick.svg new file mode 100644 index 0000000..486b60c --- /dev/null +++ b/localwiki/PolygonPick.svg @@ -0,0 +1,102 @@ + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + + + + + + diff --git a/localwiki/Position.svg b/localwiki/Position.svg new file mode 100644 index 0000000..f4b4795 --- /dev/null +++ b/localwiki/Position.svg @@ -0,0 +1,123 @@ + + + + + Position + + + + + + image/svg+xml + + Position + + + bavariaSHAPE + + + + + bavariaSHAPE + + + + + bavariaSHAPE + + + 15.10.2016 + Geometric dimensioning and tolerancing symbols +All symbols in this repository are licensed under CC-BY 3.0 + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Positions.svg b/localwiki/Positions.svg new file mode 100644 index 0000000..56ebacf --- /dev/null +++ b/localwiki/Positions.svg @@ -0,0 +1,268 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [Jose Luis Cercos Pita] + + + Positions + 2012-11-02 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Plot/resources/icons/Positions.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Povray.jpg b/localwiki/Povray.jpg new file mode 100644 index 0000000..27ec0d5 Binary files /dev/null and b/localwiki/Povray.jpg differ diff --git a/localwiki/Pref_Draft_Snapping.png b/localwiki/Pref_Draft_Snapping.png new file mode 100644 index 0000000..4fb1daf Binary files /dev/null and b/localwiki/Pref_Draft_Snapping.png differ diff --git a/localwiki/Preference_Arch_Tab_01.png b/localwiki/Preference_Arch_Tab_01.png new file mode 100644 index 0000000..d55ae25 Binary files /dev/null and b/localwiki/Preference_Arch_Tab_01.png differ diff --git a/localwiki/Preference_Arch_Tab_02.png b/localwiki/Preference_Arch_Tab_02.png new file mode 100644 index 0000000..1656c2f Binary files /dev/null and b/localwiki/Preference_Arch_Tab_02.png differ diff --git a/localwiki/Preference_Display_Tab_01.png b/localwiki/Preference_Display_Tab_01.png new file mode 100644 index 0000000..bb7ac4f Binary files /dev/null and b/localwiki/Preference_Display_Tab_01.png differ diff --git a/localwiki/Preference_Display_Tab_02.png b/localwiki/Preference_Display_Tab_02.png new file mode 100644 index 0000000..7c69445 Binary files /dev/null and b/localwiki/Preference_Display_Tab_02.png differ diff --git a/localwiki/Preference_Display_Tab_03.png b/localwiki/Preference_Display_Tab_03.png new file mode 100644 index 0000000..5cd8135 Binary files /dev/null and b/localwiki/Preference_Display_Tab_03.png differ diff --git a/localwiki/Preference_Draft_Tab_01.png b/localwiki/Preference_Draft_Tab_01.png new file mode 100644 index 0000000..a8c9e33 Binary files /dev/null and b/localwiki/Preference_Draft_Tab_01.png differ diff --git a/localwiki/Preference_Draft_Tab_02.png b/localwiki/Preference_Draft_Tab_02.png new file mode 100644 index 0000000..3940378 Binary files /dev/null and b/localwiki/Preference_Draft_Tab_02.png differ diff --git a/localwiki/Preference_Draft_Tab_03.png b/localwiki/Preference_Draft_Tab_03.png new file mode 100644 index 0000000..1c98a9e Binary files /dev/null and b/localwiki/Preference_Draft_Tab_03.png differ diff --git a/localwiki/Preference_Draft_Tab_04.png b/localwiki/Preference_Draft_Tab_04.png new file mode 100644 index 0000000..51991b5 Binary files /dev/null and b/localwiki/Preference_Draft_Tab_04.png differ diff --git a/localwiki/Preference_Fem_Tab_01.png b/localwiki/Preference_Fem_Tab_01.png new file mode 100644 index 0000000..c91af11 Binary files /dev/null and b/localwiki/Preference_Fem_Tab_01.png differ diff --git a/localwiki/Preference_Fem_Tab_02.png b/localwiki/Preference_Fem_Tab_02.png new file mode 100644 index 0000000..7f062f0 Binary files /dev/null and b/localwiki/Preference_Fem_Tab_02.png differ diff --git a/localwiki/Preference_Fem_Tab_03.png b/localwiki/Preference_Fem_Tab_03.png new file mode 100644 index 0000000..d9492f0 Binary files /dev/null and b/localwiki/Preference_Fem_Tab_03.png differ diff --git a/localwiki/Preference_Fem_Tab_04.png b/localwiki/Preference_Fem_Tab_04.png new file mode 100644 index 0000000..e83354f Binary files /dev/null and b/localwiki/Preference_Fem_Tab_04.png differ diff --git a/localwiki/Preference_Fem_Tab_05.png b/localwiki/Preference_Fem_Tab_05.png new file mode 100644 index 0000000..56e3c87 Binary files /dev/null and b/localwiki/Preference_Fem_Tab_05.png differ diff --git a/localwiki/Preference_General_Tab_01.png b/localwiki/Preference_General_Tab_01.png new file mode 100644 index 0000000..eff78b8 Binary files /dev/null and b/localwiki/Preference_General_Tab_01.png differ diff --git a/localwiki/Preference_General_Tab_02.png b/localwiki/Preference_General_Tab_02.png new file mode 100644 index 0000000..9476fc0 Binary files /dev/null and b/localwiki/Preference_General_Tab_02.png differ diff --git a/localwiki/Preference_General_Tab_03.png b/localwiki/Preference_General_Tab_03.png new file mode 100644 index 0000000..2b57256 Binary files /dev/null and b/localwiki/Preference_General_Tab_03.png differ diff --git a/localwiki/Preference_General_Tab_04.png b/localwiki/Preference_General_Tab_04.png new file mode 100644 index 0000000..bf69177 Binary files /dev/null and b/localwiki/Preference_General_Tab_04.png differ diff --git a/localwiki/Preference_General_Tab_05.png b/localwiki/Preference_General_Tab_05.png new file mode 100644 index 0000000..670a980 Binary files /dev/null and b/localwiki/Preference_General_Tab_05.png differ diff --git a/localwiki/Preference_General_Tab_06.png b/localwiki/Preference_General_Tab_06.png new file mode 100644 index 0000000..80af4bd Binary files /dev/null and b/localwiki/Preference_General_Tab_06.png differ diff --git a/localwiki/Preference_Import_Export_Tab_01.png b/localwiki/Preference_Import_Export_Tab_01.png new file mode 100644 index 0000000..f7c7053 Binary files /dev/null and b/localwiki/Preference_Import_Export_Tab_01.png differ diff --git a/localwiki/Preference_Import_Export_Tab_02.png b/localwiki/Preference_Import_Export_Tab_02.png new file mode 100644 index 0000000..d250d82 Binary files /dev/null and b/localwiki/Preference_Import_Export_Tab_02.png differ diff --git a/localwiki/Preference_Import_Export_Tab_03.png b/localwiki/Preference_Import_Export_Tab_03.png new file mode 100644 index 0000000..a76f28d Binary files /dev/null and b/localwiki/Preference_Import_Export_Tab_03.png differ diff --git a/localwiki/Preference_Import_Export_Tab_04.png b/localwiki/Preference_Import_Export_Tab_04.png new file mode 100644 index 0000000..4672489 Binary files /dev/null and b/localwiki/Preference_Import_Export_Tab_04.png differ diff --git a/localwiki/Preference_Import_Export_Tab_05.png b/localwiki/Preference_Import_Export_Tab_05.png new file mode 100644 index 0000000..078f40c Binary files /dev/null and b/localwiki/Preference_Import_Export_Tab_05.png differ diff --git a/localwiki/Preference_Import_Export_Tab_06.png b/localwiki/Preference_Import_Export_Tab_06.png new file mode 100644 index 0000000..4bc19b0 Binary files /dev/null and b/localwiki/Preference_Import_Export_Tab_06.png differ diff --git a/localwiki/Preference_Import_Export_Tab_07.png b/localwiki/Preference_Import_Export_Tab_07.png new file mode 100644 index 0000000..30bc91b Binary files /dev/null and b/localwiki/Preference_Import_Export_Tab_07.png differ diff --git a/localwiki/Preference_Import_Export_Tab_08.png b/localwiki/Preference_Import_Export_Tab_08.png new file mode 100644 index 0000000..73f984b Binary files /dev/null and b/localwiki/Preference_Import_Export_Tab_08.png differ diff --git a/localwiki/Preference_Import_Export_Tab_09.png b/localwiki/Preference_Import_Export_Tab_09.png new file mode 100644 index 0000000..6ccbdb7 Binary files /dev/null and b/localwiki/Preference_Import_Export_Tab_09.png differ diff --git a/localwiki/Preference_OpenSCAD_Tab_01.png b/localwiki/Preference_OpenSCAD_Tab_01.png new file mode 100644 index 0000000..b3deb8b Binary files /dev/null and b/localwiki/Preference_OpenSCAD_Tab_01.png differ diff --git a/localwiki/Preference_Part_Design_Tab_01.png b/localwiki/Preference_Part_Design_Tab_01.png new file mode 100644 index 0000000..14c1b66 Binary files /dev/null and b/localwiki/Preference_Part_Design_Tab_01.png differ diff --git a/localwiki/Preference_Part_Design_Tab_02.png b/localwiki/Preference_Part_Design_Tab_02.png new file mode 100644 index 0000000..f0e823f Binary files /dev/null and b/localwiki/Preference_Part_Design_Tab_02.png differ diff --git a/localwiki/Preference_Path_Tab_01_1.png b/localwiki/Preference_Path_Tab_01_1.png new file mode 100644 index 0000000..b459fcc Binary files /dev/null and b/localwiki/Preference_Path_Tab_01_1.png differ diff --git a/localwiki/Preference_Path_Tab_01_2.png b/localwiki/Preference_Path_Tab_01_2.png new file mode 100644 index 0000000..e5e70cd Binary files /dev/null and b/localwiki/Preference_Path_Tab_01_2.png differ diff --git a/localwiki/Preference_Path_Tab_01_3.png b/localwiki/Preference_Path_Tab_01_3.png new file mode 100644 index 0000000..86c46be Binary files /dev/null and b/localwiki/Preference_Path_Tab_01_3.png differ diff --git a/localwiki/Preference_Path_Tab_02.png b/localwiki/Preference_Path_Tab_02.png new file mode 100644 index 0000000..d396f82 Binary files /dev/null and b/localwiki/Preference_Path_Tab_02.png differ diff --git a/localwiki/Preference_Path_Tab_03.png b/localwiki/Preference_Path_Tab_03.png new file mode 100644 index 0000000..ed35b59 Binary files /dev/null and b/localwiki/Preference_Path_Tab_03.png differ diff --git a/localwiki/Preference_Raytracing_Tab_01.png b/localwiki/Preference_Raytracing_Tab_01.png new file mode 100644 index 0000000..1527087 Binary files /dev/null and b/localwiki/Preference_Raytracing_Tab_01.png differ diff --git a/localwiki/Preference_Sketcher_Tab_01.png b/localwiki/Preference_Sketcher_Tab_01.png new file mode 100644 index 0000000..9611ffd Binary files /dev/null and b/localwiki/Preference_Sketcher_Tab_01.png differ diff --git a/localwiki/Preference_Sketcher_Tab_02.png b/localwiki/Preference_Sketcher_Tab_02.png new file mode 100644 index 0000000..a04c80c Binary files /dev/null and b/localwiki/Preference_Sketcher_Tab_02.png differ diff --git a/localwiki/Preferences-arch.svg b/localwiki/Preferences-arch.svg new file mode 100644 index 0000000..0840f43 --- /dev/null +++ b/localwiki/Preferences-arch.svg @@ -0,0 +1,666 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [triplus] + + + ArchWorkbench + 2016-02-26 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Arch/Resources/icons/ArchWorkbench.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Preferences-display.svg b/localwiki/Preferences-display.svg new file mode 100644 index 0000000..97ea133 --- /dev/null +++ b/localwiki/Preferences-display.svg @@ -0,0 +1,487 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + Video Display + + + + Jakub Steiner + + + + + video + display + monitor + LCD + CRT + + + + http://jimmac.musichall.cz/ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Preferences-draft.svg b/localwiki/Preferences-draft.svg new file mode 100644 index 0000000..8ac1558 --- /dev/null +++ b/localwiki/Preferences-draft.svg @@ -0,0 +1,364 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + preferences-draft + + Mon Oct 10 13:44:52 2011 +0000 + + + [wmayer] + + + + + FreeCAD LGPL2+ + + + + + FreeCAD + + + FreeCAD/src/Mod/Draft/Resources/icons/preferences-draft.svg + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + [agryson] Alexander Gryson + + + + + drafting board + ruler + right angle ruler + + + A right angle ruler resting on a ruler on a drafting board + + + + diff --git a/localwiki/Preferences-fem.svg b/localwiki/Preferences-fem.svg new file mode 100644 index 0000000..7b98dca --- /dev/null +++ b/localwiki/Preferences-fem.svg @@ -0,0 +1,1692 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Preferences-general.svg b/localwiki/Preferences-general.svg new file mode 100644 index 0000000..a6183e8 --- /dev/null +++ b/localwiki/Preferences-general.svg @@ -0,0 +1,396 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + Jakub Steiner + + + http://jimmac.musichall.cz + + Preferences System + + + preferences + settings + control panel + tweaks + system + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Preferences-import-export.svg b/localwiki/Preferences-import-export.svg new file mode 100644 index 0000000..8087778 --- /dev/null +++ b/localwiki/Preferences-import-export.svg @@ -0,0 +1,898 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + 2005-10-15 + + + Andreas Nilsson + + + + + edit + copy + + + + + + Jakub Steiner + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Preferences-openscad.svg b/localwiki/Preferences-openscad.svg new file mode 100644 index 0000000..b7b2ef6 --- /dev/null +++ b/localwiki/Preferences-openscad.svg @@ -0,0 +1,159 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [Sebastian Hoogen] + + + preferences-openscad + 2012-05-03 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/OpenSCAD/Resources/icons/preferences-openscad.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Preferences-part_design.svg b/localwiki/Preferences-part_design.svg new file mode 100644 index 0000000..ea4f3ee --- /dev/null +++ b/localwiki/Preferences-part_design.svg @@ -0,0 +1,184 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + Video Display + + + + Jakub Steiner + + + + + video + display + monitor + LCD + CRT + + + + http://jimmac.musichall.cz/ + 2011-10-10 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Part/Gui/Resources/icons/preferences-part_design.svg + + + FreeCAD LGPL2+ + + + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Preferences-path.svg b/localwiki/Preferences-path.svg new file mode 100644 index 0000000..64d5a67 --- /dev/null +++ b/localwiki/Preferences-path.svg @@ -0,0 +1,159 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + preferences-path + 2015-07-04 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Path/Gui/Resources/icons/preferences-path.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Preferences-raytracing.svg b/localwiki/Preferences-raytracing.svg new file mode 100644 index 0000000..6d36825 --- /dev/null +++ b/localwiki/Preferences-raytracing.svg @@ -0,0 +1,85 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + $committer + + + preferences-raytracing + 2011-10-10 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Raytracing/Gui/Resources/icons/preferences-raytracing.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + diff --git a/localwiki/Preferences-system.svg b/localwiki/Preferences-system.svg new file mode 100644 index 0000000..a6183e8 --- /dev/null +++ b/localwiki/Preferences-system.svg @@ -0,0 +1,396 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + Jakub Steiner + + + http://jimmac.musichall.cz + + Preferences System + + + preferences + settings + control panel + tweaks + system + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Preferences-techdraw.svg b/localwiki/Preferences-techdraw.svg new file mode 100644 index 0000000..41a0034 --- /dev/null +++ b/localwiki/Preferences-techdraw.svg @@ -0,0 +1,196 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [agryson] Alexander Gryson + + + http://agryson.net + + preferences-techdraw + 2016-01-19 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/TechDraw/Gui/Resources/icons/preferences-techdraw.svg + + + FreeCAD LGPL2+ + + + + + + [agryson] Alexander Gryson + + + [agryson] Alexander Gryson + + + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Preferences_Editor.html b/localwiki/Preferences_Editor.html new file mode 100644 index 0000000..4591dcd --- /dev/null +++ b/localwiki/Preferences_Editor.html @@ -0,0 +1,79 @@ +Preferences Editor

      Preferences Editor

      + +

      The preferences system of FreeCAD is located in the Edit menu → Preferences. +

      FreeCAD functionality is divided into different modules, each module being responsible for the working of a specific workbench. FreeCAD also uses a concept called late loading, which means that components are loaded only when they are needed. You may have noticed that when you select a workbench on the FreeCAD toolbar, that workbench and all its components get loaded at that moment. This includes its preferences settings. +

      Without any module loaded, you will have access to two configuration sections, responsible for the general application settings and for the display settings. +

      + + +

      The general preferences settings

      +

      When you start FreeCAD with no workbench loaded, you will then have a minimal preferences window. As you load additional modules, new sections will appear in the preferences window, allowing you to configure the details of each workbench. +

      +

      General

      +
      Preference General Tab 01.png
      +
      +

      Document

      +
      Preference General Tab 02.png
      +
      +

      Editor

      +
      Preference General Tab 03.png
      +
      +

      Output window

      +
      Preference General Tab 04.png
      +
      +

      Macro

      +
      Preference General Tab 05.png
      +
      +

      Units

      +
      Preference General Tab 06.png
      +
      +

      The display settings

      +

      FreeCAD is always in constant evolution, so the contents of those screens might differ from the above screenshots. The settings are usually self-explanatory, so you shouldn't have any difficulty configuring FreeCAD to your needs. +

      +

      3D View

      +
      Preference Display Tab 01.png
      +
      +

      Colors

      +
      Preference Display Tab 02.png
      +
      +

      Part Colors

      +
      Preference Display Tab 03.png
      +
      +

      The Draft module has its preferences screen +

      + +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Preview-rendered.svg b/localwiki/Preview-rendered.svg new file mode 100644 index 0000000..188558e --- /dev/null +++ b/localwiki/Preview-rendered.svg @@ -0,0 +1,65 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + $committer + + + preview-rendered + 2013-11-19 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Material/Resources/icons/preview-rendered.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + diff --git a/localwiki/Preview-vector.svg b/localwiki/Preview-vector.svg new file mode 100644 index 0000000..ba65341 --- /dev/null +++ b/localwiki/Preview-vector.svg @@ -0,0 +1,157 @@ + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + $committer + + + preview-vector + 2013-11-19 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Material/Resources/icons/preview-vector.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + diff --git a/localwiki/PrintPreview1.png b/localwiki/PrintPreview1.png new file mode 100644 index 0000000..9240828 Binary files /dev/null and b/localwiki/PrintPreview1.png differ diff --git a/localwiki/Process-stop.svg b/localwiki/Process-stop.svg new file mode 100644 index 0000000..6cf7df6 --- /dev/null +++ b/localwiki/Process-stop.svg @@ -0,0 +1,343 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + 2005-10-16 + + + Andreas Nilsson + + + + + stop + halt + error + + + + + + Jakub Steiner + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Product_structure_modeling_Process-Data_diagram.gif b/localwiki/Product_structure_modeling_Process-Data_diagram.gif new file mode 100644 index 0000000..d65c30e Binary files /dev/null and b/localwiki/Product_structure_modeling_Process-Data_diagram.gif differ diff --git a/localwiki/Profile_of_line.svg b/localwiki/Profile_of_line.svg new file mode 100644 index 0000000..fa2d795 --- /dev/null +++ b/localwiki/Profile_of_line.svg @@ -0,0 +1,112 @@ + + + + + Profile of line + + + + + + image/svg+xml + + Profile of line + + + bavariaSHAPE + + + + + bavariaSHAPE + + + + + bavariaSHAPE + + + 15.10.2016 + Geometric dimensioning and tolerancing symbols +All symbols in this repository are licensed under CC-BY 3.0 + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Profile_of_surface.svg b/localwiki/Profile_of_surface.svg new file mode 100644 index 0000000..f38d7c8 --- /dev/null +++ b/localwiki/Profile_of_surface.svg @@ -0,0 +1,112 @@ + + + + + Profile of surface + + + + + + image/svg+xml + + Profile of surface + + + bavariaSHAPE + + + + + bavariaSHAPE + + + + + bavariaSHAPE + + + 15.10.2016 + Geometric dimensioning and tolerancing symbols +All symbols in this repository are licensed under CC-BY 3.0 + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/ProjGroupSample.png b/localwiki/ProjGroupSample.png new file mode 100644 index 0000000..b153ffc Binary files /dev/null and b/localwiki/ProjGroupSample.png differ diff --git a/localwiki/ProjectShape1_it.png b/localwiki/ProjectShape1_it.png new file mode 100644 index 0000000..049b698 Binary files /dev/null and b/localwiki/ProjectShape1_it.png differ diff --git a/localwiki/ProjectShapeOptions_it.png b/localwiki/ProjectShapeOptions_it.png new file mode 100644 index 0000000..80e89fc Binary files /dev/null and b/localwiki/ProjectShapeOptions_it.png differ diff --git a/localwiki/ProjectShapeSet_it.png b/localwiki/ProjectShapeSet_it.png new file mode 100644 index 0000000..efc396a Binary files /dev/null and b/localwiki/ProjectShapeSet_it.png differ diff --git a/localwiki/Project_template.html b/localwiki/Project_template.html new file mode 100644 index 0000000..59ebc78 --- /dev/null +++ b/localwiki/Project_template.html @@ -0,0 +1,50 @@ +Project template

      Project template

      + +

      This template is the guideline for a FreeCAD development project. It follows the rules of the Getting Things Done (GTD) process. The projects are collected in the Development roadmap. +

      Lets start by looking at the Natural Planning Model. The Natural Planning Model really is nothing new. It is not some fantastic new model devised by David Allen to help us plan and manage our projects. it is however, the planning model that is recommended by David in his Getting Things Done book. The Natural Planning Model is based upon the planning that we do on a daily basis, using just our brains. For example, think of how many tasks we plan on a day by day basis that we do not even bother to write down as these are normally classed as mundane tasks. For example, getting dressed, or driving to work. All of these can be thought of tasks but we just go ahead and plan them without any thought whatsoever. We utilize the planning aspects of our brain that are conditioned for this natural type of planning. +

      You mind goes through five steps to accomplish virtually any task. These five steps are: +


      +

      + + +

      Purpose and principles

      +

      The first step in the model is to define purpose and principles. Think about the last time you booked a family holiday. There is always a purpose for the holiday. This could be to take a well earned break from work, to relax and spend quality time with your spouse and children, or simply to go and see a specific tourist attraction whilst on your holiday. Whatever the reason, there will have been purpose and principles for your trip. You don’t just get up one day and go on holiday, you implement stage one of the natural planning model and this is to have a purpose for the trip. +

      +

      Outcome

      +

      The second step is outcome visioning. Once you had defined a purpose and the principle for your holiday, the next thing you will have done is to have a vision of the outcome, in other words, where do you want to go, when, and who with? This is classed as outcome visioning as you are thinking about the outcome of your holiday and making mental notes about what you want the outcome to be. +

      +

      Brainstorming

      +

      The third step is brainstorming. This brainstorming is normally done within your mind, and also other people are usually included when the project or decision impacts upon them. For example, lets say you think about the Maldives for your holiday, but you are going in June. The brainstorming aspect will look at this and probably decide that as June is the rainy season in the Maldives, it may not be the best time to visit. This is a naturally creative aspect of your brain that helps narrow down the vision of the outcome into a definite decision. I say other people are included because for projects such as planning a holiday, you also have to take other peoples viewpoints into consideration. I am sure your spouse would have something to say if you booked the holiday with consulting, and brainstorming their viewpoints on the suitability of the trip and destination choice. + +

      +

      Organizing

      +

      The next, and fourth step is organizing. Once you have generated your ideas about the project, or holiday in this case, you start to organize these ideas. For example, you may have thought about the travel agent to use for the booking, or whether to book direct, if the in-laws would like to come on the vacation also to double as baby sitters, etc. Your mind normally sorts and organizes these thoughts automatically. +

      +

      Next actions

      +

      The last, and fifth step is to identify and set the next actions. The GTD methodology covers that the best way to get a task done, is to decide and set the next actions. We do not do tasks, we do next actions. So the best way to get your holiday booked is to decide what the next actions are. These normally would be items such as, look up the resort on the Internet, check online travel comparison sites for cheap flights and accommodation, call in and see a travel agent for their price and recommendation within the resort. Again, I would be surprised if any of you would take the time and effort to write these next actions down, but also, I would be surprised if any of you forgot these next actions. it is funny how our mind has a great way of remembering projects assigned and planning using the Natural Planning Method. +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Project_utility.html b/localwiki/Project_utility.html new file mode 100644 index 0000000..25b6ab2 --- /dev/null +++ b/localwiki/Project_utility.html @@ -0,0 +1,70 @@ +Project utility

      Project utility

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Std Project utility.png Std Project utility

      +
      Menu location +
      Tools → Project utility +
      Workbenches +
      All +
      Default shortcut +
      None +
      See also +
      ... +

      + +
      +


      +

      +

      Description

      +

      The "Project utility" is a tool to fix an FCStd file in case it's broken for any reason. Since an FCStd file is a zip archive the tool offers a function to extract a project, then the user can e.g. make changes on the Document.xml (or whatever he wants to do) and then he can build again a valid FCStd file. +


      +‎ +

      +
      +


      +

      +

      Links

      +

      File Format FCStd +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Project_utility_en.png b/localwiki/Project_utility_en.png new file mode 100644 index 0000000..3cf5867 Binary files /dev/null and b/localwiki/Project_utility_en.png differ diff --git a/localwiki/Property.html b/localwiki/Property.html new file mode 100644 index 0000000..397cba8 --- /dev/null +++ b/localwiki/Property.html @@ -0,0 +1,55 @@ +Property

      Property

      + +

      A property is a piece of information like a number or a text string that is attached to a FreeCAD document or an object in a document. Properties can be viewed and - if allowed - modified with the Property editor. +

      Properties play a very important part in FreeCAD, since it is from the beginning made to work with parametric objects, which are objects defined only by their properties. +

      Custom scripted objects in FreeCAD can have properties of the following types: +

      +
      Boolean
      +Float
      +FloatList
      +FloatConstraint
      +Angle
      +Distance
      +Integer
      +IntegerConstraint
      +Percent
      +Enumeration
      +IntegerList
      +String
      +StringList
      +Link
      +LinkList
      +Matrix
      +Vector
      +VectorList
      +Placement
      +PlacementLink
      +Color
      +ColorList
      +Material
      +Path
      +File
      +FileIncluded
      +PartShape
      +FilletContour
      +Circle
      +
      +


      +

      + +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Property.png b/localwiki/Property.png new file mode 100644 index 0000000..d923c9b Binary files /dev/null and b/localwiki/Property.png differ diff --git a/localwiki/Property.svg b/localwiki/Property.svg new file mode 100644 index 0000000..a23fd79 --- /dev/null +++ b/localwiki/Property.svg @@ -0,0 +1,301 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/PropertyMemo.png b/localwiki/PropertyMemo.png new file mode 100644 index 0000000..f582494 Binary files /dev/null and b/localwiki/PropertyMemo.png differ diff --git a/localwiki/Property_editor.html b/localwiki/Property_editor.html new file mode 100644 index 0000000..d2b81a8 --- /dev/null +++ b/localwiki/Property_editor.html @@ -0,0 +1,137 @@ +Property editor

      Property editor

      + +
      + +

      Overview

      +

      The Property Editor is one of the most important tools of FreeCAD and a main element while working with FreeCAD. +The Property Editor allows managing the properties of the objects in your document. +

      Generally the Property Editor is intended to deal with just one object at one time. The values shown in the Property Editor belong to the active object of your active document (be careful of which document is really active if you work on multiple documents). If you did not select any element (or there are no elements), the Property Editor will be blank. +

      Not all the properties can be modified in any moment. Depending on the specific status, some properties will be shown as read-only. +

      The properties of an object are grouped in View properties and Data properties, and shown under different tabs. +

      Different objects may have different properties. However, some properties are common among all objects, for instance the position and the rotation of an object are Data properties that can be manipulated. +

      +

      Property definition

      +

      A property is a piece of information like a number or a text string that is attached to a FreeCAD document or an object in a document. Properties can be viewed and - if allowed - modified with the Property editor. +

      Properties play a very important part in FreeCAD, since it is from the beginning made to work with parametric objects, which are objects defined only by their properties. +

      Custom scripted objects in FreeCAD can have properties of the following types: +

      +
      Boolean
      +Float
      +FloatList
      +FloatConstraint
      +Angle
      +Distance
      +Integer
      +IntegerConstraint
      +Percent
      +Enumeration
      +IntegerList
      +String
      +StringList
      +Link
      +LinkList
      +Matrix
      +Vector
      +VectorList
      +Placement
      +PlacementLink
      +Color
      +ColorList
      +Material
      +Path
      +File
      +FileIncluded
      +PartShape
      +FilletContour
      +Circle
      +
      +


      +

      +

      Function

      +

      The Property Editor has two tabs: the View tab and the Data tab. +

      +
      • The View tab provides access to the properties related to the visual display of the object
      • +
      • The Data tab allows modification of the physical parameters of an object.
      +

      Example of Part object properties

      +

      Properties

      +

      There are two types of feature properties, accessible through tabs at the bottom of the Property editor: +

      +
      VIEWView :properties related to the visual display of the object.
      +
      DATAData : properties related to the physical parameters of an object.
      +

      View

      +
      PartDesign Revolution en 03.png
      +

      Base +

      +
      • VIEWBounding Box : To view the occupation, and, overall, of the object dimensions in space. Value False, or True (Default, False).
      +
      • VIEWControl Point : Value False, or True (Default, False).
      +
      • VIEWDeviation : Sets the accuracy of the polygonal representation of the model in 3d view (tessellation). Lower values = better quality. The value is in percent of object's size (deviation in mm = (w+h+d)/3*valueInPercent/100, where w,h,d are sizes of bounding box).
      +
      • VIEWDisplay Mode :Display mode of the form, Flat lines, Shaded, Wireframe, Points Vue DisplayModePartDesign fr 00.png. (Default, Flat lines).
      +
      • VIEWLighting : Lighting One side, Two side Vue Lighting fr 00.png. (Default, Two side).
      +
      • VIEWLine Color : Gives the color of the line (edges) (Default, 25, 25, 25).
      +
      • VIEWLine Width : Gives the thickness of the line (edges) (Default, 2).
      +
      • VIEWPoint Color : Gives the color of the points (ends of the form) (Default, 25, 25, 25).
      +
      • VIEWPoint Size : Gives the size of the points (Default, 2).
      +
      • VIEWSelectable : Allows the selection of the form. Value False, ou True (Default, True).
      +
      • VIEWShape Color : Give the color shape (default, 204, 204, 204).
      +
      • VIEWTransparency : Sets the degree of transparency in the form of 0 to 100 (Default, 0).
      +
      • VIEWVisibility : Determines the visibility of the form (like the bar SPACE). Value False, or True (Default, True).
      +
      +


      +


      +

      +
      +


      +

      +

      Data

      +
      PartDesign Revolution en 04.png
      +

      Base +DATAAngle : The argument Angle, indicates the angle that will be used with the option Axis (below). Here, an angle is defined. The angle on the axis is set with the option Axis.
      The object takes the specified angle around the specified axis.
      An example, if you create an object with a required revolution should be rotate functionality of a certain amount, in order to enable it to take the same angle that another element existing. +

      DATAAxis : This option specifies the axis/axes to rotate the created object. The exact value of rotation comes from the angle (see above) option.
      This option takes three arguments, these arguments, are transmitted in the form of numbers, x, y or z. Adding a value, more of an axis, will the rotation to each specified axis angle.
      For example, with a Angle of 15 ° : specifying, 1.0 for x and 2.0 for y, will rotate 15 ° and 30 ° in the y-axis and the x-axis (final position), +

      DATABase : This option specifies the offset in either axes x, y, or z, and accept any number as the argument for each field. +

      DATALabel : The Label is the name given to the operation, this name can be changed at convenience. +

      DATAPlacement : [(0.00 0.00 1.00);0.00;(0.00 0.00 0.00)] Summary below data. +Every feature has a placement that can be controlled through the Data Properties table. It controls the placement of the part with respect to the coordinate system. NOTE: The placement options do not affect the physical dimensions of the feature, but merely its position in space!
      If you select the title Placement Options Placement, a button with three small points appears, clicking this button ..., you have access to the options window Tasks_Placement. +

      DATAAngle : +The Angle argument specifies the angle to be used with the axis option (below). An angle is set here, and the axis that the angle acts upon is set with the axis option. +The feature is rotated by the specified angle, about the specified axis. +A usage example might be if you created a revolution feature as required, but then needed to rotate the whole feature by some amount, in order to allow it to line-up with another pre-existing feature. +

      DATAAxis : +This option specifies the axis/axes about which the created feature is to be rotated. The exact value of rotation comes from the angle option (above). +This option takes three arguments, which are passed as numbers to either the x, y, or z boxes in the tool. Adding a value to more than one of the axes will cause the part to be rotated by the angle in each axis. +For example, with an angle of 15° set, specifying a value of 1.0 for x, and 2.0 for y will cause the finished part to be rotated 15° in the x-axis AND 30° in the y-axis. +

      DATAPosition : +This option specifies the base point to which all dimensions refer. This option takes three arguments, which are passed as numbers to either the x, y, or z boxes in the tool. Adding a value to more than one of the boxes will cause the part to be translated by the number of units along the corresponding axis. +

      +
      +

      PS: The displayed properties can vary, depending on the tool used. +


      +

      + +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Px.svg b/localwiki/Px.svg new file mode 100644 index 0000000..a776067 --- /dev/null +++ b/localwiki/Px.svg @@ -0,0 +1,151 @@ + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + + + + + + + + + + diff --git a/localwiki/PyQt.html b/localwiki/PyQt.html new file mode 100644 index 0000000..13eb2a0 --- /dev/null +++ b/localwiki/PyQt.html @@ -0,0 +1,38 @@ +PyQt

      PyQt

      (Redirected from PyQt)
      + +

      PySide

      +

      PySide is a Python binding of the cross-platform GUI toolkit Qt. FreeCAD uses PySide for all GUI (Graphic User Interface) purposes inside of Python. PySide is an alternative to the PyQt package which was previously used by FreeCAD for its GUI. PySide has a more permissible licence. See Differences Between PySide and PyQt for more information on the differences. +

      Users of FreeCAD often achieve everything using the built-in interface. But for users who want to customise their operations then the Python interface exists which is documented in the Python Scripting Tutorial. The Python interface for FreeCAD had great flexibility and power. For its user interaction Python with FreeCAD uses PySide, which is what is documented on this page. +

      Python offers the 'print' statement which gives the code: +

      +
      print 'Hello World' 
      +

      With Python's print statement you have only limited control of the appearance and behaviour. PySide supplies the missing control and also handles environments (such as the FreeCAD macro file environment) where the built-in facilities of Python are not enough. +

      PySide's abilities range from: +

      PySideScreenSnapshot1.jpg +

      to: +

      PySideScreenSnapshot2.jpg +

      PySide is described in the following 3 pages which should follow on one from each other: +

      + +

      They divide the subject matter into 3 parts, differentiated by level of exposure to PySide, Python and the FreeCAD internals. The first page has overview and background material giving a description of PySide and how it is put together while the second and third pages are mostly code examples at different levels. +

      The intention is that the associated pages will provide simple Python code to run PySide so that the user working on a problem can easily copy the code, paste it into their own work, adapt it as necessary and return to their problem solving with FreeCAD. Hopefully they don't have to go chasing off across the internet looking for answers to PySide questions. At the same time this page is not intended to replace the various comprehensive PySide tutorials and reference sites available on the web. +

      + +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/PySide.html b/localwiki/PySide.html new file mode 100644 index 0000000..3a7283c --- /dev/null +++ b/localwiki/PySide.html @@ -0,0 +1,38 @@ +PySide

      PySide

      + +

      PySide

      +

      PySide is a Python binding of the cross-platform GUI toolkit Qt. FreeCAD uses PySide for all GUI (Graphic User Interface) purposes inside of Python. PySide is an alternative to the PyQt package which was previously used by FreeCAD for its GUI. PySide has a more permissible licence. See Differences Between PySide and PyQt for more information on the differences. +

      Users of FreeCAD often achieve everything using the built-in interface. But for users who want to customise their operations then the Python interface exists which is documented in the Python Scripting Tutorial. The Python interface for FreeCAD had great flexibility and power. For its user interaction Python with FreeCAD uses PySide, which is what is documented on this page. +

      Python offers the 'print' statement which gives the code: +

      +
      print 'Hello World' 
      +

      With Python's print statement you have only limited control of the appearance and behaviour. PySide supplies the missing control and also handles environments (such as the FreeCAD macro file environment) where the built-in facilities of Python are not enough. +

      PySide's abilities range from: +

      PySideScreenSnapshot1.jpg +

      to: +

      PySideScreenSnapshot2.jpg +

      PySide is described in the following 3 pages which should follow on one from each other: +

      + +

      They divide the subject matter into 3 parts, differentiated by level of exposure to PySide, Python and the FreeCAD internals. The first page has overview and background material giving a description of PySide and how it is put together while the second and third pages are mostly code examples at different levels. +

      The intention is that the associated pages will provide simple Python code to run PySide so that the user working on a problem can easily copy the code, paste it into their own work, adapt it as necessary and return to their problem solving with FreeCAD. Hopefully they don't have to go chasing off across the internet looking for answers to PySide questions. At the same time this page is not intended to replace the various comprehensive PySide tutorials and reference sites available on the web. +

      + +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/PySideScreenSnapshot1.jpg b/localwiki/PySideScreenSnapshot1.jpg new file mode 100644 index 0000000..c88a841 Binary files /dev/null and b/localwiki/PySideScreenSnapshot1.jpg differ diff --git a/localwiki/PySideScreenSnapshot2.jpg b/localwiki/PySideScreenSnapshot2.jpg new file mode 100644 index 0000000..b9718e6 Binary files /dev/null and b/localwiki/PySideScreenSnapshot2.jpg differ diff --git a/localwiki/PySideScreenSnapshot3.jpg b/localwiki/PySideScreenSnapshot3.jpg new file mode 100644 index 0000000..4f95a35 Binary files /dev/null and b/localwiki/PySideScreenSnapshot3.jpg differ diff --git a/localwiki/PySideScreenSnapshot4.jpg b/localwiki/PySideScreenSnapshot4.jpg new file mode 100644 index 0000000..7e0fcc4 Binary files /dev/null and b/localwiki/PySideScreenSnapshot4.jpg differ diff --git a/localwiki/PySideScreenSnapshot5.jpg b/localwiki/PySideScreenSnapshot5.jpg new file mode 100644 index 0000000..a350d3c Binary files /dev/null and b/localwiki/PySideScreenSnapshot5.jpg differ diff --git a/localwiki/PySideScreenSnapshot6.jpg b/localwiki/PySideScreenSnapshot6.jpg new file mode 100644 index 0000000..ecc4483 Binary files /dev/null and b/localwiki/PySideScreenSnapshot6.jpg differ diff --git a/localwiki/PySideScreenSnapshot7.jpg b/localwiki/PySideScreenSnapshot7.jpg new file mode 100644 index 0000000..bd723e5 Binary files /dev/null and b/localwiki/PySideScreenSnapshot7.jpg differ diff --git a/localwiki/PySideScreenSnapshot8.jpg b/localwiki/PySideScreenSnapshot8.jpg new file mode 100644 index 0000000..fc58098 Binary files /dev/null and b/localwiki/PySideScreenSnapshot8.jpg differ diff --git a/localwiki/PySide_Advanced_Examples.html b/localwiki/PySide_Advanced_Examples.html new file mode 100644 index 0000000..f9ba1ed --- /dev/null +++ b/localwiki/PySide_Advanced_Examples.html @@ -0,0 +1,84 @@ +PySide Advanced Examples

      PySide Advanced Examples

      + +
      + +

      Introduction

      +

      The purpose of this page is to cover advanced level examples of the PySide GUI manager (there are accompanying pages Beginner PySide Examples and Medium PySide Examples). +

      By using the PySide module from inside FreeCAD, you have full control over its interface. You can for example: +

      +
      • Add your own panels, widgets and toolbars
      • +
      • Add or hide elements to existing panels
      • +
      • Change, redirect or add connections between all those elements
      +

      Create Reference for the Main Window

      +

      If you want to work on the FreeCAD interface, the very first thing to do is create a reference to the FreeCAD main window: +

      +
      import sys
      +from PySide import QtGui ,QtCore 
      +app = QtGui.qApp
      +mw = FreeCADGui.getMainWindow() 
      +

      Browse the Children of the Main Window

      +

      Then, you can for example browse through all the widgets of the interface: +

      +
      for child in mw.children():
      +   print 'widget name = ', child.objectName(), ', widget type = ', child 
      +

      The widgets in a Qt interface are usually nested into "container" widgets, so the children of our main window can themselves contain other children. Depending on the widget type, there are a lot of things you can do. Check the API documentation to see what is possible. +

      +

      Add New Widget Manually

      +

      Adding a new widget, for example a dockWidget (which can be placed in one of FreeCAD's side panels) is easy: +

      +
      myWidget = QtGui.QDockWidget()
      +mw.addDockWidget(QtCore.Qt.RightDockWidgetArea,myWidget) 
      +

      You could then add stuff directly to your widget: +

      +
      myWidget.setObjectName("my Nice New Widget")
      +myWidget.resize(QtCore.QSize(300,100)) # sets size of the widget
      +label = QtGui.QLabel("Hello World", myWidget) # creates a label
      +label.setGeometry(QtCore.QRect(2,50,200,24))  # sets its size
      +label.setObjectName("myLabel") # sets its name, so it can be found by name 
      +

      Add New Widget by Creating UI Object

      +

      But a preferred method is to create a UI object which will do all of the setup of your widget at once. The big advantage is that such an UI object can be created graphically with the Qt Designer program. A typical object generated by Qt Designer is like this: +

      +
      class myWidget_Ui(object):
      +  def setupUi(self, myWidget):
      +    myWidget.setObjectName("my Nice New Widget")
      +    myWidget.resize(QtCore.QSize(300,100).expandedTo(myWidget.minimumSizeHint())) # sets size of the widget
      +
      +    self.label = QtGui.QLabel(myWidget) # creates a label
      +    self.label.setGeometry(QtCore.QRect(50,50,200,24)) # sets its size
      +    self.label.setObjectName("label") # sets its name, so it can be found by name
      +
      +  def retranslateUi(self, draftToolbar): # built-in QT function that manages translations of widgets
      +    myWidget.setWindowTitle(QtGui.QApplication.translate("myWidget", "My Widget", None, QtGui.QApplication.UnicodeUTF8))
      +    self.label.setText(QtGui.QApplication.translate("myWidget", "Welcome to my new widget!", None, QtGui.QApplication.UnicodeUTF8)) 
      +

      To use it, you just need to apply it to your freshly created widget like this: +

      +
      app = QtGui.qApp
      +FCmw = app.activeWindow()
      +myNewFreeCADWidget = QtGui.QDockWidget() # create a new dckwidget
      +myNewFreeCADWidget.ui = myWidget_Ui() # load the Ui script
      +myNewFreeCADWidget.ui.setupUi(myNewFreeCADWidget) # setup the ui
      +FCmw.addDockWidget(QtCore.Qt.RightDockWidgetArea,myNewFreeCADWidget) # add the widget to the main window 
      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/PySide_Beginner_Examples.html b/localwiki/PySide_Beginner_Examples.html new file mode 100644 index 0000000..ccbd12c --- /dev/null +++ b/localwiki/PySide_Beginner_Examples.html @@ -0,0 +1,162 @@ +PySide Beginner Examples

      PySide Beginner Examples

      + +
      + +

      Introduction

      +

      The purpose of this page is to cover beginner level examples of the PySide GUI manager (there are accompanying pages Medium PySide Examples and Advanced PySide Examples). +

      Newcomers to GUI programming may stumble over the word "widget". It's meaning outside of computing is usually given as +

      +
      "a small gadget or mechanical device, especially one whose name is unknown or unspecified"
      +

      For GUI work such as PySide the term "widget" is most often used to refer to the visible elements of the GUI - windows, dialogs, and input/output features. All visible elements of PySide are called widgets, and, for those who are interested, they all descend from a common parent class, QWidget. In addition to the visible elements PySide also offers widgets for networking, XML, multimedia, and database integration. +

      A widget that is not embedded in a parent widget is called a window and usually windows have a frame and a title bar. The most common types of windows are the "main window" (from the Class QMainWindow) and the various subclasses of the dialog (from the Class QDialog). One big difference is that QDialog is modal (i.e. the user can not do anything outside of the Dialog window while it is open) and the QMainWindow is non-modal which allows the user to interact with other windows in parallel. +

      This guide is a shortcut list for getting a PySide program working quickly under FreeCAD, it isn't intended to teach Python or PySide. Some sites that do that are: +

      + +

      Import Statement

      +

      PySide is not loaded with Python by default, it must be requested prior to using it. The following command: +

      +
      from PySide import QtGui, QtCore 
      +

      causes the 2 parts of PySide to be loaded - QtGui holds classes for managing the Graphic User Interface while QtCore contains classes that do not directly relate to management of the GUI (e.g. timers and geometry). Although it is possible to only import the one that is needed, generally they are both needed and both imported. +

      Note: the 'import' statement is not repeated in each code snippet below, it is assumed that it is already in the Python file. +

      +

      Simplest Example

      +

      The simplest interaction with PySide is to present a message to the user which they can only accept: +

      +
      reply = QtGui.QMessageBox.information(None,"","Houston, we have a problem") 
      +


      +PySideScreenSnapshot5.jpg +

      +

      Yes or No Query

      +

      The next most simple interaction is to ask for a yes/no answer: +

      +
      reply = QtGui.QMessageBox.question(None, "", "This is your chance to answer, what do you think?",
      +         QtGui.QMessageBox.Yes | QtGui.QMessageBox.No, QtGui.QMessageBox.No)
      +if reply == QtGui.QMessageBox.Yes:
      +         # this is where the code relevant to a 'Yes' answer goes
      +         pass
      +if reply == QtGui.QMessageBox.No:
      +         # this is where the code relevant to a 'No' answer goes
      +         pass 
      +


      +PySideScreenSnapshot6.jpg +

      +

      Enter Text Query

      +

      The next code snippet asks the user for a piece of text - note this can be any key on the keyboard really: +

      +
      reply = QtGui.QInputDialog.getText(None, "Ouija Central","Enter your thoughts for the day:")
      +if reply[1]:
      +# user clicked OK
      +replyText = reply[0]
      +else:
      +# user clicked Cancel
      +replyText = reply[0] # which will be "" if they clicked Cancel 
      +


      +PySideScreenSnapshot7.jpg +

      Remember that even if the user enters only digits, "1234" for example, they are strings and must be converted to number representation with either of the following: +

      +
      anInteger = int(userInput) # to convert to an integer from a string representation
      +
      +aFloat = float(userInput) # to convert to a float from a string representation 
      +

      More Than 2 Buttons

      +

      The final Beginner Level example is of how to build a dialog with an arbitrary number of buttons. This example is programmatically too complex to be invoked from a single Python statement so in some ways it should be on the next page which is PySide Medium examples. But on the other hand this is often all that is needed without getting into complex GUI definitions, so the code is placed at the end of the page of this Beginner PySide page rather than the beginning of the following Medium PySide page. +

      +
      from PySide import QtGui, QtCore
      +
      +class MyButtons(QtGui.QDialog):
      +""""""
      +def __init__(self):
      +super(MyButtons, self).__init__()
      +self.initUI()
      +def initUI(self):      
      +option1Button = QtGui.QPushButton("Option 1")
      +option1Button.clicked.connect(self.onOption1)
      +option2Button = QtGui.QPushButton("Option 2")
      +option2Button.clicked.connect(self.onOption2)
      +option3Button = QtGui.QPushButton("Option 3")
      +option3Button.clicked.connect(self.onOption3)
      +option4Button = QtGui.QPushButton("Option 4")
      +option4Button.clicked.connect(self.onOption4)
      +option5Button = QtGui.QPushButton("Option 5")
      +option5Button.clicked.connect(self.onOption5)
      +#
      +buttonBox = QtGui.QDialogButtonBox()
      +buttonBox = QtGui.QDialogButtonBox(QtCore.Qt.Horizontal)
      +buttonBox.addButton(option1Button, QtGui.QDialogButtonBox.ActionRole)
      +buttonBox.addButton(option2Button, QtGui.QDialogButtonBox.ActionRole)
      +buttonBox.addButton(option3Button, QtGui.QDialogButtonBox.ActionRole)
      +buttonBox.addButton(option4Button, QtGui.QDialogButtonBox.ActionRole)
      +buttonBox.addButton(option5Button, QtGui.QDialogButtonBox.ActionRole)
      +#
      +mainLayout = QtGui.QVBoxLayout()
      +mainLayout.addWidget(buttonBox)
      +self.setLayout(mainLayout)
      +# define windowxLoc,yLoc,xDim,yDim
      +self.setGeometry(250, 250, 0, 50)
      +self.setWindowTitle("Pick a Button")
      +self.setWindowFlags(QtCore.Qt.WindowStaysOnTopHint)
      +def onOption1(self):
      +self.retStatus = 1
      +self.close()
      +def onOption2(self):
      +self.retStatus = 2
      +self.close()
      +def onOption3(self):
      +self.retStatus = 3
      +self.close()
      +def onOption4(self):
      +self.retStatus = 4
      +self.close()
      +def onOption5(self):
      +self.retStatus = 5
      +self.close()
      +
      +def routine1():
      +print 'routine 1'
      +
      +form = MyButtons()
      +form.exec_()
      +if form.retStatus==1:
      +routine1()
      +elif form.retStatus==2:
      +routine2()
      +elif form.retStatus==3:
      +routine3()
      +elif form.retStatus==4:
      +routine4()
      +elif form.retStatus==5:
      +routine5() 
      +

      Each piece of code under test would be in a function with the name 'routine1()', 'routine2()', etc. As many buttons as you can fit on the screen may be used. Follow the patterns in the code sample and add extra buttons as needed - the Dialog box will set it's width accordingly, up to the width of the screen. +

      PySideScreenSnapshot8.jpg +

      There is a line of code: +

      +
      buttonBox = QtGui.QDialogButtonBox(QtCore.Qt.Horizontal) 
      +

      which causes the buttons to be in a horizontal line. To put them into a vertical line, change the line of code to read: +

      +
      buttonBox = QtGui.QDialogButtonBox(QtCore.Qt.Vertical) 
      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/PySide_Medium_Examples.html b/localwiki/PySide_Medium_Examples.html new file mode 100644 index 0000000..82ded16 --- /dev/null +++ b/localwiki/PySide_Medium_Examples.html @@ -0,0 +1,687 @@ +PySide Medium Examples

      PySide Medium Examples

      + +
      + +

      Introduction

      +

      This page covers medium level examples of the PySide GUI manager (accompanying pages cover aspects that are both less or more advanced, Beginner PySide Examples and +Advanced PySide Examples). In this page an example program is used to cover the different PySide topics. The intention is to present some functional PySide code so anyone who needs to use PySide can copy out the relevant section, modify and adapt it to their own purposes. +

      +

      Notes

      +
      • This page is not intended to cover the Python language or to serve as an instruction in Python.
      • +
      • The variable names are not descriptive but have been kept in sequence to better organise the explanations
      • +
      • There are numerous naming conventions for GUI components, none of which are "right" or "wrong"
      • +
      • There are a variety of different sequencings of the declarations for the widgets, the signals, the methods, once again none are "right" or "wrong"
      • +
      • It is worth keeping in mind that PySide operates with strings when dealing with user input, what appears on the screen as a number is actually a text representation of a number
      +

      Code Based Discussion - Declarative Portion

      +

      The "example program" is actually a large Class definition, the definition of a PySide GUI class, and has over 150 lines of code (including comments). There is no functional purpose to the Class or it's behaviour, the sole purpose is to demonstrate possible GUI actions and present some code that hopefully can be used by other FreeCAD users. +

      The Class definition and the small number of lines of code that invoke are described in the order the occur in the file. This order is based on the screen layout which is rather arbitrary and solely intended to demonstrate features. This is the modal GUI screen the PySide Class generates: +

      PySideScreenSnapshot3.jpg +


      +Most of the remainder of this section will describe the contents of the Class definition which appears at the end of this section. First we will cover the declarative elements that define how things operate and how the GUI is assembled, then we will cover the operative sections (i.e. the code that will execute when user interactions occur). This window is based on the class QDialog and so is modal - which means no activities can be made outside of the window while it is open. +

      +

      Import Statement

      +

      The mandatory Import statement +

      +
      from PySide import QtGui, QtCore 
      +

      This is best placed at the top of the Python file. +

      +

      Class Definition

      +
      class ExampleModalGuiClass(QtGui.QDialog):
      +""""""
      +def __init__(self):
      +super(ExampleModalGuiClass, self).__init__()
      +self.initUI()
      +def initUI(self): 
      +

      This code is best copied out verbatim and altered. The gist of the code is that we are sub-classing the QDialog Class of PySide. In adapting this code you will want to change the class name "ExampleModalGuiClass" - make sure to change it in both locations (e.g. lines 1 & 4). +

      +

      Window Return Status

      +
      self.result = userCancelled 
      +

      This is not mandatory but rather a good programming practice, this sets a default return status for the window which will be there regardless of what the user does. Later in the code this may be changed by the Python code to indicate different options the user may have selected. +

      +

      Window Creation

      +
      # create our window
      +# define windowxLoc,yLoc,xDim,yDim
      +self.setGeometry(250, 250, 400, 350)
      +self.setWindowTitle("Our Example Program Window")
      +self.setWindowFlags(QtCore.Qt.WindowStaysOnTopHint) 
      +

      Remembering that screen dimensions are measured from the upper-left corner, on the 3rd line the values refer to: +

      +
      • the number of pixels the upper-left corner will be to the right of the lefthand screen edge (250)
      • +
      • the number of pixels the upper-left corner will be below the upper screen edge (250)
      • +
      • the width of the screen in pixels (400)
      • +
      • the height of the screen in pixels (350)
      +

      The title of the window is set and the final line simply means that this window will never be obscured by another window - if this is not desired then simply place a Python comment character ('#') as the first character of the line. +

      +

      Label Creation

      +
      # create some Labels
      +self.label1 = QtGui.QLabel("                       ", self)
      +self.label1.setFont('Courier') # set to a non-proportional font
      +self.label1.move(20, 20)
      +self.label2 = QtGui.QLabel("sample string number two", self)
      +self.label2.move(20, 70)
      +self.label3 = QtGui.QLabel("                        ", self)
      +self.label3.setFont('Courier') # set to a non-proportional font
      +self.label3.move(20, 120)
      +self.label4 = QtGui.QLabel("can you see this?", self)
      +self.label4.move(20, 170) 
      +

      In PySide labels serve two purposes, static labels (as the name implies) as well as read-only (i.e. display-only) text fields. So unchanging instructions to the user such as "Don't push the red button" as well as dynamic calculation results such as "42" can be communicated to the user. The 2nd line declares a Label and sets it's initial value (which is blank in this case). The 3rd line specifies the font, any font (on the system) can be specified, if not specified the default font is used. In this case the font is specified as a non-proportional one. The label is moved to it's location in the window - it's coordinates specify it's position with respect to the window (not the screen). +

      +

      Checkbox Creation

      +
      # checkboxes
      +self.checkbox1 = QtGui.QCheckBox("Left side", self)
      +self.checkbox1.clicked.connect(self.onCheckbox1)
      +#self.checkbox1.toggle() # will set an initial value if executed
      +self.checkbox1.move(210,10)
      +#
      +self.checkbox2 = QtGui.QCheckBox("Right side", self)
      +self.checkbox2.clicked.connect(self.onCheckbox2)
      +self.checkbox2.move(210,30) 
      +

      Checkboxes can be off and on in any combination (unlike radio buttons). Line 2 declares one and set's it initial Value. Line 3 specifies which method will be executed when the Checkbox is clicked (in this case the method 'onCheckBox1'). If the 4th line did not have the Python comment character ('#') as the first character, then it would be executed and it would mark the checkbox as checked. Finally the 5th line moves the Checkbox into position. +

      +

      Radio Button Creation

      +
      # radio buttons
      +self.radioButton1 = QtGui.QRadioButton("random string one",self)
      +self.radioButton1.clicked.connect(self.onRadioButton1)
      +self.radioButton1.move(210,60)
      +#
      +self.radioButton2 = QtGui.QRadioButton("owt gnirts modnar",self)
      +self.radioButton2.clicked.connect(self.onRadioButton2)
      +self.radioButton2.move(210,80) 
      +

      The creation of the Radio BUttons is very similar to the Checkboxes. The only difference really is the behaviour of the Radio Buttons in that only one of them can be 'on' at a time. +

      +

      Pop-Up Menu Creation

      +
      # set up lists for pop-ups
      +self.popupItems1 = ("pizza","apples","candy","cake","potatoes")
      +# set up pop-up menu
      +self.popup1 = QtGui.QComboBox(self)
      +self.popup1.addItems(self.popupItems1)
      +self.popup1.setCurrentIndex(self.popupItems1.index("candy"))
      +self.popup1.activated[str].connect(self.onPopup1)
      +self.popup1.move(210, 115) 
      +

      In line 2 a list is built up of what will be the user choices. An alternative is to build up a Dictionary but only use the Keys for the list of menu choices. Line 4 creates the pop-up menu (known as a ComboBox to PySide), the user options are added in line 5. +

      As a side note, if the Dictionary was used then the lines would appear as: +

      +
      self.popupItems1 = OrderedDict([("2","widget"),("pink","foobar"),("4","galopsis")])
      +
      +self.popup1.addItems(self.popupItems1.keys()) 
      +

      Returning to the main code sample for this section, line 6 sets the default choice, this line may be omitted, also the value of the default choice could be loaded into the corresponding Label (once again if appropriate). And finally the move into position at line 8. +

      +

      Button Creation Part 1

      +
      # toggle visibility button
      +pushButton1 = QtGui.QPushButton('Toggle visibility', self)
      +pushButton1.clicked.connect(self.onPushButton1)
      +pushButton1.setAutoDefault(False)
      +pushButton1.move(210, 165) 
      +

      The button is created in line 2 with it's name, the handler for it's signal when clicked is specified in line 3. Line 4 is there to prevent the button from becoming the 'default button' - the button that will be clicked if the user simply presses the Return key. And a move to position finished up the code segment. +

      +

      Text Input Creation

      +
      # text input field
      +self.textInput = QtGui.QLineEdit(self)
      +self.textInput.setText("cats & dogs")
      +self.textInput.setFixedWidth(190)
      +self.textInput.move(20, 220) 
      +

      The QLineEdit widget is probably the most common for user textual input, in this example the code section after this one will set up a contextual menu to operate on it. This code section creates (line 2), sets an initial value (line 3), sets a width to the field (line 4) and moves the widget into place (line 5). +

      +

      Contextual Menu Creation

      +
      # set contextual menu options for text editing widget
      +# set text field to some dogerel
      +popMenuAction1 = QtGui.QAction(self)
      +popMenuAction1.setText("load some text")
      +popMenuAction1.triggered.connect(self.onPopMenuAction1)
      +# make text uppercase
      +popMenuAction2 = QtGui.QAction(self)
      +popMenuAction2.setText("uppercase")
      +popMenuAction2.triggered.connect(self.onPopMenuAction2)
      +# menu dividers
      +popMenuDivider = QtGui.QAction(self)
      +popMenuDivider.setText('---------')
      +popMenuDivider.triggered.connect(self.onPopMenuDivider)
      +# remove all text
      +popMenuAction3 = QtGui.QAction(self)
      +popMenuAction3.setText("clear")
      +popMenuAction3.triggered.connect(self.onPopMenuAction3)
      +# define menu and add options
      +self.textInput.setContextMenuPolicy(QtCore.Qt.ActionsContextMenu)
      +self.textInput.addAction(popMenuAction1)
      +self.textInput.addAction(popMenuAction2)
      +self.textInput.addAction(popMenuDivider)
      +self.textInput.addAction(popMenuAction3) 
      +

      This code has numerous repetitions as the same action is performed with different values - this is part of what makes GUI code so lengthy (no matter what the system). First a QAction is created - it is a pairing (or linkage) of the text that the user will see as their selectable option along with the method that will execute if they select that option. It is basically a pairing of a user choice with a piece of code. Line 3 creates it, line 4 defines the user option (as they will see it) and line 5 specifies which piece of Python code will execute. +

      Skipping to line 19 (the line with "self.textInput.setContextMenuPolicy") a ActionsContextMenu is created which is holder for all the separate QAction linkages between user choice and code to execute. Each widget can only have a single Contextual Menu (i.e. the menu associated with the right-click) so line 19 defines that menu. The following 4 lines add the linkages created at the beginning of this code section. Order is significant here, the user will see the menu options in the order they are added. Notice that the 3rd menu option is really a bit of nothing, it's code is null but it serves to separate 2 groups of options on the Contextual Menu. +

      +

      Numeric Input Creation

      +
      # numeric input field
      +self.numericInput = QtGui.QLineEdit(self)
      +self.numericInput.setInputMask("999")
      +self.numericInput.setText("000")
      +self.numericInput.setFixedWidth(50)
      +self.numericInput.move(250, 220) 
      +

      The creation of the field for numeric input really follows that for Text Input earlier. In fact the code is identical with exception of the 3rd and 4th lines. The 3rd line sets the Mask as defined by PySide, which in this case specifies up to 3 digits (which may include 0). A full list of the InputMask codes can be found at QLineEdit InputMask +

      +

      Button Creation Part 2

      +
      # cancel button
      +cancelButton = QtGui.QPushButton('Cancel', self)
      +cancelButton.clicked.connect(self.onCancel)
      +cancelButton.setAutoDefault(True)
      +cancelButton.move(150, 280)
      +# OK button
      +okButton = QtGui.QPushButton('OK', self)
      +okButton.clicked.connect(self.onOk)
      +okButton.move(260, 280) 
      +

      Both buttons are created with a name (which will appear as their label), associated with a method which will execute when they are clicked, and moved into position. The one exception is line 4 which specifies the 'Cancel' button as the default button - that means it will be "clicked" if the user preses the Return key. +

      +

      Window Display

      +
      # now make the window visible
      +self.show() 
      +

      There is only one line and it causes the GUI to be displayed after the setup. +

      +

      Code Based Discussion - Operative Portion

      +

      We now move onto the operative portion of the GUI definition which is the code that executes in response to user interactions with the GUI. The order of statement groups is not very relevant - with the caveat that something must be declared before it can be referenced. Some people put all the handlers of a certain type (e.g. handlers for buttons) in one group, others list the handlers alphabetically. For specific application there may be a problem related reason that all handlers relating to a specific aspect be gathered together +

      There is a high degree of similarity between the handlers. Most do not receive a parameter, the fact they are executing is realy the only parameter (or signal) they get. Others like "onPopup1" and "mousePressEvent" accept a parameter. +

      There must be a one to one correspondance between the handlers specified in the declarative section and the handler declared in this, the operative section. There may be extra handlers declared which are never invoked but there may not be any missing. +

      +

      Generic Handler

      +

      In this code example, generic handlers handle the following events: +

      +
      • onCheckbox1
      • +
      • onCheckbox2
      • +
      • onRadioButton1
      • +
      • onRadioButton2
      • +
      • onPushButton1
      • +
      • onPopMenuAction1
      • +
      • onPopMenuAction2
      • +
      • onPopMenuDivider
      • +
      • onPopMenuAction3
      • +
      • onCancel
      • +
      • onOk
      +

      The general form for the handlers is: +

      +
      def handlerName(self):
      +lineOfCode1
      +lineOfCode2 
      +

      The first line has the keyword "def" followed by the handler name. The handler name must match the name from the earlier declarative section exactly. The parameter "self" is part of the standard syntax as are the enclosing parenthesis and the final colon character. Once the first line is finished then there are no requirements of the following code, it is purely application specific. +

      +

      Pop-Up Menu Handler

      +
      def onPopup1(self, selectedText): 
      +

      The Pop-Up menu handler is the same as the generic handler with exception that a second parameter, the text selected by the user, is passed in. Remember that everything is text coming from the Pop-Up menu and even if the user has selected the number 3, it will be passed in as the string "3". +

      +

      Mouse Event Handler

      +
      def mousePressEvent(self, event):
      +# print mouse position, X & Y
      +print "X = ", event.pos().x()
      +print "Y = ", event.pos().y()
      +#
      +if event.button() == QtCore.Qt.LeftButton:
      +print "left mouse button"
      +if self.label1.underMouse():
      +print "over the text '"+self.label1.text()+"'" 
      +

      The Mouse Event handler is the same as the generic handler with exception that a second parameter, the mouse event (e.g. left-click, right-click) from the user is passed in. The name of the handler, "mousePressEvent", is reserved and if it is changed then the handler will no longer receive the event from the mouse presses. +

      The X and Y coordinates of the mouse press are given by the reference "event.pos().x()" and "event.pos().y()". The constants "QtCore.Qt.LeftButton" and "QtCore.Qt.RightButton" are used to determine which mouse button was pressed. +

      A reference to a widget can be made of the form "self.widgetName.underMouse()" which will return TRUE or FALSE as to whether the mouse cursor is over the widget "widgetName". Although presented in the same code excerpt the "underMouse()" handler is not tied to the "mousePressEvent" handler and can be used at any time. +

      +

      Code Based Discussion - Main Routine

      +

      Most of the volume of code is in the GUI Class definition, there is not much in the main procedure. +

      +
      # Constant definitions
      +global userCancelled, userOK
      +userCancelled= "Cancelled"
      +userOK= "OK" 
      +

      Lines 2,3 & 4 deal with coordinating the status of the user interaction with the GUI - e.g. Cancelled, OK, or any other application defined status. The handler routines On Cancel and OnOk earlier also set these statuses. +

      +
      form = ExampleGuiClass()
      +form.exec_()
      +
      +if form.result==userCancelled:
      +pass # steps to handle user clicking Cancel
      +if form.result==userOK:
      +# steps to handle user clicking OK
      +localVariable1 = form.label1.text()
      +localVariable2 = form.label2.text()
      +localVariable3 = form.label3.text()
      +localVariable4 = form.label4.text() 
      +

      Lines 1 and 2 show the method for invoking the GUI. There may be multiple GUI definitions for a program and also the GUI need not be invoked as the first thing in the Python file, it may be invoked at any point. The Name of the GUI Class is specified in line 1 ("ExampleGuiClass" in this case) but the rest of the 2 lines are to be copied verbatim. +

      Lines 4 and 6 use the result field to determine the appropriate action. The last 4 lines simply show the copying of the data in the GUI object to variables local to the executing main procedure. +

      +

      Complete Modal Code Example

      +

      This is the complete code example (developed on FreeCAD v0.14): +

      +
      # import statements
      +
      +from PySide import QtGui, QtCore
      +
      +# UI Class definitions
      +
      +class ExampleModalGuiClass(QtGui.QDialog):
      +""""""
      +def __init__(self):
      +super(ExampleModalGuiClass, self).__init__()
      +self.initUI()
      +def initUI(self):
      +self.result = userCancelled
      +# create our window
      +# define windowxLoc,yLoc,xDim,yDim
      +self.setGeometry(250, 250, 400, 350)
      +self.setWindowTitle("Our Example Modal Program Window")
      +self.setWindowFlags(QtCore.Qt.WindowStaysOnTopHint)
      +# create some Labels
      +self.label1 = QtGui.QLabel("                       ", self)
      +self.label1.setFont('Courier') # set to a non-proportional font
      +self.label1.move(20, 20)
      +self.label2 = QtGui.QLabel("sample string number two", self)
      +self.label2.move(20, 70)
      +self.label3 = QtGui.QLabel("                        ", self)
      +self.label3.setFont('Courier') # set to a non-proportional font
      +self.label3.move(20, 120)
      +self.label4 = QtGui.QLabel("can you see this?", self)
      +self.label4.move(20, 170)
      +# checkboxes
      +self.checkbox1 = QtGui.QCheckBox("Left side", self)
      +self.checkbox1.clicked.connect(self.onCheckbox1)
      +#self.checkbox1.toggle() # will set an initial value if executed
      +self.checkbox1.move(210,10)
      +#
      +self.checkbox2 = QtGui.QCheckBox("Right side", self)
      +self.checkbox2.clicked.connect(self.onCheckbox2)
      +self.checkbox2.move(210,30)
      +# radio buttons
      +self.radioButton1 = QtGui.QRadioButton("random string one",self)
      +self.radioButton1.clicked.connect(self.onRadioButton1)
      +self.radioButton1.move(210,60)
      +#
      +self.radioButton2 = QtGui.QRadioButton("owt gnirts modnar",self)
      +self.radioButton2.clicked.connect(self.onRadioButton2)
      +self.radioButton2.move(210,80)
      +# set up lists for pop-ups
      +self.popupItems1 = ("pizza","apples","candy","cake","potatoes")
      +# set up pop-up menu
      +self.popup1 = QtGui.QComboBox(self)
      +self.popup1.addItems(self.popupItems1)
      +self.popup1.setCurrentIndex(self.popupItems1.index("candy"))
      +self.popup1.activated[str].connect(self.onPopup1)
      +self.popup1.move(210, 115)
      +# toggle visibility button
      +pushButton1 = QtGui.QPushButton('Toggle visibility', self)
      +pushButton1.clicked.connect(self.onPushButton1)
      +pushButton1.setAutoDefault(False)
      +pushButton1.move(210, 165)
      +# text input field
      +self.textInput = QtGui.QLineEdit(self)
      +self.textInput.setText("cats & dogs")
      +self.textInput.setFixedWidth(190)
      +self.textInput.move(20, 220)
      +# set contextual menu options for text editing widget
      +# set text field to some dogerel
      +popMenuAction1 = QtGui.QAction(self)
      +popMenuAction1.setText("load some text")
      +popMenuAction1.triggered.connect(self.onPopMenuAction1)
      +# make text uppercase
      +popMenuAction2 = QtGui.QAction(self)
      +popMenuAction2.setText("uppercase")
      +popMenuAction2.triggered.connect(self.onPopMenuAction2)
      +# menu dividers
      +popMenuDivider = QtGui.QAction(self)
      +popMenuDivider.setText('---------')
      +popMenuDivider.triggered.connect(self.onPopMenuDivider)
      +# remove all text
      +popMenuAction3 = QtGui.QAction(self)
      +popMenuAction3.setText("clear")
      +popMenuAction3.triggered.connect(self.onPopMenuAction3)
      +# define menu and add options
      +self.textInput.setContextMenuPolicy(QtCore.Qt.ActionsContextMenu)
      +self.textInput.addAction(popMenuAction1)
      +self.textInput.addAction(popMenuAction2)
      +self.textInput.addAction(popMenuDivider)
      +self.textInput.addAction(popMenuAction3)
      +# numeric input field
      +self.numericInput = QtGui.QLineEdit(self)
      +self.numericInput.setInputMask("999")
      +self.numericInput.setText("000")
      +self.numericInput.setFixedWidth(50)
      +self.numericInput.move(250, 220)
      +# cancel button
      +cancelButton = QtGui.QPushButton('Cancel', self)
      +cancelButton.clicked.connect(self.onCancel)
      +cancelButton.setAutoDefault(True)
      +cancelButton.move(150, 280)
      +# OK button
      +okButton = QtGui.QPushButton('OK', self)
      +okButton.clicked.connect(self.onOk)
      +okButton.move(260, 280)
      +# now make the window visible
      +self.show()
      +#
      +def onCheckbox1(self):
      +text = self.label1.text()
      +if text[0]==' ':
      +self.label1.setText('left'+text[4:])
      +else:
      +self.label1.setText('    '+text[4:])
      +def onCheckbox2(self):
      +text = self.label1.text()
      +if text[-1]==' ':
      +self.label1.setText(text[:-5]+'right')
      +else:
      +self.label1.setText(text[:-5]+'     ')
      +def onRadioButton1(self):
      +self.label2.setText(self.radioButton1.text())
      +def onRadioButton2(self):
      +self.label2.setText(self.radioButton2.text())
      +def onPopup1(self, selectedText):
      +if self.label3.text().isspace():
      +self.label3.setText(selectedText)
      +else:
      +self.label3.setText(self.label3.text()+","+selectedText)
      +def onPushButton1(self):
      +if self.label4.isVisible():
      +self.label4.hide()
      +else:
      +self.label4.show()
      +def onPopMenuAction1(self):
      +# load some text into field
      +self.textInput.setText("Lorem ipsum dolor sit amet")
      +def onPopMenuAction2(self):
      +# set text in field to uppercase
      +self.textInput.setText(self.textInput.text().upper())
      +def onPopMenuDivider(self):
      +# this option is the divider and is really there as a spacer on the menu list
      +# consequently it has no functional code to execute if user selects it
      +pass
      +def onPopMenuAction3(self):
      +# clear the text from the field
      +self.textInput.setText('')
      +def onCancel(self):
      +self.result= userCancelled
      +self.close()
      +def onOk(self):
      +self.result= userOK
      +self.close()
      +def mousePressEvent(self, event):
      +# print mouse position, X & Y
      +print "X = ", event.pos().x()
      +print "Y = ", event.pos().y()
      +#
      +if event.button() == QtCore.Qt.LeftButton:
      +print "left mouse button"
      +if self.label1.underMouse():
      +print "over the text '"+self.label1.text()+"'"
      +if self.label2.underMouse():
      +print "over the text '"+self.label2.text()+"'"
      +if self.label3.underMouse():
      +print "over the text '"+self.label3.text()+"'"
      +if self.label4.underMouse():
      +print "over the text '"+self.label4.text()+"'"
      +if self.textInput.underMouse():
      +print "over the text '"+self.textInput.text()+"'"
      +if event.button() == QtCore.Qt.RightButton:
      +print "right mouse button"
      +
      +# Class definitions
      +
      +# Function definitions
      +
      +# Constant definitions
      +userCancelled= "Cancelled"
      +userOK= "OK"
      +
      +# code ***********************************************************************************
      +
      +form = ExampleModalGuiClass()
      +form.exec_()
      +
      +if form.result==userCancelled:
      +pass # steps to handle user clicking Cancel
      +if form.result==userOK:
      +# steps to handle user clicking OK
      +localVariable1 = form.label1.text()
      +localVariable2 = form.label2.text()
      +localVariable3 = form.label3.text()
      +localVariable4 = form.label4.text()
      +print localVariable1
      +print localVariable2
      +print localVariable3
      +print localVariable4
      +#
      +#OS: Mac OS X
      +#Word size: 64-bit
      +#Version: 0.14.3703 (Git)
      +#Branch: releases/FreeCAD-0-14
      +#Hash: c6edd47334a3e6f209e493773093db2b9b4f0e40
      +#Python version: 2.7.5
      +#Qt version: 4.8.6
      +#Coin version: 3.1.3
      +#SoQt version: 1.5.0
      +#OCC version: 6.7.0
      +#
      +

      The best way to use this code is to copy it into an editor or FreeCAD macro file and play around with it. +

      +

      Code Based Discussion - Nonmodal Code Example

      +

      All of the widget specific from the previous modal example transfer to use in a nonmodal window. The main difference is that the nonmodal window does not restrict the user from interacting with other windows. Basically, a nonmodal window is one that can be opened and left open for as long as needed without it placing any restrictions on other application windows. There are a small number of code differences between the two which will be highlighted, consequently this code example is quite brief. Anything that is the same as the previous modal example will be left out in the interests of keeping this overview brief. This is the nonmodal GUI screen the PySide Class generates: +

      PySideScreenSnapshot4.jpg +

      +

      Import Statement

      +

      The mandatory Import statement +

      +
      from PySide import QtGui, QtCore 
      +

      This is best placed at the top of the Python file. +

      +

      Class Definition

      +
      class ExampleNonmodalGuiClass(QtGui.QMainWindow):
      +""""""
      +def __init__(self):
      +super(ExampleNonmodalGuiClass, self).__init__()
      +self.initUI()
      +def initUI(self): 
      +

      This code is best copied out verbatim and altered. The gist of the code is that we are sub-classing the QMainWindow Class of PySide. In adapting this code you will want to change the class name "ExampleNonmodalGuiClass" - make sure to change it in both locations (e.g. lines 1 & 4). +

      +

      Window Creation

      +
      # create our window
      +# define windowxLoc,yLoc,xDim,yDim
      +self.setGeometry(250, 250, 400, 150)
      +self.setWindowTitle("Our Example Nonmodal Program Window")
      +self.setWindowFlags(QtCore.Qt.WindowStaysOnTopHint)
      +self.setMouseTracking(True) 
      +

      Obviously our window dimensions and title are different. The main point to note is the last line which lets PySide know that it is to send out mouse position events as they happen. Note that these events will not be sent out when the mouse is over a widget like a button as the widget will capture the events. +

      +

      Mouse Move Event Handler

      +
      def mouseMoveEvent(self,event):
      +self.label6.setText("X: "+str(event.x()) + " Y: "+str(event.y())) 
      +

      This handler receives the event of a Mouse Move and displays the formatted form of it. Test what happens when it is over widgets or outside of the window. +

      +

      Invoking the Window

      +
      form = ExampleNonmodalGuiClass() 
      +

      Invoking the window is another area of difference from the previous example. This time only 1 line is needed for invoking the GUI. +

      +

      Complete Nonmodal Code Example

      +
      # import statements
      +
      +from PySide import QtGui, QtCore
      +
      +# UI Class definitions
      +
      +class ExampleNonmodalGuiClass(QtGui.QMainWindow):
      +""""""
      +def __init__(self):
      +super(ExampleNonmodalGuiClass, self).__init__()
      +self.initUI()
      +def initUI(self):
      +self.result = userCancelled
      +# create our window
      +# define windowxLoc,yLoc,xDim,yDim
      +self.setGeometry(250, 250, 400, 150)
      +self.setWindowTitle("Our Example Nonmodal Program Window")
      +self.setWindowFlags(QtCore.Qt.WindowStaysOnTopHint)
      +self.setMouseTracking(True)
      +# create Labels
      +self.label4 = QtGui.QLabel("can you see this?", self)
      +self.label4.move(20, 20)
      +self.label5 = QtGui.QLabel("Mouse position:", self)
      +self.label5.move(20, 70)
      +self.label6 = QtGui.QLabel("               ", self)
      +self.label6.move(135, 70)
      +# toggle visibility button
      +pushButton1 = QtGui.QPushButton('Toggle visibility', self)
      +pushButton1.clicked.connect(self.onPushButton1)
      +pushButton1.setMinimumWidth(150)
      +#pushButton1.setAutoDefault(False)
      +pushButton1.move(210, 20)
      +# cancel button
      +cancelButton = QtGui.QPushButton('Cancel', self)
      +cancelButton.clicked.connect(self.onCancel)
      +cancelButton.setAutoDefault(True)
      +cancelButton.move(150, 110)
      +# OK button
      +okButton = QtGui.QPushButton('OK', self)
      +okButton.clicked.connect(self.onOk)
      +okButton.move(260, 110)
      +# now make the window visible
      +self.show()
      +#
      +def onPushButton1(self):
      +if self.label4.isVisible():
      +self.label4.hide()
      +else:
      +self.label4.show()
      +def onCancel(self):
      +self.result= userCancelled
      +self.close()
      +def onOk(self):
      +self.result= userOK
      +self.close()
      +def mouseMoveEvent(self,event):
      +self.label6.setText("X: "+str(event.x()) + " Y: "+str(event.y()))
      +# Class definitions
      +
      +# Function definitions
      +
      +# Constant definitions
      +global userCancelled, userOK
      +userCancelled= "Cancelled"
      +userOK= "OK"
      +
      +# code ***********************************************************************************
      +
      +form = ExampleNonmodalGuiClass()
      +#
      +#OS: Mac OS X
      +#Word size: 64-bit
      +#Version: 0.14.3703 (Git)
      +#Branch: releases/FreeCAD-0-14
      +#Hash: c6edd47334a3e6f209e493773093db2b9b4f0e40
      +#Python version: 2.7.5
      +#Qt version: 4.8.6
      +#Coin version: 3.1.3
      +#SoQt version: 1.5.0
      +#OCC version: 6.7.0
      +#
      +

      Misc Additional Topics

      +

      There are 3 concepts to the screen real estate in a GUI environment: +

      +
      • physical space on the screen
      • +
      • frame
      • +
      • geometry
      +

      Within the software all are measured in pixels. PySide has function to measure in real world units but these are undependable as the manufacturers have no standard for pixel size or aspect ratio. +

      The Frame is the size of a window including it's side bars, top bar (possibly with a menu in it) and bottom bar. The Geometry is the space lying within the Frame and so is always less than or equal to the Frame. In turn the Frame is always less than or equal to the available screen size. +

      +

      Available Screen Size

      +
      # get screen dimensions (Available Screen Size)
      +screenWidth= QtGui.QDesktopWidget().screenGeometry().width()
      +screenHeight= QtGui.QDesktopWidget().screenGeometry().height()
      +# get dimensions for available space on screen
      +availableWidth= QtGui.QDesktopWidget().availableGeometry().width()
      +availableHeight= QtGui.QDesktopWidget().availableGeometry().height() 
      +

      Generally the "availableHeight" should be less than the "screenHeight" by the height of the menu bar. These 4 values are based on the hardware environment and will change from computer to computer. They are not dependent on any application window size. +

      +

      Frame Size and Geometry

      +
      # set up a variable to hold the Main Window to save some typing...
      +mainWin = FreeCAD.Gui.getMainWindow()
      +
      +mainWin.showFullScreen() # no menu bars, every last pixel is given over to FreeCAD
      +mainWin.geometry()
      +mainWin.frameSize()
      +mainWin.frameGeometry()
      +
      +mainWin.showMaximized() # show maximised within the screen, window edges and the menu bar will be displayed
      +mainWin.geometry()
      +mainWin.frameSize()
      +mainWin.frameGeometry()
      +
      +mainWin.showNormal() # show at the last non-maximised or non-minimised size (and location)
      +mainWin.geometry()
      +mainWin.frameSize()
      +mainWin.frameGeometry()
      +
      +mainWin.setGeometry(50, 50, 800, 800) # specifically set FreeCAD main window's size and location, this will become the new setting for 'showNormal()'
      +
      +mainWin.showMinimized() # FreeCAD will disappear from view after this command...
      +mainWin.geometry()
      +mainWin.frameSize()
      +mainWin.frameGeometry() 
      +

      These same commands can be executed on a user generated window, the syntax does not change. +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Pyramides.gif b/localwiki/Pyramides.gif new file mode 100644 index 0000000..23ad960 Binary files /dev/null and b/localwiki/Pyramides.gif differ diff --git a/localwiki/Python.svg b/localwiki/Python.svg new file mode 100644 index 0000000..570de5b --- /dev/null +++ b/localwiki/Python.svg @@ -0,0 +1,310 @@ + + + + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/PythonDevelopmentEnvironment.jpg b/localwiki/PythonDevelopmentEnvironment.jpg new file mode 100644 index 0000000..08315d8 Binary files /dev/null and b/localwiki/PythonDevelopmentEnvironment.jpg differ diff --git a/localwiki/PythonOCC.html b/localwiki/PythonOCC.html new file mode 100644 index 0000000..466a654 --- /dev/null +++ b/localwiki/PythonOCC.html @@ -0,0 +1,22 @@ +PythonOCC

      PythonOCC

      + +

      PythonOCC is a pretty young and active project that aims at binding the whole range of OpenCasCADe functions into a python module. This is a very different approach than FreeCAD, where only certain components of OpenCasCade are used, resulting in a much simpler structure. +

      PythonOCC, on the other hand, since it provides you access to all of OCC classes and functions, is very complex, but also very powerful. It is therefore a very fine addition to FreeCAD. When you are limited by FreeCAD's available OCC functionality in your python scripts, it's time to load pythonOCC. +

      Currently in the Part module we have the methods: Part.__toPythonOCC__() and Part.__fromPythonOCC__() to exchange TopoDS_Shape entities to/from pythonOCC. This allows to use the full power of OCC in python (using pythonocc) and then put the resulting shapes back to FreeCAD. +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Python_3.html b/localwiki/Python_3.html new file mode 100644 index 0000000..e4983ea --- /dev/null +++ b/localwiki/Python_3.html @@ -0,0 +1,131 @@ +Python 3

      Python 3

      + +

      The port of FreeCAD to Python 3 support is currently underway and progress is being tracked in this forum thread. The master branch of FreeCAD is already usable with python3. Tests are passing, but there are still many little incompatibilities. TESTERS WANTED! +

      This document is a placeholder for various platforms' build instructions and a checklist to monitor progress. +

      + + +

      Building FreeCAD w/ Python 3

      +

      Ubuntu

      +

      The first step in building FreeCAD for Python 3 is ensuring you can build normally. +Tip: It's also helpful to have a cmake GUI tool like cmake-qt-gui or cmake-curses-gui. +

      The following instructions are adapted from a post by looo in the Python 3 porting thread: +Note: tested only with linux/ubuntu. +

      Download the current master of FreeCAD +

      +
       git clone https://github.com/FreeCAD/FreeCAD
      +
      +

      If python3 is your default python then there shouldn't be much to do. If not I think the easiest is to do: +Set the python relevant cmake variables with cmake-gui which are: +

      +
       - PYTHON_EXECUTABLE
      + - PYTHON_INCLUDE_DIR
      + - PYTHON_LIBRARY
      + - PYTHON_BASENAME (=PySideConfigPYTHON_SUFFIX.cmake) -> for me on ubuntu this would be this: .cpython-35m-x86_64-linux-gnu
      + - PYTHON_SUFFIX (=ShibokenConfigPYTHON_SUFFIX.cmake) -> eg.: .cpython-35m-x86_64-linux-gnu
      +
      +

      Pivy

      +

      python3 builds for freecad are available with this ppa +

      +
       sudo add-apt-repository ppa:sppedflyer/mytestppa1
      + sudo apt-get update
      + sudo apt-get install python3-pivy
      +
      +

      Pysidse

      +

      PySide for python3.5 isn't officially available, but I think ubuntu provides a build. +

      +
       sudo apt-get install python3-pyside
      +
      +


      +

      +

      Test builds on anaconda (linux64)

      +
      wget -c http://repo.continuum.io/miniconda/Miniconda-latest-Linux-x86_64.sh
      +bash Miniconda-latest-Linux-x86_64.sh
      +
      +

      and follow the instructions +

      once miniconda is installed we have to configure conda to have access to the freecad-builds: +

      +
      conda config --add channels conda-forge
      +conda config --add channels freecad
      +
      +

      now we create a new enviroment and install freecad +

      +
      conda create --name freecad_py3 python=3.6 freecad
      +
      +

      this will download all the necessary packages. When done activate the enviroment and start FreeCAD +

      +
      source activate freecad_py3
      +FreeCAD
      +
      +

      the first time you launch freecad, matplotlib loads some modules, and therefore FreeCAD will need some time to show up. +


      +

      +

      Alternate Install

      +

      Conda

      +
       Install miniconda: http://conda.pydata.org/miniconda.html 
      +
      +

      Install conda-build: +

      +
       conda install conda_build
      +
      +

      Add channels: +

      +
       conda config --add channels freecad
      + conda config --add channels conda-forge
      +
      +

      Clone the current Python 3 port of FreeCAD +

      +
       git clone https://github.com/looooo/FreeCAD/tree/py3-27
      +
      +

      Clone the conda-recipes for FreeCAD +

      +
       git clone https://github.com/looooo/FreeCAD_Conda
      +
      +

      - go to FreeCAD_Conda/.FreeCAD_debug +

      - set the variables on top of the script (the path to FreeCAD, and if you want to build with calling cmake) +

      +
       conda build . --python=3.6 --dirty
      +
      +

      (the dirty flag isn't necessary if you build the first time. If it isn't set conda does a full build all the time. The python option is not necessary if you have installed python3.6 miniconda version. But then you have to set this flag to build with python2.7....) +

      +

      Links

      +
      • Follow latest Pyside developments:
      +
      + + + +
      + +
      +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Python_Development_Environment.html b/localwiki/Python_Development_Environment.html new file mode 100644 index 0000000..3c667b6 --- /dev/null +++ b/localwiki/Python_Development_Environment.html @@ -0,0 +1,375 @@ +Python Development Environment

      Python Development Environment

      + +
      + +

      A Simplistic Development Environment for Python within FreeCAD

      +

      Python is a programming environment which has been incorporated into the FreeCAD system. Using Python many operations offered by FreeCAD are available for programmatic access. Python programs for FreeCAD are usually developed to be either run on the Python console or through the Macro facility of FreeCAD (see How to install macros). +

      There are numerous tools available for program development in Python. The complicating factors for developing Python to use with FreeCAD are twofold: first the tools do not have any support for the numerous data structures and access points of FreeCAD; secondly they do not work "within FreeCAD". This means that you can use them to develop code outside of FreeCAD and not be able to test in the target environment; or you can develop Python in the target environment (i.e. the FreeCAD environment) but not have any support from the development tools. Neither of these is an acceptable solution. +

      +

      Background

      +

      Modern software development at the commercial standard is usually done using a set of tools generically referred to as 'IDE'. Typically these tools include the following 3: +

      +
      • source code editor
      • +
      • build automation tools
      • +
      • debugger
      +

      which are standard while the following are present in some IDEs but not in others: +

      +
      • intelligent code completion
      • +
      • integrated compiler, interpreter, or both
      • +
      • version control system
      • +
      • Graphical User Interface (GUI) construction
      • +
      • class browser
      • +
      • object browser
      • +
      • class hierarchy diagram
      +

      A summary of the status of these tools within FreeCAD is ('N/A' meaning 'Not Available'): +

      + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
      source code editor
      +
      a variety of editors are available for the platforms supported by FreeCAD, discussed below
      +
      build automation tools
      +
      N/A
      +
      debugger
      +
      planned but not available yet, there are some work-arounds discussed below
      +
      intelligent code completion
      +
      there is some available through the Python console but that is all
      +
      integrated compiler, interpreter, or both
      +
      The Python compiler is integrated with the Python console but not with the editors
      +
      version control system
      +
      N/A - there is only one version of the file
      +
      Graphical User Interface (GUI) construction
      +
      what is available is basic and based on copy/paste of code (see PySide)
      +
      class browser
      +
      N/A
      +
      object browser
      +
      N/A
      +
      class hierarchy diagram
      +
      N/A
      +
      +

      Many tools exist to support the above function for Python programming but unfortunately they do not integrate with the FreeCAD development environment. +

      A list of IDEs for Python is located at Integrated Development Environments for Python +

      +

      Editors

      +

      There is an editor for Python as part of FreeCAD, it is started by clicking the Edit button on the Macro->Macros... If you want to use a 3rd party editor which takes advantage of your platform then there are various Python editors available, for numerous platforms and with a variety of level of functionality. One advantage of using an external editor is that the display area of FreeCAD can be used for output (both graphic and textual to the console) while the source code is displayed in a different application. A list of editors for Python for a variety of platforms is available at Python Editors +

      Note: For the Macintosh the text editor TextWrangler works well. It has code highlighting and excellent search facilities. There are options to execute jobs in Python but of course they do not work with the FreeCAD environment. +

      +

      Macro Source Code Directories

      +

      There are two directories used by FreeCAD, by default they are the same directory but they are pointed to by different callable point in FreeCAD: +

      +
      • FreeCAD.ConfigGet("UserAppData")
      • +
      • FreeCAD.ParamGet('User parameter:BaseApp/Preferences/Macro').GetString('MacroPath')
      +

      The first one "UserAppData" points to a directory where things like configuration files or other files intended for the user but not to be edited by the user may be stored. +

      The second one "MacroPath" points to a directory where the Python files which are macro files for FreeCAD are stored. To mark a Python file as a macro file for FreeCAD, the file extension is changed from ".py" to ".FCMacro". +

      By default these two directories are the same location but this is not necessary. It might be convenient to alter the location for the macro files (*.FCMacro) to a different location. +

      Editing files located in the "MacroPath" is straight forward, the text editor will accommodate this. For ease of use of FreeCAD Macro files, it is advisable to keep all the macro files in the directory pointed to by "MacroPath". +

      To alter the "MacroPath" directory, use Tools->Edit Parameters and then select Preferences/Macro/MacroPath where the text may be double-clicked and edited. Alternatively "MacroPath" can be altered by the code: +

      +
      FreeCAD.ParamGet('User parameter:BaseApp/Preferences/Macro').SetString('MacroPath','/me/myself/and/I') 
      +

      Debugger

      +
      A debugger is planned for FreeCAD and these steps are a work-around until it is available. See github.com/mumme74/FreeCAD/tree/editor_fixes
      +

      Debuggers typically provide two main features (amongst others): +

      +
      • breakpoints in the source code
      • +
      • variable inspection
      +

      Breakpoints are 'traps' that are placed in the code, if the execution path through the code encounters one of these breakpoints, then execution is halted or suspended. Note that execution is not stopped as when a program is stopped all memory resident information such as variables is lost. While the program is suspended the contents of variables can be inspected and sometimes altered (which depends on the ability of the debugger). Generally the source code can not be changed although some environments do support this. When ready, the execution of the source code can be resumed. Numerous breakpoints can be placed in the code and numerous suspensions through the breakpoints may occur. The purpose of the debugger is to make sure that the execution with the breakpoints and suspensions is functionally identical to execution without breakpoints. +

      Variable Inspections are available during the suspension of execution caused by a breakpoint. Generally the contents of variables can be viewed, many debuggers also support the editing of the contents before execution resumes. +

      Although a fully functioned debugger is planned for FreeCAD it is not available as of yet. This section will detail some work-arounds for the interim until the debugger is released. +

      +

      Breakpoints

      +

      Implementing breakpoints involves a supervisory level of code which administers the execution of the code under development. Such a level of code for Python development within FreeCAD is not presently available. As a weak substitute, the following code is an option. Instead of suspending the execution the code will halt execution completely by dividing a number by zero. This really is a very weak option compared to a proper debugger breakpoint, also this option is only of use when used alongside the routine shown in the next section 'Variable Inspection'. +

      Breakpoint Code +

      +
      def breakpoint(*args):
      +# this routine will print an optional parameter on the console and then stop execution by diving by zero
      +# e.g. breakpoint()
      +# e.g. breakpoint("summation module")
      +#
      +if len(args)>0:
      +FreeCAD.Console.PrintMessage('Breakpoint: '+str(args[0])+"\n")
      +hereWeStop = 12/0 
      +

      Console Traceback +

      When a program fails during execution, Python generates what is known as a traceback which lists the order of program execution (i.e. which program called which program in which order). +

      For the code sample +

      +
      breakpoint('amalgamation routine') 
      +

      we get the following traceback: +

      +
      Breakpoint: amalgamation routine
      +Traceback (most recent call last):
      +  File "/Users/wylbur/Library/Preferences/FreeCAD/testStub.FCMacro", line 40, in <module>
      +    breakpoint()
      +  File "/Users/wylbur/Library/Preferences/FreeCAD/myNewMacro.FCMacro", line 28, in breakpoint
      +    hereWeStop = 12/0
      +ZeroDivisionError: integer division or modulo by zero 
      +

      Reading the traceback we can determine that: +

      +
      • a message of 'Breakpoint: amalgamation routine' was sent by the breakpoint which has the string 'amalgamation routine'
      • +
      • the execution error occurred at line 28 of module 'myNewMacro'
      • +
      • routine 'myNewMacro' was called from line 40 in the module 'testStub'
      +

      Assuming the string passed to the breakpoint call is meaningful then the location of the breakpoint can easily be determined. Note that is a complex system the traceback may have tens or even hundreds of entries in it. +

      To become productive with these breakpoints, continue on to the next section. +

      +

      Variable Inspection

      +

      The second main feature of a debugger is to examine and possibly alter the contents of variables. Once again, until the FreeCAD debugger for Python is ready we have to depend on work-arounds. +

      A feature of the FreeCAD system is the provision of global variables. These variables that are created by the Python code and exist in FreeCAD's memory until the user Quits from FreeCAD. The form of these variables is: +

      +
      FreeCAD.myVariable = 123 
      +

      The statement creates a Python variable in the FreeCAD memory which is fully accessible to Python code, in fact it behaves identically to a normal Python variable. Yet +after the Python code finishes running, no matter if it is running as a macro or through the console, there will be a variable 'FreeCAD.myVariable' remaining in memory with the value of 123. Entering: +

      +
      >>> FreeCAD.myVariable
      +123 
      +

      will produce the contents of the variable on the console. This value will remain in FreeCAD until either it is changed or the user Quits from FreeCAD. This means the value is present and available for a subsequent Python program to read from. At any time it can be checked from the console by typing it's name. So a program called 'Program A': +

      +
      # program A
      +myListVariable = list()
      +myListVariable.append(123)
      +myListVariable.append('abc')
      +FreeCAD.myVariable = myListVariable 
      +

      can run and load values into the global variable. Later a second program called 'Program B' can run and retrieve the value: +

      +
      myOtherVariable = FreeCAD.myVariable
      +# further calculations involving myOtherVariable 
      +

      Presumably 'Program B' then goes on to make calculations involving the values left in FreeCAD.myVariable. At any time the user can type on the console to inspect the variable contents: +

      +
      >>> FreeCAD.myVariable
      +[123, 'abc']
      +>>> 
      +

      An important fact to be aware of with FreeCAD global variables is that they exist in memory and are lost when the program is Quit from. They are not saved with documents but only exist in memory. +

      +

      Usage

      +

      This brings us to a point where we can put the two steps together and use them to trace down errors in code. This is a bit cumbersome to use but is only the option until the FreeCAD debugger is ready. +

      It's probably easiest to present through an example, say the following program is being debugged: +

      +
      def monthCounter():
      +# program to calculate the number of months in the year
      +signsInTheZodiac = 12
      +numberOfSeasons = 3
      +numberOfCompassPoints = 5
      +#
      +temporaryVariable1 = signsInTheZodiac + numberOfSeasons
      +numberOfMonths = temporaryVariable1 - numberOfCompassPoints
      +#
      +FreeCAD.Console.PrintMessage(numberOfMonths) 
      +

      Execution of the program on the console yields: +

      +
      >>> monthCounter()
      +10 
      +

      which is not what we expected! Assuming we are unable to see the errors we can use our unsophisticated breakpoint and variable examiner as follows. We can insert a line to copy the value of the variable we are wondering about to a global variable, then we can place a breakpoint to halt execution there: +

      +
      def monthCounter():
      +# program to calculate the number of months in the year
      +signsInTheZodiac = 12
      +numberOfSeasons = 3
      +numberOfCompassPoints = 5
      +#
      +temporaryVariable1 = signsInTheZodiac + numberOfSeasons
      +FreeCAD.saveMyVariable = temporaryVariable1 # <<<<<<<<<<< first inserted line
      +breakpoint('is this assignment faulty?') # <<<<<<<<<<<<<< second inserted line
      +numberOfMonths = temporaryVariable1 - numberOfCompassPoints
      +#
      +FreeCAD.Console.PrintMessage(numberOfMonths) 
      +

      Now when we run the program we get: +

      +
      >>> monthCounter()
      +Breakpoint: is this assignment faulty?
      +Traceback (most recent call last):
      +  File "<input>", line 1, in <module>
      +  File "<input>", line 9, in monthCounter
      +  File "<input>", line 5, in breakpoint
      +ZeroDivisionError: integer division or modulo by zero
      +>>> 
      +

      Probably things don't look so good, but what we can now do is inspect the value of the Python variable 'temporaryVariable1' as we assigned it's value to the global variable 'FreeCAD.saveMyVariable': +

      +
      >>> FreeCAD.saveMyVariable
      +15
      +>>> 
      +

      Remembering that the variable 'FreeCAD.saveMyVariable' holds the value of the Python variable 'temporaryVariable1' we can now determine the error in the value and start tracing back to determine where the error came from. When we are looking at 'FreeCAD.saveMyVariable' it is important to realise that the variable 'temporaryVariable1' is no longer available - it has been garbage collected away by the Python system. +

      Once the error has been located in the statement +

      +
      numberOfSeasons = 3 
      +

      and corrected to: +

      +
      numberOfSeasons = 4 
      +

      Then we can run the program again, and get the value of '11' which is still not right. We can make more assignments to FreeCAD global variables, have multiple breakpoints (although the first one encountered will stop execution) +

      +
      def monthCounter():
      +# program to calculate the number of months in the year
      +signsInTheZodiac = 12
      +numberOfSeasons = 4
      +numberOfCompassPoints = 5
      +#
      +temporaryVariable1 = signsInTheZodiac + numberOfSeasons
      +FreeCAD.saveMyVariable1 = temporaryVariable1
      +#breakpoint('first assignment')
      +numberOfMonths = temporaryVariable1 - numberOfCompassPoints
      +FreeCAD.saveMyVariable2 = numberOfMonths
      +breakpoint('second assignment')
      +#
      +FreeCAD.Console.PrintMessage(numberOfMonths) 
      +

      We now have two breakpoints (although one is commented out) and two FreeCAD global variables in use. There is no practical limit to the global variables available from FreeCAD so there is no need to economise unnecessarily. We can now produce the following on the console: +

      +
      >>> FreeCAD.saveMyVariable1
      +10
      +>>> FreeCAD.saveMyVariable2
      +11
      +>>> 
      +

      Some points about the use of the FreeCAD global variables: +

      +
      • Python treats these variables identically to any other Python variable
      • +
      • these variables may hold any Python data type - anything a regular Python variable would hold
      • +
      • these variables may be used to 'bring out' the contents of a Python variable so we can see them
      • +
      • also these variables may be used to 'supply' values to a Python variable by setting their value from the console prior to running a routine, or setting it in a previous Python program
      • +
      • these variables may be used to pass data between two programs that run at different points in time
      • +
      • (to repeat) these variables are only for the duration of the FreeCAD session, once the user Quits from FreeCAD then the variables are lost
      +

      Variable Watcher

      +

      There is a utility Global Variable Watcher to help monitor the global variables of FreeCAD. It can display the contents of a global variable either on request or on a timed basis. +

      +

      Name Space Clash

      +

      One thing to be aware of is as there is no management of global variable names by FreeCAD so there is the possibility of changing a variable from the system or another piece of code. Consequently it is a good idea to prefix your variables with something unique such as the routine name. For example to use a variablefrom a routine called 'alpha1' the global name could be 'FreeCAD.alpha1MyVariable'. +

      +

      Coding Framework

      +

      When developing small pieces of Python code in FreeCAD it may be sufficient to use the Python console. However as the number of lines of code grows it makes more sense to store them in a file. Python can be in any file ending with the extension ".py", however FreeCAD also provides a mechanism called Macro for storing such programs and interacting with them (e.g. editing, running). Python in regular '.py' files may only run from the Python console while python in macro file '.FCMacro' can be run from the FreeCAD interface for executing macros. One downside with the FreeCAD menu interface is it is menu based with a control window and potentially causes some clutter on the on-screen GUI. +

      An easier approach is to take the Python code and instead of starting it from the FreeCAD Macro menu, start it from a toolbar. A Python routine linked to a button on a toolbar may be executed by one click. Also as the toolbars are floating windows they do not clutter the on-screen display. In fact if the FreeCAD window is less then the physical size of the screen the toolbar may be left to float outside of the FreeCAD window. This is beneficial when screen snapshots are required of the FreeCAD display. Also the toolbar can be much smaller than the macro control window displayed by the Macro menu of FreeCAD. +

      Connecting a macro to a button on a toolbar is covered in How to Install Macros and How to Customise a Toolbar. It can take a number of minutes to connect a macro to button on toolbar, select an icon etc. This is not always required as sometimes you simply want to quickly flesh out a piece of code which will then be integrated in some other code. For this situation a Test Stub can be beneficial. There is no real definition for what a test stub would entail, it really depends on the person and the application area. An example is shown below: +

      +
      #
      +#TEST
      +#TEST stub to clip any code onto...
      +#TEST
      +#
      +################################
      +# routine to <description goes here>
      +"""
      +script does <long winded description goes here>
      +"""
      +
      +# import statements
      +import FreeCAD
      +from FreeCAD import Base
      +import math, collections
      +from PySide import QtGui, QtCore
      +
      +# UI Class definitions
      +
      +# Class definitions
      +
      +# Functions definitions
      +
      +# Constant definitions
      +
      +# code ***********************************************************************************
      +
      +QtGui.QMessageBox.information(None,"","Test Stub")
      +
      +##########################################################################################
      +##########################################################################################
      +########################################################################################## 
      +

      This test stub also serves as a template for code with locations defined for the different aspects of a large Python program. When executed the test stub program simply generates a message showing it's name and finishes. In using a test stub, any main line code written is placed at the very end of the file with code for class definition, functions etc. placed in the previous sections. The template can easily be altered to match the situation. Obviously for a program of 5 lines there is no need for such an amount of documentation. +

      By keeping a button permanently on a toolbar and linking that button to the test sub, there is always an area to write code and execute it immediately. The execution will be independent of the Python console. Also the execution can be independent of the screen GUI. Output from the program under development will appear as it should on the screen without any other artifacts from the programming environment. The Python console can be hidden to increase display area or used for any other purpose if needed. When execution is handled by the button on the toolbar the console is not required. +

      When the code is finished then is can simply be copied/pasted over to another file and the text stub left empty until the next time it is needed. +

      Multiple pieces of code can be developed using the same test stub with some extra code for providing multiple buttons which is located at PySide Beginner Examples - More Than 2 Buttons. +


      +More PySide Support +

      For more support using the PySide GUI there is the page PySide +


      +More Python Programming Support +

      For more assistance with Python coding, there is a macro written to aid in developing Python code, is it located at Python Assistant Window +

      +

      Putting It All Together

      +

      Screen management can be a challenge when developing code that has complex and detailed graphical output like FreeCAD does. The following system works well: +

      +
      • FreeCAD for console, report, GUI display
      • +
      • toolbar to invoke code being developed
      • +
      • external editor to modify code
      • +
      • PAW (Python Assistant Window) to aid Python code generation
      +


      +Screen Management +

      With the test stub operated from a toolbar, and an external editor used, the window layout on the screen will be something like: +

      PythonDevelopmentEnvironment.jpg +

      "tree" in the diagram refers to the Combi or Tree browsers, the Python console and Report view are combined into the lower window and selectable by buttons. By selective use of the tools the development stream can be optimised, the above is only one idea. Tailoring is done on a personal basis. +

      +

      Miscellaneous Links

      +

      Some other links about IDEs for Python which might be of interest are: +

      + +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Python_scripting_tutorial.html b/localwiki/Python_scripting_tutorial.html new file mode 100644 index 0000000..d59882d --- /dev/null +++ b/localwiki/Python_scripting_tutorial.html @@ -0,0 +1,247 @@ +Python scripting tutorial

      Python scripting tutorial

      + +
      + + + + + + + + + + + + + + + + + + + + + + + + + + + +
      +

      Base ExampleCommandModel.png Tutorial

      +
      Topic +
      Programming +
      Level +
      Intermediate +
      Time to complete +
      +
      Author +
      +
      FreeCAD version +
      +
      Example File(s) +
      +

      + +
      +


      +


      +Python is a programming language, very simple to use and very fast to learn. It is open-source, multi-platform, and can be used alone for a wide array of things, from programming simple shell scripts to very complex programs. But one of its most widespread uses is as a scripting language, since it is easy to embed in other applications. That's exactly how it is used inside FreeCAD. From the python console, or from your custom scripts, you can pilot FreeCAD, and make it perform very complex actions for which there is still no graphical user interface tool. +

      For example, from a python script, you can: +

      +
      • create new objects
      • +
      • modify existing objects
      • +
      • modify the 3D representation of those objects
      • +
      • modify the FreeCAD interface
      +

      There are also several different ways to use python in FreeCAD: +

      +
      • From the FreeCAD python interpreter, where you can issue simple commands like in a "command line"-style interface
      • +
      • From macros, which are a convenient way to quickly add a missing tool to the FreeCAD interface
      • +
      • From external scripts, which can be used to program much more complex things. like entire Workbenches.
      +

      In this tutorial, we'll work on a couple of simple examples to get you started, but there is also much more documentation about python scripting available on this wiki. If you are totally new to python and want to understand how it works, we also have a basic introduction to Python. +

      Important! Before proceeding with Python scripting, go to Edit->Prefences->General->Output window and check 2 boxes: +

      +
      • Redirect internal Python output to report view
      • +
      • Redirect internal Python errors to report view
      +

      Then go to View->Panels and check: +

      +
      • Report view
      +

      This will save you a lot of aggravation! +

      +

      Writing python code

      +

      There are two easy ways to write python code in FreeCAD: From the python console (available from the View -> Panels -> Python console menu) or from the Macro editor (Tools -> Macros). In the console, you write python commands one by one, which are executed when you press return, while the macros can contain a more complex script made of several lines, which is executed only when the macro is executed. +

      +
      The FreeCAD python console
      +

      In this tutorial, you will be able to use both methods, either by copying/pasting each line one by one in the python console and pressing Return after each line, or by copying/pasting the entire code in a new Macro window. +

      +

      Exploring FreeCAD

      +

      Let's start by creating a new empty document: +

      +
      doc = FreeCAD.newDocument() 
      +

      If you type this in the FreeCAD python console, you will notice that as soon as you type "FreeCAD.", a windows pops up, allowing to quickly autocomplete the rest of your line. Even better, each entry in the autocomplete list has a tooltip explaining what it does. This makes it very easy to explore the functionality available. Before choosing "newDocument", have a look at the other options available. +

      +
      The autocomplete mechanism of the FreeCAD python console
      +

      Now our new document will be created. This is similar to pressing the "new document" button on the toolbar. In fact, most buttons in FreeCAD do nothing else than executing a line or two of python code. Even better, you can set an option in Edit->Preferences->General->Macro to "show script commands in python console". This will print in the console all python code executed when you press buttons. Very useful to learn how to reproduce actions in python. +

      Now let's get back to our document. Let's see what we can do with it: +

      +
      doc. 
      +

      Explore the available options. Usually names that begin with a capital letter are attributes, they contain a value, while names that begin with small letter are functions (also called methods), they "do something". Names that begin with an underscore are usually there for the internal working of the module, and you shouldn't care about them. Let's use one of the methods to add a new object to our document: +

      +
      box = doc.addObject("Part::Box","myBox") 
      +

      Nothing happens. Why? Because FreeCAD is made for the big picture. One day, it will work with hundreds of complex objects, all depending one from another. Making a small change somewhere could have a big impact, you may need to recalculate the whole document, which could take a long time... For that reason, almost no command updates the scene automatically. You must do it manually: +

      +
      doc.recompute() 
      +

      See? Now our box appeared! Many of the buttons that add objects in FreeCAD actually do 2 things: add the object, and recompute. If you turned on the "show script commands in python console" option above, try now adding a sphere with the GUI button, you'll see the two lines of python code being executed one after the other. +

      What about the "Part::Box" will you ask? How can I know what other kind of objects can be added? It's all here: +

      +
      doc.supportedTypes() 
      +

      Now let's explore the contents of our box: +

      +
      box. 
      +

      You'll immediately see a couple of very interesting things such as: +

      +
      box.Height 
      +

      This will print the current height of our box. Now let's try to change that: +

      +
      box.Height = 5 
      +

      If you select your box with the mouse, you'll see that in the properties panel, in the "Data" tab, our "Height" property appears. All properties of a FreeCAD object that appear there (and also in the "View" tab, more about that later), are directly accessible by python too, by their names, like we did with the "Height" property. Try changing the other dimensions of that box. +

      +

      Vectors and Placements

      +

      Vectors are a very fundamental concept in any 3D application. It is a list of 3 numbers (x, y and z), describing a point or position in the 3D space. A lot of things can be done with vectors, such as additions, subtractions, projections and much more. In FreeCAD vectors work like this: +

      +
      myvec = FreeCAD.Vector(2,0,0)
      +myvec
      +myvec.x
      +myvec.y
      +othervec = FreeCAD.Vector(0,3,0)
      +sumvec = myvec.add(othervec) 
      +

      Another common feature of FreeCAD objects is their placement. Each object has a Placement attributes, which contains the position (Base) and orientation (Rotation) of the object. It is easy to manipulate, for example to move our object: +

      +
      box.Placement
      +box.Placement.Base
      +box.Placement.Base = sumvec
      + 
      +otherpla = FreeCAD.Placement()
      +box.Placement = otherpla 
      +

      Now you must understand a couple of important concepts before we get further. +

      +

      App and Gui

      +

      FreeCAD is made from the beginning to work as a command-line application, without its user interface. As a result, almost everything is separated between a "geometry" component and a "visual" component. When you work in command-line mode, the geometry part is present, but all the visual part is simply disabled. Almost any object in FreeCAD therefore is made of two parts, an Object and a ViewObject. +

      To illustrate the concept, see our cube object, the geometric properties of the cube, such as its dimensions, position, etc... are stored in the object, while its visual properties, such as its color, line thickness, etc... are stored in the viewobject. This corresponds to the "Data" and "View" tabs in the property window. The view object of an object is accessed like this: +

      +
      vo = box.ViewObject 
      +

      Now you can also change the properties of the "View" tab: +

      +
      vo.Transparency = 80
      +vo.hide()
      +vo.show() 
      +

      When you start FreeCAD, the python console already loads 2 base modules: FreeCAD and FreeCADGui (which can also be accessed by their shortcuts App and Gui). They contain all kinds of generic functionality to work with documents and their objects. To illustrate our concept, see that both FreeCAD and FreeCADGui contain an ActiveDocument attribute, which is the currently opened document. FreeCAD.ActiveDocument and FreeCADGui.ActiveDocument are not the same object. They are the two components of a FreeCAD document, and they contain different attributes and methods. For example, FreeCADGui.ActiveDocument contains ActiveView, which is the currently opened 3D view +

      +

      Modules

      +

      Now, you must be wondering, what, other than "Part::Box", can I do? The FreeCAD base application is more or less an empty container. Without its modules, it can do little more than create new, empty documents. The true power of FreeCAD is in its faithful modules. Each of them adds not only new workbenches to the interface, but also new python commands and new object types. As a result, several different or even totally incompatible object types can coexist in the same document. The most important modules in FreeCAD, that we'll look at in this tutorial, are Part, Mesh, Sketcher or Draft. +

      Sketcher and Draft both use the Part module to create and handle their geometry, which are BRep while Mesh is totally independent, and handles its own objects. More about that below. +

      You can check all the available base object types for the current document like this: +

      +
      doc.supportedTypes() 
      +

      The different FreeCAD modules, although they added their object types to FreeCAD, are not automatically loaded in the python console. This is to avoid having a very slow startup. Modules are loaded only when you need them. So, for example, to explore what's inside the Part module: +

      +
      import Part
      +Part. 
      +

      But we'll talk more about the Part module below. +

      By now, you know a bit more about the different modules of FreeCAD: The core modules (FreeCAD, FreeCADGui), and the workbenches modules (Part, Mesh, Sketcher). The other important modules are the 3d scene module (pivy) and the interface module (pyside), we'll talk about them too below. +

      Now it's time to explore a bit deeper the important ones, which are the workbench modules. +

      +

      Mesh

      +

      Meshes are a very simple kind of 3D objects, used for example by Sketchup, Blender or 3D studio Max. They are composed of 3 elements: points (also called vertices), lines (also called edges) and faces. In many applications, FreeCAD included, faces can have only 3 vertices. But of course nothing prevents you from having a bigger plane face made of several coplanar triangles. +

      Meshes are simple, this can be a bad thing, but for many applications such as those mentioned above, it turns to be an advantage, because they are so simple that you can easily have millions of them in a single document. In FreeCAD, though, they have less use, and are mostly there so you can import objects in mesh formats (.stl, .obj) from other applications. It was also used extensively as the main test module in the first month of FreeCAD's life. +

      Mesh objects and FreeCAD objects are different things. You can see the FreeCAD object as a container for a Mesh object (like, we'll see below, for Part objects too). So in order to add a mesh object to FreeCAD, we must first create a FreeCAD object and a Mesh object, then add the Mesh object to the FreeCAD object: +

      +
      import Mesh
      +mymesh = Mesh.createSphere()
      +mymesh.
      +mymesh.Facets
      +mymesh.Points
      + 
      +meshobj = doc.addObject("Mesh::Feature","MyMesh")
      +meshobj.Mesh = mymesh
      +doc.recompute() 
      +

      This is a standard example, that uses the createSphere() method to automatically create a sphere, but you can very well create custom meshes from scratch, by defining their vertices and faces. +

      Read more about mesh scripting... +

      +

      Part

      +

      The Part Module is the most powerful module of the whole FreeCAD. It allows to create and manipulate BRep objects. This kind of object, unlike meshes, can have a wide variety of components. To resume a bit, Brep means Boundary Representation. which means that they are defined by their surfaces, which enclose and define an inner volume. These surface can be a variety of things, such as plane faces or very complex NURBS surfaces. They also carry the concept of volume. +

      The Part module is based on the powerful OpenCasCade library, which allows a wide range of complex operations to be easily performed on those objects, such as boolean operations, filleting, lofts, etc... +

      The Part module works the same way as the Mesh module: You create a FreeCAD object, a Part object, then add the Part object to the FreeCAD object: +

      +
      import Part
      +myshape = Part.makeSphere(10)
      +myshape.
      +myshape.Volume
      +myshape.Area
      +
      +shapeobj = doc.addObject("Part::Feature","MyShape")
      +shapeobj.Shape = myshape
      +doc.recompute() 
      +

      The Part module (like the Mesh module) also has a shortcut that automatically creates a FreeCAD object and add a shape to it, so you can skip the 3 last lines above: +

      +
      Part.show(myshape) 
      +

      By exploring the contents of myshape, you will notice many interesting available subcomponents such as Faces, Edges, Vertexes, Solids or Shells, and a wide range of geometry operations such as cut (subtraction), common (intersection) or fuse (union). The Topological data scripting page explains all that in detail. +

      Read more about part scripting... +

      +

      Draft

      +

      FreeCAD features many more modules, such as Sketcher or Draft, which also create Part objects, but add parameters to it, or even carry a whole new way to handle the Part geometry in them. Our box example above, is a perfect example of parametric object. All you need, to define the box, is to specify a couple of parameters, such as height, width and length. Based on those, the object will automatically calculate its Part shape. FreeCAD allows you to create such objects in python. +

      The Draft Module adds a couple of 2D parametric objects types (which are all Part objects) such as lines and circles, and also provides some generic functions that work not only on Draft-made objects, but on any Part object. To explore what is available, simply do: +

      +
      import Draft
      +Draft.
      +rec = Draft.makeRectangle(5,2)
      +mvec = FreeCAD.Vector(4,4,0)
      +Draft.move(rec,mvec)
      +Draft.move(box,mvec) 
      +

      Interface

      +

      The FreeCAD user interface is made with Qt, a powerful graphical interface system, responsible for drawing and handling all the controls, menus, toolbars, buttons around the 3D view. Qt provides a module, called PySide, which allows python to access and modify Qt interfaces, such as FreeCAD. Let's try to fiddle with the Qt interface and produce a simple dialog: +

      +
      from PySide import QtGui
      +QtGui.QMessageBox.information(None,"Apollo program","Houston, we have a problem") 
      +

      See that the dialog that appears has the FreeCAD icon in its toolbar, meaning that Qt knows that the order has been issued from inside the FreeCAD application. We can therefore easily directly manipulate any part of the FreeCAD interface. +

      Qt is a very powerful interface system, that allows you to do very complex things, but also has a couple of very easy-to use tools such as the Qt Designer with which you can design dialogs graphically and then add them to the FreeCAD interface with a couple of lines of python. +

      Read more about PySide here... +

      +

      Macros

      +

      Now that you have a good understanding of the basics, where are we going to keep our python scripts, and how are we going to launch them easily from FreeCAD? There is an easy mechanism for that, called Macros. A macro is simply a python script, that can then be added to a toolbar and be launched from a simple mouse click. FreeCAD provides you with a simple text editor (Macro -> Macros -> Create) where you can write or paste scripts. Once it is done, the Tools -> Customize -> Macros allow you to define a button for it, that can be added to toolbars. +

      Now you are ready for more in-depth FreeCAD scripting. Head on to the Power users hub! +

      + +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Qt_Example.html b/localwiki/Qt_Example.html new file mode 100644 index 0000000..fcae347 --- /dev/null +++ b/localwiki/Qt_Example.html @@ -0,0 +1,838 @@ +Qt Example

      Qt Example

      + +
      + + + + + + + + + + + + + + + + + + + + + + + + + + +
      +

      MEPlan.png Macro Qt Example

      +
      Description +
      It describes Qt commands. +
      Author +
      Mario52 +
      Links +
      Macros recipes
      How to install macros
      How to customize toolbars +
      Version +
      "0.3" (12/06/2017) +
      Date last modification +
      YYYY-MM-DD +
      +

      + +
      +


      +

      This macro is an example of using Qt commands their connections, extraction and data assignment. +

      +
      + +
      +
      +

      Are treated : +

      +
      1. icon for window : The icon displayed on main window
      2. +
      3. horizontalSlider : horizontal slider its connection and data extraction / assignment
      4. +
      5. progressBar horizontal : progress bar horizontal its connection and data extraction / assignment
      6. +
      7. verticalSlider : vertical slider its connection and data extraction / assignment
      8. +
      9. progressBar vertical : progress bar vertical its connection and data extraction / assignment
      10. +
      11. lineEdit : line edit its connection and data extraction / assignment
      12. +
      13. lineEdit : line edit its connection and data extraction / assignment
      14. +
      15. doubleSpinBox : double spinbox its connection and data extraction / assignment
      16. +
      17. doubleSpinBox :
      18. +
      19. doubleSpinBox :
      20. +
      21. buttom : buttom its connection
      22. +
      23. buttom :
      24. +
      25. radioButtom : radio button with icons its connection and checked
      26. +
      27. checkBox : checkbox with icon its connection checked and unchecked
      28. +
      29. textEdit : text edit its connection and data extraction / assignment
      30. +
      31. graphicsView : graphic view with 2 graphs and method used for change image
      +

      The tools used are : +python-2.7.8 +

      PyQt4-4.11.4-gpl-Py2.7-Qt4.8.7-x32 +

      For convert the file .ui in .py you must uses pyuic.py is located in "C:\Python27\Lib\site-packages\PyQt4\uic\pyuic.py" (for Windows) +

      you can create a convertuitopy.bat file to automate the process +1: Create a new file in your Qt working directory and name it convertuitopy.bat +

      2: Edit the file and paste this line there +

      @"C:\Python27\python" "C:\Python27\Lib\site-packages\PyQt4\uic\pyuic.py" -x %1.ui > %1.py +

      3: then in a Dos console type convertuitopy myproject (Do not give extension the command automatically adds) +

      4: monprojet.py your file is created +

      +

      The icons used

      +

      MEpipe01.png MEpipe02.png MEPlan.png MEPlanD.png MEPlanF.png MEPlanT.png MEPlanI.png +

      MEPlanFC.png MEPlanPY.png +You must copy and paste the images in the same directory as the macro, here : +

      +
      path = FreeCAD.ConfigGet("UserAppData")    # path FreeCAD User data 
      +

      Linux : "home/user/.FreeCAD/Macro" +

      Windows : "C:\Users\UserName\AppData\Roaming\FreeCAD\Macro" +

      +

      Script

      +

      Qt_Example.FCMacro +

      +
      # -*- coding: utf-8 -*-
      +"""
      +***************************************************************************
      +*   Copyright (c) 2015 2017 <mario52>                                     *
      +*                                                                         *
      +*   This file is a supplement to the FreeCAD CAx development system.      *
      +*                                                                         *
      +*   This program is free software; you can redistribute it and/or modify  *
      +*   it under the terms of the GNU Lesser General Public License (LGPL)    *
      +*   as published by the Free Software Foundation; either version 2 of     *
      +*   the License, or (at your option) any later version.                   *
      +*   for detail see the LICENCE text file.                                 *
      +*                                                                         *
      +*   This software is distributed in the hope that it will be useful,      *
      +*   but WITHOUT ANY WARRANTY; without even the implied warranty of        *
      +*   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the         *
      +*   GNU Library General Public License for more details.                  *
      +*                                                                         *
      +*   You should have received a copy of the GNU Library General Public     *
      +*   License along with this macro; if not, write to the Free Software     *
      +*   Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  *
      +*   USA                                                                   *
      +***************************************************************************
      +*           WARNING! All changes in this file will be lost and            *  
      +*                  may cause malfunction of the program                   *
      +***************************************************************************
      +"""
      +# this macro is made with Python 2.7 and Qt 4.8.7
      +# 
      +# the modules used hare :
      +# python-2.7.8.msi                                 #    https://www.python.org/downloads/
      +# PyQt4-4.11.4-gpl-Py2.7-Qt4.8.7-x32.exe           #    https://riverbankcomputing.com/software/pyqt/download
      +#
      +# FreeCAD
      +##OS: Windows 8                                    # OS: Windows 10
      +##Word size of OS: 64-bit                          # Word size of OS: 64-bit
      +##Word size of FreeCAD: 64-bit                     # Word size of FreeCAD: 64-bit
      +##Version: 0.15.4671 (Git)                         # Version: 0.16.6706 (Git)
      +##"Branch: releases/FreeCAD-0-15                   # Build type: Release
      +##Hash: 244b3aef360841646cbfe80a1b225c8b39c8380c   # Branch: releases/FreeCAD-0-16
      +##Python version: 2.7.8                            # Hash: f86a4e411ff7848dea98d7242f43b7774bee8fa0
      +##Qt version: 4.8.6                                # Python version: 2.7.8
      +##Coin version: 4.0.0a                             # Qt version: 4.8.7
      +##OCC version: 6.8.0.oce-0.17                      # Coin version: 4.0.0a
      +#                                                  # OCC version: 6.8.0.oce-0.17
      +# this macro is an example of use some buttons and connection :
      +#                                                    ********** is a connection  ** references lines **********
      +# 
      +# horizontalScrollBar                                                               lines 151 to 161, 431, 432, 642
      +#    def on_horizontal_scrolling(self, val_X):                  #connection         lines 161, 526, 531
      +# verticalScrollBar                                                                 lines 163 to 173, 393, 394, 433, 643
      +#    def on_vertical_scrolling(self, val_Y):                    #connection         lines 173, 534, 539
      +# horizontalSlider                                                                  lines 174 to 181, 575, 577, 644
      +#    def on_horizontal_slider(self, val_X):                     #connection         lines 181,  542, 553
      +# verticalSlider                                                                    lines 183 to 188, 593, 595, 645
      +#    def on_vertical_slider(self, val_Y):                       #connection         lines 188, 556, 564
      +# progressBar
      +#     progressBar_1_Red                                                             lines 190 to 199, 533, 548, 579
      +#     progressBar_1_Green                                                           lines 205 to 214, 552, 583
      +#     progressBar_1_Blue                                                            lines 217 to 228, 553, 584
      +#     progressBar_1_gradient                                                        lines 230 to 242, 554, 585
      +#     progressBar_2                                                                 lines 244 to 252, 540, 565, 600
      +
      +# lineEdit
      +#     lineEdit_1                                                                    lines 256 to 262, 455, 531, 550, 644
      +#        def on_lineEdit_1_Pressed(self):                       #connection         lines 261, 262, 572
      +#     lineEdit_2                                                                    lines 264 to 270, 458, 539, 564, 645
      +#        def on_lineEdit_2_Pressed(self):                       #connection         lines 269, 270, 590
      +# doubleSpinBox
      +#     doubleSpinBox_1                                                               lines 272 to 279, 461, 462, 641
      +#        def on_doubleSpinBox_1_valueChanged(self,echelle):     #connection         lines 279, 674
      +#     doubleSpinBox_2                                                               lines 281 to 287, 464, 465, 642
      +#        def on_doubleSpinBox_2_valueChanged(self,angle):       #connection         lines 287, 681
      +#     doubleSpinBox_3                                                               lines 289 to 295, 467, 468, 643 
      +#        def on_doubleSpinBox_3_valueChanged(self,epaisseur):   #connection         lines 295, 687
      +# pushButton
      +#     pushButton_1                                                                  lines 297 to 301, 450, 451, 631, 663, 670
      +#        def on_pushButton_1_clicked(self):                     #connection         lines 301, 636
      +#     pushButton_2                                                                  lines 303 to 307, 452, 453
      +#        def on_pushButton_2_clicked(self):                     #connection         lines 307, 627
      +# groupBox                                                                          lines 309 to 312, 315, 326, 336, 346, 356, 439
      +#     radioButton
      +#         radioButton_1                                                             lines 315 to 323, 440, 441, 486, 487, 651
      +#            def on_radioButton_1_clicked(self):                #connection         lines 323, 482
      +#         radioButton_2                                                             lines 325 to 333, 442, 443, 494, 495
      +#            def on_radioButton_2_clicked(self):                #connection         lines 333, 490
      +#         radioButton_3                                                             lines 335 to 343, 444, 445, 501, 502
      +#            def on_radioButton_3_clicked(self):                #connection         lines 343, 498
      +#         radioButton_4                                                             lines 345 to 353, 446, 447, 509, 510
      +#            def on_radioButton_4_clicked(self):                #connection         lines 353, 505
      +# checkBox
      +#        checkBox_1                                                                 lines 355 to 364, 448, 449, 610, 614, 615, 621, 622, 652, 655
      +#        def on_checkBox_1_clicked(self):                       #connection         lines 360, 606
      +# textEdit
      +#        textEdit                                                                   lines 391 to 399, 534, 542, 556, 567, 650, 695
      +#        def on_textEdit_Changed(self):                         #connection         lines 399, 694
      +# graphicsView                                                                      lines 401 to 410, 662, 669
      +# 
      +# 
      +# 
      +# 
      + 
      +__title__   = "Examples_QT "
      +__author__  = "mario52"
      +__version__ = "00.03"
      +__date__    = "12/06/2017"
      + 
      +__url__     = "http://www.freecadweb.org/index-fr.html"
      +__Comment__ = "Example make and use buttom and . . . ."
      +__Communication__ = "http://www.freecadweb.org/wiki/index.php?title=User:Mario52"
      +__Icon__  = "home/user/.FreeCAD"
      +__IconW__  = "C:/Users/UserName/AppData/Roaming/FreeCAD"
      + 
      +import PySide
      +from PySide import QtCore, QtGui
      +#from PySide.QtGui import qApp, QApplication, QGridLayout, QLineEdit, QPushButton, QTextBrowser, QWidget, QProgressBar
      + 
      +global switch ; switch = 0
      + 
      +global path
      +#path  = FreeCAD.ConfigGet("AppHomePath")                           # path FreeCAD installation
      +#path  = FreeCAD.ConfigGet("UserAppData")                           # path FreeCAD User data
      +#path  = "your path"                                                # your directory path
      +param = FreeCAD.ParamGet("User parameter:BaseApp/Preferences/Macro")# macro path
      +path = param.GetString("MacroPath","") + "/"                        # macro path
      +path = path.replace("\\","/")                                       # convert the "\" to "/"
      +print "Path for the icons : " , path                                # 
      + 
      +try:
      +    _fromUtf8 = QtCore.QString.fromUtf8
      +except AttributeError:
      +    def _fromUtf8(s):
      +        return s
      + 
      +try:
      +    _encoding = QtGui.QApplication.UnicodeUTF8
      +    def _translate(context, text, disambig):
      +        return QtGui.QApplication.translate(context, text, disambig, _encoding)
      +except AttributeError:
      +    def _translate(context, text, disambig):
      +        return QtGui.QApplication.translate(context, text, disambig)
      + 
      +class Ui_MainWindow(object):
      +    def setupUi(self, MainWindow):
      +        self.window = MainWindow
      +        global switch
      + 
      +        MainWindow.setObjectName(_fromUtf8("MainWindow"))
      +        MainWindow.resize(400, 450)
      +        MainWindow.setMinimumSize(QtCore.QSize(400, 450))
      +        MainWindow.setMaximumSize(QtCore.QSize(400, 450))
      +        self.widget = QtGui.QWidget(MainWindow)
      +        self.widget.setObjectName(_fromUtf8("widget"))
      + 
      +##        section horizontalScrollBar                                                        (same Slider)
      +#        self.horizontalScrollBar = QtGui.QScrollBar(self.widget)                           # create horizontalScrollBar
      +#        self.horizontalScrollBar.setGeometry(QtCore.QRect(64, 5, 302, 16))                 # coordinates position
      +#        #self.horizontalScrollBar.setMinimum(-100)                                         # minimum value
      +#        self.horizontalScrollBar.setMaximum(100)                                           # maximum value
      +#        #self.horizontalScrollBar.setSingleStep(3)                                         # here step 3 ..
      +#        self.horizontalScrollBar.setValue( 5)                                              # value by default
      +#        self.horizontalScrollBar.setOrientation(QtCore.Qt.Horizontal)                      # orientation Horizontal
      +#        #self.horizontalScrollBar.setInvertedAppearance(True)                              # displacement rigth to left or left to rigth value "True" or "False"
      +#        self.horizontalScrollBar.setObjectName(_fromUtf8("horizontalScrollBar"))           # object Name
      +#        self.horizontalScrollBar.valueChanged.connect(self.on_horizontal_scrolling)        # connect on "def on_horizontal_scrolling:" for execute action
      +#
      +##        section verticalScrollBar
      +#        self.verticalScrollBar = QtGui.QScrollBar(self.widget)                             # create verticalScrollBar
      +#        self.verticalScrollBar.setGeometry(QtCore.QRect(20, 44, 20, 250))                  # coordinates position
      +#        #self.verticalScrollBar.setMinimum(-100)                                           # minimum value
      +#        self.verticalScrollBar.setMaximum(100)                                             # maximum value
      +#        #self.verticalScrollBar.setSingleStep(3)                                           # here step 3 .. degault 1
      +#        self.verticalScrollBar.setValue(5)                                                 # value by default
      +#        self.verticalScrollBar.setOrientation(QtCore.Qt.Vertical)                          # orientation Vertical
      +#        self.verticalScrollBar.setInvertedAppearance(True)                                 # displacement top to bottom or botton to top value "True" or "False" 
      +#        self.verticalScrollBar.setObjectName(_fromUtf8("verticalScrollBar"))               # object Name
      +#        self.verticalScrollBar.valueChanged.connect(self.on_vertical_scrolling)            # connect on "def on_vertical_scrolling:" for execute action
      + 
      +#        section horizontalSlider 
      +        self.horizontalSlider = QtGui.QSlider(self.widget)                                  # create horizontalSlider
      +        self.horizontalSlider.setGeometry(QtCore.QRect(64, 5, 302, 16))                     # coordinates position
      +        self.horizontalSlider.setOrientation(QtCore.Qt.Horizontal)                          # orientation Horizontal
      +        self.horizontalSlider.setInvertedAppearance(False)                                  # displacement rigth to left or left to rigth value "True" or "False"
      +        self.horizontalSlider.setObjectName(_fromUtf8("horizontalSlider"))                  # object Name
      +        self.horizontalSlider.valueChanged.connect(self.on_horizontal_slider)               # connect on "def on_horizontal_slider:" for execute action
      + 
      +#        section verticalSlider 
      +        self.verticalSlider = QtGui.QSlider(self.widget)                                    # create verticalSlider
      +        self.verticalSlider.setGeometry(QtCore.QRect(20, 44, 20, 365))                      # coordinates position
      +        self.verticalSlider.setOrientation(QtCore.Qt.Vertical)                              # orientation Vertical
      +        self.verticalSlider.setObjectName(_fromUtf8("verticalSlider"))                      # object Name
      +        self.verticalSlider.valueChanged.connect(self.on_vertical_slider)                   # connect on "def on_vertical_slider:" for execute action
      + 
      +#        section progressBar 1 Red
      +        self.progressBar_1_Red = QtGui.QProgressBar(self.widget)                            # create object progressBar_1
      +        self.progressBar_1_Red.setGeometry(QtCore.QRect(60, 21, 315, 23))                   # coordinates position
      +        self.progressBar_1_Red.setValue(0)                                                  # value by default
      +        self.progressBar_1_Red.setOrientation(QtCore.Qt.Horizontal)                         # orientation Horizontal
      +        self.progressBar_1_Red.setAlignment(QtCore.Qt.AlignCenter)                          # align text center
      +        self.progressBar_1_Red.setObjectName(_fromUtf8("progressBar_1_Red"))                # object Name
      +        self.progressBar_1_Red.setToolTip(_translate("MainWindow", "progressBar_1_Red for lineEdit 1 and horizontal ScrollBar", None)) # tooltip for explanation
      +                                                                                            # a tooltip can be set to all objects
      +        self.progressBar_1_Red.setStyleSheet("QProgressBar {color:black; }"
      +                                              "QProgressBar:chunk {background-color: #FF0000;}") # modify the progressBar color 
      +
      +#        section progressBar 1 Green
      +        self.progressBar_1_Green = QtGui.QProgressBar(self.widget)                          # create object progressBar_1
      +        self.progressBar_1_Green.setGeometry(QtCore.QRect(60, 51, 315, 23))                 # coordinates position
      +        self.progressBar_1_Green.setValue(0)                                                # value by default
      +        self.progressBar_1_Green.setOrientation(QtCore.Qt.Horizontal)                       # orientation Horizontal
      +        self.progressBar_1_Green.setAlignment(QtCore.Qt.AlignCenter)                        # align text center
      +        self.progressBar_1_Green.setObjectName(_fromUtf8("progressBar_1_Green"))            # object Name
      +        self.progressBar_1_Green.setToolTip(_translate("MainWindow", "progressBar_1_Green for lineEdit 1 and horizontal ScrollBar", None)) # tooltip for explanation
      +                                                                                            # a tooltip can be set to all objects
      +        self.progressBar_1_Green.setStyleSheet("QProgressBar {color:black; }"
      +                                              "QProgressBar:chunk {background-color: #00FF00;}") # modify the progressBar color 
      +
      +#        section progressBar 1 Blue
      +        self.progressBar_1_Blue = QtGui.QProgressBar(self.widget)                           # create object progressBar_1
      +        self.progressBar_1_Blue.setGeometry(QtCore.QRect(60, 81, 315, 23))                  # coordinates position
      +        self.progressBar_1_Blue.setValue(0)                                                 # value by default
      +        self.progressBar_1_Blue.setOrientation(QtCore.Qt.Horizontal)                        # orientation Horizontal
      +        self.progressBar_1_Blue.setAlignment(QtCore.Qt.AlignCenter)                         # align text center
      +        self.progressBar_1_Blue.setObjectName(_fromUtf8("progressBar_1_Blue"))              # object Name
      +        self.progressBar_1_Blue.setToolTip(_translate("MainWindow", "progressBar_1_Blue for lineEdit 1 and horizontal ScrollBar", None)) # tooltip for explanation
      +                                                                                            # a tooltip can be set to all objects
      +        self.progressBar_1_Blue.setStyleSheet(
      +         "QProgressBar {color:black; text-align:right; padding:2px; border-radius: 5px;}" # modify the progressBar color and display
      +         "QProgressBar:chunk {background-color: #0000FF; width: 10px; margin-left:2px;}")
      +
      +#        section progressBar 1 gradient
      +        self.progressBar_1_gradient = QtGui.QProgressBar(self.widget)                       # create object progressBar_1
      +        self.progressBar_1_gradient.setGeometry(QtCore.QRect(60, 110, 315, 23))             # coordinates position
      +        self.progressBar_1_gradient.setValue(0)                                             # value by default
      +        self.progressBar_1_gradient.setOrientation(QtCore.Qt.Horizontal)                    # orientation Horizontal
      +        self.progressBar_1_gradient.setAlignment(QtCore.Qt.AlignCenter)                     # align text center
      +        self.progressBar_1_gradient.setObjectName(_fromUtf8("progressBar_1_gradient"))      # object Name
      +        self.progressBar_1_gradient.setToolTip(_translate("MainWindow", "progressBar_1_gradient for lineEdit 1 and horizontal ScrollBar", None)) # tooltip for explanation
      +                                                                                            # a tooltip can be set to all objects
      +        ##http://pyqt.sourceforge.net/Docs/PyQt4/qlineargradient.html
      +        self.progressBar_1_gradient.setStyleSheet(
      +         "QProgressBar {color:red; text-align:right; padding:1px; }"                    # modify the progressBar color and display
      +             "QProgressBar:chunk {text-align: center; background: qlineargradient(x1: 0, y1: 0.5, x2: 1, y2: 0.5, stop: 0 #FFFF00, stop: 1 #00FFFF);}")
      +
      +#        section progressBar 2
      +        self.progressBar_2 = QtGui.QProgressBar(self.widget)                                # create object progressBar_2
      +        self.progressBar_2.setGeometry(QtCore.QRect(40, 44, 20, 365))                       # coordinates position
      +        self.progressBar_2.setValue(0)                                                      # value by default
      +        self.progressBar_2.setOrientation(QtCore.Qt.Vertical)                               # position Vertical
      +        self.progressBar_2.setAlignment(QtCore.Qt.AlignCenter)                              # align text center (not text displayed ?)
      +        self.progressBar_2.setOrientation(QtCore.Qt.Vertical)                               # orientation Vertical
      +        self.progressBar_2.setObjectName(_fromUtf8("progressBar_2"))                        # progressBar 2 Y Vertical
      +        self.progressBar_2.setToolTip(_translate("MainWindow", "progressBar_2 for lineEdit 2 and vertical ScrollBar", None)) # tooltip for explanation
      +                                                                                            # a tooltip can be set to all objects
      + 
      +#        section lineEdit 1
      +        self.lineEdit_1 = QtGui.QLineEdit(self.widget)                                      # create object lineEdit_1
      +        self.lineEdit_1.setGeometry(QtCore.QRect(70, 150, 60, 22))                           # coordinates position
      +        self.lineEdit_1.setObjectName(_fromUtf8("lineEdit_1"))                              # name of object
      +        self.lineEdit_1.setText(QtGui.QApplication.translate("Form", "0", None, QtGui.QApplication.UnicodeUTF8))              # text by default
      +        #self.lineEdit_1.returnPressed.connect(self.on_lineEdit_1_Pressed)                  # connect on def "on_lineEdit_1_Pressed" for execute actionn   # for validate the data with press on return touch
      +        self.lineEdit_1.textChanged.connect(self.on_lineEdit_1_Pressed)                     # connect on def "on_lineEdit_1_Pressed" for execute actionn   # with tips key char by char
      +                                                                                            # a tooltip can be set to all objects
      +#        section lineEdit 2
      +        self.lineEdit_2 = QtGui.QLineEdit(self.widget)                                      # create object lineEdit_2
      +        self.lineEdit_2.setGeometry(QtCore.QRect(70, 180, 60, 22))                           # coordinates position
      +        self.lineEdit_2.setObjectName(_fromUtf8("lineEdit_2"))                              # name of object
      +        self.lineEdit_2.setText(QtGui.QApplication.translate("Form", "0", None, QtGui.QApplication.UnicodeUTF8)) # text by default
      +#        self.lineEdit_2.returnPressed.connect(self.on_lineEdit_2_Pressed)                  # connect on def "on_lineEdit_2_Pressed" for execute actionn   # for validate the data with press on return touch
      +        self.lineEdit_2.textChanged.connect(self.on_lineEdit_2_Pressed)                     # connect on def "on_lineEdit_2_Pressed" for execute actionn   # with tips key char by char
      + 
      +        # accelerated minimum maximum singleStep prefix suffix
      +        self.doubleSpinBox_1 = QtGui.QDoubleSpinBox(self.widget)                            # create object doubleSpinBox_1
      +        self.doubleSpinBox_1.setGeometry(QtCore.QRect(70, 210, 62, 22))                     # coordinates position
      +        self.doubleSpinBox_1.setMinimum(-10000.0)                                           # minimum value
      +        self.doubleSpinBox_1.setMaximum(10000.0)                                            # maximum value
      +        self.doubleSpinBox_1.setSingleStep(0.1)                                             # step for increase or decrease value here 0.1
      +        self.doubleSpinBox_1.setObjectName(_fromUtf8("doubleSpinBox_1"))                    # name of object
      +        self.doubleSpinBox_1.valueChanged.connect(self.on_doubleSpinBox_1_valueChanged)     #connect on def "on_doubleSpinBox_1_valueChanged"
      + 
      +        self.doubleSpinBox_2 = QtGui.QDoubleSpinBox(self.widget)                            # create object doubleSpinBox_2
      +        self.doubleSpinBox_2.setGeometry(QtCore.QRect(70, 240, 62, 22))                     # coordinates position
      +        self.doubleSpinBox_2.setMinimum(-361.0)                                             # minimum value
      +        self.doubleSpinBox_2.setMaximum(361.0)                                              # maximum value
      +        self.doubleSpinBox_2.setSingleStep(1)                                               # step for increase or decrease value here 1
      +        self.doubleSpinBox_2.setObjectName(_fromUtf8("doubleSpinBox_2"))                    # name of object
      +        self.doubleSpinBox_2.valueChanged.connect(self.on_doubleSpinBox_2_valueChanged)     # connect on def "on_doubleSpinBox_2_valueChanged"
      + 
      +        self.doubleSpinBox_3 = QtGui.QDoubleSpinBox(self.widget)                            # create object doubleSpinBox_3
      +        self.doubleSpinBox_3.setGeometry(QtCore.QRect(70, 270, 62, 22))                     # coordinates position
      +        self.doubleSpinBox_3.setMinimum(0)                                                  # minimum value
      +        self.doubleSpinBox_3.setMaximum(100.0)                                              # maximum value
      +        self.doubleSpinBox_3.setSingleStep(0.05)                                            # step for increase or decrease value here 0.05
      +        self.doubleSpinBox_3.setObjectName(_fromUtf8("doubleSpinBox_3"))                    # name of object
      +        self.doubleSpinBox_3.valueChanged.connect(self.on_doubleSpinBox_3_valueChanged)     # connect on def "on_doubleSpinBox_3_valueChanged"
      + 
      +#        section pushButton 1
      +        self.pushButton_1 = QtGui.QPushButton(self.widget)                                  # create object PushButton_1
      +        self.pushButton_1.setGeometry(QtCore.QRect(70, 298, 65, 20))                        # coordinates position
      +        self.pushButton_1.setObjectName(_fromUtf8("pushButton_1"))                          # name of object
      +        self.pushButton_1.clicked.connect(self.on_pushButton_1_clicked)                     # connect on def "on_pushButton_1_clicked"
      + 
      +#        section pushButton 2
      +        self.pushButton_2 = QtGui.QPushButton(self.widget)                                  # create object pushButton_2
      +        self.pushButton_2.setGeometry(QtCore.QRect(150, 298, 65, 20))                       # coordinates position
      +        self.pushButton_2.setObjectName(_fromUtf8("pushButton_2"))                          # name of object
      +        self.pushButton_2.clicked.connect(self.on_pushButton_2_clicked)                     # connect on def "on_pushButton_2_clicked"
      + 
      +#        section groupBox for the four radioButton
      +        self.groupBox = QtGui.QGroupBox(self.widget)                                        # this is the group for associate the four radioButton
      +        self.groupBox.setGeometry(QtCore.QRect(250, 140, 125, 181))                          # coordinates position
      +        self.groupBox.setObjectName(_fromUtf8("groupBox"))                                  # name of window groupBox
      + 
      +#        section radioButton 1
      +        self.radioButton_1 = QtGui.QRadioButton(self.groupBox)                              # create object QRadioButton in groupBox
      +        self.radioButton_1.setGeometry(QtCore.QRect(10, 30, 110, 20))                       # coordinates position
      +        self.radioButton_1.setObjectName(_fromUtf8("radioButton_1"))                        # name of object
      +        self.radioButton_1.setChecked(True)                                                 # by default True or False (one in the group))
      +        self.image_01 = path+"MEPlanT.png"                                                  # image dedicate of the button
      +        icon01 = QtGui.QIcon()                                                              # create image name
      +        icon01.addPixmap(QtGui.QPixmap(self.image_01),QtGui.QIcon.Normal, QtGui.QIcon.Off)  #
      +        self.radioButton_1.setIcon(icon01)                                                  # associate button and image
      +        self.radioButton_1.clicked.connect(self.on_radioButton_1_clicked)                   # connect radioButton_1 on "def on_radioButton_1_clicked:"
      + 
      +#        section radioButton 2
      +        self.radioButton_2 = QtGui.QRadioButton(self.groupBox)                              # create object QRadioButton in groupBox
      +        self.radioButton_2.setGeometry(QtCore.QRect(10, 60, 110, 20))                       # coordinates position
      +        self.radioButton_2.setObjectName(_fromUtf8("radioButton_2"))                        # name of object
      +        self.image_02 = path+"MEPlanF.png"                                                  # image dedicate of the button
      +        icon02 = QtGui.QIcon()                                                              # create image name
      +        icon02.addPixmap(QtGui.QPixmap(self.image_02),QtGui.QIcon.Normal, QtGui.QIcon.Off)  #
      +        self.radioButton_2.setIcon(icon02)                                                  # associate button and image
      +        self.radioButton_2.clicked.connect(self.on_radioButton_2_clicked)                   # connect radioButton_2 on "def on_radioButton_2_clicked:"
      + 
      +#        section radioButton 3
      +        self.radioButton_3 = QtGui.QRadioButton(self.groupBox)                              # create object QRadioButton in groupBox
      +        self.radioButton_3.setGeometry(QtCore.QRect(10, 90, 110, 20))                       # coordinates position
      +        self.radioButton_3.setObjectName(_fromUtf8("radioButton_3"))                        # name of object
      +        self.image_03 = path+"MEPlanD.png"                                                  # image dedicate of the button
      +        icon03 = QtGui.QIcon()                                                              # create image name
      +        icon03.addPixmap(QtGui.QPixmap(self.image_03),QtGui.QIcon.Normal, QtGui.QIcon.Off)  #
      +        self.radioButton_3.setIcon(icon03)                                                  # associate button and image
      +        self.radioButton_3.clicked.connect(self.on_radioButton_3_clicked)                   # connect radioButton_3 on "def on_radioButton_3_clicked:"
      + 
      +#        section radioButton 4
      +        self.radioButton_4 = QtGui.QRadioButton(self.groupBox)                              # create object QRadioButton in groupBox
      +        self.radioButton_4.setGeometry(QtCore.QRect(10, 150, 110, 20))                      # coordinates position
      +        self.radioButton_4.setObjectName(_fromUtf8("radioButton_4"))                        # name of object
      +        self.image_04 = path+"MEPlanI.png"                                                  # image dedicate of the button
      +        icon04 = QtGui.QIcon()                                                              # create image name
      +        icon04.addPixmap(QtGui.QPixmap(self.image_04),QtGui.QIcon.Normal, QtGui.QIcon.Off)  #
      +        self.radioButton_4.setIcon(icon04)                                                  # associate button and image
      +        self.radioButton_4.clicked.connect(self.on_radioButton_4_clicked)                   # connect radioButton_4 on "def on_radioButton_4_clicked:"
      + 
      +#        section checkBox 1
      +        self.checkBox_1 = QtGui.QCheckBox(self.groupBox)                                    # create object QRadioButton in groupBox
      +        self.checkBox_1.setGeometry(QtCore.QRect(20, 120, 110, 20))                         # coordinates position
      +        self.checkBox_1.setObjectName(_fromUtf8("checkBox_1"))                              # name of object
      +        self.checkBox_1.setChecked(True)                                                    # Check by default True or False
      +        self.checkBox_1.clicked.connect(self.on_checkBox_1_clicked)                         # connect on def "on_checkBox_1_clicked"
      +        self.image_1 = path+"MEpipe01.png"                                                  # image dedicate of the button
      +        icon1 = QtGui.QIcon()                                                               # create image name
      +        icon1.addPixmap(QtGui.QPixmap(self.image_1),QtGui.QIcon.Normal, QtGui.QIcon.Off)    # 
      +        self.checkBox_1.setIcon(icon1)                                                      # associate button and image
      + 
      + 
      +        self.label_1 = QtGui.QLabel(self.widget)                                            # labels displayed on widget
      +        self.label_1.setGeometry(QtCore.QRect(140, 150, 110, 16))                           # label coordinates 
      +        self.label_1.setObjectName(_fromUtf8("label_1"))                                    # label name
      + 
      +        self.label_2 = QtGui.QLabel(self.widget)
      +        self.label_2.setGeometry(QtCore.QRect(140, 180, 110, 16))
      +        self.label_2.setObjectName(_fromUtf8("label_2"))
      + 
      +        self.label_3 = QtGui.QLabel(self.widget)
      +        self.label_3.setGeometry(QtCore.QRect(140, 210, 100, 16))
      +        self.label_3.setObjectName(_fromUtf8("label_3"))
      + 
      +        self.label_4 = QtGui.QLabel(self.widget)
      +        self.label_4.setGeometry(QtCore.QRect(140, 240, 100, 16))
      +        self.label_4.setObjectName(_fromUtf8("label_4"))
      + 
      +        self.label_5 = QtGui.QLabel(self.widget)
      +        self.label_5.setGeometry(QtCore.QRect(140, 270, 100, 16))
      +        self.label_5.setObjectName(_fromUtf8("label_5"))
      + 
      +        self.label_6 = QtGui.QLabel(self.widget)
      +        self.label_6.setGeometry(QtCore.QRect(70, 315, 159, 25))
      +        self.label_6.setObjectName(_fromUtf8("label_6"))
      + 
      +        self.textEdit = QtGui.QTextEdit(self.widget)
      +        self.textEdit.setGeometry(QtCore.QRect(251, 350, 124, 58))
      +        self.textEdit.setObjectName(_fromUtf8("textEdit"))
      +        #self.textEdit.setTextInteractionFlags(QtCore.Qt.TextSelectableByMouse)            #
      +        self.textEdit.setText("TexEdit ")
      +        self.textEdit.setToolTip(_translate("MainWindow", "textEdit", None))
      +        #self.textEdit.verticalScrollBar().setValue(0)                                      # verticalScrollBar Position
      +        #self.textEdit.verticalScrollBar().setSliderPosition(0)                             # Slider Position
      +        self.textEdit.textChanged.connect(self.on_textEdit_Changed)                         #connection on_textEdit_Changed
      + 
      +        ### ---graphicsView---
      +        self.graphicsView = QtGui.QGraphicsView(self.widget)                                # graphic view declaration
      +        self.graphicsView.setGeometry(QtCore.QRect(70, 350, 168, 60))                       # coordinates position
      +        self.graphicsView.setFrameShape(QtGui.QFrame.StyledPanel)                           # Frame for the gaphic view
      +        self.graphicsView.setObjectName(_fromUtf8("graphicsView"))                          # name gaphicView
      +        pic = QtGui.QPixmap(path+"MEPlanFC.png")                                            # image displayed in the graphicView
      +        self.scene = QtGui.QGraphicsScene()                                                 #
      +        self.scene.addPixmap(QtGui.QPixmap(pic))                                            # adding image in the graphicView
      +        self.graphicsView.setScene(ui.scene)                                                # display image in the graphicView
      +        ### ---graphicsView---
      + 
      +        MainWindow.setCentralWidget(self.widget)
      +        self.menuBar = QtGui.QMenuBar(MainWindow)
      +        self.menuBar.setGeometry(QtCore.QRect(0, 0, 400, 26))
      +        self.menuBar.setObjectName(_fromUtf8("menuBar"))
      +        MainWindow.setMenuBar(self.menuBar)
      +        self.mainToolBar = QtGui.QToolBar(MainWindow)
      +        self.mainToolBar.setObjectName(_fromUtf8("mainToolBar"))
      +        MainWindow.addToolBar(QtCore.Qt.TopToolBarArea, self.mainToolBar)
      +        self.statusBar = QtGui.QStatusBar(MainWindow)
      +        self.statusBar.setObjectName(_fromUtf8("statusBar"))
      +        MainWindow.setStatusBar(self.statusBar)
      +        self.statusbar = QtGui.QStatusBar(MainWindow)
      +        self.statusbar.setObjectName(_fromUtf8("statusbar"))
      +        MainWindow.setStatusBar(self.statusbar)
      + 
      +        self.retranslateUi(MainWindow)
      +        QtCore.QMetaObject.connectSlotsByName(MainWindow)
      + 
      +    def retranslateUi(self, MainWindow):
      +        MainWindow.setWindowFlags(PySide.QtCore.Qt.WindowStaysOnTopHint)                   # this function turns the front window (stay to hint)
      +        MainWindow.setWindowTitle(_translate("MainWindow", "Qt_Example", None))            # title main window
      +        MainWindow.setWindowIcon(QtGui.QIcon(path+'MEPlan.png'))                           # change the icon of the main window
      + 
      +#        for horizontalScrollBar
      +#        self.horizontalScrollBar.setToolTip(_translate("MainWindow", "horizontalScrollBar", None))
      +#        self.verticalScrollBar.setToolTip(_translate("MainWindow", "verticalScrollBar", None))
      + 
      +        self.groupBox.setTitle(_translate("MainWindow", "View", None))
      +        self.radioButton_1.setToolTip(_translate("MainWindow", "radioButton_1", None))
      +        self.radioButton_1.setText(_translate("MainWindow", "radioButton_1", None))
      +        self.radioButton_2.setToolTip(_translate("MainWindow", "radioButton_2", None))
      +        self.radioButton_2.setText(_translate("MainWindow", "radioButton_2", None))
      +        self.radioButton_3.setToolTip(_translate("MainWindow", "radioButton_3" , None))
      +        self.radioButton_3.setText(_translate("MainWindow", "radioButton_3", None))
      +        self.radioButton_4.setToolTip(_translate("MainWindow", "radioButton_4", None))
      +        self.radioButton_4.setText(_translate("MainWindow", "radioButton_4", None))
      +        self.checkBox_1.setToolTip(_translate("MainWindow", "checkBox_1", None))
      +        self.checkBox_1.setText(_translate("MainWindow", "checkBox_1", None))
      +        self.pushButton_1.setToolTip(_translate("MainWindow", "pushButton_1", None))
      +        self.pushButton_1.setText(_translate("MainWindow", "Reset", None))
      +        self.pushButton_2.setToolTip(_translate("MainWindow", "pushButton_2", None))
      +        self.pushButton_2.setText(_translate("MainWindow", "Quit", None))
      + 
      +        self.lineEdit_1.setToolTip(_translate("MainWindow", "LineEdit 1", None))
      +        self.label_1.setText(_translate("MainWindow", "LineEdit 1", None))
      + 
      +        self.lineEdit_2.setToolTip(_translate("MainWindow", "LineEdit_2", None))
      +        self.label_2.setText(_translate("MainWindow", "LineEdit 2", None))
      + 
      +        self.label_3.setText(_translate("MainWindow", "doubleSpinBox_1", None))
      +        self.doubleSpinBox_1.setToolTip(_translate("MainWindow", "doubleSpinBox_1", None))
      + 
      +        self.label_4.setText(_translate("MainWindow", "doubleSpinBox_2", None))
      +        self.doubleSpinBox_2.setToolTip(_translate("MainWindow", "doubleSpinBox_2", None))
      + 
      +        self.label_5.setText(_translate("MainWindow", "doubleSpinBox_3", None))
      +        self.doubleSpinBox_3.setToolTip(_translate("MainWindow", "doubleSpinBox_3", None))
      + 
      +        font = QtGui.QFont()          # see http://doc.qt.io/qt-4.8/qfont.html              # label text displayed and colored in red
      +        font.setFamily("Times New Roman")                                                   # font used (Windows)
      +        font.setPointSize(10)                                                               # font PointSize
      +        font.setWeight(10)                                                                  # font Weight
      +        font.setBold(True)                                                                  # Bolt True or False 
      +        self.label_6.setFont(font)                                                          # associate label_6 and font
      +        self.label_6.setObjectName("label_6")                                               # name of object
      +        self.label_6.setStyleSheet("color : #ff0000")                                       # Color text
      +        self.label_6.setText(_translate("MainWindow", "Hello world", None))                 # same resultt with "<b>Hello world</b>"
      + 
      +    ########### section connections on def #############################
      +    # radioboutons
      +    def on_radioButton_1_clicked(self):                                                     # connection on_radioButton_1_clicked
      +        #
      +        #here your code
      +        #
      +        self.label_6.setText(_translate("MainWindow", "radioButton_1          ", None))     # display in the label_6 (red)
      +        print "radioButton_1"
      +        #
      + 
      +    def on_radioButton_2_clicked(self):                                                     # connection on_radioButton_2_clicked
      +        #
      +        #here your code
      +        #
      +        self.label_6.setText(_translate("MainWindow", "radioButton_2          ", None))     # display in the label_6 (red)
      +        print "radioButton_2"
      +        #
      + 
      +    def on_radioButton_3_clicked(self):                                                     # connection on_radioButton_3_clicked
      +        #
      +        #here your code
      +        self.label_6.setText(_translate("MainWindow", "radioButton_3          ", None))     # display in the label_6 (red)
      +        print "radioButton_3"
      +        #
      + 
      +    def on_radioButton_4_clicked(self):                                                     # connection on_radioButton_4_clicked
      +        #
      +        #here your code
      +        #
      +        self.label_6.setText(_translate("MainWindow", "radioButton_4         ", None))      # display in the label_6 (red)
      +        print "radioButton_4"
      +        #
      + 
      +    def affectation_X (self,val_X0):                                                        # connection affectation_X
      +        #val_X = float(val_X0)                                                              # extract the value and transform it in float
      +        #
      +        #here your code
      +        #
      +        print val_X0
      +        #
      + 
      +    def affectation_Y (self,val_Y0):                                                        # connection affectation_Y
      +        #val_Y = float(val_Y0)                                                              # extract the value and transform it in float
      +        #
      +        #here your code
      +        #
      +        print val_Y0
      +        #
      + 
      +#    # scroll bar barres coulissantes
      +#    def on_horizontal_scrolling(self, val_X):                                              # connection on_horizontal_scrolling
      +#        self.lineEdit_1.setText(str(val_X))
      +#        self.affectation_X(val_X)
      +#        self.progressBar_1_Red.setValue(val_X)
      +#        self.textEdit.setText(str(val_X))
      +#        print "on_horizontal_scrolling"
      +#
      +#
      +#    def on_vertical_scrolling(self, val_Y):                                                # connection on_vertical_scrolling
      +#        self.lineEdit_2.setText(str(val_Y))
      +#        self.affectation_Y(val_Y)
      +#        self.progressBar_2.setValue(val_Y)
      +#        self.textEdit.setText(str(val_Y))
      +#        print "on_vertical_scrolling"
      + 
      +    # slider barres coulissantes
      +    def on_horizontal_slider(self, val_X):                                                  # connection on_horizontal_slider
      +        #
      +        #here your code
      +        #
      +        self.lineEdit_1.setText(str(val_X))                                                 # affect the value "val_X" and displayed in lineEdit_1
      +        self.affectation_X(val_X)
      +        self.progressBar_1_Red.setValue(val_X)                                              # affect the value "val_X" in progressbar_1
      +        self.progressBar_1_Green.setValue(val_X)                                            # affect the value "val_X" in progressbar_1
      +        self.progressBar_1_Blue.setValue(val_X)                                             # affect the value "val_X" in progressbar_1
      +        self.progressBar_1_gradient.setValue(int(val_X))                                    # affect the value "val_X" on progressBar_1 and modify this
      +        self.textEdit.setText(str(val_X))                                                   # affect the value "val_X" in textEdit 
      +        print "on_horizontal_slider"                                                        # displayed on View repport
      +        #
      + 
      +    def on_vertical_slider(self, val_Y):                                                    # connection on_vertical_slider
      +        #
      +        #here your code
      +        #
      +        self.lineEdit_2.setText(str(val_Y))                                                 # affect the value "val_Y" and displayed in lineEdit_2
      +        self.affectation_Y(val_Y)
      +        self.progressBar_2.setValue(val_Y)                                                  # affect the value "val_Y" in progressbar_2
      +        self.textEdit.setText(str(val_Y))                                                   # affect the value "val_Y" in textEdit 
      +        print "on_vertical_slider"                                                          # displayed on View repport
      +        #
      + 
      +    # lineEdit
      +    def on_lineEdit_1_Pressed(self):                                                        # connection on_lineEdit_1_Pressed
      +        val_X = self.lineEdit_1.text()                                                      # extract the string in the lineEdit
      +        #
      +        #here your code
      +        #
      +        self.affectation_X(val_X)
      +        try:
      +            self.horizontalSlider.setValue(int(val_X))                                      # affect the value "val_X" on horizontalSlider and modify this
      +        except Exception:                                                                   # if error
      +            self.horizontalSlider.setValue(int(0))                                          # affect the value "0" on horizontalSlider and modify this
      +            val_X = "0"
      +        self.progressBar_1_Red.setValue(int(val_X))                                         # affect the value "val_X" on progressBar_1 and modify this
      +        self.progressBar_1_Green.setValue(int(val_X))                                       # affect the value "val_X" on progressBar_1 and modify this
      +        self.progressBar_1_Blue.setValue(int(val_X))                                        # affect the value "val_X" on progressBar_1 and modify this
      +        self.progressBar_1_gradient.setValue(int(val_X))                                    # affect the value "val_X" on progressBar_1 and modify this
      +        print val_X
      +        #
      + 
      +    def on_lineEdit_2_Pressed(self):                                                        # connection on_lineEdit_2_Pressed
      +        val_Y = self.lineEdit_2.text()                                                      # extract the string in the lineEdit
      +        #
      +        #here your code
      +        #
      +        self.affectation_Y(val_Y)
      +        try:
      +            self.verticalSlider.setValue(int(val_Y))                                        # affect the value "val_Y" on verticalSlider and modify this
      +        except Exception:                                                                   # if error
      +            self.verticalSlider.setValue(int(0))                                            # affect the value "0" on verticalSlider and modify this
      +            val_Y = "0"
      +        self.progressBar_2.setValue(int(val_Y))                                             # affect the value "val_Y" on progressBar_2 and modify this
      +        print val_Y
      +        #
      + 
      +    #  checkbox_01
      +    def on_checkBox_1_clicked(self):                                                        # connection on_checkBox_1_clicked
      +        #
      +        #here your code
      +        #
      +        if self.checkBox_1.isChecked():                                                     # if checkbox_01 is checked then ....
      +            self.image_1 = path+"MEpipe01.png"                                              # configure image_1
      +            icon1 = QtGui.QIcon()
      +            icon1.addPixmap(QtGui.QPixmap(self.image_1),QtGui.QIcon.Normal, QtGui.QIcon.Off)
      +            self.checkBox_1.setIcon(icon1)                                                  # affect image_1 to checkBox_1
      +            self.checkBox_1.setText(_translate("MainWindow", "Attached", None))             # text for checkBox_1
      +            print "Mode attached"                                                           # diplayed on View Repport
      +        else:                                                                               # if checkbox_01 is not checked then ....
      +            self.image_2 = path+"MEpipe02.png"                                              # configure image_2
      +            icon2 = QtGui.QIcon() 
      +            icon2.addPixmap(QtGui.QPixmap(self.image_2),QtGui.QIcon.Normal, QtGui.QIcon.Off)
      +            self.checkBox_1.setIcon(icon2)                                                  # affect image_2 to checkBox_1
      +            self.checkBox_1.setText(_translate("MainWindow", "Free", None))                 # text for checkBox_1
      +            print "Mode free"                                                               # diplayed on View Repport
      +        #
      + 
      +    # Buttons
      +    def on_pushButton_2_clicked(self):    # Button Quit                                     # connection on_pushButton_2_clicked
      +        #
      +        #here your code
      +        #
      +        self.pushButton_1.setStyleSheet("background-color: QPalette.Base")                  # origin system color pushButton_1
      +        App.Console.PrintMessage("End\r\n")
      +        self.window.hide()                                                                  # hide the window and close the macro
      +        #
      + 
      +    def on_pushButton_1_clicked(self):    # Button Reset                                    # connection on_pushButton_1_clicked
      +        #
      +        #here your code
      +        #
      +        global switch
      +        self.doubleSpinBox_1.setValue(0)                                                    # gives the value "0" to the doubleSpinBox_1
      +        self.doubleSpinBox_2.setValue(0)                                                    # gives the value "0" to the doubleSpinBox_2
      +        self.doubleSpinBox_3.setValue(0)                                                    # gives the value "0" to the doubleSpinBox_3
      +        self.lineEdit_1.setText(QtGui.QApplication.translate("Form", "0", None, QtGui.QApplication.UnicodeUTF8)) # gives the value "0" to the lineEdit_1
      +        self.lineEdit_2.setText(QtGui.QApplication.translate("Form", "0", None, QtGui.QApplication.UnicodeUTF8)) # gives the value "0" to the lineEdit_2
      +        #self.horizontalScrollBar.setValue(0)                                               # gives the value "0" to the horizontalScrollBar
      +        #self.verticalScrollBar.setValue(0)                                                 # gives the value "0" to the verticalScrollBar
      +        self.horizontalSlider.setValue(0)                                                   # gives the value "0" to the horizontalSlider
      +        self.verticalSlider.setValue(0)                                                     # gives the value "0" to the verticalSlider
      +        self.textEdit.clear()                                                               # cleans the textEdit
      +        self.radioButton_1.setChecked(True)                                                 # by default True or False (one in the group))
      +        self.checkBox_1.setChecked(True)                                                    # Check by default True or False
      +        icon1 = QtGui.QIcon()                                                               # create image name
      +        icon1.addPixmap(QtGui.QPixmap(self.image_1),QtGui.QIcon.Normal, QtGui.QIcon.Off)    # 
      +        self.checkBox_1.setIcon(icon1)                                                      # associate button and image
      + 
      +        if switch == 0:                                                                     # switch for image in the graphic view Py or FC
      +            switch = 1
      +            pic = QtGui.QPixmap(path+"MEPlanPY.png")                                        # image (Python)
      +            self.scene = QtGui.QGraphicsScene()                                             # name of image
      +            self.scene.addPixmap(QtGui.QPixmap(pic))                                        # add image "pic" (MEPlanPY.png)
      +            self.graphicsView.setScene(ui.scene)                                            # display the image in graphicview
      +            self.pushButton_1.setStyleSheet("color : #ff0000; background-color : #0000ff;") # text color; background color pushButton_1
      +        else:
      +            switch = 0
      +            pic = QtGui.QPixmap(path+"MEPlanFC.png")                                        # image (FreeCAD)
      +            self.scene = QtGui.QGraphicsScene()                                             # name of image
      +            self.scene.addPixmap(QtGui.QPixmap(pic))                                        # add image "pic" (MEPlanFC.png)
      +            self.graphicsView.setScene(ui.scene)                                            # display the image in graphicview
      +            self.pushButton_1.setStyleSheet("color : #0000ff; background-color : #ff0000;") # text color; background color pushButton_1
      +        print "Reset"
      +        #
      + 
      +    def on_doubleSpinBox_1_valueChanged(self,echelle):                                      # connection on_doubleSpinBox_1_valueChanged
      +        #
      +        #here your code
      +        #
      +        print "SpinBox 1 ", echelle
      +        #
      + 
      +    def on_doubleSpinBox_2_valueChanged(self,angle):                                        # connection on_doubleSpinBox_2_valueChanged
      +        #
      +        #here your code
      +        #
      +        print "SpinBox 2 ", angle
      + 
      +    def on_doubleSpinBox_3_valueChanged(self,epaisseur):                                    # connection on_doubleSpinBox_3_valueChanged
      +        #
      +        #here your code
      +        #
      +        print "SpinBox 3 ", epaisseur
      +        #
      + 
      +    def on_textEdit_Changed(self):                                                          # conection on_textEdit_Changed
      +        texte = unicode(self.textEdit.toPlainText())                                        # extract the string of textEdit
      +        #
      +        #here your code
      +        #
      +        print texte
      +        #
      + 
      +#######################################
      + 
      +MainWindow = QtGui.QMainWindow()
      +ui = Ui_MainWindow()
      +ui.setupUi(MainWindow)
      +MainWindow.show() 
      +

      Enjoy +

      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Qt_Example_02.png b/localwiki/Qt_Example_02.png new file mode 100644 index 0000000..5bb5c55 Binary files /dev/null and b/localwiki/Qt_Example_02.png differ diff --git a/localwiki/Qtdesigner-screenshot.jpg b/localwiki/Qtdesigner-screenshot.jpg new file mode 100644 index 0000000..47b6d26 Binary files /dev/null and b/localwiki/Qtdesigner-screenshot.jpg differ diff --git a/localwiki/Qtpropeditor.jpg b/localwiki/Qtpropeditor.jpg new file mode 100644 index 0000000..a4f8909 Binary files /dev/null and b/localwiki/Qtpropeditor.jpg differ diff --git a/localwiki/Qttestdialog.jpg b/localwiki/Qttestdialog.jpg new file mode 100644 index 0000000..06c355d Binary files /dev/null and b/localwiki/Qttestdialog.jpg differ diff --git a/localwiki/Quadrangles.gif b/localwiki/Quadrangles.gif new file mode 100644 index 0000000..19886e5 Binary files /dev/null and b/localwiki/Quadrangles.gif differ diff --git a/localwiki/Quality_project.html b/localwiki/Quality_project.html new file mode 100644 index 0000000..f642c02 --- /dev/null +++ b/localwiki/Quality_project.html @@ -0,0 +1,104 @@ +Quality project

      Quality project

      + +

      This is the project plan of the Quality project as part of the Development roadmap. +

      + + +

      Purpose and principles

      +

      This project is partial a software development and a documentation project. It aims to raise +the quality of the main components of FreeCAD and delivers a better experience to the +first FreeCAD contact. +

      +

      Outcome

      +
      HelpViewer.jpg
      +

      One important step is the Complete workbench which is the starting workbench +for the average user (if there is one). The complete workbench hold all +Commands and Features from all the modules and workbenches which met certain + quality criteria. That will hide away +the stormy development and half implemented features from the user which wants just model. +


      +Another important outcome is a complete help system for all Commands and Features +at least in the Complete workbench. That mean a help page like Draft ShapeString +exist for all in the List of Commands. +

      +

      Brainstorming

      +
      • Switching to QAssistant +
        • changing wiki2help
        • +
        • changing Developer docu doxygen
      +

      Organizing

      +

      Next actions

      +

      Work through all the unfinished commands and make a documentation: +

      + +
      +
      + + + +
      +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Quantity.html b/localwiki/Quantity.html new file mode 100644 index 0000000..120efef --- /dev/null +++ b/localwiki/Quantity.html @@ -0,0 +1,282 @@ +Quantity

      Quantity

      + +

      The Quantity is a combination of a floating point number and an Unit. It is used throughout all of FreeCAD to handle parameters and all other kind of input/output. +

      + + +

      General

      +

      In a CAD or CAE system its very important to keep track on the unit of an value. Lot of trouble can arise when mixing up units or calculating results in different unit systems. One famous disaster is the crash of the Mars Climate Orbiter through out a unit mix-up. Even in the same unit-system the units come in lots of different flavors always tailored to the field of use. Simple examples are e.g. velocity in km/h (cars), m/s (robotics) or mm/minute (milling). A CAD system has to keep reliably track of units. Also it has to calculate with them and check on the right unit for special parameters. +

      For that reason the FreeCAD Quantity framework was created. It includes all the code and objects to deal with units, unit calculations, user input, conversion in other unit systems and the pretty output of units and values. In the long run no parameter in FreeCAD should be just a number. +

      +

      Supported units

      +

      The FreeCAD input parser supports a bunch of units and units-systmes. We do use the Greek letter for micro but also accept 'u' as a replacement. +

      +
      • Length +
        • "nm"
        • +
        • "µm"
        • +
        • "mm"
        • +
        • "cm"
        • +
        • "dm"
        • +
        • "m"
        • +
        • "km"
        • +
        • "in"
        • +
        • "ft"
        • +
        • "thou"
        • +
        • "mil"
        • +
        • "yd"
        • +
        • "mi"
      +

      Todo: all the rest... +


      +The detailed specification you find in the code: +

      + +

      Internal representation

      +

      All physical units can be expressed as a combination of the seven SI-Units: +

      SI-Derived-Units.jpg +


      +An easy way to express a Unit is a integer array of size 7 (number of base units) that defines what the unit is. +The signature of the 7 base units are: +

      +
      • LENGTH: [1,0,0,0,0,0,0]
      • +
      • MASS: [0,1,0,0,0,0,0]
      • +
      • TIME: [0,0,1,0,0,0,0]
      • +
      • ELECTRIC CURRENT: [0,0,0,1,0,0,0]
      • +
      • THERMODYNAMIC TEMPERATURE: [0,0,0,0,1,0,0]
      • +
      • AMOUNT OF SUBSTANCE: [0,0,0,0,0,1,0]
      • +
      • LUMINOUS INTENSITY: [0,0,0,0,0,0,1]
      +

      From these 7 units, we are then able to express all derived units defined in Guide for the Use of the International System of Units (SI) and create new ones as needed such as for instance: +

      +
      • MASS DENSITY: [-3,1,0,0,0,0,0]
      • +
      • AREA: [0,2,0,0,0,0,0]
      +

      Since angle is physically dimensionless, but never the less important to a CAD system we add one more virtual unit for Angle. This makes a vector of 8 in the FreeCAD unit signature. +

      +

      Units calculator

      +

      Often you are in need of calculating units from one system to another. For example you have old parameter tables with wired units. In that cases FreeCAD offers a conversion tool called Units-Calculator which helps in translating units. +

      Its description in detail is here: +Std_UnitsCalculator +

      +

      InputField

      +

      The InputField is a QLineEdit derived Qt widget to handle all kind of user interaction with Quantities and parameters. It features following properties: +

      +
      • parsing arbitrary value/unit input
      • +
      • checking on the right unit (if given) and give the user feedback
      • +
      • special context menu for operations on Quantities/Values
      • +
      • history management (save the last used values)
      • +
      • save often needed values as shortcut in context menu
      • +
      • dialing values with mouse wheel and arrow keys (tbd)
      • +
      • dialing with middle mouse button and mouse move (tbd)
      • +
      • python integration for usage in python only dialogs (tbd)
      +

      The UnitsCalculator uses the InputField already. +

      Main docu: InputField +

      Code: +

      + +

      Python scripting

      +

      The Unit and Quantity system in FreeCAD is (as nearly everything) fully accessibly via Python. +

      +

      Unit

      +

      The Unit class represents the Fingerprint of any physical unit. As descriped in the Basics section a vector of 8 numbers is used to represent this fingerprint. The Unit class allows the handling and calculation with this information. +

      +
      from Units import Unit
      +
      +# creating a Unit with certain signature
      +Unit(0,1)      # Mass     (kg)
      +Unit(1)        # Length   (mm)
      +Unit(-1,1,-2)  # Pressure (kg/mm*s^2)
      +
      +# using predefined constats
      +Unit(FreeCAD.Units.Length)
      +Unit(FreeCAD.Units.Mass)
      +Unit(FreeCAD.Units.Pressure)
      +
      +# parsing unit out of an string
      +Unit('kg/(m*s^2)')    # Pressure
      +Unit('Pa')            # the same as combined Unit Pascale
      +Unit('J')             # Joul (Work,Energy) mm^2*kg/(s^2)
      +
      +# you can use units from all supported unit-systems
      +Unit('psi')           # Imperial pressure
      +Unit('lb')            # Mass
      +Unit('ft^2')          # Area
      +
      +# comparing units
      +Unit(0,1) == Unit(FreeCAD.Units.Mass)
      +
      +# getting type of unit
      +Unit('kg/(m*s^2)').Type == 'Pressure'
      +
      +# calculating
      +Unit('kg') * Unit('m^-1*s^-2') == Unit('kg/(m*s^2)')
      +

      The Unit is mainly used to descripe a certain unit-type for a parameter. There fore a special Property Type in FreeCAD can transport a Unit to check and ensure the right Unit. +A Unit and a float value is called Quantity. +

      +

      Quantity

      +
      from Units import Unit,Quantity
      +
      +# to create a quantity you need a value (float) and a Unit
      +Quantity(1.0,Unit(0,1))               # Mass      1.0 kg
      +Quantity(1.0,Unit(1))                 # Length    1.0 mm
      +Quantity(1.0,Unit(-1,1,-2))           # Pressure  1.0 kg/mm*s^2
      +Quantity(1.0,FreeCAD.Units.Pressure)  # Pressure  1.0 kg/mm*s^2
      +
      +# you can directly give a signature
      +Quantity(1.0,0,1)      # Mass      1.0 kg
      +Quantity(1.0,1)        # Length    1.0 mm
      +Quantity(1.0,-1,1,-2)  # Pressure  1.0 kg/mm*s^2
      +
      +# parsing Quantitis out of a string
      +Quantity('1.0 kg/(m*s^2)')    # Pressure
      +Quantity('1.0 Pa')            # the same as combined Unit Pascale
      +Quantity('1.0 J')             # Joul (Work,Energy) mm^2*kg/(s^2)
      +
      +# You can using a point or comma as float delimiter
      +Quantity('1,0 m')    
      +Quantity('1.0 m')   
      +
      +# you can use units from all supported unit-systems
      +Quantity('1.0 psi')           # Imperial pressure
      +Quantity('1.0 lb')            # Mass
      +Quantity('1.0 ft^2')    
      +
      +# the quantity parser can do calculations too
      +Quantity('360/5 deg')           # splitting circle 
      +Quantity('1/16 in')             # fractions
      +Quantity('5.3*6.3 m^2')         # calculating an area
      +Quantity('1/(log(2.3)/sin(pi)*3.4)+1.8e-3 m')
      +Quantity('1ft 3in')             # imperial style
      +
      +# and for sure calculation and comparison
      +Quantity('1 Pa')* Quantity(2.0) == Quantity('2 Pa')
      +Quantity('1 m')* Quantity('2 m') == Quantity('2 m^2')
      +Quantity('1 m')* Quantity('2 ft') + Quantity('2 mm^2')
      +Quantity('1 m') > Quantity('2 ft')
      +
      +# accessing the components
      +Quantity('1 m').Value     # get the number (allways internal system (mm/kg/s)
      +Quantity('1 m').Unit      # get the unit
      +Quantity('1 m') == Quantity( Quantity('1 m').Value , Quantity('1 m').Unit )
      +
      +# translating the value into other units then the internal system (mm/kg/s)
      +Quantity('1 km/h').getValueAs('m/s')               # translate value
      +Quantity('1 m').getValueAs(2.45,1)                 # translation value and unit signature
      +Quantity('1 kPa').getValueAs(FreeCAD.Units.Pascal) # predefined standard units 
      +Quantity('1 MPa').getValueAs(Quantity('N/m^2'))    # a quantity
      +

      User facing values

      +

      Normally in script you can use Quantity for all kind of calculation and checking, but there comes the time you have to output information to the user. You could use getValueAs() to force a certain unit, but normally the user sets his preferred unit-schema in the preferences. This unit-schema do all the translations to the representation the user likes to see. At the moment there are 3 schema implemented: +

      +
      • 1: Internal (mm/kg/s)
      • +
      • 2: MKS (m/kg/s)
      • +
      • 3: US customary (in/lb)
      +

      There can be easily additional schemas implemented in the future... +

      The quantity class has two possibilities to use the actual schema translation: +

      +
      from Units import Unit,Quantity
      +
      +# Use the translated string:
      +Quantity('1m').UserString             # '1000 mm' in 1; '1 m' in 2; and '1.09361 yr' in 3
      +

      This does the job if you only need a string. But somethimes you need more control, e.g. if you want to have a dialog button which dial up and down. Then you need more information about the translation output. There fore the getUserPreferred() method of quantity is used: +

      +
      Quantity('22 m').getUserPreferred()  # gets a tubple:('22 m', 1000.0, 'm')
      +Quantity('2  m').getUserPreferred()  # Tuple: ('2000 mm', 1.0, 'mm')
      +

      Here you get two more informations as a tuple of size 3. You get the string as before, plus the factor the number is translated and the raw string with only the unit chosen by the translation schema. With this information you can implement a much richer user interaction. +

      The code for the schema translation you can see here: +

      + +

      Appendix

      +

      Parser supported Units

      +

      Although all physical units can be described with the seven SI units, most of the units used in technical areas are common combined units (like Pa = N/m^2 Pascal ). There fore the units parser in FreeCAD support lot of SI and Imperial combined units. This units are defined in src/Base/QuantityParser.l file and can be further advanced in the future. +


      +

      +
      "nm"   = Quantity(1.0e-6    ,Unit(1));           // nano meter
      +"µm"   = Quantity(1.0e-3    ,Unit(1));           // micro meter
      +"mm"   = Quantity(1.0       ,Unit(1));           // milli meter
      +"cm"   = Quantity(10.0      ,Unit(1));           // centi meter
      +"dm"   = Quantity(100.0     ,Unit(1));           // deci meter
      +"m"    = Quantity(1.0e3     ,Unit(1));           // meter
      +"km"   = Quantity(1.0e6     ,Unit(1));           // kilo meter
      +"l"    = Quantity(1000000.0 ,Unit(3));           // Liter      dm^3
      +                                                 
      +"µg"   = Quantity(1.0e-9    ,Unit(0,1));         // micro gram
      +"mg"   = Quantity(1.0e-6    ,Unit(0,1));         // milli gram
      +"g"    = Quantity(1.0e-3    ,Unit(0,1));         // gram
      +"kg"   = Quantity(1.0       ,Unit(0,1));         // kilo gram
      +"t"    = Quantity(1000.0    ,Unit(0,1));         // ton
      +                                                 
      +"s"    = Quantity(1.0       ,Unit(0,0,1));       // second                          (internal standard time)
      +"min"  = Quantity(60.0      ,Unit(0,0,1));       // minute
      +"h"    = Quantity(3600.0    ,Unit(0,0,1));       // hour  
      +                                                 
      +"A"    = Quantity(1.0       ,Unit(0,0,0,1));     // Ampere          (internal standard electric current)
      +"mA"   = Quantity(0.001     ,Unit(0,0,0,1));     // milli Ampere         
      +"kA"   = Quantity(1000.0    ,Unit(0,0,0,1));     // kilo Ampere         
      +"MA"   = Quantity(1.0e6     ,Unit(0,0,0,1));     // Mega Ampere         
      +                                                 
      +"K"    = Quantity(1.0       ,Unit(0,0,0,0,1));   // Kelvin (internal standard thermodynamic temperature)
      +"mK"   = Quantity(0.001     ,Unit(0,0,0,0,1));   // Kelvin         
      +"µK"   = Quantity(0.000001  ,Unit(0,0,0,0,1));   // Kelvin         
      +
      +
      "mol"  = Quantity(1.0       ,Unit(0,0,0,0,0,1));   // Mole     (internal standard amount of substance)        
      +
      +
      "cd"   = Quantity(1.0       ,Unit(0,0,0,0,0,0,1)); // Candela   (internal standard luminous intensity)        
      +
      +
      "deg"  = Quantity(1.0           ,Unit(0,0,0,0,0,0,0,1));  // degree         (internal standard angle)
      +"rad"  = Quantity(180/M_PI      ,Unit(0,0,0,0,0,0,0,1));  // radian         
      +"gon"  = Quantity(360.0/400.0   ,Unit(0,0,0,0,0,0,0,1));  // gon         
      +
      +
      "in"   = Quantity(25.4          ,Unit(1));       // inch
      +"\""   = Quantity(25.4          ,Unit(1));       // inch
      +"fo"   = Quantity(304.8         ,Unit(1));       // foot
      +"'"    = Quantity(304.8         ,Unit(1));       // foot
      +"th"   = Quantity(0.0254        ,Unit(1));       // thou
      +"yd"   = Quantity(914.4         ,Unit(1));       // yard
      +
      +


      +

      +
      "lb"   = Quantity(0.45359237    ,Unit(0,1));    // pound
      +"oz"   = Quantity(0.0283495231  ,Unit(0,1));    // ounce
      +"st"   = Quantity(6.35029318    ,Unit(0,1));    // Stone
      +"cwt"  = Quantity(50.80234544   ,Unit(0,1));    // hundredweights
      +
      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/RPH_after.png b/localwiki/RPH_after.png new file mode 100644 index 0000000..f79dde2 Binary files /dev/null and b/localwiki/RPH_after.png differ diff --git a/localwiki/RPH_before.png b/localwiki/RPH_before.png new file mode 100644 index 0000000..830d128 Binary files /dev/null and b/localwiki/RPH_before.png differ diff --git a/localwiki/Ray_Tracing_Workbench.html b/localwiki/Ray_Tracing_Workbench.html new file mode 100644 index 0000000..c1e4d9d --- /dev/null +++ b/localwiki/Ray_Tracing_Workbench.html @@ -0,0 +1,192 @@ +Ray Tracing Workbench

      Ray Tracing Workbench

      (Redirected from Ray Tracing Workbench)
      + +

      The Raytracing module is used to generate photorealistic images of your models by rendering them with an external renderer. The Raytracing workbench works with templates, the same way as the Drawing workbench, by allowing you to create a Raytracing project in which you add views of your objects. The project can then be exported to a ready-to-render file, or be rendered directly. +

      Raytracing example.jpg +

      Currenly, two renderers are supported: povray and luxrender. To be able to render directly from FreeCAD, at least one of those renderers must be installed on your system, and its path must be configured in the FreeCAD Raytracing preferences. Without any renderer installed, though, you are still able to export a scene file that can be used in any of those renderers later, or on another machine. +

      The raytracing workbench works with templates, which are complete scene files for the given external renderer, including lights and possibly additional geometry such as ground planes. These scene files contain placeholders, where FreeCAD will insert the position of the camera, and geometry and materials information of each of the objects you insert in the project. That modified scene file is what is then exported to the external renderer. +

      + + +

      Tools

      +

      Raytracing project tools

      +

      These are the main tools for exporting your 3D work to external renderers +

      +
      • Raytracing New.png New PovRay project: Insert new PovRay project in the document
      • +
      • Raytracing Lux.png New LuxRender project: Insert new LuxRender project in the document
      • +
      • Raytracing InsertPart.png Insert part: Insert a view of a Part in a raytracing project
      • +
      • Raytracing ResetCamera.png Reset camera: Matches the camera position of a raytracing project to the current view
      • +
      • Raytracing ExportProject.png Export project: Exports a raytracing project to a scene file for rendering in an external renderer
      • +
      • Raytracing Render.png Render: Renders a raytracing project with an external renderer
      +

      Utilities

      +

      These are helper tools to perform specific tasks manually +

      + +

      Preferences

      + +


      +

      +

      Typical workflow

      +
      1. Create or open a FreeCAD project, add some Part-based objects (meshes are currently not supported)
      2. +
      3. Create a Raytracing project (luxrender or povray)
      4. +
      5. Select the objects you wish to add to the raytracing project and add them to the project with the "Insert Part" tool
      6. +
      7. Export or render directly
      +

      Creating a povray file manually

      +

      The utility tools described above allow you to export the current 3D view and all of its content to a Povray file. First, you must load or create your CAD data and position the 3D View orientation as you wish. Then choose "Utilities->Export View..." from the raytracing menu. +

      +
      FreeCAD Raytracing.jpg
      +

      You will be asked for a location to save the resulting *.pov file. After that you can open it in Povray and render: +

      +
      Povray.jpg
      +

      As usual in a renderer you can make big and nice pictures: +

      Scharniergreifer render.jpg +

      +

      Scripting

      +

      Outputting render files

      +

      The Raytracing and RaytracingGui modules provide several methods to write scene contents as povray or luxrender data. The most useful are Raytracing.getPartAsPovray() and Raytracing.getPartAsLux() to render a FreeCAD Part object into a povray or luxrender definition, and RaytracingGui.povViewCamera() and RaytracinGui.luxViewCamera() to get the current point of view of the FreeCAD 3D window into povray or luxrender format. +

      Here is how to write a povray file from python, assuming your document contains a "Box" object: +

      +
      import Raytracing,RaytracingGui
      +OutFile = open('C:/Documents and Settings/jriegel/Desktop/test.pov','w')
      +OutFile.write(open(App.getResourceDir()+'Mod/Raytracing/Templates/ProjectStd.pov').read())
      +OutFile.write(RaytracingGui.povViewCamera())
      +OutFile.write(Raytracing.getPartAsPovray('Box',App.activeDocument().Box.Shape,0.800000,0.800000,0.800000))
      +OutFile.close()
      +del OutFile 
      +

      And the same for luxrender: +

      +
      import Raytracing,RaytracingGui
      +OutFile = open('C:/Documents and Settings/jriegel/Desktop/test.lxs','w')
      +OutFile.write(open(App.getResourceDir()+'Mod/Raytracing/Templates/LuxClassic.lxs').read())
      +OutFile.write(RaytracingGui.luxViewCamera())
      +OutFile.write(Raytracing.getPartAsLux('Box',App.activeDocument().Box.Shape,0.800000,0.800000,0.800000))
      +OutFile.close()
      +del OutFile 
      +

      Creating a custom render object

      +

      Apart from standard povray and luxrender view objects that provide a view of an existing Part object, and that can be inserted in povray and luxrender projects respectively, a third object exist, called RaySegment, that can be inserted either in povray or luxrender projects. That RaySegment object is not linked to any of the FreeCAD objects, and can contain custom povray or luxrender code, that you might wish to insert into your raytracing project. You can also use it, for example, to output your FreeCAD objects a certain way, if you are not happy with the standard way. You can create and use it like this from the python console: +

      +
      myRaytracingProject = FreeCAD.ActiveDocument.PovProject
      +myCustomRenderObject = FreeCAD.ActiveDocument.addObject("Raytracing::RaySegment","myRenderObject")
      +myRaytracingProject.addObject(myCustomRenderObject)
      +myCustomRenderObject.Result = "// Hello from python!" 
      +

      Links

      +

      POVRay

      + +

      Luxrender

      + +

      Future possible renderers to implement

      + +
      +

      Currently there is a new Renderer Workbench in development to support multiple back-ends such as Lux Renderer and Yafaray. Information for using the development version can be viewed at Render_project +

      For Development status of the Render Module look here Raytracing_project +

      +

      Templates

      +

      FreeCAD comes with a couple of default templates for povray and luxrender, but you can easily create your own. All you need to do is to create a scene file for the given renderer, then edit it manually with a text editor to insert special tags that FreeCAD will recognize and where it will insert its contents (camera and objects data) +

      +

      Povray

      +

      Povray scene files (with extension .pov) can be created manually with a text editor (povray is made primarily to be used as a scripting language), but also with a wide range of 3D applications, such as blender. On the povray website you can find further information and a list of applications able to produce .pov files. +

      When you have a .pov file ready, you need to open it with a text editor, and do two operations: +

      +
      1. Strip out the camera information, because FreeCAD will place its own camera data. To do so, locate a text block like this: camera { ... }, which describes the camera parameters, and delete it (or put "//" in front of each line to comment them out).
      2. +
      3. Insert the following line somewhere: //RaytracingContent. This is where FreeCAD will insert its contents (camera and objects data). You can, for example, put this line at the very end of the file.
      +

      Note that FreeCAD will also add some declarations, that you can use in your template, after the //RaytracingContent tag. These are: +

      +
      • cam_location: the location of the camera
      • +
      • cam_look_at: the location of the target point of the camera
      • +
      • cam_sky: the up vector of the camera.
      • +
      • cam_angle: the angle of the camera
      +

      If you want, for example, to place a lamp above the camera, you can use this: +

      +
      light_source {
      + cam_location + cam_angle * 100
      + color rgb <10, 10, 10>
      +} 
      +

      Luxrender

      +

      Luxrender scene files (with extension.lxs) can either be single files, or a master .lxs file that includes world definition (.lxw), material definition (.lxm) and geometry definition (.lxo) files. You can work with both styles, but it is also easy to transform a group of 4 files in a single .lxs file, by copying the contents of each .lxw, .lxm and .lxo file and pasting it at the point where that file is inserted in the master .lxs file. +

      Luxrender scene files are hard to produce by hand, but are easy to produce with many 3D applications such as blender. On the luxrender website, you'll find more information and plugins for the main 3D applications out there. +

      If you will work with separated .lxw, .lxm and .lxo files, beware that the final .lxs exported by FreeCAD might be at a different location than the template file, and therefore these files might not be found by Luxrender at render time. In this case you should or copy these files to the location of your final file, or edit their paths in the exported .lxs file. +

      If you are exporting a scene file from blender, and wish to merge everything into one single file, you will need to perform one step before exporting: By default, the luxrender exporter in blender exports all mesh geometry as separate .ply files, instead of placing the mesh geometry directly inside the .lxo file. To change that behaviour, you need to select each of your meshes in blender, go to the "mesh" tab and set the option "export as" to "luxrender mesh" for each one of them. +

      After you have your scene file ready, to turn it into a FreeCAD template, you need to perform the following steps: +

      +
      1. Locate the camera position, a single line that begins with LookAt, and delete it (or place a "#" at the beginning of the line to comment it out)
      2. +
      3. At that place, insert the following line: #RaytracingCamera
      4. +
      5. At a desired point, for example just after the end of the materials definition, before the geometry information, or at the very end, just before the final WorldEnd line, insert the following line: #RaytracingContent. That is where FreeCAD will insert its own objects.
      +

      Note that in luxrender, the objects stored in a scene file can define transformation matrixes, that perform location, rotation or scaling operations. These matrixes can stack and affect everything that come after them, so, by placing your #RaytracingContent tag at the end of the file, you might see your FreeCAD objects affected by a transformation matrix placed earlier in the template. To make sure that this doesn't happen, place your #RaytracingContent tag before any other geometry object present in the template. FreeCAD itself won't define any of those transformation matrixes. +

      +

      Exporting to Kerkythea

      +

      Although direct export to the Kerkythea XML-File-Format is not supported yet, you can export your Objects as Mesh-Files (.obj) and then import them in Kerkythea. +

      +
      • if using Kerkythea for Linux, remember to install the WINE-Package (needed by Kerkythea for Linux to run)
      • +
      • you can convert your models with the help of the mesh workbench to meshes and then export these meshes as .obj-files
      • +
      • If your mesh-export resulted in errors (flip of normals, holes ...) you may try your luck with netfabb studio basic
      +
      Free for personal use, available for Windows, Linux and Mac OSX.
      +
      It has standard repair tools which will repair you model in most cases.
      +
      • another good program for mesh analysing/repairing is Meshlab
      +
      Open Source, available for Windows, Linux and Mac OSX.
      +
      It has standard repair tools which will repair you model in most cases (fill holes, re-orient normals, etc.)
      +
      • you can use "make compound" and then "make single copy" or you can fuse solids to group them before converting to meshes
      • +
      • remember to set in Kerkythea an import-factor of 0.001 for obj-modeler, since Kerkythea expects the obj-file to be in m (but standard units-scheme in FreeCAD is mm)
      +
      Within WIndows 7 64-bit Kerkythea does not seem to be able to save these settings.
      +
      So remember to do that each time you start Kerkythea
      +
      • if importing multiple objects in Kerkythea you can use the "File > Merge" command in Kerkythea
      +

      Links

      + +


      +

      + +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Raytrace_Camera.svg b/localwiki/Raytrace_Camera.svg new file mode 100644 index 0000000..ee46d40 --- /dev/null +++ b/localwiki/Raytrace_Camera.svg @@ -0,0 +1,159 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + $committer + + + Raytrace_Camera + 2011-10-10 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Raytracing/Gui/Resources/icons/Raytrace_Camera.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Raytrace_Export.svg b/localwiki/Raytrace_Export.svg new file mode 100644 index 0000000..f3189a7 --- /dev/null +++ b/localwiki/Raytrace_Export.svg @@ -0,0 +1,97 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + $committer + + + Raytrace_Export + 2011-10-10 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Raytracing/Gui/Resources/icons/Raytrace_Export.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Raytrace_ExportProject.svg b/localwiki/Raytrace_ExportProject.svg new file mode 100644 index 0000000..a0daa5d --- /dev/null +++ b/localwiki/Raytrace_ExportProject.svg @@ -0,0 +1,281 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [agryson] Alexander Gryson + + + http://agryson.net + + Raytrace_ExportProject + 2012-02-29 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Raytracing/Gui/Resources/icons/Raytrace_ExportProject.svg + + + FreeCAD LGPL2+ + + + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Raytrace_Lux.svg b/localwiki/Raytrace_Lux.svg new file mode 100644 index 0000000..9d0a80c --- /dev/null +++ b/localwiki/Raytrace_Lux.svg @@ -0,0 +1,134 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [agryson] Alexander Gryson + + + http://agryson.net + + Raytrace_Lux + 2013-09-27 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Raytracing/Gui/Resources/icons/Raytrace_Lux.svg + + + FreeCAD LGPL2+ + + + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Raytrace_New.svg b/localwiki/Raytrace_New.svg new file mode 100644 index 0000000..841a584 --- /dev/null +++ b/localwiki/Raytrace_New.svg @@ -0,0 +1,134 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [agryson] Alexander Gryson + + + http://agryson.net + + Raytrace_New + 2011-10-10 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Raytracing/Gui/Resources/icons/Raytrace_New.svg + + + FreeCAD LGPL2+ + + + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Raytrace_NewPartSegment.svg b/localwiki/Raytrace_NewPartSegment.svg new file mode 100644 index 0000000..c2f3c53 --- /dev/null +++ b/localwiki/Raytrace_NewPartSegment.svg @@ -0,0 +1,277 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [agryson] Alexander Gryson + + + http://agryson.net + + Raytrace_NewPartSegment + 2012-02-29 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Raytracing/Gui/Resources/icons/Raytrace_NewPartSegment.svg + + + FreeCAD LGPL2+ + + + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Raytrace_Part.svg b/localwiki/Raytrace_Part.svg new file mode 100644 index 0000000..61c4eaa --- /dev/null +++ b/localwiki/Raytrace_Part.svg @@ -0,0 +1,135 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + $committer + + + Raytrace_Part + 2011-10-10 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Raytracing/Gui/Resources/icons/Raytrace_Part.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Raytrace_Render.svg b/localwiki/Raytrace_Render.svg new file mode 100644 index 0000000..cb69e2e --- /dev/null +++ b/localwiki/Raytrace_Render.svg @@ -0,0 +1,137 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + $committer + + + Raytrace_Render + 2013-09-17 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Raytracing/Gui/Resources/icons/Raytrace_Render.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Raytrace_ResetCamera.svg b/localwiki/Raytrace_ResetCamera.svg new file mode 100644 index 0000000..adfd136 --- /dev/null +++ b/localwiki/Raytrace_ResetCamera.svg @@ -0,0 +1,166 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [agryson] Alexander Gryson + + + http://agryson.net + + Raytrace_ResetCamera + 2013-10-01 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Raytracing/Gui/Resources/icons/Raytrace_ResetCamera.svg + + + FreeCAD LGPL2+ + + + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/RaytracingWorkbench.svg b/localwiki/RaytracingWorkbench.svg new file mode 100644 index 0000000..0d9c78e --- /dev/null +++ b/localwiki/RaytracingWorkbench.svg @@ -0,0 +1,306 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + $committer + + + RaytracingWorkbench + 2016-02-26 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Raytracing/Gui/Resources/icons/RaytracingWorkbench.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + diff --git a/localwiki/Raytracing_Camera.html b/localwiki/Raytracing_Camera.html new file mode 100644 index 0000000..3f007ac --- /dev/null +++ b/localwiki/Raytracing_Camera.html @@ -0,0 +1,73 @@ +Raytracing Camera

      Raytracing Camera

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Raytracing Camera.png Raytracing Camera‏‎

      +
      Menu location +
      Raytracing → Camera‏‎ +
      Workbenches +
      Raytracing +
      Default shortcut +
      +
      See also +
      +

      + +
      +


      +

      +

      Description

      +

      Exports the current camera properties to a pov-file for use in a POV-Ray project. +

      +

      Use

      +
      1. Make sure that the view is set to perspective view
      2. +
      3. Choose Raytracing UtilitiesRaytracing Camera.png Export camera to POV-Ray... from the top menu.
      +

      Limitations

      +


      +

      +

      Notes

      +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Raytracing_Export.html b/localwiki/Raytracing_Export.html new file mode 100644 index 0000000..7068443 --- /dev/null +++ b/localwiki/Raytracing_Export.html @@ -0,0 +1,73 @@ +Raytracing Export

      Raytracing Export

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Raytracing Export.png Raytracing Export‏‎

      +
      Menu location +
      Raytracing → Export‏‎ +
      Workbenches +
      Raytracing +
      Default shortcut +
      +
      See also +
      +

      + +
      +


      +

      +

      Description

      +

      Exports the current view properties to a pov-file for use in a POV-Ray project. +

      +

      Use

      +
      1. Make sure that the view is set to perspective view
      2. +
      3. Choose Raytracing UtilitiesRaytracing Export.png Export view to POV-Ray... from the top menu.
      +

      Limitations

      +


      +

      +

      Notes

      +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Raytracing_ExportProject.html b/localwiki/Raytracing_ExportProject.html new file mode 100644 index 0000000..5659fed --- /dev/null +++ b/localwiki/Raytracing_ExportProject.html @@ -0,0 +1,74 @@ +Raytracing ExportProject

      Raytracing ExportProject

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Raytracing ExportProject.png Raytracing ExportProject

      +
      Menu location +
      Raytracing → ExportProject +
      Workbenches +
      Raytracing +
      Default shortcut +
      +
      See also +
      +

      + +
      +


      +

      +

      Description

      +

      Exports the selected raytracing project to a file. +

      +

      Use

      +
      1. Select raytracing project in the tree view.
      2. +
      3. Click on Raytracing ExportProject.png or choose RaytracingRaytracing ExportProject.png Export project... from the top menu.
      +

      Limitations

      +


      +

      +

      Notes

      +


      +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Raytracing_InsertPart.html b/localwiki/Raytracing_InsertPart.html new file mode 100644 index 0000000..f8dcfbe --- /dev/null +++ b/localwiki/Raytracing_InsertPart.html @@ -0,0 +1,76 @@ +Raytracing InsertPart

      Raytracing InsertPart

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Raytracing InsertPart.png Raytracing InsertPart

      +
      Menu location +
      Raytracing → InsertPart‏‎ +
      Workbenches +
      Raytracing +
      Default shortcut +
      +
      See also +
      +

      + +
      +


      +

      +

      Description

      +

      Insert a view of a Part in a raytracing project. +

      +

      Use

      +
      1. Select object in the tree view.
      2. +
      3. Click on Raytracing InsertPart.png or choose RaytracingRaytracing InsertPart.png Insert Part from the top menu.
      4. +
      5. View of selected part will be inserted in the raytracing project.
      6. +
      7. If more than one raytracing projects exist in the active document you will be promted to choose on specific project.
      +

      Limitations

      +


      +

      +

      Notes

      +


      +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Raytracing_Lux.html b/localwiki/Raytracing_Lux.html new file mode 100644 index 0000000..f8b3a69 --- /dev/null +++ b/localwiki/Raytracing_Lux.html @@ -0,0 +1,76 @@ +Raytracing Lux

      Raytracing Lux

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Raytracing Lux.png Raytracing Lux

      +
      Menu location +
      Raytracing → New Luxrender project‏‎ +
      Workbenches +
      Raytracing +
      Default shortcut +
      +
      See also +
      +

      + +
      +


      +

      +

      Description

      +

      Insert new LuxRender project in the document. +

      +

      Use

      +
      1. Click on the black "down"-icon after Raytracing Lux.png to select between the different pre-defined templates
      2. +
      3. Or choose Raytracing New Luxrender project and one of the pre-defined templates from the top menu.
      4. +
      5. A new LuxRender project will be created named "LuxProject"
      +

      Limitations

      +

      Project can only be created from pre-defined templates. +
      +Additional project-setups would require definition of extra templates. +

      +

      Notes

      +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Raytracing_Module.html b/localwiki/Raytracing_Module.html new file mode 100644 index 0000000..520da55 --- /dev/null +++ b/localwiki/Raytracing_Module.html @@ -0,0 +1,192 @@ +Raytracing Module

      Raytracing Module

      + +

      The Raytracing module is used to generate photorealistic images of your models by rendering them with an external renderer. The Raytracing workbench works with templates, the same way as the Drawing workbench, by allowing you to create a Raytracing project in which you add views of your objects. The project can then be exported to a ready-to-render file, or be rendered directly. +

      Raytracing example.jpg +

      Currenly, two renderers are supported: povray and luxrender. To be able to render directly from FreeCAD, at least one of those renderers must be installed on your system, and its path must be configured in the FreeCAD Raytracing preferences. Without any renderer installed, though, you are still able to export a scene file that can be used in any of those renderers later, or on another machine. +

      The raytracing workbench works with templates, which are complete scene files for the given external renderer, including lights and possibly additional geometry such as ground planes. These scene files contain placeholders, where FreeCAD will insert the position of the camera, and geometry and materials information of each of the objects you insert in the project. That modified scene file is what is then exported to the external renderer. +

      + + +

      Tools

      +

      Raytracing project tools

      +

      These are the main tools for exporting your 3D work to external renderers +

      +
      • Raytracing New.png New PovRay project: Insert new PovRay project in the document
      • +
      • Raytracing Lux.png New LuxRender project: Insert new LuxRender project in the document
      • +
      • Raytracing InsertPart.png Insert part: Insert a view of a Part in a raytracing project
      • +
      • Raytracing ResetCamera.png Reset camera: Matches the camera position of a raytracing project to the current view
      • +
      • Raytracing ExportProject.png Export project: Exports a raytracing project to a scene file for rendering in an external renderer
      • +
      • Raytracing Render.png Render: Renders a raytracing project with an external renderer
      +

      Utilities

      +

      These are helper tools to perform specific tasks manually +

      + +

      Preferences

      + +


      +

      +

      Typical workflow

      +
      1. Create or open a FreeCAD project, add some Part-based objects (meshes are currently not supported)
      2. +
      3. Create a Raytracing project (luxrender or povray)
      4. +
      5. Select the objects you wish to add to the raytracing project and add them to the project with the "Insert Part" tool
      6. +
      7. Export or render directly
      +

      Creating a povray file manually

      +

      The utility tools described above allow you to export the current 3D view and all of its content to a Povray file. First, you must load or create your CAD data and position the 3D View orientation as you wish. Then choose "Utilities->Export View..." from the raytracing menu. +

      +
      FreeCAD Raytracing.jpg
      +

      You will be asked for a location to save the resulting *.pov file. After that you can open it in Povray and render: +

      +
      Povray.jpg
      +

      As usual in a renderer you can make big and nice pictures: +

      Scharniergreifer render.jpg +

      +

      Scripting

      +

      Outputting render files

      +

      The Raytracing and RaytracingGui modules provide several methods to write scene contents as povray or luxrender data. The most useful are Raytracing.getPartAsPovray() and Raytracing.getPartAsLux() to render a FreeCAD Part object into a povray or luxrender definition, and RaytracingGui.povViewCamera() and RaytracinGui.luxViewCamera() to get the current point of view of the FreeCAD 3D window into povray or luxrender format. +

      Here is how to write a povray file from python, assuming your document contains a "Box" object: +

      +
      import Raytracing,RaytracingGui
      +OutFile = open('C:/Documents and Settings/jriegel/Desktop/test.pov','w')
      +OutFile.write(open(App.getResourceDir()+'Mod/Raytracing/Templates/ProjectStd.pov').read())
      +OutFile.write(RaytracingGui.povViewCamera())
      +OutFile.write(Raytracing.getPartAsPovray('Box',App.activeDocument().Box.Shape,0.800000,0.800000,0.800000))
      +OutFile.close()
      +del OutFile 
      +

      And the same for luxrender: +

      +
      import Raytracing,RaytracingGui
      +OutFile = open('C:/Documents and Settings/jriegel/Desktop/test.lxs','w')
      +OutFile.write(open(App.getResourceDir()+'Mod/Raytracing/Templates/LuxClassic.lxs').read())
      +OutFile.write(RaytracingGui.luxViewCamera())
      +OutFile.write(Raytracing.getPartAsLux('Box',App.activeDocument().Box.Shape,0.800000,0.800000,0.800000))
      +OutFile.close()
      +del OutFile 
      +

      Creating a custom render object

      +

      Apart from standard povray and luxrender view objects that provide a view of an existing Part object, and that can be inserted in povray and luxrender projects respectively, a third object exist, called RaySegment, that can be inserted either in povray or luxrender projects. That RaySegment object is not linked to any of the FreeCAD objects, and can contain custom povray or luxrender code, that you might wish to insert into your raytracing project. You can also use it, for example, to output your FreeCAD objects a certain way, if you are not happy with the standard way. You can create and use it like this from the python console: +

      +
      myRaytracingProject = FreeCAD.ActiveDocument.PovProject
      +myCustomRenderObject = FreeCAD.ActiveDocument.addObject("Raytracing::RaySegment","myRenderObject")
      +myRaytracingProject.addObject(myCustomRenderObject)
      +myCustomRenderObject.Result = "// Hello from python!" 
      +

      Links

      +

      POVRay

      + +

      Luxrender

      + +

      Future possible renderers to implement

      + +
      +

      Currently there is a new Renderer Workbench in development to support multiple back-ends such as Lux Renderer and Yafaray. Information for using the development version can be viewed at Render_project +

      For Development status of the Render Module look here Raytracing_project +

      +

      Templates

      +

      FreeCAD comes with a couple of default templates for povray and luxrender, but you can easily create your own. All you need to do is to create a scene file for the given renderer, then edit it manually with a text editor to insert special tags that FreeCAD will recognize and where it will insert its contents (camera and objects data) +

      +

      Povray

      +

      Povray scene files (with extension .pov) can be created manually with a text editor (povray is made primarily to be used as a scripting language), but also with a wide range of 3D applications, such as blender. On the povray website you can find further information and a list of applications able to produce .pov files. +

      When you have a .pov file ready, you need to open it with a text editor, and do two operations: +

      +
      1. Strip out the camera information, because FreeCAD will place its own camera data. To do so, locate a text block like this: camera { ... }, which describes the camera parameters, and delete it (or put "//" in front of each line to comment them out).
      2. +
      3. Insert the following line somewhere: //RaytracingContent. This is where FreeCAD will insert its contents (camera and objects data). You can, for example, put this line at the very end of the file.
      +

      Note that FreeCAD will also add some declarations, that you can use in your template, after the //RaytracingContent tag. These are: +

      +
      • cam_location: the location of the camera
      • +
      • cam_look_at: the location of the target point of the camera
      • +
      • cam_sky: the up vector of the camera.
      • +
      • cam_angle: the angle of the camera
      +

      If you want, for example, to place a lamp above the camera, you can use this: +

      +
      light_source {
      + cam_location + cam_angle * 100
      + color rgb <10, 10, 10>
      +} 
      +

      Luxrender

      +

      Luxrender scene files (with extension.lxs) can either be single files, or a master .lxs file that includes world definition (.lxw), material definition (.lxm) and geometry definition (.lxo) files. You can work with both styles, but it is also easy to transform a group of 4 files in a single .lxs file, by copying the contents of each .lxw, .lxm and .lxo file and pasting it at the point where that file is inserted in the master .lxs file. +

      Luxrender scene files are hard to produce by hand, but are easy to produce with many 3D applications such as blender. On the luxrender website, you'll find more information and plugins for the main 3D applications out there. +

      If you will work with separated .lxw, .lxm and .lxo files, beware that the final .lxs exported by FreeCAD might be at a different location than the template file, and therefore these files might not be found by Luxrender at render time. In this case you should or copy these files to the location of your final file, or edit their paths in the exported .lxs file. +

      If you are exporting a scene file from blender, and wish to merge everything into one single file, you will need to perform one step before exporting: By default, the luxrender exporter in blender exports all mesh geometry as separate .ply files, instead of placing the mesh geometry directly inside the .lxo file. To change that behaviour, you need to select each of your meshes in blender, go to the "mesh" tab and set the option "export as" to "luxrender mesh" for each one of them. +

      After you have your scene file ready, to turn it into a FreeCAD template, you need to perform the following steps: +

      +
      1. Locate the camera position, a single line that begins with LookAt, and delete it (or place a "#" at the beginning of the line to comment it out)
      2. +
      3. At that place, insert the following line: #RaytracingCamera
      4. +
      5. At a desired point, for example just after the end of the materials definition, before the geometry information, or at the very end, just before the final WorldEnd line, insert the following line: #RaytracingContent. That is where FreeCAD will insert its own objects.
      +

      Note that in luxrender, the objects stored in a scene file can define transformation matrixes, that perform location, rotation or scaling operations. These matrixes can stack and affect everything that come after them, so, by placing your #RaytracingContent tag at the end of the file, you might see your FreeCAD objects affected by a transformation matrix placed earlier in the template. To make sure that this doesn't happen, place your #RaytracingContent tag before any other geometry object present in the template. FreeCAD itself won't define any of those transformation matrixes. +

      +

      Exporting to Kerkythea

      +

      Although direct export to the Kerkythea XML-File-Format is not supported yet, you can export your Objects as Mesh-Files (.obj) and then import them in Kerkythea. +

      +
      • if using Kerkythea for Linux, remember to install the WINE-Package (needed by Kerkythea for Linux to run)
      • +
      • you can convert your models with the help of the mesh workbench to meshes and then export these meshes as .obj-files
      • +
      • If your mesh-export resulted in errors (flip of normals, holes ...) you may try your luck with netfabb studio basic
      +
      Free for personal use, available for Windows, Linux and Mac OSX.
      +
      It has standard repair tools which will repair you model in most cases.
      +
      • another good program for mesh analysing/repairing is Meshlab
      +
      Open Source, available for Windows, Linux and Mac OSX.
      +
      It has standard repair tools which will repair you model in most cases (fill holes, re-orient normals, etc.)
      +
      • you can use "make compound" and then "make single copy" or you can fuse solids to group them before converting to meshes
      • +
      • remember to set in Kerkythea an import-factor of 0.001 for obj-modeler, since Kerkythea expects the obj-file to be in m (but standard units-scheme in FreeCAD is mm)
      +
      Within WIndows 7 64-bit Kerkythea does not seem to be able to save these settings.
      +
      So remember to do that each time you start Kerkythea
      +
      • if importing multiple objects in Kerkythea you can use the "File > Merge" command in Kerkythea
      +

      Links

      + +


      +

      + +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Raytracing_New.html b/localwiki/Raytracing_New.html new file mode 100644 index 0000000..46d8e6c --- /dev/null +++ b/localwiki/Raytracing_New.html @@ -0,0 +1,77 @@ +Raytracing New

      Raytracing New

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Raytracing New.png Raytracing New

      +
      Menu location +
      Raytracing → New Pov-Ray project‏‎ +
      Workbenches +
      Raytracing +
      Default shortcut +
      +
      See also +
      +

      + +
      +


      +

      +

      Description

      +

      Insert new PovRay project in the document. +

      +

      Use

      +
      1. Click on the black "down"-icon after Raytracing New.png to select between the different pre-defined templates
      2. +
      3. Or choose Raytracing New Pov-Ray project and one of the pre-defined templates from the top menu.
      4. +
      5. A new POVRay project will be created named "PovProject"
      +

      Limitations

      +

      Project can only be created from pre-defined templates. +
      +Additional project-setups would require definition of extra templates. +

      +

      Notes

      +


      +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Raytracing_Part.html b/localwiki/Raytracing_Part.html new file mode 100644 index 0000000..46c734b --- /dev/null +++ b/localwiki/Raytracing_Part.html @@ -0,0 +1,73 @@ +Raytracing Part

      Raytracing Part

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Raytracing Part.png Raytracing Part‏‎

      +
      Menu location +
      Raytracing → Part‏‎ +
      Workbenches +
      Raytracing +
      Default shortcut +
      +
      See also +
      +

      + +
      +


      +

      +

      Description

      +

      Exports the selected part to a pov-file for use in a POV-Ray project. +

      +

      Use

      +
      1. Select part to be exported in the tree-view
      2. +
      3. Choose Raytracing UtilitiesRaytracing Part.png Export part to POV-Ray from the top menu.
      +

      Limitations

      +


      +

      +

      Notes

      +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Raytracing_Preferences.html b/localwiki/Raytracing_Preferences.html new file mode 100644 index 0000000..92f44e2 --- /dev/null +++ b/localwiki/Raytracing_Preferences.html @@ -0,0 +1,23 @@ +Raytracing Preferences

      Raytracing Preferences

      + +

      The preferences screen of the Raytracing are found in the Preferences window (Menu Edit → Preferences → Raytracing). +

      +

      Raytracing

      +

      Preference Raytracing Tab 01.png +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Raytracing_Render.html b/localwiki/Raytracing_Render.html new file mode 100644 index 0000000..f18c59c --- /dev/null +++ b/localwiki/Raytracing_Render.html @@ -0,0 +1,73 @@ +Raytracing Render

      Raytracing Render

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Raytracing Render.png Raytracing Render

      +
      Menu location +
      Raytracing → Render‏‎ +
      Workbenches +
      Raytracing +
      Default shortcut +
      +
      See also +
      +

      + +
      +


      +

      +

      Description

      +

      Renders the selected raytracing project using an external renderer. +

      +

      Use

      +
      1. Select raytracing project in the tree view.
      2. +
      3. Click on Raytracing Render.png or choose RaytracingRaytracing Render.png Render from the top menu.
      +

      Limitations

      +

      Currently only POV-Ray and Luxrender are supported. +

      +

      Notes

      +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Raytracing_ResetCamera.html b/localwiki/Raytracing_ResetCamera.html new file mode 100644 index 0000000..ee648e2 --- /dev/null +++ b/localwiki/Raytracing_ResetCamera.html @@ -0,0 +1,76 @@ +Raytracing ResetCamera

      Raytracing ResetCamera

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Raytracing ResetCamera.png Raytracing ResetCamera

      +
      Menu location +
      Raytracing → ResetCamera +
      Workbenches +
      Raytracing +
      Default shortcut +
      +
      See also +
      +

      + +
      +


      +

      +

      Description

      +

      Sets the camera of the selected raytracing project to match the current view. +

      +

      Use

      +
      1. Select raytracing project in the tree-view
      2. +
      3. Make sure that the view is set to perspective view
      4. +
      5. Click on Raytracing ResetCamera.png or choose RaytracingRaytracing ResetCamera.png Reset Camera from the top menu
      6. +
      7. Selecting a raytracing project in the tree-view and looking at the data-tab in the property view will show the current camera-properties
      +

      Limitations

      +


      +

      +

      Notes

      +


      +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Raytracing_Workbench.html b/localwiki/Raytracing_Workbench.html new file mode 100644 index 0000000..062ff61 --- /dev/null +++ b/localwiki/Raytracing_Workbench.html @@ -0,0 +1,192 @@ +Raytracing Workbench

      Raytracing Workbench

      (Redirected from Raytracing Workbench)
      + +

      The Raytracing module is used to generate photorealistic images of your models by rendering them with an external renderer. The Raytracing workbench works with templates, the same way as the Drawing workbench, by allowing you to create a Raytracing project in which you add views of your objects. The project can then be exported to a ready-to-render file, or be rendered directly. +

      Raytracing example.jpg +

      Currenly, two renderers are supported: povray and luxrender. To be able to render directly from FreeCAD, at least one of those renderers must be installed on your system, and its path must be configured in the FreeCAD Raytracing preferences. Without any renderer installed, though, you are still able to export a scene file that can be used in any of those renderers later, or on another machine. +

      The raytracing workbench works with templates, which are complete scene files for the given external renderer, including lights and possibly additional geometry such as ground planes. These scene files contain placeholders, where FreeCAD will insert the position of the camera, and geometry and materials information of each of the objects you insert in the project. That modified scene file is what is then exported to the external renderer. +

      + + +

      Tools

      +

      Raytracing project tools

      +

      These are the main tools for exporting your 3D work to external renderers +

      +
      • Raytracing New.png New PovRay project: Insert new PovRay project in the document
      • +
      • Raytracing Lux.png New LuxRender project: Insert new LuxRender project in the document
      • +
      • Raytracing InsertPart.png Insert part: Insert a view of a Part in a raytracing project
      • +
      • Raytracing ResetCamera.png Reset camera: Matches the camera position of a raytracing project to the current view
      • +
      • Raytracing ExportProject.png Export project: Exports a raytracing project to a scene file for rendering in an external renderer
      • +
      • Raytracing Render.png Render: Renders a raytracing project with an external renderer
      +

      Utilities

      +

      These are helper tools to perform specific tasks manually +

      + +

      Preferences

      + +


      +

      +

      Typical workflow

      +
      1. Create or open a FreeCAD project, add some Part-based objects (meshes are currently not supported)
      2. +
      3. Create a Raytracing project (luxrender or povray)
      4. +
      5. Select the objects you wish to add to the raytracing project and add them to the project with the "Insert Part" tool
      6. +
      7. Export or render directly
      +

      Creating a povray file manually

      +

      The utility tools described above allow you to export the current 3D view and all of its content to a Povray file. First, you must load or create your CAD data and position the 3D View orientation as you wish. Then choose "Utilities->Export View..." from the raytracing menu. +

      +
      FreeCAD Raytracing.jpg
      +

      You will be asked for a location to save the resulting *.pov file. After that you can open it in Povray and render: +

      +
      Povray.jpg
      +

      As usual in a renderer you can make big and nice pictures: +

      Scharniergreifer render.jpg +

      +

      Scripting

      +

      Outputting render files

      +

      The Raytracing and RaytracingGui modules provide several methods to write scene contents as povray or luxrender data. The most useful are Raytracing.getPartAsPovray() and Raytracing.getPartAsLux() to render a FreeCAD Part object into a povray or luxrender definition, and RaytracingGui.povViewCamera() and RaytracinGui.luxViewCamera() to get the current point of view of the FreeCAD 3D window into povray or luxrender format. +

      Here is how to write a povray file from python, assuming your document contains a "Box" object: +

      +
      import Raytracing,RaytracingGui
      +OutFile = open('C:/Documents and Settings/jriegel/Desktop/test.pov','w')
      +OutFile.write(open(App.getResourceDir()+'Mod/Raytracing/Templates/ProjectStd.pov').read())
      +OutFile.write(RaytracingGui.povViewCamera())
      +OutFile.write(Raytracing.getPartAsPovray('Box',App.activeDocument().Box.Shape,0.800000,0.800000,0.800000))
      +OutFile.close()
      +del OutFile 
      +

      And the same for luxrender: +

      +
      import Raytracing,RaytracingGui
      +OutFile = open('C:/Documents and Settings/jriegel/Desktop/test.lxs','w')
      +OutFile.write(open(App.getResourceDir()+'Mod/Raytracing/Templates/LuxClassic.lxs').read())
      +OutFile.write(RaytracingGui.luxViewCamera())
      +OutFile.write(Raytracing.getPartAsLux('Box',App.activeDocument().Box.Shape,0.800000,0.800000,0.800000))
      +OutFile.close()
      +del OutFile 
      +

      Creating a custom render object

      +

      Apart from standard povray and luxrender view objects that provide a view of an existing Part object, and that can be inserted in povray and luxrender projects respectively, a third object exist, called RaySegment, that can be inserted either in povray or luxrender projects. That RaySegment object is not linked to any of the FreeCAD objects, and can contain custom povray or luxrender code, that you might wish to insert into your raytracing project. You can also use it, for example, to output your FreeCAD objects a certain way, if you are not happy with the standard way. You can create and use it like this from the python console: +

      +
      myRaytracingProject = FreeCAD.ActiveDocument.PovProject
      +myCustomRenderObject = FreeCAD.ActiveDocument.addObject("Raytracing::RaySegment","myRenderObject")
      +myRaytracingProject.addObject(myCustomRenderObject)
      +myCustomRenderObject.Result = "// Hello from python!" 
      +

      Links

      +

      POVRay

      + +

      Luxrender

      + +

      Future possible renderers to implement

      + +
      +

      Currently there is a new Renderer Workbench in development to support multiple back-ends such as Lux Renderer and Yafaray. Information for using the development version can be viewed at Render_project +

      For Development status of the Render Module look here Raytracing_project +

      +

      Templates

      +

      FreeCAD comes with a couple of default templates for povray and luxrender, but you can easily create your own. All you need to do is to create a scene file for the given renderer, then edit it manually with a text editor to insert special tags that FreeCAD will recognize and where it will insert its contents (camera and objects data) +

      +

      Povray

      +

      Povray scene files (with extension .pov) can be created manually with a text editor (povray is made primarily to be used as a scripting language), but also with a wide range of 3D applications, such as blender. On the povray website you can find further information and a list of applications able to produce .pov files. +

      When you have a .pov file ready, you need to open it with a text editor, and do two operations: +

      +
      1. Strip out the camera information, because FreeCAD will place its own camera data. To do so, locate a text block like this: camera { ... }, which describes the camera parameters, and delete it (or put "//" in front of each line to comment them out).
      2. +
      3. Insert the following line somewhere: //RaytracingContent. This is where FreeCAD will insert its contents (camera and objects data). You can, for example, put this line at the very end of the file.
      +

      Note that FreeCAD will also add some declarations, that you can use in your template, after the //RaytracingContent tag. These are: +

      +
      • cam_location: the location of the camera
      • +
      • cam_look_at: the location of the target point of the camera
      • +
      • cam_sky: the up vector of the camera.
      • +
      • cam_angle: the angle of the camera
      +

      If you want, for example, to place a lamp above the camera, you can use this: +

      +
      light_source {
      + cam_location + cam_angle * 100
      + color rgb <10, 10, 10>
      +} 
      +

      Luxrender

      +

      Luxrender scene files (with extension.lxs) can either be single files, or a master .lxs file that includes world definition (.lxw), material definition (.lxm) and geometry definition (.lxo) files. You can work with both styles, but it is also easy to transform a group of 4 files in a single .lxs file, by copying the contents of each .lxw, .lxm and .lxo file and pasting it at the point where that file is inserted in the master .lxs file. +

      Luxrender scene files are hard to produce by hand, but are easy to produce with many 3D applications such as blender. On the luxrender website, you'll find more information and plugins for the main 3D applications out there. +

      If you will work with separated .lxw, .lxm and .lxo files, beware that the final .lxs exported by FreeCAD might be at a different location than the template file, and therefore these files might not be found by Luxrender at render time. In this case you should or copy these files to the location of your final file, or edit their paths in the exported .lxs file. +

      If you are exporting a scene file from blender, and wish to merge everything into one single file, you will need to perform one step before exporting: By default, the luxrender exporter in blender exports all mesh geometry as separate .ply files, instead of placing the mesh geometry directly inside the .lxo file. To change that behaviour, you need to select each of your meshes in blender, go to the "mesh" tab and set the option "export as" to "luxrender mesh" for each one of them. +

      After you have your scene file ready, to turn it into a FreeCAD template, you need to perform the following steps: +

      +
      1. Locate the camera position, a single line that begins with LookAt, and delete it (or place a "#" at the beginning of the line to comment it out)
      2. +
      3. At that place, insert the following line: #RaytracingCamera
      4. +
      5. At a desired point, for example just after the end of the materials definition, before the geometry information, or at the very end, just before the final WorldEnd line, insert the following line: #RaytracingContent. That is where FreeCAD will insert its own objects.
      +

      Note that in luxrender, the objects stored in a scene file can define transformation matrixes, that perform location, rotation or scaling operations. These matrixes can stack and affect everything that come after them, so, by placing your #RaytracingContent tag at the end of the file, you might see your FreeCAD objects affected by a transformation matrix placed earlier in the template. To make sure that this doesn't happen, place your #RaytracingContent tag before any other geometry object present in the template. FreeCAD itself won't define any of those transformation matrixes. +

      +

      Exporting to Kerkythea

      +

      Although direct export to the Kerkythea XML-File-Format is not supported yet, you can export your Objects as Mesh-Files (.obj) and then import them in Kerkythea. +

      +
      • if using Kerkythea for Linux, remember to install the WINE-Package (needed by Kerkythea for Linux to run)
      • +
      • you can convert your models with the help of the mesh workbench to meshes and then export these meshes as .obj-files
      • +
      • If your mesh-export resulted in errors (flip of normals, holes ...) you may try your luck with netfabb studio basic
      +
      Free for personal use, available for Windows, Linux and Mac OSX.
      +
      It has standard repair tools which will repair you model in most cases.
      +
      • another good program for mesh analysing/repairing is Meshlab
      +
      Open Source, available for Windows, Linux and Mac OSX.
      +
      It has standard repair tools which will repair you model in most cases (fill holes, re-orient normals, etc.)
      +
      • you can use "make compound" and then "make single copy" or you can fuse solids to group them before converting to meshes
      • +
      • remember to set in Kerkythea an import-factor of 0.001 for obj-modeler, since Kerkythea expects the obj-file to be in m (but standard units-scheme in FreeCAD is mm)
      +
      Within WIndows 7 64-bit Kerkythea does not seem to be able to save these settings.
      +
      So remember to do that each time you start Kerkythea
      +
      • if importing multiple objects in Kerkythea you can use the "File > Merge" command in Kerkythea
      +

      Links

      + +


      +

      + +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Raytracing_project.html b/localwiki/Raytracing_project.html new file mode 100644 index 0000000..bcfed6f --- /dev/null +++ b/localwiki/Raytracing_project.html @@ -0,0 +1,79 @@ +Raytracing project

      Raytracing project

      + +

      This is the FreeCAD Raytracing development project. It follows the rules of the Getting things done process. The projects are collected in the Development roadmap. +

      + + +

      Purpose and principles

      +

      This project is to update the current render module Raytracing that currently uses povray, a biased renderer which gives satisfactory results and allow more modern renderers such as Lux Render, Yafaray, Indigo renderers to be used. +

      Also to provide a generic interface to allow multiple render back-ends to be used to visualise Features within FreeCad. Providing a more generic programming interface will allow render plugins to be created more easily. +

      The interface will allow both open source and proprietary external renderers to be used by generating a compatible scene file and launching a separate process in the background. The output can then be previewed inside Freecad directly by opening the temporary output file (if available). +

      Each renderer will be a plugin into a generic interface and provide compatible materials and rendering modes. +

      +

      Outcome

      +

      Nice Visuals!!! Produce high quality outputs of parts within the Freecad document and provide a very simple interface with presets to allow quick initialisation for rendering and previews. +

      The user interface should allow more complex situations to be created and possibly previewed such as changing and modifying lights and positions. However, the aim is to not provide a full featured render suite. +

      +

      Brainstorming

      +

      A library of material 'must' be created for each render plugin along with presets. Material properties can be changed. +Scene presets should allow users with inexperience with Rendering to produce nice visuals in little time. +

      +

      Organising

      +

      The generic inteface is currently being created and to test the integration Lux render, an unbiased renderer will be first implemented. +Current work is being completed by mrlukeparry on his render branch Github Render Branch. +

      Currently it is possible to render objects to Lux Render: +

      LuxRenderOutput.png +

      Featured is a part that was creating using PartDesign/Sketcher then rendered using the new render workbench being developed in Lux Render. Lux Render allows nice effects such as DOF to be created to improve realism. +

      +

      Next actions

      +
      • Create the Abstraction to provide the interface between renderers (Done)
      • +
      • Implement an interface for describing generic materials and collecting these (Done)
      • +
      • Implement an interface for describing render presets (Done)
      • +
      • Implement an interface for describing templates (Done)
      • +
      • Implement a feature to store all this information permanently (WIP)
      • +
      • Create a workbench environment for displaying the output (Done)
      • +
      • Create workbench tools for changing render properties (Done)
      • +
      • Create workbench tools for browsing, changing and applying materials to part features (Done)
      • +
      • Create automake scripts (WIP)
      • +
      • Remove any GUI dependencies from Raytracing/App (Done) +
        • Bounding Box data structure should not use coin3d SbBox3f (Done)
        • +
        • QWidget Included in QProcess for some reason (Fixed)
      • +
      • Test compatibility with Windows (in progress) +
        • Update Libpack to include QT 4.7 - QT 4.8
        • +
        • Remove compiler warnings and errors
      • +
      • Implement saving of Material Properties (Done)
      • +
      • Tidying the QML interface (WIP)
      • +
      • Creating Render Templates / Render Materials / Render Presets
      • +
      • Create a blender scene to lux template converter
      • +
      • Convert LuxBlender Materials .lbm (http://www.luxrender.net/lrmdb/en/material/) to useful Render Materials
      • +
      • Create python bindings for Render Materials, Cameras, Lights
      • +
      • Create a RenderCamera Document object
      • +
      • Allow scene template to be imported into the render feature.
      • +
      • User defined preset/material/template directories
      • +
      • Improve the View Provider
      • +
      • Convert Povray/Yafaray to use the new Render Module Infrastructure
      • +
      • Testing
      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Raytracing_tutorial.html b/localwiki/Raytracing_tutorial.html new file mode 100644 index 0000000..4080967 --- /dev/null +++ b/localwiki/Raytracing_tutorial.html @@ -0,0 +1,131 @@ +Raytracing tutorial

      Raytracing tutorial

      + +
      + + + + + + + + + + + + + + + + + + + + + + + + + + + +
      +

      Base ExampleCommandModel.png Tutorial

      +
      Topic +
      Raytracing +
      Level +
      Beginner +
      Time to complete +
      10 minutes + Render time +
      Author +
      Drei +
      FreeCAD version +
      0.16 or above +
      Example File(s) +
      +

      + +
      +


      +

      +

      Introduction

      +

      This tutorial is meant to introduce the reader to the basic workflow of the Raytracing Workbench, as well as most of the tools that are available to create a rendered image. +

      Raytracing tutorial result.png +

      +

      Requirements

      +
      • FreeCAD version 0.16 or above
      • +
      • POV-Ray and/or LuxRender is installed on the system
      • +
      • In the case of POV-Ray, it's not enough to have just the binary executable in place, but it also requires the installation of supporting files, and in Ubuntu these are provided by the Recommends-flagged package povray-includes. Potential issues have also been seen with Linux installations requiring local configuration files to be manually created in a user's home folder, as discussed here.
      • +
      • In the case of POV-Ray, installation of psicofil's macro is recommended
      • +
      • The reader has the basic knowledge to use the Part and PartDesign Workbenches
      +

      Procedure

      +

      Modeling

      +

      In this example a Cube is used as the study object, but models created in the Part or PartDesign Workbenches can be used instead. +

      +
      1. Create a new document
      2. +
      3. Activate the Part Workbench
      4. +
      5. Create a Cube. You are free to change its properties in any way.
      +

      Now we have a model with which to work. +

      +

      Preparing for the render

      +
      1. Switch to the Raytracing Workbench
      2. +
      3. Change your View to Perspective. Go to View menu and select Perspective.
      4. +
      5. Set the location for the renderer. Go to the Edit menu and select Preferences. Click on Raytracing and set the location to the executable.
      6. +
      7. Set the size of the rendered image. Go to the Edit menu and select Preferences. Click on Raytracing and set the desired image size.
      +
      POV-Ray
      +
      1. Select Raytracing New.png New PovRay project. From the dropdown menu pick RadiosityNormal
      +
      LuxRender
      +
      1. Select Raytracing Lux.png New LuxRender project. From the dropdown menu pick LuxClassic
      +

      Setting the camera position

      +
      1. Position the 3D View to the desired location and distance from the model. In this case we will use the Axonometric View.
      2. +
      3. Select the Project Folder from the Tree View
      4. +
      5. Select Raytracing ResetCamera.png Reset camera
      +

      Importing the model

      +
      1. Select the model to render.
      2. +
      3. Select Raytracing InsertPart.png Insert part
      +

      Running the Renderer

      +
      1. Select Raytracing Render.png Render.
      2. +
      3. Set the path to which the image will be stored.
      4. +
      5. Wait for the rendering to finish. This may take a while.
      +

      Viewing the results

      +

      FreeCAD will immediately open the image after the render is finished. +

      We are now finished with the basic workflow for the Raytracing Module. +


      +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/RebarDistributionDialog.png b/localwiki/RebarDistributionDialog.png new file mode 100644 index 0000000..b9eea92 Binary files /dev/null and b/localwiki/RebarDistributionDialog.png differ diff --git a/localwiki/Rectellipse.png b/localwiki/Rectellipse.png new file mode 100644 index 0000000..9f5387b Binary files /dev/null and b/localwiki/Rectellipse.png differ diff --git a/localwiki/Reference_editable.svg b/localwiki/Reference_editable.svg new file mode 100644 index 0000000..17fdf26 --- /dev/null +++ b/localwiki/Reference_editable.svg @@ -0,0 +1,99 @@ + + + + + Reference + + + + + image/svg+xml + + Angularity + + + bavariaSHAPE + + + + + bavariaSHAPE + + + + + bavariaSHAPE + + + 15.10.2016 + Geometric dimensioning and tolerancing symbols +All symbols in this repository are licensed under CC-BY 3.0 + + + + + + + + + + + + + + + + + + A + + + + + diff --git a/localwiki/Release-0.13-Origin.png b/localwiki/Release-0.13-Origin.png new file mode 100644 index 0000000..93778bc Binary files /dev/null and b/localwiki/Release-0.13-Origin.png differ diff --git a/localwiki/Release-0.13-PointTool.png b/localwiki/Release-0.13-PointTool.png new file mode 100644 index 0000000..aa0841f Binary files /dev/null and b/localwiki/Release-0.13-PointTool.png differ diff --git a/localwiki/Release-0.13-RubberBandSelection.png b/localwiki/Release-0.13-RubberBandSelection.png new file mode 100644 index 0000000..4183b5e Binary files /dev/null and b/localwiki/Release-0.13-RubberBandSelection.png differ diff --git a/localwiki/Release-0.13-SketcherDimensions.png b/localwiki/Release-0.13-SketcherDimensions.png new file mode 100644 index 0000000..7112015 Binary files /dev/null and b/localwiki/Release-0.13-SketcherDimensions.png differ diff --git a/localwiki/Release-0.13-SketcherFullyConstrained.png b/localwiki/Release-0.13-SketcherFullyConstrained.png new file mode 100644 index 0000000..46aa4a1 Binary files /dev/null and b/localwiki/Release-0.13-SketcherFullyConstrained.png differ diff --git a/localwiki/Release011-dependency.jpg b/localwiki/Release011-dependency.jpg new file mode 100644 index 0000000..2730a74 Binary files /dev/null and b/localwiki/Release011-dependency.jpg differ diff --git a/localwiki/Release011-draft-drawing.jpg b/localwiki/Release011-draft-drawing.jpg new file mode 100644 index 0000000..9027ae3 Binary files /dev/null and b/localwiki/Release011-draft-drawing.jpg differ diff --git a/localwiki/Release011-draft.jpg b/localwiki/Release011-draft.jpg new file mode 100644 index 0000000..1873f7a Binary files /dev/null and b/localwiki/Release011-draft.jpg differ diff --git a/localwiki/Release011-robot.jpg b/localwiki/Release011-robot.jpg new file mode 100644 index 0000000..f289f07 Binary files /dev/null and b/localwiki/Release011-robot.jpg differ diff --git a/localwiki/Release011-sketcher.jpg b/localwiki/Release011-sketcher.jpg new file mode 100644 index 0000000..0f12466 Binary files /dev/null and b/localwiki/Release011-sketcher.jpg differ diff --git a/localwiki/Release011-translation.jpg b/localwiki/Release011-translation.jpg new file mode 100644 index 0000000..9d47303 Binary files /dev/null and b/localwiki/Release011-translation.jpg differ diff --git a/localwiki/Release_notes_0.13.html b/localwiki/Release_notes_0.13.html new file mode 100644 index 0000000..d213b5c --- /dev/null +++ b/localwiki/Release_notes_0.13.html @@ -0,0 +1,140 @@ +Release notes 0.13

      Release notes 0.13

      (Redirected from Release notes 0.13)
      + +

      This is a summary of the most interesting changes occured in FreeCAD since latest version. See the Mantis changelog on SourceForge for the complete list of changes. +

      Older versions: 0.12 - 0.11 +

      FreeCAD013.jpg +

      modeled in FreeCAD by psicofil +


      +

      + + +

      General

      +
      • Color preferences: Getting bored of the good old grey-shapes-on-black-lines FreeCAD default aspect? It is now changeable in the user preferences (Display -> Color), together with several other default colors.
      • +
      • Alignment: two shapes can be aligned to each other with up to three points with this tool available in the Edit menu.
      +

      Drawing module

      +
      • Clip feature: A new Drawing Clip object allows to place views of objects inside clipped rectangles on Drawing pages.
      • +
      • Editable titleblocks: When designing Drawing templates, it is now possible to mark texts as editable. Those texts become then directly editable in FreeCAD.
      • +
      • Annotation feature: A new Drawing Annotation object, a simple feature to quickly place text blocks on a Drawing page.
      • +
      • Orthographic Views: A new Drawing Orthographic Views tool facilitate creation of multiple views all aligned to each other, according to first-angle or third-angle projection.
      • +
      • Browser preview: Since all SVG capabilities are not always supported by the internal Qt SVG viewer, this button allows you to check how a page looks like in the webkit browser, which fully supports the SVG format. This is provisory, until we definitely switch our SVG viewer to webkit...
      • +
      • DXF export: you can now export a view of a page directly to a DXF file.
      • +
      • Some bug fixes now allow printing of pages to scale.
      +

      Sketcher module

      +
      • Point Creation
      +

      Release-0.13-PointTool.png +

      Points can now be added and used as a feature within a sketch +

      +
      • Sketch Origin
      +

      Release-0.13-Origin.png +

      User can now use the sketch's origin to define geometry as well as the sketch axes. +

      +
      • Tangency and perpendicularity constraints for arcs and circles.
      • +
      • Constraints with respect to external (projected) geometry.
      • +
      • Improved counting of the sketch degrees of freedom.
      • +
      • Symmetry constraint with respect to a symmetry point (midpoint constraint).
      +
      • Improved Datum Label and Constraint Visuals:
      +

      Release-0.13-SketcherDimensions.png +

      +
        • Each constraint label (including arrows) will correctly scale to the size of the scene automatically to the 3D viewport
        • +
        • Datum label text for Distance, Distance X, Distance Y and Radius can be freely positioned now with greater control.
        • +
        • Small improvements to overlapping constraint icons and fix freezes.
        • +
        • Datum Label text will reverse when the view is orientated from the opposite side.
      +


      +

      +
      • Fully constrained Sketches are now highlighted:
      +

      The sketch color turns from white to green to indicate it is fully constrained. These default colors can be customized. +


      +

      +
      • Rubber band selection:
      +

      Release-0.13-RubberBandSelection.png +

      Geometry (Points, Lines and Curves) may be selected by dragging on the background to create a rectangular selection. +

      +
      • Extended functionality of the polyline tool: using the m key one can switch between arc and line mode and among free, tangent and perpendicular transitions from the previous segment.
      +
      • Map sketch to face is a new tool to map (or remap) an existing sketch to the selected face on a solid. This allows the use of this sketch for features such as Pad and Pocket.
      +
      • Small Improvements: +
        • When constructing geometry, tool tip with related information is shown next to cursor.
        • +
        • Sketch view which sets the 3D view perpendicular to the sketch plane has now an icon in the Sketcher toolbar.
      +

      Draft module

      +
      • Taskmode: The Taskview mode of the Draft module is now default. Fear not, if you liked the toolbar, it is still available in the Draft preferences settings.
      • +
      • DXF importer: The DXF importer now supports points (translate to Draft Point) and leaders (translate to Draft Wire)
      • +
      • Brand-new snapping system: The snapping system of the Draft module has been rewritten almost from scratch. It is now much easier to extend and use in other scripts and modules, has now new visuals with snap cursor icons, and a toolbar that allows to switch on/off individual snap locations or the whole snapping system.
      +

      013-draft-snap.jpg +

      +
      • Better constraining: When entering 3D points, besides the existing Shift-constraining, you can now constrain the movement in X, Y or Z direction by pressing the X, Y or Z keys. Pressing them again switches constraining off.
      • +
      • Draft <-> Sketch conversion: The Draft workbench now features a new Draft2Sketch conversion tool, that converts selected Draft objects (or any flat shape) to Sketches, and vice-versa.
      • +
      • Clone tool: Make copies of selected objects with this handy tool. When the original changes, the clone gets updated automatically. The clone can be moved, rotated, and also has a scale property that allows you to change the size of the copy.
      • +
      • SVG importer: The SVG importer now has much better support of bezier curves. Global definition of user units is now respected and the geometry is scaled properly to millimeter. Support for new elements such as ellipses rounded rectangles has been added. The parser has been reworked and now handles paths from Adobe Illustrator.
      • +
      • Curved corners: Several Draft objects (Wires, Rectangles and Polygons) now have a Fillet Radius property, which curves their corners by the given radius value.
      +

      013-draft-fillet.jpg +

      +
      • 2D view object: The new Shape2DView tool allows to quickly place a 2D view of a selected object in the document. You can specify the projection vector.
      +

      013-draft-shape2dview.jpg +

      +

      Arch module

      +
      • Draft integration: The Arch and Draft modules are now tightly integrated. The Arch tools use the Draft snapping system, and all the Draft tools are present in the Arch workbench. In fact, if you like, you can now completely switch off the Draft module (Preferences -> Draft -> Hide the Draft workbench)
      • +
      • New wall tool: The wall tool has been greatly enhanced, and now features a direct drawing mode, that is activated when you press the Wall button with no object selected, that allows you to draw walls like you draw simple lines. In additions, walls now auto-connect when you snap to an existing wall.
      +

      013-arch-wall.jpg +

      +
      • New roof tool: A new roof tool is now available in the Arch module, that allows you to quickly create sloped roofs from a selected face.
      • +
      • New window tool: Windows are now created directly on top of a flat shape that contains one or more wires, such as a rectangle or a sketch. If that shape was drawn directly on a wall face, the window will automatically cut an opening in the wall.
      • +
      • New sections system: It is now very simple to create 2D plans, sections and elevations from your model: Place a Section Plane object, orient it the way you want, edit it to include the objects it must see, and you are done!
      • +
      • New solid renderer: In addition to the OpenCasCADe-based wireframe 2D renderer currently used by the Drawing Module, the Arch module now features a new 2D renderer, that is able to render filled faces to a SVG Drawing sheet, giving much nicer 2D views.
      +

      013-arch-vrm.jpg +

      +
      • IFC import with IfcOpenShell: The Arch module can now use IfcOpenShell if it is installed on your system. This allows for much more powerful IFC import, and all the contents of the IFC file are guaranteed to be imported.
      • +
      • New floor and building objects: Building and floors are now groups, so you can add and remove objects from them with a simple drag&drop from the tree view.
      • +
      • New axes system: A new axes system feature has been added, that allows to quickly layout complex axes systems. These axes can then be added to Structure objects, so they spread automatically on the grid nodes.
      +

      013-arch-axes.jpg +

      +
      • Arch objects from meshes: Walls and structures can now be made directly from a mesh, provided it is closed, solid and all edges are manifold. This allows for very quick transformation of geometry imported from other applications such as blender into valid Arch objects.
      +

      Part module

      +
      • Refine shape is a new utility that cleans up faces after a few operations on a shape. It can be set to run automatically after boolean operations in the Preferences.
      • +
      • New Loft tool can extrude a complex set of surfaces or a solid shape through a series of sketches or Draft objects.
      • +
      • New Sweep tool can extrude a complex set of surfaces or a solid shape through a series of sketches or Draft objects and a trajectory (sketch, edge or Draft object).
      • +
      • New Offset tool can offset a single surface or a shape.
      • +
      • New Thickness tool can hollow out a solid shape by setting a wall thickness and opening one or more faces.
      • +
      • Shape Builder and Create primitives are now in the Part toolbar for quick access.
      +

      Part Design module

      +
      • Pad and Pocket are now more powerful thanks to more parameters, such as extrude to first/to last, up to face, 2 dimensions, symmetric to plane.
      • +
      • Chamfer and Fillet got an upgrade: selecting a face is now allowed, all the outer and inner edges of this face will be processed.
      • +
      • Revolution: a construction line can now be used as a revolution axis.
      • +
      • New Groove tool: cut matter from your solid by revolving a sketch.
      • +
      • Linear pattern, Mirrored, Polar pattern and Multipattern tools, that allow you to align and distribute pads and pockets on a feature.
      • +
      • A Shaft Wizard to help you design shaft objects
      +

      Ship Design module

      + +

      3D mice

      +
      • Support for 3D mice (Spaceball, Space Navigator) has been added to the Windows version.
      • +
      • A new Spaceball Motion tab in the Customize dialog allows for fine tuning your 3D mouse to the settings you want, directly from FreeCAD.
      +

      OpenSCAD module

      +
      • This brand new (experimental) module brings OpenSCAD files import capability into FreeCAD. This file format is wildly popular in the RepRap community and on digital designs sharing site Thingiverse.
      • +
      • OpenSCAD script can be executed from within FreeCAD, by OpenSCAD (if installed on your computer), with the result appearing in your FreeCAD document.
      • +
      • For more information see the OpenSCAD Module page on the FreeCAD wiki
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Release_notes_0.14.html b/localwiki/Release_notes_0.14.html new file mode 100644 index 0000000..4f2ff57 --- /dev/null +++ b/localwiki/Release_notes_0.14.html @@ -0,0 +1,247 @@ +Release notes 0.14

      Release notes 0.14

      + +

      FreeCAD 0.14 was released on July 1, 2014. This is a summary of the most interesting changes. The complete list of changes can be found in the Mantis changelog. Older versions at: 0.13 - 0.12 - 0.11 +

      Freecad jeep.png +

      +
      Jeep model by Psicofil
      + + +

      General

      +

      Site migration

      +

      We finally moved all the web applications of FreeCAD from SourceForge to our own domain. The new FreeCAD homepage can be found at http://www.freecadweb.org, the wiki is now at http://www.freecadweb.org/wiki, the bug and features tracker at http://www.freecadweb.org/tracker, and the forum at http://forum.freecadweb.org. If you had an account on one of these applications when we were on SourceForge, you can regain your existing user following these instructions. +

      The only part of FreeCAD that remains at SourceForge is the main git repository, at the same address: http://sourceforge.net/p/free-cad/code/ci/master/tree/ but there is also have an automatic mirror of that code set up on github, at http://github.com/FreeCAD/FreeCAD_sf_master +

      If you haven't met the incredible FreeCAD community yet, pay us a visit on the forum, and be amazed by its talent, energy and helpfulness. +

      +

      Move to pyside, FreeCAD is now fully LGPL

      +

      With the many complications caused by the double-license model of FreeCAD (LGPL & GPL), some of the components of FreeCAD (namely the OpenCasCade kernel) being incompatible with GPL code, we decided to switch all the remaining bits of GPL code of FreeCAD to LGPL. As a result of this operation, PyQt is not used anymore, and has been replaced by PySide. There is not much consequence for python scriptwriters, PyQt can still be used inside FreeCAD. +

      After we finished the move to LGPL, OpenCasCade has switched to LGPL too, which would have solved all our license conflicts too. But we have now a much clearer and unified license model, which should satisfy all the strictest linux distributions. +

      +

      Plugins and side projects: Parts library, BOLTS, Eagle importer

      +

      The last year has seen a couple of interesting side projects emerge along FreeCAD. A Parts library has been started by the community and is slowly growing, consisting of a collection of reusable parts to add to your FreeCAD models. It can be launched and used from inside FreeCAD with the use of a macro. +

      Another similar but more ambitious project is BOLTS, which is also a parts library, but built from parametric scripts, able to produce a wide variety of parametric parts. BOLTS, although application-independent, can also be run from FreeCAD by launching a macro. The image below shows BOLTS running inside FreeCAD. +

      Freecad-bearing.png +

      Another interesting external project is the EAGLE importer, which allows you to import PCB board designs made from several applications into FreeCAD. +

      +

      WebGL export

      +

      From FreeCAD, you can now export your scene as a WebGL-enabled html file. This file includes an embedded three.js-based viewer that allows to inspect the scene from the web without any plugin, as long as you view it with a WebGL-capable browser. +

      +

      Units system

      +

      Finally, a units system has been implemented at FreeCAD level, so it is available to all modules. You are now able to choose a units schema from the preferences. Currently available schemas include millimeters, meters and imperial measurements, but more should become available soon. Once this schema is set, most properties and tools of FreeCAD will use this unit preferentially. But the system is very flexible, and in most places, you can mix units as much as you like, for example giving measures in inches in a document set in millimeters. +

      +

      Style Sheets

      +

      FreeCAD 0.14 becomes even more customizable with the addition of Style Sheets being used to control the background image in the main window. No longer is the user stuck with the grey stone background. Almost any image, picture or custom tile may be used to fill the background space in FreeCAD's main Window. +

      Style Sheets.png +

      +

      Display style override

      +

      The default View toolbar has been extended with a couple of new buttons to easily switch the display of the whole 3D view to wireframe, shaded or flat lines mode. +

      +

      3D window anti-aliasing

      +

      New options have been added to the 3D view anti-aliasing system of FreeCAD, that you can find in the preferences. If you have a good 3D graphic chip, you can now enjoy FreeCAD with very high-quality anti-aliasing. +

      +

      Part

      +

      Loft and Sweep

      +

      The Part Loft and Part Sweep tools have been bettered and can now use Draft Workbench objects as profiles +

      +

      Offset

      +

      The new Part Offset tool creates copies of a selected shape at a certain distance from the base shape. +

      +

      Thickness

      +

      A new Part Thickness tool is now available. This tool works on a solid shape, and turns it into a hollow object, by giving each of its faces a given thickness. +

      +

      Make Compound

      +

      The Part Workbench now features a Make Compound tool, which allows you to quickly create a compound object from a set of selected shapes. +

      +

      Part Primitives

      +

      New Part primitives have been added to the Part CreatePrimitives tool: Prisms, regular polygons and spirals are now easy to create by filling out a couple of parameters. Furthermore, some tools from the Draft Workbench can now take advantage of this feature and create these primitives too, instead of their regular Draft object, when the appropriate option is set in the Draft preferences settings. +

      Part Create Primitives1.jpeg +

      +

      Measure tools

      +

      A new measurement toolset has been added to the Part workbench. With it, you can select two shape elements (vertices, edges or faces), and display the distance between the two in absolute distance, and along X and Y axes. +

      +

      PartDesign & Sketcher

      +

      Validate sketch

      +

      The Sketcher now features a new Validate sketch tool to help you to validate a sketch, by finding missing or redundant constraints. It can also automatically add some missing constraints, in order to make your sketch fully constrained. +

      +

      Gear generator

      +

      An involute gear generator tool has been added to the PartDesign workbench, to quickly create such gears from parameters. +

      +

      Drawing

      +

      Automatic projections

      +

      The Drawing Workbench continues to be improved with some exciting new features. Orthographic Projections now allows all views to be displayed as well as much greater control over individual views. Another key feature, Drawing Templates may now contain data defining Border and Title Block locations that will automatically confine Projections within the border while at the same time automatically avoiding the space occupied by the Title Block. +

      DrawingWB.png +

      +

      Symbols

      +

      A new Drawing Symbol tool is available on the Drawing Workbench allowing to quickly place SVG objects on the Drawing sheet. These objects are stored within the FreeCAD file, so you don't need to ship the original SVG file when distributing your files. +

      +

      Raytracing

      +

      New rendering tools

      +

      Raytracing example.jpg +

      The Raytracing workbench has also received some love, and its toolbar has been reworked. The "old" buttons that manually produced partial povray files have been removed (they are still there in the Raytracing menu), and you can now produce a rendering pretty much the same way as you use the Drawing workbench: You create a new project, give it a template, then fill it with views of your objects. When you are done, just hit the render button, or export it to a file that is ready to render outside of FreeCAD. +

      The Raytracing templates system has also been extended, and templates are now easier to manipulate and create. +

      FreeCAD produced .pov scripts now contain auto-aspect ratio. Users no longer need to maintain a 4:3 aspect ratio in their Raytracing settings or need to manually edit the output to change ratios in order to get a proper render. Any width and height may now be entered without fear that the rendered objects will come out squashed or stretched. +

      +

      Luxrender support

      +

      Together with the existing support for POV-Ray, the Raytracing workbench now also supports LuxRender. Where POV-Ray is a classical-style raytracer, that shoots rays from the camera in order to find the color of each pixel of the image, Luxrender is an unbiased renderer, which takes much longer to render scenes, but can produce much more realistic lighting. +

      +

      Spreadsheet

      +

      A new Spreadsheet Workbench has been added to FreeCAD. It allows you to create spreadsheet objects, that contain 2-dimensional spreadsheet data. It also features an editor so you can edit the spreadsheet contents (texts, numbers and some basic formulas are supported), and a special cell controller object, that can scan the document for certain types of objects, extract a certain property from them, and fill a certain range of cells with these values. +

      Arch tutorial 53.jpg +

      +

      Draft

      +

      DWG import/export

      +

      FreeCAD is now able to import and export to the DWG format, thanks to the free, multiplatform Teigha Converter. Once the Teigha Converter is installed, and its path set in the FreeCAD Draft preferences settings, FreeCAD will be able to use it to import and export dwg files, by converting them to dxf, then using the Draft dxf importer and exporter. The import and export of dwg files has therefore the same limitations as the dxf format. +

      +

      Draft to Drawing works with groups

      +

      The Draft to Drawing tool, used to place Draft objects on a Drawing sheet, can now be applied on groups, allowing to create fewer View objects on the Drawing sheet. By intelligently combine your Draft objects into a couple of groups, you have a quick way to control the appearance of many objects on your page. +

      +

      Dimensions recoded

      +

      The Draft Dimension tool has been fully recoded, and dimension objects now behave much better, and have gained a few new properties, allowing to fine-tune them better, such as nicer and scalable arrows, more control over the position of the text and the direction of the dimension, and, above all, better support for the Drawing Module. You can now place dimensions in any plane of the 3D space, and expect correct results when placing them on a Drawing sheet with the Draft Drawing tool. +

      Draft dimensions recode.jpg +

      +

      Hatches

      +

      The Draft workbench also features a new toy: hatching. On specific Draft objects (those that form a closed shape such as closed polylines, rectangles, regular polygons or circles), it is now possible to apply hatching. Currently, only a couple of default hatch patterns are available, but since those patterns are very easy to create (they are simple svg files), and custom patterns can already be added by the user, the default collection might grow quickly. Draft objects with patterns are also faithfully supported by the Drawing workbench. +

      Draft hatches.jpg +

      +

      Ellipses

      +

      Support for ellipses has been added, the Draft workbench now allows you to draw full or portions of ellipses. +

      +

      Chamfer

      +

      In the same fashion as fillets, that had appeared in release 013, Draft rectangles, wires and polygons now gained a chamfer property, which chamfers their angle. The chamfer is applied before the fillet,and both properties can be used together, allowing you to quickly turn a very simple wire into a complex object made of many sections. +

      +

      Upgrade and downgrade recoded

      +

      The Draft Upgrade and Draft Downgrade tools, before hermetic pieces of magic, from which you were never too sure what the result would be, have been recoded, and now output much friendlier messages, informing you what has been done and why. They are now also available to python scripting, not only as a whole, but also their internal operations, so you can precisely order a certain upgrade type to be performed. +

      +

      Facebinder

      +

      A new Draft Facebinder tool has been added, that does a very simple but potentially very useful operation: It gathers any number of selected faces from different objects, and creates a new object from these faces. The new object keeps links to the original objects, so any change in them is reflected in the facebinder object. This should prove useful above all for architectural objects, where you can now construct new objects from the faces of several others. +

      +

      Shape strings

      +

      The Draft ShapeString tool creates planar objects from a text and a truetype font. These objects, unlike common annotations such as the Draft Text, are real 3D objects, can be extruded, and can therefore be used to create engravings and other kinds of 3D objects with text in relief. +

      +

      Bezier Curves

      +

      Alongside the existing arcs of circle and B-spline curves, a new type of curve has just been merged in the Draft module: Bezier curves. They can be created by clicking points, the same way as other Draft objects, but you can then edit them and modify their handle points, gaining a very precise control over the curve shape. +

      +

      Arch

      +

      Structure presets + profiles

      +

      The Arch Structure tool has gained several improvements: it now features presets, which allow you to quickly build a beam or column based on a standard profile such as INP or HEB, and an easier placement system, with a special snapping mode. You can now also give structural elements an extrusion path, so very advanced configurations become possible. Some of the pieces offered by BOLTS can also be created directly as Arch structural elements. +

      +

      Window presets

      +

      The Arch Window tool also gained a new presets system. Although still based on sketches, which ensures maximum flexibility (virtually any window type can be easily created), new windows can now be made from a series of presets. You only need to choose a preset, fill a couple of parameters, and place your window, in an exiting wall or structural element if you wish so. Underneath, an appropriate sketch will be created, which is still editable at any later time. +

      Screenshot arch window.jpg +

      +

      Spaces

      +

      A new Space object is now available, allowing you to build, mark and compute spaces and floor areas. These space objects always encompass a solid volume, so you can always know their volume and floor area. They can be built from a solid shape, or from a set of boundary faces. +

      +

      Multilayer walls

      +

      Walls can now be multilayer, with a very simple trick: Several walls can be based on a same baseline, specifying an offset distance from the baseline. This, combined for example with Arch Frames, allows for example to create complex framed walls, or walls with an insulation layer. Furthermore, these walls are aware of their "brothers" (other walls based on the same baseline), and any window placed on one of these walls will also create a hole on its brothers. +

      Screenshot arch multiwall.jpg +

      +

      Stairs

      +

      A new Stairs tool has also been added, which allows you to build complex stairs from a couple of parameters. Currently only straight stairs are available, but the list will grow over time. These stairs have many configuration parameters, such as the size of the step floor, or the type of their structure. +

      +

      Reinforcing bars

      +

      Reinforcing bars (also called rebars) have been introduced with the Arch Rebar tool. They are also based on sketches, which ensures great flexibility. They are created basically by drawing thr diagrams of the bars on the appropriate faces of structural elements, then turning those diagrams into actual rebars. +

      Screenshot arch rebar.jpg +

      +

      Frames

      +

      Frame systems are used everywhere in architecture: Railings, structural systems, frame walls, etc. The new Arch Frame tool allows to easily create all kinds of frames, by combining a profile object, which can be any flat, extrudable shape, such as a rectangle or a circle, and a layout object, which defines extrusion lines on which the members of the frame object are placed. Layouts are typically drawn with the Sketcher Workbench. These Frame objects can then be turned into walls or structures if needed. +

      +

      Survey

      +

      Another simple but useful tool is now available in the Arch workbench: the Arch Survey mode. In this mode, you click on vertices, edges, faces or whole objects, and get their height, length, area or volume. This information is shown on the model, but also copied to the clipboard, and gathered as text, so it is easy to paste in other applications, giving you a pretty fast workflow when building quantities bills. +

      +

      Tutorial

      +

      A new 35-page tutorial describes the Arch workbench in all its details, following a complete exercise. +

      +

      IFC import & export

      +

      Much work has been done on both FreeCAD and IfcOpenShell, which is the piece of software responsible for handling IFC files in the Arch module. When using a development version of IfcOpenShell, apart from a spectacular gain in speed when importing medium-sized IFC files (around 50Mb), FreeCAD is also able to export models to the IFC format. The support to export is still in first stages of development, but already manages to export files readable without errors by most of the major IFC-supporting applications. +

      +

      Full list

      +

      The full list of bugfixes and new features can be read on http://freecadweb.org/tracker/changelog_page.php +

      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Release_notes_0.15.html b/localwiki/Release_notes_0.15.html new file mode 100644 index 0000000..da7cc30 --- /dev/null +++ b/localwiki/Release_notes_0.15.html @@ -0,0 +1,168 @@ +Release notes 0.15

      Release notes 0.15

      (Redirected from Release notes 0.15)
      + +

      FreeCAD 0.15 was released on April 8, 2015. This is a summary of the most interesting changes. The complete list of changes can be found in the Mantis changelog. Older versions at: 0.14 - 0.13 - 0.12 - 0.11 +


      +Spark-Plug-Plane.jpg +

      +
      Spark Plug Plane by r-frank
      + + +

      General

      +

      Search box in Selection view

      +

      The selection window allow users to search inside the selected objects. Moreover you have now possibilities to select only one entity, unselect an entity, zoom fit on an entity and go to the entity in the tree view. +

      FeatureSelectionView.jpg +

      +

      Units support is spreading

      +

      The new units system of FreeCAD, introduced in version 0.14, is now used by almost all modules of FreeCAD, including the Sketcher, Draft or Arch. A few areas still don't use it, but generally speaking, you can now count on proper units support throughout your whole workflow. +

      +

      Minor enhancements

      +
      • Import/Export now has an own section in the Edit > Preferences section. Now all file formats are grouped into their own tab, which makes it easier for new users to find the right options.
      • +
      • Customized keyboard shortcuts now accept up to 4 keys.
      • +
      • FreeCAD now supports the VR Occulus Rift device.
      • +
      • Support of custom global toolbars: Aside from adding custom toolbars with your own tools to any workbench, it is now also possible to add custom toolbars which will stay present on all workbenches.
      • +
      • New Lib Pack for Windows, with the latest OCE 0.17
      +

      Part Workbench

      +
      • A couple of new geometric elements have been added: Parabola, ArcOfParabola, Hyperbola & ArcOfHyperbola
      +

      Part Design & Sketcher Workbench

      +

      Ellipses

      +

      The Sketcher gained proper support for ellipses. Those can be constructed in different ways, and can be used for any kind of subsequent operation. +

      Ellipse-example.png +

      +

      Enhanced selection tools

      +

      The Sketcher also gained a series of new tools to help you diagnose, optimize or fix problems in your sketches. You can now, for example, easily select the elements associated with a constraint, or select the constraint associated with an element, or find conflicting or redundant constraints. +

      The Sketcher UI also gained some new panels, and now shows you a selectable list of elements of your sketch. +

      +

      Merging sketches

      +

      It is now possible to merge several sketches into one with the click of a button. +

      +

      Enhanced sketch properties

      +

      The properties view of sketch objects has also been enhanced, and named Datum constraints (distance, horizontal distance, vertical distance) inside the sketch will now appear and be editable directly in the properties view of the sketch, without the need to enter edit mode. +

      +

      Minor improvements

      +
      • Added more regular polygons to sketcher
      • +
      • Added new constraint: Symmetry constraint perpendicular to axis of symmetry
      +


      +

      +

      Spreadsheet Workbench

      +

      The Spreadsheet Workbench has been completely recoded. FreeCAD now possesses a state-of-the-art, robust, feature-rich spreadsheet editor. A couple of functionalities found in the previous version of this workbench have been removed, such as the property controllers, but this is a complex issue requiring more time to design properly. At the present time, however, the new spreadsheet already offer far better possibilities to gather data from your model. +

      Spreadsheet screenshot.jpg +

      +

      Draft Workbench

      +

      Allow sticky fonts in ShapeString

      +

      For the nostalgic of old CAD software, sticky fonts (in which letters are made of simple lines, not filled shapes) can now be used with the ShapeString tool. +

      Stickyfonts.jpg +

      +

      Minor improvements

      +
      • Lines can now be defined by their length and angle in the current working plane
      • +
      • Relative extension lines for dimensions
      • +
      • Support for sketcher ellipses
      • +
      • Array objects can now be fused
      +

      Drawing Workbench

      +

      Export drawing pages to DXF

      +

      The system used to export Drawing pages to DXF until now used a very complicated hack to convert the SVG code to FreeCAD object then back to DXF with the Draft exporters. Now, the export is done internally inside the Drawing module, which gives much faster and reliable results. DXF export now uses a template system similar to SVG sheets. If your Drawing page uses a certain SVG template, and a DXF template with the same name is found at the same location, it is used to generate the DXF file. +

      Drawing-dxf-export.jpg +

      In the DXF file, the different views are placed as scaled blocks. This allows to quickly restore the 1:1 scale. +

      +

      Minor improvements

      +
      • It is now possible to reuse projection settings from an existing view when creating new draft views.
      +

      Arch Workbench

      +

      Updated IFC importer/exporter

      +

      FreeCAD's IFC importer has received a lot of work and testing, and a massive upgrade. The old, python-based importer, has been disabled (it is still usable from the python console, though), and FreeCAD now uses exclusively and intensively the newest, bleeding-edge version 5 (read more about it) of IfcOpenShell that is now available on all main platforms (be sure to download the version that matches the python version used by your FreeCAD installation). We now benefit from a much faster and reliable import and export, a much simpler and cleaner code (read: easier to extend), and already a few additional goodies, such as better support for curve-based objects and IFC properties. +

      +

      New feature: Cut object with plane

      +

      This new functionality, Arch CutPlane, makes it possible to cut an object according to a plane defined by the face of another object. It is possible to cut the object behind or in front of the selected plane. +

      Arch CutPlane example.jpg +

      +

      New roof tool

      +

      The Roof tool was completely remade and now makes it possible to define slopes different for each sides from roof, moreover it is possible to define a thickness of roof, the length of the overflow. +

      RoofExample.png +

      +

      Panels

      +

      A new Panel object has been added to the Arch Workbench. It allows to create all kinds of panel-like objects, and will be specially useful for panel constructions such as the wikihouse or popup house projects. +

      Arch Panel example.jpg +

      +

      Furniture

      +

      The new Arch Equipment object is designed to add all kinds of non-structural standalone objects to your architectural projects, such as lighting appliances, sanitary equipments or furniture. +

      +

      Minor enhancements

      +
      • The Basepoint of Arch Frame object can now be set to a specific vertex of the profile.
      +

      External modules

      +

      There has also been some very interesting work on new workbenches and macros, that are not integrated into the FreeCAD source code (yet!), but are easy to install on an existing FreeCAD 0.15 installation. Instructions are provided on the pages linked below: +

      +

      Assembly2

      +

      The Assembly 2 workbench provides tools to create multi-part assemblies, and is a very good alternative for the official Assembly workbench which is still under development (see forum thread). +

      Assembly2 example.jpg +

      +

      Drawing Dimensioning

      +

      The Drawing dimensioning workbench adds powerful dimensioning and annotation tools to the Drawing workbench (see forum thread). +

      Drawing Dimensioning example.jpg +

      +

      Work Features

      +

      The WorkFeature macro adds a wide range of helper objects such as alignment planes or axes, and tools to help you to position and align objects along those helper objects (see forum thread). +

      WF.png +

      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Release_notes_0.16.html b/localwiki/Release_notes_0.16.html new file mode 100644 index 0000000..ea5d83a --- /dev/null +++ b/localwiki/Release_notes_0.16.html @@ -0,0 +1,119 @@ +Release notes 0.16

      Release notes 0.16

      + +

      FreeCAD 0.16 was released on 18. April, 2016, get it from Github. This is a summary of the most interesting changes. The complete list of changes can be found in the Mantis changelog. Older versions at: 0.15 - 0.14 - 0.13 - 0.12 - 0.11
      +

      Satnogs Rotator FreeCAD.jpg +

      +
      Satnogs Rotator (https://satnogs.org/)
      + + +

      Highlights

      +

      Expression support has been introduced, which allows to define formula relationships between properties of objects. Expression support is a major leap forward for making better parametric models in FreeCAD. Expressions offer easy interface for making models controlled by spreadsheets. +

      Expressions-demo.png +

      Sketcher solver behavior has been majorly improved. Not only it became faster and more stable, it also doesn't hang anymore on unsolvable sketches. And automatic document recomputes triggered after each tiny tweak to the sketch can now be switched off, allowing smooth editing of sketches buried under deep dependencies. +

      Sketcher-v0.16-demo.png +

      FreeCAD now supports touchscreen 3D navigation. This makes it possible to use FreeCAD without a mouse on a convertible laptop with touchscreen and pen, away from a desk. +

      The FEM workbench has made tons of improvements. It has proven to be useabele for various kind of mechanical analysises. +

      Multiple material.jpg +

      +

      General

      +
      • Support for expressions/formulas
      • +
      • Three new navigation styles: Gesture Navigation (with touchscreen support on Windows), Maya Navigation, and OpenCascade Navigation.
      • +
      • Customization of workbenches list (list can be reordered, and any workbenches can be made hidden from the list)
      • +
      • Recovery tool
      • +
      • New save options (Revert, save as a copy)
      • +
      • New homepage
      +

      Part Workbench

      +
      • New tools for joining walled objects (e.g., pipes): Connect, Embed and Cutout
      • +
      • New feature: make face from a sketch (parametric)
      +

      Part Design & Sketcher Workbench

      +
      • New Feature: Toggle Mode for Reference/Driving constraints
      • +
      • New Feature: Continuous creation mode
      • +
      • New Feature: Non-driving constraints (aka Driven constraints)
      • +
      • Major speedup
      • +
      • Advanced solver control
      • +
      • New features: tools for duplication, mirroring and rectangular array
      • +
      • Support for expressions/formulas in constraints and properties
      +

      Spreadsheet Workbench

      +
      • Added functions: round, trunc, ceil, and floor.
      +

      Draft Workbench

      +
      • New DXF importer: The Draft Workbench now features a brand-new DXF importer, fully coded in C++, inherited from HeeksCad, which doesn't need anymore to download external components, and is now much faster and able to load much larger DXF files. An option in the DXF preferences allows to switch back to the old importer if needed.
      • +
      • A new Mirror tool allows to do mirroring of objects "the Draft way"
      • +
      • Many DXF templates have been added to the corresponding built-in SVG templates, making the export of Drawing pages to DXF much better.
      • +
      • Rectangles,wires and lines can now be subdivided, allowing all kinds of new shape combinations.
      +


      +Draft subdivisions.jpg +

      +

      Drawing Workbench

      + +

      Drawing spreadsheetview.jpg +

      +

      Arch Workbench

      +
      • Materials support: Arch objects can now have a material attached, which uses FreeCAD's builtin materials framework. These materials are shared among other workbenches. These materials are fully supported by IFC import and export.
      • +
      • The Section plane can now do clipping of the 3D view, showing the section in realtime.
      +

      Arch clip plane.jpg +

      +
      • Several improvements to the IFC importer such as new options for treating large IFC files, better support for extrusions (now detected on import) and curved segments, and support of 2D annotation objects. The import of Analytical IFC has been added. At the moment import of geometrical representations off all analytical objects is supported.
      • +
      • Better meshing options for DAE and IFC formats.
      • +
      • A new Arch Schedule tool allows to create different kinds of schedules from a BIM model.
      • +
      • IFC attributes can now be imported, edited and exported. This is basically a spreadsheet object attached to an Arch object.
      +

      FEM Workbench

      +
      • GUI FEM commands have keyboard short cuts now. A preference dialog for FEM was introduced. The binary path of CalculiX is one of the preference settings.
      • +
      • GUI analysis container Analysis member uses drag & drop. They can be moved in and out of a analysis container. Since there is now support for multiple analysis, member can be moved into another analysis too. Multiple constraints can be created in an analysis.
      • +
      • GUI one click analysis A one click analysis button has been added to the GUI. It does purging results, writing CalculiX input file and does the analysis for the selected solver. It is detected if multithreading is available for CalculiX and uses the maximum possible threads.
      • +
      • Input file FreeCAD's build-in editor supports editing CalculiX input files (*.inp). Syntax highlighting was implemented too.
      • +
      • Netgen mesh object The GUI and property editor of the Netgen mesh object has been reworked. Tetraeder meshing off one order and second order elements is supported as well as adjusting meshing parameter.
      • +
      • Constraint force and constraint fix objects It is now possible to add Forces and Fixes on edges and Vertexes.
      • +
      • Constraint pressure object A new object for pressure load on faces has been added. The pressure (load per area) is passed directly to CalculiX which means the node loads are not calculated by FreeCAD but CalculiX instead.
      • +
      • Constraint prescribed displacement object A new object for prescribed displacements has been added. The prescribed displacement can be added to vertexes, edges and faces. For shell and beam analysis’s it is possible to fix the rotational degrees of freedom.
      • +
      • Beam section object The new beam section object allows to define rectangle cross section for beam FEM. There is support for different beam sections in one analysis by defining reference shapes for each cross section
      • +
      • Shell thickness object The new shell thickness object allows to define thicknesses of shell plates. Like in beam section there is support for multiple shell thicknesses in one analysis by defining reference shapes.
      • +
      • Material object Multiple materials are supported for edge, shell and solid meshes. Like for the beam section and shell thickness objects a appropriate FEM Mesh is needed to use the multiple material.
      • +
      • Solver object As a base for multiple solver a solver object has been implemented. All analysis properties moved from analysis to solver.
      • +
      • Frequency analysis A frequency analysis can be made. The number of eigenvalue or eigenshape to calculate can be adjusted in preference GUI.
      • +
      • View provider Shell and beam FEM-Meshes can be viewed in FreeCAD and thus the results of such analysis too.
      • +
      • Python API Methods for working with FEM-Meshes and making an Analysis from python have been added.
      • +
      • GMSH Macro An interesting external developing is the Macro_GMSH which makes it possible to use GMSH for meshing. Very useful for all not able to compile FreeCAD with Netgen or for meshing shell- or edge meshes.
      • +
      • General Improvements Due to the heavy development taking place, there have been tons of improvements on the code base of FEM module.
      +

      Path Workbench

      +

      Exercise path 02.jpg +

      A new Path Workbench has been added to FreeCAD. This workbench, although still under development, already implements some CAM operations, and allows to export full G-code programs for a variety of CNC machines. +

      In its current state, the workbench allows to create profiles and pockets around Part-based objects, create complex paths by joining several partial paths, inspect and edit the g-code contents of paths, manage tooltable, and choose between different pre-processing and post-processing scripts when importing and exporting G-code. It also already provides a complete python API. +

      +

      Additional Modules

      +

      A couple of new addons workbenches have been created by community members. These workbenches are easily pluggable into an existing FreeCAD installation. Among them are: +

      +
      • An Animation Workbench allows you to create animations from your FreeCAD models, by defining the movement of a camera and exporting a sequence of images.
      • +
      • A Kerkythea exporter macro permits to export your FreeCAD documents to the free Kerkythea renderer.
      • +
      • A work-in-progress Menu is also already available.
      • +
      • Finally, an addons repository has been created to gather all the interesting workbenches, modules and other macros that are flourishing around FreeCAD. This repository features a installer that takes care of the installing and updating of these addons for you.
      +

      Macro installer 02.jpg +

      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Release_notes_0.17.html b/localwiki/Release_notes_0.17.html new file mode 100644 index 0000000..0e00d00 --- /dev/null +++ b/localwiki/Release_notes_0.17.html @@ -0,0 +1,240 @@ +Release notes 0.17

      Release notes 0.17

      + +
      +This release of FreeCAD is dedicated to our friend Roland Frank who left us in 2017. He was an active and well-appreciated member of the FreeCAD forum, and his video tutorials on the Learn FreeCAD and BPLFRE Youtube channels helped many people get started with FreeCAD.
      +

      FreeCAD 0.17 was released on 06 April, 2018, get it from the Download page. This is a summary of the most interesting changes. The complete list of changes can be found in the MantisBT bugtracker FC 0.17 changelog. +

      Older FreeCAD release notes can be found in Getting started. +

      +
      Release017 Title.jpg
      +

      Garden Railway Coach O&K (by FreeCAD-User "Garden Railway Coach O&K", see Users Showcase) +

      + + +

      Highlights

      +

      It's been 2 years since the previous 0.16 release, but the FreeCAD team didn't stay idle during that time. More than 6,800 revisions were added to FreeCAD's source code. For comparison, this is more than three times the work done between v0.16 and 0.15! Most existing workbenches benefited from improvements, and two completely new workbenches were added. New additional modules were also developed by the community. Some of the highlights: +


      +The PartDesign workbench has been completely overhauled. A new Body container now holds a chain of features and lifts the requirement of mapping sketches to planar faces. New tools to create datum (reference) geometry such as points, axes and planes make PartDesign a lot more versatile. +

      +
      PartDesign Body tree.png
      +

      The new Addon manager available from the Tools menu (which was previously available as the addons installer macro) makes installing and updating add-on modules and macros much easier and standardized across Windows, Mac OS X and Linux. +

      +
      Addon manager.png
      +

      The Sketcher now supports B-spline creation with many ways to control curves and display curve information. +

      +
      FC017 Sketcher B-spline 01.png
      +

      The new TechDraw workbench aims to replace the Drawing workbench, and already provides more features than the old Drawing workbench. +TechDraw Workbench Example.png +

      +

      General

      +
      • Yorik van Havre wrote "The FreeCAD Manual" as an introductory book on how to use FreeCAD.
      • +
      • Document recomputes can now be disabled/enabled via the context menu.
      • +
      • There's a new Revit navigation style.
      • +
      • A new Navigation Indicator at the bottom right of the FreeCAD window allows quick access to the navigation styles.
      +

      FC017 Navigation Indicator 01.png FC017 Navigation Indicator 02.png +

      +
      • The dependency graph benefited from graphical enhancements.
      • +
      • STEP import leverages the new Part container and uses it to organize an imported STEP assembly into sub-assemblies, now more closely following the original document's structure. stpZ (a compressed STEP format) is now supported.
      • +
      • Most of FreeCAD's icons were reworked to better comply with Tango guidelines.
      +
      • The FreeCAD project acknowledges the contributions of its community by adding a Credits tab in the About FreeCAD dialog. New License and Libraries tabs list FreeCAD's license and provide info on used third-party libraries.
      +

      AboutFreeCAD Credits.png +

      +

      Arch Workbench

      +
      • New Arch Schedule tool: This tool has been completely rewritten, and offers now a much more flexible way to gather data from the document into a spreadsheet, using different kinds of queries, such as counting all objects of a certain type, or summing up the total volume of a certain category of objects.
      +
      • New set of piping tools to design piping systems. You can use lines, sketches or wires as a base to place tubes, and automatically create connections between 2 or 3 tubes.
      +
      • The Arch Structure tool has now been extended with a series of new presets to build precast concrete elements.
      +
      • During the Google Summer of Code 2017 edition, to which FreeCAD participated, the Arch Rebar tool was greatly extended and gained a friendly User Interface to easily add several standard types of Reinforcement bars to your concrete structures.
      +

      Arch Rebar preview.png +

      +
      • Windows gained several enhancements, such as the possibility to define subcomponents as openable, show opening symbols, appear open, and have louver panels.
      +

      Arch Door preview.png +

      +
      • Arch Axis tools have also been rewritten, and allow more complex systems by combining different series of axes together. They can also be customized to show different kinds of situations such as levels.
      +
      • A new Arch Grid tool allows to easily create spreadsheet-like base objects by stretching, joining or splitting cells. These grid objects can then be used as axes systems, or as bases for complex window or panel arrangements.
      +
      • New Panel tools were specifically designed for panel constructions. They allow to build a model composed of Arch Panels, and then generate cutting sheets that can be used by the Path Workbench to generate cutting machine code.
      +
      • A new Nesting tool (still experimental), allows to compose cut sheets by automatically placing 2D shapes in a containing shape.
      +
      • Multi-materials have been introduced in the Arch workbench. They allow to automatically create multilayer walls, or control the different material of compound objects such as windows.
      +
      • The Arch Workbench OBJ and DAE exporter now support materials, both when importing and exporting.
      +
      • Import support for the 3DS format has been added.
      +

      Draft Workbench

      +
      • Autogroup system: The Draft workbench now features an auto-group button on its main toolbar. When activated, all newly created Draft and Arch objects will automatically be placed in that group.
      +
      • Slope tool: When used on a Draft Line or Draft Wire, this tool will allow you to give it a given slope/inclination. That is, the intermediate and end points will get a lower Z value, so the whole object gets a constant inclination. This is useful to use Lines or Wires as bases for objects that needs a precise inclination, such as roof panes or sewer pipes.
      +
      • Working Plane proxies: When working with Draft working planes, you often need to store working plane locations that you use often. This is now possible by placing one of those proxies in your document. It will remember the current working plane location, and can also restore the current view and/or objects visibility.
      +

      Draft WP preview.png +

      +
      • Draft Stretch: The Draft workbench now has a stretch tool, that allows to move vertices of several Draft objects at once.
      +
      • Draft Label: With this tool, one can place labels in the document, which as composed of a piece of text and a leader line that can be free or stick to a specific object. The text can be made to display a custom piece of text, or automatically display the contents of a property of the target object.
      +

      Draft Label Preview.png +

      +

      FEM Workbench

      +
      • FEM Mesh +
        • Gmsh object is a mesh object, which allows to use Gmesh meshing tool inside FreeCAD. Various options of Gmesh are supported.
        • +
        • Boundary layer object for gmsh makes it possible to create boundary layer.
        • +
        • Mesh group object for gmsh makes it possible to create nodes and element groups. The names can be changed by the user.
        • +
        • Mesh region object for gmsh makes it possible to define mesh regions with different mesh element size for nodes, edges, faces and volumes.
        • +
        • GUI clear mesh tool clears the mesh but keeps all mesh adjustments. This is very handy if files should be shared.
        • +
        • GUI print mesh info tool print all kind of mesh informations.
        • +
        • GUI mesh view provider is able to display quad face mesh as well as hexaeder, pentaeder and pyramid mesh elements.
        • +
        • Mesh data model was updated to SMESH to version 7.7.1 https://github.com/FreeCAD/FreeCAD/commit/666a3e5a
        • +
        • Mesh API was extended to read mesh group data out of the FreeCAD SMESH FEM mesh data by Python. This was the base for the Gmsh group object.
        • +
        • Mesh API was extended to export mesh groups to Abaqus and CalculiX inp file format.
        • +
        • FEM mesh 2 mesh tool converts a surface of a volume mesh into a mesh for FreeCAD's mesh module.
        • +
        • Mesh problems: Non-positive Jacobians are an often seen problem in FEM meshes. Elements which have non-positive Jacobians in CalculiX solver are colored in FreeCAD.
        • +
        • Fenics Import and export of Fenics mesh format has been added.
      +
      • Objects +
        • Beam rotation object enables the analysis of beams rotated around their main axis.
        • +
        • Nonlinear material object adds nonlinear material behavior to FreeCAD FEM. It supports linear change of stress strain curve.
        • +
        • Fluid material ...
        • +
        • Constraint initial flow velocity ...
        • +
        • Constraint fluid boundary
        • +
        • Constraint electrostatic potential ...
        • +
        • Constraint body heat source ...
        • +
        • Constraint transform ...
        • +
        • Constraint temperature ...
        • +
        • Constraint contact ...
        • +
        • Constraint plane rotation ...
        • +
        • Constraint self weight ...
      +
      • Solver +
        • Solver frame work was written from scratch during a Google Summer of Code project.
        • +
        • Support for FEM solver software ElmerFEM, https://www.csc.fi/web/elmer, was added.
        • +
        • Inside the solver frame work the analysis type can be chosen by an equation object (Elmer solver only, ATM.)
        • +
        • Basic support for FEM solver software Z88, https://en.z88.de/z88os/, was added.
        • +
        • CalculiX was ported to the solver frame work. The ccxtools solver object remains in FreeCAD FEM because it is very well tested and has extended pre checks.
      +
      • Calculix analysis +
        • Coupled Thermal Structural Analysis ...
        • +
        • 1D pipe Flow analysis Analysis ...
        • +
        • Coupled Beam Shell Solid models ...
      +
      • Standard Post Processing +
        • Shell and beam 3D output Make it possible to output shell and beam analysis as 3D solid output to see stresses in sections.
        • +
        • Peeq strain Support for equivalent plastic strain has been added to the result object, result reader and vtk post processing.
      +
      • Extended Post Processing +
        • 'VTK An extended post processing based on VTK has been added.
        • +
        • Clip filter ...
        • +
        • Scalar clip filter ...
        • +
        • Cut filter ...
        • +
        • Wrap vector filter ...
        • +
        • Linearized stresses ...
        • +
        • Data at point A tool to get the result data for a specific point.
        • +
        • Data along line A tool to get the result data for a specific line printed as a diagram.
      +
      • Fixes, code and other stuff +
        • The unit tests suite for FEM work bench has been extended.
        • +
        • The code basis has been massively improved.
        • +
        • Most of FEM code has been ported to Python3.
        • +
        • Furthermore there have been tons of bugs found and fixed.
        • +
        • All icons have been nicely redrawn and in conjunction with guidelines.
        • +
        • Code formating There should be no more tabs and white spaces in all FEM source code.
        • +
        • Python codes is according most rules of flake8.
        • +
        • Dozens of typos inside source code have been fixed (AFAIK this applies to all FreeCAD, luzpaz finds all of them like finding a needle in the haystack).
      +
      • Some Pictures
      +

      Bridge-all.png +Bridge-detail.png +

      +

      Part Workbench

      +
      • The Open Cascade geometric modeling kernel was updated from 6.8.0 to 7.2.0 (actual OCC version may depend on platform/distro). This version brings a lot of bug fixes in Boolean operations, hidden line removal algorithm, as well as allowing new features to be added to the Part workbench.
      + +
      • Thanks to the new features above, composite solids (compsolids) can now be created in FreeCAD. They are of great use in FEM.
      +
      • Connect performance and reliability were improved, and the tool was made more versatile.
      +
      • New feature: 2D Offset, to offset planar wires.
      +
      • Enhancement: Part Extrude tool now supports parametric Normal direction, direction controlled by linked edge, reversing, 2nd length, 2nd taper angle, and symmetric. Also, Make Solid checkbox is now checked automatically if you open dialog and the selected object is a closed wire (e.g., a sketch).
      +
      • Enhancement: Part Revolve tool now supports parametric link to revolution axis.
      +
      • The new Part Attachment utility accessible from the Part → Attachment… menu can be used to attach most types of objects to other geometry parametrically.
      +
      • The new Part container can be used to group most types of shapes and to move them as a unit. It also contains standard planes and axes to attach objects to. It will serve as basis for the future Assembly workbench by providing a way to move parts around. It is available in all workbenches from a toolbar along with Group.
      +

      PartDesign workbench

      +

      The PartDesign workbench received massive changes, the fruit of combined efforts from multiple developers over a period of 5 years. +PartDesign017-teaser-motor-core.png +

      +
      • The new Body container holds a chain of of PartDesign features making up a single contiguous solid. It also contains standard planes and axes to attach objects to. Thanks to the Body container, it is no longer necessary to map sketches to faces when adding features. This requirement was a major limitation of the old PartDesign, that could cause many models to break upon parameter changes. So, it is now recommended to avoid mapping sketches to faces whenever possible.
      + +
      • New datum features, which are planes, lines and points useful for placing sketches, alignment, and serving as axes of revolution.
      +
      • New automatic workbench switching between PartDesign and Sketcher. When creating a new sketch from within the PartDesign workbench, once the sketch attachment is set, the UI automatically switches to the Sketcher workbench and its tools in editing mode. When the sketch is closed, the UI switches back to the PartDesign workbench, and restores the view to its previous state. Thus the Sketcher tools were removed from the PartDesign toolbars to liberate space for the new PartDesign features.
      +

      Path Workbench

      +

      The Path workbench has been massively overhauled in version 0.17. The overhaul saw the removal of all older HeeksCNC code and replacement of the libarea python wrapper with the new Path-Area module. As a result operations have gotten much more powerful, faster, with a simplified code base. +

      + + +
      • Path can use Arch Panel as base object to group multiple parts together for 2D cutting.
      +
      • Introduction of Path Job. The job is now a central object of the path workflow. It organizes and coordinates multiple operations, tools, stock material, part orientation and alignment. A customized Job can be saved as a 'Job Template' and re-used to streamline the setup of future jobs. Job SetupSheets provide a mechanism to automate the configuration of depth and speed settings.
      +
      • All operations have a consistent task panel organization
      +
      • New or improved post-processors for LinuxCNC, Smoothieboard, GRBL, Phillips, OpenSBP (shopbot), Roland Modela, Centroid, Fablin, and Dynapath. Most post-processors support arguments.
      + +
      • Path Inspect tool allows highlighting individual commands to visualize path and explore gcode.
      +
      • Path Simulator tool does 3D simulated cutting to visualize Path execution
      + +

      Sketcher Workbench

      +
      • Sketches can now be attached in a wide variety of ways, not only to flat faces as it used to be. Of particular importance is attachment perpendicular to edges, useful for making profiles for sweeping.
      +
      • External geometry links are no longer limited to only the object the sketch is mapped to. Geometry from other sketches is supported. External geometry links can be created within a Part container, or a Body container, or even a whole project if Part and Body containers are not used.
      +
      • Visibility automation: now, when you start editing a sketch, objects depending on it are automatically hidden to unclutter the view, and objects used for external geometry links are automatically shown; old visibilities are restored as you close the sketch.
      +
      • New constraint continuous creation mode: constraint tools are now active even without any element selected. Press a constraint, then select objects to apply the constraint to.
      +
      • New arc of hyperbola and arc of parabola creation tools.
      +
      • New Extend edge editing tool.
      +
      • New B-spline creation tool, with many ways to control curves (degree, knot multiplicity, control point weight) and display information (control polygon, curvature comb, knot multiplicity indicator).
      +

      FC017 Sketcher B-spline 01.png +

      +
      • New Carbon Copy tool to copy geometry from another sketch.
      +
      • Virtual space switches all constraints to a different "virtual space", in effect hiding them from view.
      +
      • Constraints List box includes ability to hide internal alignment, as well as individual hiding of constraints with a checkbox.
      +
      • The Block constraint removes all degrees of freedom for a geometry element in place with the use of a single constraint. It should be particularly useful to work with B-Splines, which are cumbersome to constrain.
      +
      • New Regular polygon with user defined number of sides.
      +
      • Alternative sketch solvers available through Show Advanced Solver Control in Task Bar in Sketcher preferences.
      +
      • Geometry style based rendering order allows reordering between normal, construction and external geometry. Useful when these type of geometry overlap.
      +
      • The solver now automatically substitutes a combination of coincident constraint + tangent constraint with a point-on-point tangent constraint, as the former is an improper use that induces tolerance error that can cause further problems in the model. The user is advised of the substitution by a dialog which can be disabled in Sketcher preferences by unchecking "Notify automatic constraint substitutions".
      +
      • New tick box in edit mode task view "Avoid redundant auto constraints"
      +
      • Horizontal and Vertical constraints can be used to align selected points.
      +

      Spreadsheet Workbench

      +
      • An Excel-file importer was added.
      +

      Surface Workbench

      +
      • A new addition in v0.17, for now the Surface workbench has 4 functioning surface creation commands.
      +

      TechDraw Workbench

      +

      TechDraw is a new workbench for creating technical drawings that aims to replace the aging Drawing workbench. FreeCAD v0.17 is still shipped with the Drawing workbench so you can still open and edit your files containing Drawing pages, but Drawing will be phased out in a future release. Some of the exciting new stuff that TechDraw brings: +

      +
      • Most tools from the Drawing workbench have a TechDraw counterpart.
      • +
      • Easier view creation and manipulation. Views can be grabbed by their border with the mouse and dragged on the page. Orthogonal views alignment can be locked.
      • +
      • Better line type management (hard, smooth, iso, seam). Better hidden line removal thanks to an updated OCC library.
      • +
      • Section view, detail view creation.
      • +
      • Better template management.
      • +
      • Dimensioning is now supported, through multiple dimensioning tools: horizontal, vertical, length, radial, diameter, angular.
      • +
      • Decoration tools: hatching, hatching compatible to Autodesk PAT specification, symbols, images.
      +

      Additional Modules

      +

      Some of the new community modules that were created. +

      +
      • Manipulator Workbench is aimed to help in Aligning, Moving, Rotating and Measuring 3D objects (Part Design allowed) through a friendly GUI.
      +
      • Curves, a collection of tools to create and edit NURBS curves and surfaces.
      +
      • Nurbs, a collection of scripts for managing freeform surfaces and curves.
      +
      • Silk, a collection of NURBS surface modeling tools focused on low degree and seam continuity.
      +
      • Flamingo Workbench, a set of customized FreeCAD commands and objects that help to speed-up the drawing of frames and pipelines.
      + +
      • GDT, geometric dimensioning and tolerancing (GD&T).
      + + +


      +

      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Release_notes_0.18.html b/localwiki/Release_notes_0.18.html new file mode 100644 index 0000000..04ed69a --- /dev/null +++ b/localwiki/Release_notes_0.18.html @@ -0,0 +1,84 @@ +Release notes 0.18

      Release notes 0.18

      + +
      +

      This release of FreeCAD is dedicated to +

      +
      +

      FreeCAD 0.18 was released on DD Month, 201x, get it from the Download page. This is a summary of the most interesting changes. The complete list of changes can be found in the MantisBT bugtracker FC 0.18 changelog. +

      Older FreeCAD release notes can be found in Getting started. +


      +

      + + +

      Highlights

      +

      Description +

      Screenshot 300px +

      Description +

      Screenshot 300px +

      Description +

      Screenshot 300px +

      Description +

      Screenshot 300px +

      +

      General

      +
      • +
      • +
      • +
      • +
      +

      Arch Workbench

      +
      +

      Draft Workbench

      +

      FEM Workbench

      +

      Part Workbench

      +

      PartDesign workbench

      +

      Path Workbench

      +

      Sketcher Workbench

      +

      Spreadsheet Workbench

      +

      Surface Workbench

      +

      TechDraw Workbench

      +

      Additional Modules

      +

      Some of the new community modules that were created. +

      +
      • Manipulator Workbench is aimed to help in Aligning, Moving, Rotating and Measuring 3D objects (Part Design allowed) through a friendly GUI.
      +
      • Curves, a collection of tools to create and edit NURBS curves and surfaces.
      +
      • Nurbs, a collection of scripts for managing freeform surfaces and curves.
      +
      • Silk, a collection of NURBS surface modeling tools focused on low degree and seam continuity.
      +
      • Flamingo Workbench, a set of customized FreeCAD commands and objects that help to speed-up the drawing of frames and pipelines.
      + +
      • GDT, geometric dimensioning and tolerancing (GD&T).
      + + +
      • CadQuery FreeCAD Module is a workbench that allows users to write Python scripts, and is tailored to those based on the CadQuery CAD scripting API. A new code editor is made available, and script variables can be edited dynamically through the use of a parameter dialog. The workbench also adds a menu that includes normal file operations for CadQuery scripts (open, new, close, etc), and example scripts to help users learn new concepts.
      +


      +


      +

      + + +
      + +
      +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Release_notes_011.html b/localwiki/Release_notes_011.html new file mode 100644 index 0000000..53aaa2c --- /dev/null +++ b/localwiki/Release_notes_011.html @@ -0,0 +1,71 @@ +Release notes 011

      Release notes 011

      + +

      This is a summary of the most important changes and new features available in the 0.11 release of FreeCAD. The complete list can be found here. +

      FreeCAD011.png +

      A screenshot of the 0.11 version +

      + + +

      General

      +
      • The FreeCAD translation project has received huge help from many people around the world and FreeCAD now ships with no less than 15 languages: English, German, French, Italian, Swedish, Spanish, Portuguese, Russian, Ukrainian, Norwegian, Afrikaans, Finnish, Simplified Chinese, Croatian and Dutch. And many more languages are being worked on for the next releases.
      +

      Release011-translation.jpg +

      +
      • Several improvements have been brought all over FreeCAD, for example the hierarchy tree now allows complex object stacks, keeping all your geometry history clean and easily accessible and modifiable. New Python API improvements also allow objects to interact better with the tree, defining their own behaviour, icons, etc.
      +

      Release011-dependency.jpg +

      +
      • The copy/paste mechanism has also been much improved, now allowing easy copy/pasting of objects between documents.
      • +
      • The Part Workbench features new tools such as mirroring and edge fillets and chamfers.
      +

      Sketch and part design

      +
      • The constraint solver of the Sketcher Workbench has been totally rewritten and the Sketcher, even if still not complete, features already a good array of tools such as lines, rectangles, and constraints such as point coincidence, parallelism, fixed length or horizontal or vertical constraints.
      +
      • In addition to the Sketcher, a new PartDesign workbench now allow you to quickly build solids on top of Sketches. As a rule now in FreeCAD, everything is parametric, you can go back anytime to change your sketch, and all geometry that depends on it will be adapted automatically
      +

      Release011-sketcher.jpg +

      Movie.png Examples: Sketcher demoPartDesign demo +

      +

      Robot simulation

      +
      • The Robot Workbench has been extended with many GUI tools and is now fairly functional and allows you to easily simulate industrial robot movements
      +

      Release011-robot.jpg +

      +

      2D drafting

      +
      • Snapping has been greatly optimized and now works pretty fast, even on complex objects
      • +
      • The "Trim/Extend" tool can now be called "Trim/Extend/Extrude", since it allows you to quickly extrude single faces, offering a convenient shortcut to the standard Part Extrude tool
      • +
      • The Draft-to-Drawing sheet workflow has also been enhanced, all the Draft workbench objects can now be placed on a Drawing page, and they all offer the same level of comfort as standard Part objects, offering the ability to change their position, rotation and scale on the fly. They also offer some extra features, such as hatch pattern fillings
      +

      Release011-draft-drawing.jpg +

      +
      • The Draft workbench also offers new tools such as regular polygons and bSplines
      • +
      • There is also a new Edit tool, allowing to edit the geometry of most of the Draft objects
      +

      Release011-draft.jpg +

      +
      • Dimensions can now have their text edited and moved, and wires can have an end arrow, allowing to use them as leaders
      • +
      • Several commands such as move, rotate or dimensioning now allow you to do several copies without exiting the tool
      • +
      • The Draft workbench also gained a Python API.
      • +
      • The DXF importer now support block attributes
      +

      Movie.png Examples: Draft module demo +

      +

      Images

      +
      • The image workbench now features an ImagePlane object, allowing you to display an image file inside the 3D scene, that can be used for example to construct geometry on top of scanned blueprints
      +

      Documentation

      +
      • The FreeCAD manual now has several well advanced translations. Check the main page!
      + + + + +
      + +
      +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Release_notes_012.html b/localwiki/Release_notes_012.html new file mode 100644 index 0000000..319aa74 --- /dev/null +++ b/localwiki/Release_notes_012.html @@ -0,0 +1,53 @@ +Release notes 012

      Release notes 012

      + +

      This is a summary of the most interesting changes occured in FreeCAD since latest version. See here for the complete list of changes. +

      Older versions: 0.11 +

      + + +

      Welcome!

      +
      • When you open FreeCAD for the first time, you are now welcomed by a brand new start center, which gathers the most common actions you would want to perform, such as open a particular workbench, load one of the recent files you worked on, read the latest news from the FreeCAD development, or watch one of the many new videos tutorials the heroic FreeCAD community has been making recently.
      +

      FreeCAD start center.jpg +

      +

      Sketcher & PartDesign

      +

      Rim bling.png +

      +
      • The Sketcher has received a huge amount of work since the previous version, and is now based on a new solver designed from scratch for the task. The sketcher is now able to perform almost all 2D drawing operations of the Draft Module, and place a wide array of constraints on the sketch elements.
      +
      • In addition, the PartDesign Workbench has also evolved a lot and offers several common (and totally parametric) tools to work on top of sketches, such as extrusion, lofting or revolution.
      +

      Architecture

      +
      • A new Architecture module is now part of FreeCAD. It is still in early development, but already features a couple of handy helper objects, such as walls and structural elements (columns and beams). Those can be built on top of existing 2D geometry, such as lines, wires and sketches, by specifying a width and a height, or, in case of structural elements, on top of 2D profiles. They can also be based on solids, or even include other solid shapes, as additions or even as subtractions, allowing virtually any possible geometry.
      +

      Arch screenshot.jpg +

      +
      • The Arch module also features an IFC importer, a DAE (collada) importer and exporter, and a special OBJ exporter more suited to architecture models than the standard one.
      +
      • Included in the Arch module is also a growing collection of tools to make the process of working with Mesh objects from other applications such as Blender easier. Mesh objects, if well modeled, can easily and automatically be turned into clean shapes, and then into parametric Arch objects.
      +

      2D Drafting

      +

      Draft taskview.jpg +

      +
      • Reclaim your work space! The Draft module now features a new UI mode that uses the FreeCAD Task system, which gathers all user interaction in one place, redeeming the precious space eaten by the Draft toolbar. To enable this, go to the Draft preferences and enable Taskbar mode.
      +
      • The Draft Trim/Extend tool is now able to extrude single faces of existing objects.
      +
      • Several new snap modes have been added, now allowing to snap perpendicularly and parallel to existing lines, and to locations that are aligned with other line segments.
      +
      • The Draft module also features a new tool that produces, inside the same document, a projected 2D view of any 3D shape.
      +
      • Draft objects can now be drawn directly on top of existing faces. If you didn't specify a working plane, it will be adapted temporarily to the underlying face.
      +
      • The Draft module is now able to import Bézier curves from SVG files.
      + + + + +
      + +
      +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Release_notes_013.html b/localwiki/Release_notes_013.html new file mode 100644 index 0000000..18db022 --- /dev/null +++ b/localwiki/Release_notes_013.html @@ -0,0 +1,140 @@ +Release notes 013

      Release notes 013

      + +

      This is a summary of the most interesting changes occured in FreeCAD since latest version. See the Mantis changelog on SourceForge for the complete list of changes. +

      Older versions: 0.12 - 0.11 +

      FreeCAD013.jpg +

      modeled in FreeCAD by psicofil +


      +

      + + +

      General

      +
      • Color preferences: Getting bored of the good old grey-shapes-on-black-lines FreeCAD default aspect? It is now changeable in the user preferences (Display -> Color), together with several other default colors.
      • +
      • Alignment: two shapes can be aligned to each other with up to three points with this tool available in the Edit menu.
      +

      Drawing module

      +
      • Clip feature: A new Drawing Clip object allows to place views of objects inside clipped rectangles on Drawing pages.
      • +
      • Editable titleblocks: When designing Drawing templates, it is now possible to mark texts as editable. Those texts become then directly editable in FreeCAD.
      • +
      • Annotation feature: A new Drawing Annotation object, a simple feature to quickly place text blocks on a Drawing page.
      • +
      • Orthographic Views: A new Drawing Orthographic Views tool facilitate creation of multiple views all aligned to each other, according to first-angle or third-angle projection.
      • +
      • Browser preview: Since all SVG capabilities are not always supported by the internal Qt SVG viewer, this button allows you to check how a page looks like in the webkit browser, which fully supports the SVG format. This is provisory, until we definitely switch our SVG viewer to webkit...
      • +
      • DXF export: you can now export a view of a page directly to a DXF file.
      • +
      • Some bug fixes now allow printing of pages to scale.
      +

      Sketcher module

      +
      • Point Creation
      +

      Release-0.13-PointTool.png +

      Points can now be added and used as a feature within a sketch +

      +
      • Sketch Origin
      +

      Release-0.13-Origin.png +

      User can now use the sketch's origin to define geometry as well as the sketch axes. +

      +
      • Tangency and perpendicularity constraints for arcs and circles.
      • +
      • Constraints with respect to external (projected) geometry.
      • +
      • Improved counting of the sketch degrees of freedom.
      • +
      • Symmetry constraint with respect to a symmetry point (midpoint constraint).
      +
      • Improved Datum Label and Constraint Visuals:
      +

      Release-0.13-SketcherDimensions.png +

      +
        • Each constraint label (including arrows) will correctly scale to the size of the scene automatically to the 3D viewport
        • +
        • Datum label text for Distance, Distance X, Distance Y and Radius can be freely positioned now with greater control.
        • +
        • Small improvements to overlapping constraint icons and fix freezes.
        • +
        • Datum Label text will reverse when the view is orientated from the opposite side.
      +


      +

      +
      • Fully constrained Sketches are now highlighted:
      +

      The sketch color turns from white to green to indicate it is fully constrained. These default colors can be customized. +


      +

      +
      • Rubber band selection:
      +

      Release-0.13-RubberBandSelection.png +

      Geometry (Points, Lines and Curves) may be selected by dragging on the background to create a rectangular selection. +

      +
      • Extended functionality of the polyline tool: using the m key one can switch between arc and line mode and among free, tangent and perpendicular transitions from the previous segment.
      +
      • Map sketch to face is a new tool to map (or remap) an existing sketch to the selected face on a solid. This allows the use of this sketch for features such as Pad and Pocket.
      +
      • Small Improvements: +
        • When constructing geometry, tool tip with related information is shown next to cursor.
        • +
        • Sketch view which sets the 3D view perpendicular to the sketch plane has now an icon in the Sketcher toolbar.
      +

      Draft module

      +
      • Taskmode: The Taskview mode of the Draft module is now default. Fear not, if you liked the toolbar, it is still available in the Draft preferences settings.
      • +
      • DXF importer: The DXF importer now supports points (translate to Draft Point) and leaders (translate to Draft Wire)
      • +
      • Brand-new snapping system: The snapping system of the Draft module has been rewritten almost from scratch. It is now much easier to extend and use in other scripts and modules, has now new visuals with snap cursor icons, and a toolbar that allows to switch on/off individual snap locations or the whole snapping system.
      +

      013-draft-snap.jpg +

      +
      • Better constraining: When entering 3D points, besides the existing Shift-constraining, you can now constrain the movement in X, Y or Z direction by pressing the X, Y or Z keys. Pressing them again switches constraining off.
      • +
      • Draft <-> Sketch conversion: The Draft workbench now features a new Draft2Sketch conversion tool, that converts selected Draft objects (or any flat shape) to Sketches, and vice-versa.
      • +
      • Clone tool: Make copies of selected objects with this handy tool. When the original changes, the clone gets updated automatically. The clone can be moved, rotated, and also has a scale property that allows you to change the size of the copy.
      • +
      • SVG importer: The SVG importer now has much better support of bezier curves. Global definition of user units is now respected and the geometry is scaled properly to millimeter. Support for new elements such as ellipses rounded rectangles has been added. The parser has been reworked and now handles paths from Adobe Illustrator.
      • +
      • Curved corners: Several Draft objects (Wires, Rectangles and Polygons) now have a Fillet Radius property, which curves their corners by the given radius value.
      +

      013-draft-fillet.jpg +

      +
      • 2D view object: The new Shape2DView tool allows to quickly place a 2D view of a selected object in the document. You can specify the projection vector.
      +

      013-draft-shape2dview.jpg +

      +

      Arch module

      +
      • Draft integration: The Arch and Draft modules are now tightly integrated. The Arch tools use the Draft snapping system, and all the Draft tools are present in the Arch workbench. In fact, if you like, you can now completely switch off the Draft module (Preferences -> Draft -> Hide the Draft workbench)
      • +
      • New wall tool: The wall tool has been greatly enhanced, and now features a direct drawing mode, that is activated when you press the Wall button with no object selected, that allows you to draw walls like you draw simple lines. In additions, walls now auto-connect when you snap to an existing wall.
      +

      013-arch-wall.jpg +

      +
      • New roof tool: A new roof tool is now available in the Arch module, that allows you to quickly create sloped roofs from a selected face.
      • +
      • New window tool: Windows are now created directly on top of a flat shape that contains one or more wires, such as a rectangle or a sketch. If that shape was drawn directly on a wall face, the window will automatically cut an opening in the wall.
      • +
      • New sections system: It is now very simple to create 2D plans, sections and elevations from your model: Place a Section Plane object, orient it the way you want, edit it to include the objects it must see, and you are done!
      • +
      • New solid renderer: In addition to the OpenCasCADe-based wireframe 2D renderer currently used by the Drawing Module, the Arch module now features a new 2D renderer, that is able to render filled faces to a SVG Drawing sheet, giving much nicer 2D views.
      +

      013-arch-vrm.jpg +

      +
      • IFC import with IfcOpenShell: The Arch module can now use IfcOpenShell if it is installed on your system. This allows for much more powerful IFC import, and all the contents of the IFC file are guaranteed to be imported.
      • +
      • New floor and building objects: Building and floors are now groups, so you can add and remove objects from them with a simple drag&drop from the tree view.
      • +
      • New axes system: A new axes system feature has been added, that allows to quickly layout complex axes systems. These axes can then be added to Structure objects, so they spread automatically on the grid nodes.
      +

      013-arch-axes.jpg +

      +
      • Arch objects from meshes: Walls and structures can now be made directly from a mesh, provided it is closed, solid and all edges are manifold. This allows for very quick transformation of geometry imported from other applications such as blender into valid Arch objects.
      +

      Part module

      +
      • Refine shape is a new utility that cleans up faces after a few operations on a shape. It can be set to run automatically after boolean operations in the Preferences.
      • +
      • New Loft tool can extrude a complex set of surfaces or a solid shape through a series of sketches or Draft objects.
      • +
      • New Sweep tool can extrude a complex set of surfaces or a solid shape through a series of sketches or Draft objects and a trajectory (sketch, edge or Draft object).
      • +
      • New Offset tool can offset a single surface or a shape.
      • +
      • New Thickness tool can hollow out a solid shape by setting a wall thickness and opening one or more faces.
      • +
      • Shape Builder and Create primitives are now in the Part toolbar for quick access.
      +

      Part Design module

      +
      • Pad and Pocket are now more powerful thanks to more parameters, such as extrude to first/to last, up to face, 2 dimensions, symmetric to plane.
      • +
      • Chamfer and Fillet got an upgrade: selecting a face is now allowed, all the outer and inner edges of this face will be processed.
      • +
      • Revolution: a construction line can now be used as a revolution axis.
      • +
      • New Groove tool: cut matter from your solid by revolving a sketch.
      • +
      • Linear pattern, Mirrored, Polar pattern and Multipattern tools, that allow you to align and distribute pads and pockets on a feature.
      • +
      • A Shaft Wizard to help you design shaft objects
      +

      Ship Design module

      + +

      3D mice

      +
      • Support for 3D mice (Spaceball, Space Navigator) has been added to the Windows version.
      • +
      • A new Spaceball Motion tab in the Customize dialog allows for fine tuning your 3D mouse to the settings you want, directly from FreeCAD.
      +

      OpenSCAD module

      +
      • This brand new (experimental) module brings OpenSCAD files import capability into FreeCAD. This file format is wildly popular in the RepRap community and on digital designs sharing site Thingiverse.
      • +
      • OpenSCAD script can be executed from within FreeCAD, by OpenSCAD (if installed on your computer), with the result appearing in your FreeCAD document.
      • +
      • For more information see the OpenSCAD Module page on the FreeCAD wiki
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Release_notes_014.html b/localwiki/Release_notes_014.html new file mode 100644 index 0000000..a7c7b58 --- /dev/null +++ b/localwiki/Release_notes_014.html @@ -0,0 +1,247 @@ +Release notes 014

      Release notes 014

      (Redirected from Release notes 014)
      + +

      FreeCAD 0.14 was released on July 1, 2014. This is a summary of the most interesting changes. The complete list of changes can be found in the Mantis changelog. Older versions at: 0.13 - 0.12 - 0.11 +

      Freecad jeep.png +

      +
      Jeep model by Psicofil
      + + +

      General

      +

      Site migration

      +

      We finally moved all the web applications of FreeCAD from SourceForge to our own domain. The new FreeCAD homepage can be found at http://www.freecadweb.org, the wiki is now at http://www.freecadweb.org/wiki, the bug and features tracker at http://www.freecadweb.org/tracker, and the forum at http://forum.freecadweb.org. If you had an account on one of these applications when we were on SourceForge, you can regain your existing user following these instructions. +

      The only part of FreeCAD that remains at SourceForge is the main git repository, at the same address: http://sourceforge.net/p/free-cad/code/ci/master/tree/ but there is also have an automatic mirror of that code set up on github, at http://github.com/FreeCAD/FreeCAD_sf_master +

      If you haven't met the incredible FreeCAD community yet, pay us a visit on the forum, and be amazed by its talent, energy and helpfulness. +

      +

      Move to pyside, FreeCAD is now fully LGPL

      +

      With the many complications caused by the double-license model of FreeCAD (LGPL & GPL), some of the components of FreeCAD (namely the OpenCasCade kernel) being incompatible with GPL code, we decided to switch all the remaining bits of GPL code of FreeCAD to LGPL. As a result of this operation, PyQt is not used anymore, and has been replaced by PySide. There is not much consequence for python scriptwriters, PyQt can still be used inside FreeCAD. +

      After we finished the move to LGPL, OpenCasCade has switched to LGPL too, which would have solved all our license conflicts too. But we have now a much clearer and unified license model, which should satisfy all the strictest linux distributions. +

      +

      Plugins and side projects: Parts library, BOLTS, Eagle importer

      +

      The last year has seen a couple of interesting side projects emerge along FreeCAD. A Parts library has been started by the community and is slowly growing, consisting of a collection of reusable parts to add to your FreeCAD models. It can be launched and used from inside FreeCAD with the use of a macro. +

      Another similar but more ambitious project is BOLTS, which is also a parts library, but built from parametric scripts, able to produce a wide variety of parametric parts. BOLTS, although application-independent, can also be run from FreeCAD by launching a macro. The image below shows BOLTS running inside FreeCAD. +

      Freecad-bearing.png +

      Another interesting external project is the EAGLE importer, which allows you to import PCB board designs made from several applications into FreeCAD. +

      +

      WebGL export

      +

      From FreeCAD, you can now export your scene as a WebGL-enabled html file. This file includes an embedded three.js-based viewer that allows to inspect the scene from the web without any plugin, as long as you view it with a WebGL-capable browser. +

      +

      Units system

      +

      Finally, a units system has been implemented at FreeCAD level, so it is available to all modules. You are now able to choose a units schema from the preferences. Currently available schemas include millimeters, meters and imperial measurements, but more should become available soon. Once this schema is set, most properties and tools of FreeCAD will use this unit preferentially. But the system is very flexible, and in most places, you can mix units as much as you like, for example giving measures in inches in a document set in millimeters. +

      +

      Style Sheets

      +

      FreeCAD 0.14 becomes even more customizable with the addition of Style Sheets being used to control the background image in the main window. No longer is the user stuck with the grey stone background. Almost any image, picture or custom tile may be used to fill the background space in FreeCAD's main Window. +

      Style Sheets.png +

      +

      Display style override

      +

      The default View toolbar has been extended with a couple of new buttons to easily switch the display of the whole 3D view to wireframe, shaded or flat lines mode. +

      +

      3D window anti-aliasing

      +

      New options have been added to the 3D view anti-aliasing system of FreeCAD, that you can find in the preferences. If you have a good 3D graphic chip, you can now enjoy FreeCAD with very high-quality anti-aliasing. +

      +

      Part

      +

      Loft and Sweep

      +

      The Part Loft and Part Sweep tools have been bettered and can now use Draft Workbench objects as profiles +

      +

      Offset

      +

      The new Part Offset tool creates copies of a selected shape at a certain distance from the base shape. +

      +

      Thickness

      +

      A new Part Thickness tool is now available. This tool works on a solid shape, and turns it into a hollow object, by giving each of its faces a given thickness. +

      +

      Make Compound

      +

      The Part Workbench now features a Make Compound tool, which allows you to quickly create a compound object from a set of selected shapes. +

      +

      Part Primitives

      +

      New Part primitives have been added to the Part CreatePrimitives tool: Prisms, regular polygons and spirals are now easy to create by filling out a couple of parameters. Furthermore, some tools from the Draft Workbench can now take advantage of this feature and create these primitives too, instead of their regular Draft object, when the appropriate option is set in the Draft preferences settings. +

      Part Create Primitives1.jpeg +

      +

      Measure tools

      +

      A new measurement toolset has been added to the Part workbench. With it, you can select two shape elements (vertices, edges or faces), and display the distance between the two in absolute distance, and along X and Y axes. +

      +

      PartDesign & Sketcher

      +

      Validate sketch

      +

      The Sketcher now features a new Validate sketch tool to help you to validate a sketch, by finding missing or redundant constraints. It can also automatically add some missing constraints, in order to make your sketch fully constrained. +

      +

      Gear generator

      +

      An involute gear generator tool has been added to the PartDesign workbench, to quickly create such gears from parameters. +

      +

      Drawing

      +

      Automatic projections

      +

      The Drawing Workbench continues to be improved with some exciting new features. Orthographic Projections now allows all views to be displayed as well as much greater control over individual views. Another key feature, Drawing Templates may now contain data defining Border and Title Block locations that will automatically confine Projections within the border while at the same time automatically avoiding the space occupied by the Title Block. +

      DrawingWB.png +

      +

      Symbols

      +

      A new Drawing Symbol tool is available on the Drawing Workbench allowing to quickly place SVG objects on the Drawing sheet. These objects are stored within the FreeCAD file, so you don't need to ship the original SVG file when distributing your files. +

      +

      Raytracing

      +

      New rendering tools

      +

      Raytracing example.jpg +

      The Raytracing workbench has also received some love, and its toolbar has been reworked. The "old" buttons that manually produced partial povray files have been removed (they are still there in the Raytracing menu), and you can now produce a rendering pretty much the same way as you use the Drawing workbench: You create a new project, give it a template, then fill it with views of your objects. When you are done, just hit the render button, or export it to a file that is ready to render outside of FreeCAD. +

      The Raytracing templates system has also been extended, and templates are now easier to manipulate and create. +

      FreeCAD produced .pov scripts now contain auto-aspect ratio. Users no longer need to maintain a 4:3 aspect ratio in their Raytracing settings or need to manually edit the output to change ratios in order to get a proper render. Any width and height may now be entered without fear that the rendered objects will come out squashed or stretched. +

      +

      Luxrender support

      +

      Together with the existing support for POV-Ray, the Raytracing workbench now also supports LuxRender. Where POV-Ray is a classical-style raytracer, that shoots rays from the camera in order to find the color of each pixel of the image, Luxrender is an unbiased renderer, which takes much longer to render scenes, but can produce much more realistic lighting. +

      +

      Spreadsheet

      +

      A new Spreadsheet Workbench has been added to FreeCAD. It allows you to create spreadsheet objects, that contain 2-dimensional spreadsheet data. It also features an editor so you can edit the spreadsheet contents (texts, numbers and some basic formulas are supported), and a special cell controller object, that can scan the document for certain types of objects, extract a certain property from them, and fill a certain range of cells with these values. +

      Arch tutorial 53.jpg +

      +

      Draft

      +

      DWG import/export

      +

      FreeCAD is now able to import and export to the DWG format, thanks to the free, multiplatform Teigha Converter. Once the Teigha Converter is installed, and its path set in the FreeCAD Draft preferences settings, FreeCAD will be able to use it to import and export dwg files, by converting them to dxf, then using the Draft dxf importer and exporter. The import and export of dwg files has therefore the same limitations as the dxf format. +

      +

      Draft to Drawing works with groups

      +

      The Draft to Drawing tool, used to place Draft objects on a Drawing sheet, can now be applied on groups, allowing to create fewer View objects on the Drawing sheet. By intelligently combine your Draft objects into a couple of groups, you have a quick way to control the appearance of many objects on your page. +

      +

      Dimensions recoded

      +

      The Draft Dimension tool has been fully recoded, and dimension objects now behave much better, and have gained a few new properties, allowing to fine-tune them better, such as nicer and scalable arrows, more control over the position of the text and the direction of the dimension, and, above all, better support for the Drawing Module. You can now place dimensions in any plane of the 3D space, and expect correct results when placing them on a Drawing sheet with the Draft Drawing tool. +

      Draft dimensions recode.jpg +

      +

      Hatches

      +

      The Draft workbench also features a new toy: hatching. On specific Draft objects (those that form a closed shape such as closed polylines, rectangles, regular polygons or circles), it is now possible to apply hatching. Currently, only a couple of default hatch patterns are available, but since those patterns are very easy to create (they are simple svg files), and custom patterns can already be added by the user, the default collection might grow quickly. Draft objects with patterns are also faithfully supported by the Drawing workbench. +

      Draft hatches.jpg +

      +

      Ellipses

      +

      Support for ellipses has been added, the Draft workbench now allows you to draw full or portions of ellipses. +

      +

      Chamfer

      +

      In the same fashion as fillets, that had appeared in release 013, Draft rectangles, wires and polygons now gained a chamfer property, which chamfers their angle. The chamfer is applied before the fillet,and both properties can be used together, allowing you to quickly turn a very simple wire into a complex object made of many sections. +

      +

      Upgrade and downgrade recoded

      +

      The Draft Upgrade and Draft Downgrade tools, before hermetic pieces of magic, from which you were never too sure what the result would be, have been recoded, and now output much friendlier messages, informing you what has been done and why. They are now also available to python scripting, not only as a whole, but also their internal operations, so you can precisely order a certain upgrade type to be performed. +

      +

      Facebinder

      +

      A new Draft Facebinder tool has been added, that does a very simple but potentially very useful operation: It gathers any number of selected faces from different objects, and creates a new object from these faces. The new object keeps links to the original objects, so any change in them is reflected in the facebinder object. This should prove useful above all for architectural objects, where you can now construct new objects from the faces of several others. +

      +

      Shape strings

      +

      The Draft ShapeString tool creates planar objects from a text and a truetype font. These objects, unlike common annotations such as the Draft Text, are real 3D objects, can be extruded, and can therefore be used to create engravings and other kinds of 3D objects with text in relief. +

      +

      Bezier Curves

      +

      Alongside the existing arcs of circle and B-spline curves, a new type of curve has just been merged in the Draft module: Bezier curves. They can be created by clicking points, the same way as other Draft objects, but you can then edit them and modify their handle points, gaining a very precise control over the curve shape. +

      +

      Arch

      +

      Structure presets + profiles

      +

      The Arch Structure tool has gained several improvements: it now features presets, which allow you to quickly build a beam or column based on a standard profile such as INP or HEB, and an easier placement system, with a special snapping mode. You can now also give structural elements an extrusion path, so very advanced configurations become possible. Some of the pieces offered by BOLTS can also be created directly as Arch structural elements. +

      +

      Window presets

      +

      The Arch Window tool also gained a new presets system. Although still based on sketches, which ensures maximum flexibility (virtually any window type can be easily created), new windows can now be made from a series of presets. You only need to choose a preset, fill a couple of parameters, and place your window, in an exiting wall or structural element if you wish so. Underneath, an appropriate sketch will be created, which is still editable at any later time. +

      Screenshot arch window.jpg +

      +

      Spaces

      +

      A new Space object is now available, allowing you to build, mark and compute spaces and floor areas. These space objects always encompass a solid volume, so you can always know their volume and floor area. They can be built from a solid shape, or from a set of boundary faces. +

      +

      Multilayer walls

      +

      Walls can now be multilayer, with a very simple trick: Several walls can be based on a same baseline, specifying an offset distance from the baseline. This, combined for example with Arch Frames, allows for example to create complex framed walls, or walls with an insulation layer. Furthermore, these walls are aware of their "brothers" (other walls based on the same baseline), and any window placed on one of these walls will also create a hole on its brothers. +

      Screenshot arch multiwall.jpg +

      +

      Stairs

      +

      A new Stairs tool has also been added, which allows you to build complex stairs from a couple of parameters. Currently only straight stairs are available, but the list will grow over time. These stairs have many configuration parameters, such as the size of the step floor, or the type of their structure. +

      +

      Reinforcing bars

      +

      Reinforcing bars (also called rebars) have been introduced with the Arch Rebar tool. They are also based on sketches, which ensures great flexibility. They are created basically by drawing thr diagrams of the bars on the appropriate faces of structural elements, then turning those diagrams into actual rebars. +

      Screenshot arch rebar.jpg +

      +

      Frames

      +

      Frame systems are used everywhere in architecture: Railings, structural systems, frame walls, etc. The new Arch Frame tool allows to easily create all kinds of frames, by combining a profile object, which can be any flat, extrudable shape, such as a rectangle or a circle, and a layout object, which defines extrusion lines on which the members of the frame object are placed. Layouts are typically drawn with the Sketcher Workbench. These Frame objects can then be turned into walls or structures if needed. +

      +

      Survey

      +

      Another simple but useful tool is now available in the Arch workbench: the Arch Survey mode. In this mode, you click on vertices, edges, faces or whole objects, and get their height, length, area or volume. This information is shown on the model, but also copied to the clipboard, and gathered as text, so it is easy to paste in other applications, giving you a pretty fast workflow when building quantities bills. +

      +

      Tutorial

      +

      A new 35-page tutorial describes the Arch workbench in all its details, following a complete exercise. +

      +

      IFC import & export

      +

      Much work has been done on both FreeCAD and IfcOpenShell, which is the piece of software responsible for handling IFC files in the Arch module. When using a development version of IfcOpenShell, apart from a spectacular gain in speed when importing medium-sized IFC files (around 50Mb), FreeCAD is also able to export models to the IFC format. The support to export is still in first stages of development, but already manages to export files readable without errors by most of the major IFC-supporting applications. +

      +

      Full list

      +

      The full list of bugfixes and new features can be read on http://freecadweb.org/tracker/changelog_page.php +

      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Release_notes_015.html b/localwiki/Release_notes_015.html new file mode 100644 index 0000000..e731e7a --- /dev/null +++ b/localwiki/Release_notes_015.html @@ -0,0 +1,168 @@ +Release notes 015

      Release notes 015

      + +

      FreeCAD 0.15 was released on April 8, 2015. This is a summary of the most interesting changes. The complete list of changes can be found in the Mantis changelog. Older versions at: 0.14 - 0.13 - 0.12 - 0.11 +


      +Spark-Plug-Plane.jpg +

      +
      Spark Plug Plane by r-frank
      + + +

      General

      +

      Search box in Selection view

      +

      The selection window allow users to search inside the selected objects. Moreover you have now possibilities to select only one entity, unselect an entity, zoom fit on an entity and go to the entity in the tree view. +

      FeatureSelectionView.jpg +

      +

      Units support is spreading

      +

      The new units system of FreeCAD, introduced in version 0.14, is now used by almost all modules of FreeCAD, including the Sketcher, Draft or Arch. A few areas still don't use it, but generally speaking, you can now count on proper units support throughout your whole workflow. +

      +

      Minor enhancements

      +
      • Import/Export now has an own section in the Edit > Preferences section. Now all file formats are grouped into their own tab, which makes it easier for new users to find the right options.
      • +
      • Customized keyboard shortcuts now accept up to 4 keys.
      • +
      • FreeCAD now supports the VR Occulus Rift device.
      • +
      • Support of custom global toolbars: Aside from adding custom toolbars with your own tools to any workbench, it is now also possible to add custom toolbars which will stay present on all workbenches.
      • +
      • New Lib Pack for Windows, with the latest OCE 0.17
      +

      Part Workbench

      +
      • A couple of new geometric elements have been added: Parabola, ArcOfParabola, Hyperbola & ArcOfHyperbola
      +

      Part Design & Sketcher Workbench

      +

      Ellipses

      +

      The Sketcher gained proper support for ellipses. Those can be constructed in different ways, and can be used for any kind of subsequent operation. +

      Ellipse-example.png +

      +

      Enhanced selection tools

      +

      The Sketcher also gained a series of new tools to help you diagnose, optimize or fix problems in your sketches. You can now, for example, easily select the elements associated with a constraint, or select the constraint associated with an element, or find conflicting or redundant constraints. +

      The Sketcher UI also gained some new panels, and now shows you a selectable list of elements of your sketch. +

      +

      Merging sketches

      +

      It is now possible to merge several sketches into one with the click of a button. +

      +

      Enhanced sketch properties

      +

      The properties view of sketch objects has also been enhanced, and named Datum constraints (distance, horizontal distance, vertical distance) inside the sketch will now appear and be editable directly in the properties view of the sketch, without the need to enter edit mode. +

      +

      Minor improvements

      +
      • Added more regular polygons to sketcher
      • +
      • Added new constraint: Symmetry constraint perpendicular to axis of symmetry
      +


      +

      +

      Spreadsheet Workbench

      +

      The Spreadsheet Workbench has been completely recoded. FreeCAD now possesses a state-of-the-art, robust, feature-rich spreadsheet editor. A couple of functionalities found in the previous version of this workbench have been removed, such as the property controllers, but this is a complex issue requiring more time to design properly. At the present time, however, the new spreadsheet already offer far better possibilities to gather data from your model. +

      Spreadsheet screenshot.jpg +

      +

      Draft Workbench

      +

      Allow sticky fonts in ShapeString

      +

      For the nostalgic of old CAD software, sticky fonts (in which letters are made of simple lines, not filled shapes) can now be used with the ShapeString tool. +

      Stickyfonts.jpg +

      +

      Minor improvements

      +
      • Lines can now be defined by their length and angle in the current working plane
      • +
      • Relative extension lines for dimensions
      • +
      • Support for sketcher ellipses
      • +
      • Array objects can now be fused
      +

      Drawing Workbench

      +

      Export drawing pages to DXF

      +

      The system used to export Drawing pages to DXF until now used a very complicated hack to convert the SVG code to FreeCAD object then back to DXF with the Draft exporters. Now, the export is done internally inside the Drawing module, which gives much faster and reliable results. DXF export now uses a template system similar to SVG sheets. If your Drawing page uses a certain SVG template, and a DXF template with the same name is found at the same location, it is used to generate the DXF file. +

      Drawing-dxf-export.jpg +

      In the DXF file, the different views are placed as scaled blocks. This allows to quickly restore the 1:1 scale. +

      +

      Minor improvements

      +
      • It is now possible to reuse projection settings from an existing view when creating new draft views.
      +

      Arch Workbench

      +

      Updated IFC importer/exporter

      +

      FreeCAD's IFC importer has received a lot of work and testing, and a massive upgrade. The old, python-based importer, has been disabled (it is still usable from the python console, though), and FreeCAD now uses exclusively and intensively the newest, bleeding-edge version 5 (read more about it) of IfcOpenShell that is now available on all main platforms (be sure to download the version that matches the python version used by your FreeCAD installation). We now benefit from a much faster and reliable import and export, a much simpler and cleaner code (read: easier to extend), and already a few additional goodies, such as better support for curve-based objects and IFC properties. +

      +

      New feature: Cut object with plane

      +

      This new functionality, Arch CutPlane, makes it possible to cut an object according to a plane defined by the face of another object. It is possible to cut the object behind or in front of the selected plane. +

      Arch CutPlane example.jpg +

      +

      New roof tool

      +

      The Roof tool was completely remade and now makes it possible to define slopes different for each sides from roof, moreover it is possible to define a thickness of roof, the length of the overflow. +

      RoofExample.png +

      +

      Panels

      +

      A new Panel object has been added to the Arch Workbench. It allows to create all kinds of panel-like objects, and will be specially useful for panel constructions such as the wikihouse or popup house projects. +

      Arch Panel example.jpg +

      +

      Furniture

      +

      The new Arch Equipment object is designed to add all kinds of non-structural standalone objects to your architectural projects, such as lighting appliances, sanitary equipments or furniture. +

      +

      Minor enhancements

      +
      • The Basepoint of Arch Frame object can now be set to a specific vertex of the profile.
      +

      External modules

      +

      There has also been some very interesting work on new workbenches and macros, that are not integrated into the FreeCAD source code (yet!), but are easy to install on an existing FreeCAD 0.15 installation. Instructions are provided on the pages linked below: +

      +

      Assembly2

      +

      The Assembly 2 workbench provides tools to create multi-part assemblies, and is a very good alternative for the official Assembly workbench which is still under development (see forum thread). +

      Assembly2 example.jpg +

      +

      Drawing Dimensioning

      +

      The Drawing dimensioning workbench adds powerful dimensioning and annotation tools to the Drawing workbench (see forum thread). +

      Drawing Dimensioning example.jpg +

      +

      Work Features

      +

      The WorkFeature macro adds a wide range of helper objects such as alignment planes or axes, and tools to help you to position and align objects along those helper objects (see forum thread). +

      WF.png +

      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Release_notes_016.html b/localwiki/Release_notes_016.html new file mode 100644 index 0000000..2f0a7e3 --- /dev/null +++ b/localwiki/Release_notes_016.html @@ -0,0 +1,119 @@ +Release notes 016

      Release notes 016

      (Redirected from Release notes 016)
      + +

      FreeCAD 0.16 was released on 18. April, 2016, get it from Github. This is a summary of the most interesting changes. The complete list of changes can be found in the Mantis changelog. Older versions at: 0.15 - 0.14 - 0.13 - 0.12 - 0.11
      +

      Satnogs Rotator FreeCAD.jpg +

      +
      Satnogs Rotator (https://satnogs.org/)
      + + +

      Highlights

      +

      Expression support has been introduced, which allows to define formula relationships between properties of objects. Expression support is a major leap forward for making better parametric models in FreeCAD. Expressions offer easy interface for making models controlled by spreadsheets. +

      Expressions-demo.png +

      Sketcher solver behavior has been majorly improved. Not only it became faster and more stable, it also doesn't hang anymore on unsolvable sketches. And automatic document recomputes triggered after each tiny tweak to the sketch can now be switched off, allowing smooth editing of sketches buried under deep dependencies. +

      Sketcher-v0.16-demo.png +

      FreeCAD now supports touchscreen 3D navigation. This makes it possible to use FreeCAD without a mouse on a convertible laptop with touchscreen and pen, away from a desk. +

      The FEM workbench has made tons of improvements. It has proven to be useabele for various kind of mechanical analysises. +

      Multiple material.jpg +

      +

      General

      +
      • Support for expressions/formulas
      • +
      • Three new navigation styles: Gesture Navigation (with touchscreen support on Windows), Maya Navigation, and OpenCascade Navigation.
      • +
      • Customization of workbenches list (list can be reordered, and any workbenches can be made hidden from the list)
      • +
      • Recovery tool
      • +
      • New save options (Revert, save as a copy)
      • +
      • New homepage
      +

      Part Workbench

      +
      • New tools for joining walled objects (e.g., pipes): Connect, Embed and Cutout
      • +
      • New feature: make face from a sketch (parametric)
      +

      Part Design & Sketcher Workbench

      +
      • New Feature: Toggle Mode for Reference/Driving constraints
      • +
      • New Feature: Continuous creation mode
      • +
      • New Feature: Non-driving constraints (aka Driven constraints)
      • +
      • Major speedup
      • +
      • Advanced solver control
      • +
      • New features: tools for duplication, mirroring and rectangular array
      • +
      • Support for expressions/formulas in constraints and properties
      +

      Spreadsheet Workbench

      +
      • Added functions: round, trunc, ceil, and floor.
      +

      Draft Workbench

      +
      • New DXF importer: The Draft Workbench now features a brand-new DXF importer, fully coded in C++, inherited from HeeksCad, which doesn't need anymore to download external components, and is now much faster and able to load much larger DXF files. An option in the DXF preferences allows to switch back to the old importer if needed.
      • +
      • A new Mirror tool allows to do mirroring of objects "the Draft way"
      • +
      • Many DXF templates have been added to the corresponding built-in SVG templates, making the export of Drawing pages to DXF much better.
      • +
      • Rectangles,wires and lines can now be subdivided, allowing all kinds of new shape combinations.
      +


      +Draft subdivisions.jpg +

      +

      Drawing Workbench

      + +

      Drawing spreadsheetview.jpg +

      +

      Arch Workbench

      +
      • Materials support: Arch objects can now have a material attached, which uses FreeCAD's builtin materials framework. These materials are shared among other workbenches. These materials are fully supported by IFC import and export.
      • +
      • The Section plane can now do clipping of the 3D view, showing the section in realtime.
      +

      Arch clip plane.jpg +

      +
      • Several improvements to the IFC importer such as new options for treating large IFC files, better support for extrusions (now detected on import) and curved segments, and support of 2D annotation objects. The import of Analytical IFC has been added. At the moment import of geometrical representations off all analytical objects is supported.
      • +
      • Better meshing options for DAE and IFC formats.
      • +
      • A new Arch Schedule tool allows to create different kinds of schedules from a BIM model.
      • +
      • IFC attributes can now be imported, edited and exported. This is basically a spreadsheet object attached to an Arch object.
      +

      FEM Workbench

      +
      • GUI FEM commands have keyboard short cuts now. A preference dialog for FEM was introduced. The binary path of CalculiX is one of the preference settings.
      • +
      • GUI analysis container Analysis member uses drag & drop. They can be moved in and out of a analysis container. Since there is now support for multiple analysis, member can be moved into another analysis too. Multiple constraints can be created in an analysis.
      • +
      • GUI one click analysis A one click analysis button has been added to the GUI. It does purging results, writing CalculiX input file and does the analysis for the selected solver. It is detected if multithreading is available for CalculiX and uses the maximum possible threads.
      • +
      • Input file FreeCAD's build-in editor supports editing CalculiX input files (*.inp). Syntax highlighting was implemented too.
      • +
      • Netgen mesh object The GUI and property editor of the Netgen mesh object has been reworked. Tetraeder meshing off one order and second order elements is supported as well as adjusting meshing parameter.
      • +
      • Constraint force and constraint fix objects It is now possible to add Forces and Fixes on edges and Vertexes.
      • +
      • Constraint pressure object A new object for pressure load on faces has been added. The pressure (load per area) is passed directly to CalculiX which means the node loads are not calculated by FreeCAD but CalculiX instead.
      • +
      • Constraint prescribed displacement object A new object for prescribed displacements has been added. The prescribed displacement can be added to vertexes, edges and faces. For shell and beam analysis’s it is possible to fix the rotational degrees of freedom.
      • +
      • Beam section object The new beam section object allows to define rectangle cross section for beam FEM. There is support for different beam sections in one analysis by defining reference shapes for each cross section
      • +
      • Shell thickness object The new shell thickness object allows to define thicknesses of shell plates. Like in beam section there is support for multiple shell thicknesses in one analysis by defining reference shapes.
      • +
      • Material object Multiple materials are supported for edge, shell and solid meshes. Like for the beam section and shell thickness objects a appropriate FEM Mesh is needed to use the multiple material.
      • +
      • Solver object As a base for multiple solver a solver object has been implemented. All analysis properties moved from analysis to solver.
      • +
      • Frequency analysis A frequency analysis can be made. The number of eigenvalue or eigenshape to calculate can be adjusted in preference GUI.
      • +
      • View provider Shell and beam FEM-Meshes can be viewed in FreeCAD and thus the results of such analysis too.
      • +
      • Python API Methods for working with FEM-Meshes and making an Analysis from python have been added.
      • +
      • GMSH Macro An interesting external developing is the Macro_GMSH which makes it possible to use GMSH for meshing. Very useful for all not able to compile FreeCAD with Netgen or for meshing shell- or edge meshes.
      • +
      • General Improvements Due to the heavy development taking place, there have been tons of improvements on the code base of FEM module.
      +

      Path Workbench

      +

      Exercise path 02.jpg +

      A new Path Workbench has been added to FreeCAD. This workbench, although still under development, already implements some CAM operations, and allows to export full G-code programs for a variety of CNC machines. +

      In its current state, the workbench allows to create profiles and pockets around Part-based objects, create complex paths by joining several partial paths, inspect and edit the g-code contents of paths, manage tooltable, and choose between different pre-processing and post-processing scripts when importing and exporting G-code. It also already provides a complete python API. +

      +

      Additional Modules

      +

      A couple of new addons workbenches have been created by community members. These workbenches are easily pluggable into an existing FreeCAD installation. Among them are: +

      +
      • An Animation Workbench allows you to create animations from your FreeCAD models, by defining the movement of a camera and exporting a sequence of images.
      • +
      • A Kerkythea exporter macro permits to export your FreeCAD documents to the free Kerkythea renderer.
      • +
      • A work-in-progress Menu is also already available.
      • +
      • Finally, an addons repository has been created to gather all the interesting workbenches, modules and other macros that are flourishing around FreeCAD. This repository features a installer that takes care of the installing and updating of these addons for you.
      +

      Macro installer 02.jpg +

      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Release_process.html b/localwiki/Release_process.html new file mode 100644 index 0000000..8ae8c76 --- /dev/null +++ b/localwiki/Release_process.html @@ -0,0 +1,136 @@ +Release process

      Release process

      + +

      The aim of this page is to gather ideas and organize things so official releases of FreeCAD require less work, and therefore can happen more often. This topic is discussed on this forum thread. +

      + + +

      General ideas

      +
      • The "target release" field of the tracker should be used more, even on bugs that are not assigned to anybody, to mark bugs that we find important to solve before a release, or features we are working on, so others are aware of "how close" we are to release. This appears on the roadmap.
      +
      • We should find a way to process the list below (A "tickable" list somewhere?)
      +

      Planning

      +
      • Ideally official releases should happen each 3 to 6 months
      • +
      • A signal should be emitted (by jriegel?) before the release (3 weeks?) so: +
        • No more new feature gets introduced, only bug fixes
        • +
        • The strings are collected and uploaded to crowdin for translation
        • +
        • The documentation can be fully updated
        • +
        • The release notes can be prepared/finished
      +

      Tasks

      +

      These are the tasks required for each release, with the name of the person responsible for it. Add your name if you want to take care of a task! +

      +
      • jriegel - Giving the signal to the release (3 weeks before?)
      • +
      • yorik - Gathering the strings to translate and uploading them on crowdin
      • +
      • yorik - Announce on the forum and on social networks that translation is needed
      • +
      • yorik - Set the splashscreen
      • +
      • Unassigned - Update years in source files
      • +
      • Unassigned - Update dependencies in README
      • +
      • Unassigned - Change the version number in the FreeCAD code
      • +
      • Unassigned - Check that all workbenches pages on the wiki are up-to-date (all their commands are listed), list missing pages
      • +
      • Unassigned - Manage the updates of the wiki
      • +
      • Unassigned - Manage the release notes
      • +
      • Unassigned - Update ChangeLog.txt
      • +
      • yorik - Merge back the translations from crowdin
      • +
      • Unassigned - Check the german translation
      • +
      • Unassigned - Check the french translation
      • +
      • Unassigned - Check the other translations that have reached 100% (add them here)
      • +
      • Unassigned - Tag the exact release commit in git
      • +
      • Unassigned - Make the windows 32bit build
      • +
      • Unassigned - Make the windows 64bit build
      • +
      • Unassigned - Make the mac build
      • +
      • Unassigned - Make the ubuntu stable build
      • +
      • Unassigned - Check the windows 32bit build
      • +
      • Unassigned - Check the windows 64bit build
      • +
      • Unassigned - Check the mac build
      • +
      • Unassigned - Check the ubuntu build
      • +
      • Unassigned - Communicate the release to package managers of linux distributions (debian, fedora)
      • +
      • yorik - Update the release numbers on the tracker
      • +
      • yorik - Update the release numbers and download locations on the main web page for all languages
      • +
      • yorik - Update the python API doc pages
      • +
      • Unassigned - Official release announcement on the FreeCAD web page
      • +
      • Unassigned - Spread it around. see chapter Publicity
      +

      Publicity

      +

      This is a raw list of sites and blogs that have at some point mentioned FreeCAD. It is mostly harvested from http://forum.freecadweb.org/viewtopic.php?f=8&t=143 (until June 29th 2014). +

      Feel free to add more pages or assign one or more pages to yourself to take care of notifying them about a new release of FreeCAD. +

      +

      Social networks

      + +

      News Sites

      + +

      Other Sites

      + +

      Spanish

      + +

      Blogs

      + +

      French

      + +

      Portugese

      + +

      Spanish

      + +

      Italian

      + +

      Polish

      + +

      Chinese

      + +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/RenderButtons.png b/localwiki/RenderButtons.png new file mode 100644 index 0000000..37aca81 Binary files /dev/null and b/localwiki/RenderButtons.png differ diff --git a/localwiki/RenderTaskView.png b/localwiki/RenderTaskView.png new file mode 100644 index 0000000..be95547 Binary files /dev/null and b/localwiki/RenderTaskView.png differ diff --git a/localwiki/Render_project.html b/localwiki/Render_project.html new file mode 100644 index 0000000..94f07d2 --- /dev/null +++ b/localwiki/Render_project.html @@ -0,0 +1,120 @@ +Render project

      Render project

      + +
      + +

      Render Module

      +

      The render module provides a simple, straightforward way to quickly create rendered work of FreeCAD parts. Its philosophy is based on a template system so you can view your work more efficiently. The Render Module intends to hide the complicated Render Process from the user, so you can worry about designing parts. +


      +The render module is designed to work with multiple render back ends, but currently only LuxRender is supported. The workflow as follows: +

      +
      • Create a Render Feature.
      • +
      • Select your desired presets and templates.
      • +
      • Assign materials to visible parts within your document.
      • +
      • Position your camera
      • +
      • Preview the render
      +


      +A brief explanation of the parts in the Render Module: +

      +

      Render Feature

      +

      The Render Feature contains the information that will be passed to the Render such as camera and render settings, and materials and also what render plugin to use. This means you can create many different features with different materials, camera settings that are independent from each other. The feature also takes control over the rendering process. +

      +

      Render Material

      +

      Each Render Material is based on a Library Material which are stored in separate .XML files. These Render Materials can be assigned properties such as colour or shininess and other parameters. These materials are then attached to an object in the your document. +


      +

      +
      +


      +

      +
      To use the new Render Workbench, currently you must be able to compile from the developer's branch.
      +


      +

      +

      Using the Render Module:

      +

      First checkout the following repository raytracing and checkout the 'render' branch. Then ensure you can build this. +

      Download or install the latest 1.2.1 Lux Render for your system from download and ensure this runs correctly. +

      Open FreeCAD and start the Raytracing workbench. You must next set the 'Executable Path' for Lux Render. This can be set in Edit->Preferences->Raytracing. This must be set to the path of the luxconsole executable. +

      LuxRenderExecPath.png +

      Create your part(s) within FreeCAD. Then return to Raytracing workbench and create a 'Render Feature'. Editing this feature a new Task View will appear: +

      RenderTaskView.png +

      When you create a Render Feature it will store the current position and type of Camera used in your 3D window. You can freely reposition this and click 'Save Camera' to store the current state of the camera into the feature. +

      You can set other render settings: +

      +

      Render Preset

      +

      Render Presets are specific to the render plugin that are used. They change the render process to improve the quality of the output or it the speed that the output is generated. With Lux Render, 'MLT Unbiased' produces good quality results in reasonable time. 'Direct Lighting Preview' produces a fast but low quality result. +


      +

      +

      Render Template

      +

      Render Templates are currently specific to the render plugin. By selecting a template, it will generate a preset scene such as lighting, geometry with your parts inside it. Currently 'Lux Classic' correctly works and produces satisfactory results. It will attempt to calculate the scene based on your camera position and the overall size of visible parts. +

      +

      Start a Render

      +

      Once the feature's settings have been set. You can render the scene. For example this is the example scene. Any parts that are not visible in the document will not be included in the Render. +

      Example.png +

      The 'Preview Window' button will render the current view of the 3D window. The 'Preview' button will use the saved camera position and also the size of the output. Only one preview can be run at a time per feature, but you may run several render feature render processes. +

      RenderButtons.png +

      After starting a render. A new preview view will appear. Depending on the complexity of your scene, this may take a few seconds to be created whilst exported and loaded by the external render program. A loading screen will appear. +

      Loading.png +

      If the render process is successful, the output will be automatically shown. You can freely move the image and zoom in and out. +

      SceneOutput.png +


      +

      +

      Unbiased Rendering

      +

      Essentially the render program will simulate light rays 'bouncing' through a scene. When this light hits a camera it will be visible in the output. Over time more rays hit the camera and an image builds up. At the beginning the image will look noisy where light hasn't reach the camera. +

      When you are happy with the output, press 'Stop Render'. You may now save the output to a desired location (currently stored in a .png format) +

      UnbiasedRendering.png +

      +

      Render Speed

      +

      The render process are typically run on the CPU. The time taken for a satisfactory result, depends on the size of the output, the scene, the number and complexity of materials used, the lights and overall system performance. A quick preview for a simple part can take one minute, whilst a high quality output can taken several hours. +


      +

      +

      Attaching Materials

      +

      Ensure you are currently in edit mode for the Render feature. Click the Add materials in the tool bar. A list of library materials will be shown in the task view.You can scroll through these by dragging the list or using the mousewheel +

      MaterialSelection.png +

      To attach a material to a part in your document. Drag the material icon and drop it onto an part in the 3D view. +

      MaterialDragNDrop.png +

      If the material has editable properties such as colour, a new dialog will appear in the task view. Otherwise the task view return to the Render Feature view. +

      MaterialProperties.png +

      When you're happy setting the properties, click 'Save'. +

      All materials inside a render feature are displayed in the list view. These can be selected and deleted or if the material has a property it can be edited by double clicking this. +

      MaterialListView.png +

      +

      Links

      +

      See also Raytracing tutorial +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Resource_framework_project.html b/localwiki/Resource_framework_project.html new file mode 100644 index 0000000..76605e9 --- /dev/null +++ b/localwiki/Resource_framework_project.html @@ -0,0 +1,130 @@ +Resource framework project

      Resource framework project

      + +

      This is the project plan for the FreeCAD resource framework as part of the Development roadmap. +

      + + +

      Purpose and principles

      +

      This is a software development project aimed to implement Product Data Management (PDM) capabilities. It's about implementing the bits and pieces needed. +

      The development steps are planned here and tracked in the Mantis issue tracking system to get a well formed change log: http://www.freecadweb.org/tracker/change_log.php +

      +

      Outcome

      +
      • Revision control for large design projects.
      • +
      • share work with others over the internet/intranet(s): Collaboration
      • +
      • Online and offline catalogs with standard parts.
      +

      Brainstorming

      +

      What the others do

      +

      Here some links on comparable commercial products: +

      +
      • PTC's PDMLink - "...when all product stakeholders are accessing a single, trusted, central data repository, manufacturers have the power to expertly manage all forms of digital product development data ... PDMLink is the ideal solution. Web-based for easy enterprise-wide access, this industry-proven product data management (PDM) system supports geographically dispersed teams while managing critical processes such as change/configuration management, and detailed design."
      • +
      • Aras Corp. Aras PLM Software - They appear to offer Open Source solutions, this may be worth investigating further...
      +

      Use Cases

      +

      Provided by Charles: +

      Of course there will different sorts of people using this software for different reasons, and they may need different PDM solutions perhaps, but it would be good to investigate solutions that could be universal. I see the following different methods of development (there must be others too): +

      +
      • Individual users - they will probably be a significant percentage of people working this way and they may be fairly self-contained, but revision control and branching still useful. Many of these people may be working in parts of the world where internet access is flaky or expensive, so they maybe working offline for long periods. Would be nice to make these individual projects very easily replicable by other people if it is a good piece of work - so the design can be evolved in multiple directions at once - lots of Darwinian evolution and faster exporing of the solution space
      +
      • Small teams of people working together - perhaps from the same education institution - but each individual may want the freedom to explore all aspects of the project rather than rigidly assigned a particular part of the project. We find it generally allows more options to be easily explored and gives greater flexibility.
      +
      • Wider open-source design projects - more members and geographically dispersed. The mirror of open-source software projects - where there does seem to be a general trend towards distributed systems (in fact Python Moved over to a DVCS last month). I see design and engineering going the same way for the same reasons. So I think there is all the more reason for us to think hard about how a distributed system could work in CAD - and if we solve this will have a big advantage over the commercial CAD vendors! I am convinced there is a solution (if we don't work it out, some other CAD system developer will!)
      +
      • More rigid hierarchical project - there may be some projects where the teams prefer this arrangement but I can only see this as being popular within companies.
      +

      The Blendswap website

      +

      Blendswap - in thier own words - is "...the place to find and share blends with the entire world. You make awesome blends, share them in the biggest repository of open source 3D models made with the awesome Open Source 3D suite Blender." +

      Blender is a very popular open source '3D content creation suite'. +

      Whilst not a CAD program, there are many parallels to be drawn and lessons to be learnt from the way Blender and it's community has gone about doing things. +

      Blendswap is an excellent example of an online repository. It's key features that I beleive we can learn from are: +

      +
      • Provides detailed thumbnail images on the website. This allows people to freely browse and find content quickly.
      • +
      • The models (blend files) come with clear license details (these details are also quicky viewable at a glance from the thumbnail, via a Creative Commons logo).
      +

      Possible revision control systems

      +

      It's only a small step to think of revision control the same way it's used in modern software development. There are basicly two different approaches to that matter: +

      + +

      Although the Use Cases demand a distributed revision control system, all the named has a major drawback. If you clone a repository all the previous versions will replicated to your computer. Which can, in the case of CAD data, be a very large Mb count. In contrast do the server centric systems only check out the head revision and therefore transfer relativly small amount of data. +

      +

      Licensing

      +

      In a distributed internet project its needed that every document carries a clear license. Its even more importand if you think of catalogs. Catalog parts get used in projects (free and non free) and need there fore a clear license to make it usage clear. Since there different licensing systems out there, here a set of possible licenses for CAD files: +

      +

      Creative Commons

      +

      The CC licenses are very popular for creative material, you can find the description here: http://creativecommons.org +

      +

      ISO 16016

      +

      fraganaut01 give us a plug to another licensing system for CAD: +

      +
      • Copyright by Provider (no more restrictions)
      • +
      • Refer to protection notice ISO16016 (no special restriction)
      • +
      • Confidential, for internal use only. Use only with confidentiality obligation. Refer to protection notice ISO16016
      • +
      • Confidential, for internal use only. Refer to protection notice ISO16016
      • +
      • Any dissemination only with the express approval of the originator
      +


      +

      +

      Design

      +

      All the revision controlled data, catalogs, tutorials and so on, have to have some kind of representation in FreeCAD. All this can be summarized under the name Resource. There have to be a class design to hold this kind of resource information and distinguish the different cases. +

      +

      Architecture

      +

      This kine of service is per definition not only local to the user's machine. Its more up in the Cloud and implemented on different services on different servers. There is to distinguish four kind of servers: +

      +
      • Cheap Server - LAMP
      • +
      • Full Server (e.g. Ubuntu/Debian server)
      • +
      • Download server - e.g. sf.net
      • +
      • BitTorrent tracker
      +

      Thad leads to following scenario: +

      ResourceFramework.png +

      +

      Organizing

      +

      Research

      +

      First of all the different alternatives of revision control systems have to be tested. To get hard numbers on how they behave on CAD data. +

      +

      Design

      +

      A class design for the Resource framwork. +


      +

      +

      Next actions

      +
      • Build up test repositories on the Server and two local machines
      • +
      • Test different use cases
      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/ReverseEngineeringWorkbench.svg b/localwiki/ReverseEngineeringWorkbench.svg new file mode 100644 index 0000000..875408b --- /dev/null +++ b/localwiki/ReverseEngineeringWorkbench.svg @@ -0,0 +1,612 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + + + + + + + + + diff --git a/localwiki/Reverse_Engineering_Workbench.html b/localwiki/Reverse_Engineering_Workbench.html new file mode 100644 index 0000000..e6fa645 --- /dev/null +++ b/localwiki/Reverse_Engineering_Workbench.html @@ -0,0 +1,23 @@ +Reverse Engineering Workbench

      Reverse Engineering Workbench

      + +

      The Reverse Engineering Workbench is intended to give you specific tools to convert shapes/solids/meshes into parametric FreeCAD-compatible features. +It is still in development. +

      At the moment there is NO functionality present in this workbench. It is used as a sandbox by the programmers. +

      + +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Right_triangle_sketcher.png b/localwiki/Right_triangle_sketcher.png new file mode 100644 index 0000000..274e76f Binary files /dev/null and b/localwiki/Right_triangle_sketcher.png differ diff --git a/localwiki/Robot.jpg b/localwiki/Robot.jpg new file mode 100644 index 0000000..f3af44b Binary files /dev/null and b/localwiki/Robot.jpg differ diff --git a/localwiki/Robot_6-Axis.html b/localwiki/Robot_6-Axis.html new file mode 100644 index 0000000..92fd8ce --- /dev/null +++ b/localwiki/Robot_6-Axis.html @@ -0,0 +1,608 @@ +Robot 6-Axis

      Robot 6-Axis

      + +
      + + + + + + + + + + + + + + + + + + + + + + + + + + + +
      +

      Base ExampleCommandModel.png Tutorial

      +
      Topic +
      Robot Workbench +
      Level +
      Intermediate +
      Time to complete +
      Unknown +
      Author +
      +
      FreeCAD version +
      +
      Example File(s) +
      +

      + +
      +


      +

      This article is about bringing a standard 6-Axis industry robot into FreeCAD for simulation +

      The description follows the Denavit-Hartenberg Parameter system, as also described in John J. Craigs book "Introduction to Robotics". +

      +

      Example Kuka

      + + + + + +
      The Kuka KR-16 + +
      KukaKR16.jpg + KukaParts.jpg + KukaAxisPosition.jpg +
      +

      Kinematic

      + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
      3D applications +
      Segment + Parameter + Description +
      KukaBase.jpg + + Base konfiguration +
      KukaSegment1.jpg + +

      <math>\theta_{1} = q_{1}</math> +

      <math>d_{1} = 675 mm </math> +

      <math>a_{1} = 260 mm </math> +

      <math>\alpha_{1} = −90</math>° +

      +
      Segment 1 +
      KukaSegment2.jpg + +

      <math>\theta_{2} = q_{2} - 90</math>° +

      <math>d_{2} = 0 mm </math> +

      <math>a_{2} = 680 mm </math> +

      <math>\alpha_{2} = 0</math>° +

      +
      Segment 2 +
      KukaSegment3.jpg + +

      <math>\theta_{3} = q_{3} </math> +

      <math>d_{3} = 0 mm </math> +

      <math>a_{3} = 0 mm </math> +

      <math>\alpha_{3} = 90</math>° +

      +
      Segment 3 +
      KukaSegment4.jpg + +

      <math>\theta_{4} = q_{4} </math> +

      <math>d_{4} = -670 mm </math> +

      <math>a_{4} = 0 mm </math> +

      <math>\alpha_{4} = -90</math>° +

      +
      Segment 4 +
      KukaSegment5.jpg + +

      <math>\theta_{5} = q_{5} </math> +

      <math>d_{5} = 0 mm </math> +

      <math>a_{5} = 0 mm </math> +

      <math>\alpha_{5} = 90</math>° +

      +
      Segment 5 +
      KukaSegment6.jpg + +

      <math>\theta_{6} = q_{6} </math> +

      <math>d_{6} = 0 mm </math> +

      <math>a_{6} = -158 mm </math> +

      <math>\alpha_{6} = 180</math>° +

      +
      Segment 6 +
      +

      This leads to following table: +

      + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
      Kinematik table +
      <math>i</math> <math>\theta</math> <math>d</math> <math>a</math> <math>\alpha</math> +
      1 q1 675 mm 260 mm -90° +
      2 q2 - 90° 0 mm 680 mm 0° +
      3 q3 0 mm 0 mm 90° +
      4 q4 -670 mm 0 mm -90° +
      5 q5 0 mm 0 mm 90° +
      6 q6 -158 mm 0 mm 180° +
      +

      Since the Kuka robots do not have all axis to 0 in the drawn L-Position, we have to change +axis 2 & 3 by 90°. +


      +

      + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
      Kinematik table +
      <math>i</math> <math>\theta</math> <math>d</math> <math>a</math> <math>\alpha</math> +
      1 q1 675 mm 260 mm -90° +
      2 q2 0 mm 680 mm 0° +
      3 q3 - 90° 0 mm 0 mm 90° +
      4 q4 -670 mm 0 mm -90° +
      5 q5 0 mm 0 mm 90° +
      6 q6 -158 mm 0 mm 180° +
      +

      In the data sheet we find additional information about the axis: +

      KukaAxisData.jpg +

      That leads to this complete table: +

      + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
      Kinematik table +
      <math>i</math> <math>\theta</math> <math>d</math> <math>a</math> <math>\alpha</math> <math>\theta_{min}</math> <math>\theta_{max}</math> Axis Speed +
      1 0 675 260 -90 -185 185 156 +
      2 0 0 680 0 -155 35 156 +
      3 - 90 0 0 90 -130 154 156 +
      4 0 -670 0 -90 -350 350 330 +
      5 0 0 0 90 -130 130 330 +
      6 0 -158 0 180 -350 350 615 +
      +

      Visual representation

      +

      FreeCAD can generate a rough visual out of the kinematic table. But if you want closer to reality you can use a VRML file with the robot shape for the simulation. +E.g. Kuka delivers for its model VRML files. +The VRML file gets loaded while the creation of the specific robot in FreeCAD. In order to allow FreeCAD to move the axis we have to edit the VRML file and insert special transformation nodes FreeCAD can find and manipulate. +

      Again shown by the example Kuka KR 16. +Beginning from line 1: +

      +
      #VRML V2.0 utf8
      +#
      +# This VRML97 file was exported using eM-Workplace
      +# (c) Tecnomatix Technologies GmbH & Co. KG
      +#     Heisenberg-Bogen 1
      +#     D-85609 Aschheim-Dornach
      +#     GERMANY
      +#
      +#Background
      +#{
      +#   skyColor   [0.752941 0.752941 0.752941]
      +#}
      +Transform
      +{
      +   #rotation 1 0 0 -1.5707963
      +   #scale .001 .001 .001
      +   children
      +   [
      +           DEF AOBJ_0001_000_TRAFO Transform
      +           {
      +              children
      +              [
      +...
      +
      +

      You see this file is exported with a robot simulation software called Tecnomatix. Remove this notice and put in a URL where you get this file from, because Tecnomatix has no copyright in the file content. It's only a converter! First of all we remove the Background node. Then remove the rotation and scale node to get the model to mm and upright Z. +

      Right at the end: +

      +
        ] }
      +  ] }
      +  ] }
      +  ]
      +}
      +#ROUTE SENS_04_OBJ.rotation_changed TO AXIS_04_OBJ.rotation
      +#ROUTE SENS_27_OBJ.rotation_changed TO AXIS_27_OBJ.rotation
      +#ROUTE SENS_32_OBJ.rotation_changed TO AXIS_32_OBJ.rotation
      +#ROUTE SENS_44_OBJ.rotation_changed TO AXIS_44_OBJ.rotation
      +#ROUTE SENS_46_OBJ.rotation_changed TO AXIS_46_OBJ.rotation
      +#ROUTE SENS_49_OBJ.rotation_changed TO AXIS_49_OBJ.rotation
      +#DEF AnySIMTimer TimeSensor
      +#{
      +#   cycleInterval 1.000000
      +#   loop          TRUE
      +#}
      +
      +

      Comment out the TimeSensor and the 6 routes. This 6 lines give you a hint where the actual axis of the robot are! First search for "AXIS_04_OBJ" that brings you to that place: +

      +
      ...
      +    Transform { rotation 1 0 0 1.570796 children [
      +        DEF SENS_04_OBJ-0001 CylinderSensor
      +        {
      +           diskAngle 1.570796
      +           minAngle  -3.228859
      +           maxAngle  3.228859
      +           offset    0.000000
      +        }
      +      DEF FREECAD_AXIS1 Transform { rotation 0 1 0 0 children [
      +      DEF AXIS_04_OBJ-0001 Transform
      +     {
      +        children
      +        [
      +        Transform { rotation 1 0 0 -1.570796 children [
      +           DEF AOBJ_0001_003_TRAFO Transform
      +           {
      +              rotation 1.000000 0.000000 0.000000 3.141593
      +              translation -600.000000 500.000000 300.000000
      +              children
      +              [
      +...
      +
      +

      You have to insert exactly above the definition of this node the line "DEF FREECAD_AXIS1 Transform { rotation 0 1 0 0 children [" which is the anchor for FreeCAD to move the axis. +

      Now do the same for FREECAD_AXIS2,FREECAD_AXIS3,FREECAD_AXIS4,FREECAD_AXIS5 and FREECAD_AXIS6. +Don't forget the closing brackets at the end of the file and you're done! +

      You can load the VRML by instantiating the robot: +

      +
      App.activeDocument().addObject("Robot::RobotObject","Robot")
      +App.activeDocument().Robot.RobotVrmlFile = "C:/_Projekte/FreeCAD0.9_build/mod/Robot/Lib/Kuka/kr16.wrl"
      +
      +

      which should give you that result: +KukaKR16FreeCAD.jpg +

      +

      KR 210

      +

      Data sheet +

      + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
      Kinematik table +
      <math>i</math> <math>\theta</math> <math>d</math> <math>a</math> <math>\alpha</math> <math>\theta_{min}</math> <math>\theta_{max}</math> Axis Speed +
      1 0 750 350 -90 -185 185 156 +
      2 0 0 1250 0 -155 35 156 +
      3 - 90 0 0 90 -130 154 156 +
      4 0 -1100 0 -90 -350 350 330 +
      5 0 0 0 90 -130 130 330 +
      6 0 -230 0 180 -350 350 615 +
      +


      +

      +

      KR 500

      +

      Data sheet +

      + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
      Kinematik table +
      <math>i</math> <math>\theta</math> <math>d</math> <math>a</math> <math>\alpha</math> <math>\theta_{min}</math> <math>\theta_{max}</math> Axis Speed +
      1 0 1045 500 -90 -185 185 156 +
      2 0 0 1300 0 -155 35 156 +
      3 - 90 0 0 90 -130 154 156 +
      4 0 -1025 0 -90 -350 350 330 +
      5 0 0 0 90 -130 130 330 +
      6 0 -250 0 180 -350 350 615 +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Robot_CreateRobot.html b/localwiki/Robot_CreateRobot.html new file mode 100644 index 0000000..000f51d --- /dev/null +++ b/localwiki/Robot_CreateRobot.html @@ -0,0 +1,94 @@ +Robot CreateRobot

      Robot CreateRobot

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Robot CreateRobot.png Robot CreateRobot

      +
      Menu location +
      Robot → Insert robot +
      Workbenches +
      Robot +
      Default shortcut +
      None +
      See also +
      None +

      + +
      +


      +

      +

      Description

      +

      Insert a new robot (KUKA IR500) into the scene. +

      +

      Usage

      +

      Click on Robot CreateRobot.png to insert a KUKA IR500 robot into the scene. +

      Inserting different/more robots can be done in two ways. +

      +
      • via the top menu
      +
      1. Select Robot Insert Robots from the top menu.
      2. +
      3. Select one of the four pre-defined robots.
      +
      • via the "Tasks"-Tab
      +
      1. Make sure a new document is/was created and activated (activate via double-click on document in tree-view).
      2. +
      3. Switch to the "Tasks"-Tab in the tree view.
      4. +
      5. Select one of the four pre-defined robots.
      +

      Limitations

      +

      [0.15/0.16] +
      +Only robots with up to six axes with rotational movement are definable. +
      +No robots with translational movements possible. +
      +The robot must be defined via code and a vrml-file, for more info refer to Robot 6-Axis. +

      +

      Notes

      +

      The pre-defined robots are +

      +
      • KUKA IR500
      • +
      • KUKA IR210
      • +
      • KUKA IR125
      • +
      • KUKA IR16
      +


      +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Robot_CreateRobot.svg b/localwiki/Robot_CreateRobot.svg new file mode 100644 index 0000000..2f43b6b --- /dev/null +++ b/localwiki/Robot_CreateRobot.svg @@ -0,0 +1,78 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + [wmayer] + + + Robot_CreateRobot + 2011-10-10 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Robot/Gui/Resources/icons/Robot_CreateRobot.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Robot_CreateTrajectory.html b/localwiki/Robot_CreateTrajectory.html new file mode 100644 index 0000000..dae700e --- /dev/null +++ b/localwiki/Robot_CreateTrajectory.html @@ -0,0 +1,78 @@ +Robot CreateTrajectory

      Robot CreateTrajectory

      + +


      +

      + + + + + + + + + + + + + + + + + + + + +
      +

      Robot CreateTrajectory.png Robot CreateTrajectory

      +
      Menu location +
      Robot → Create trajectory +
      Workbenches +
      Robot +
      Default shortcut +
      None +
      See also +
      None +

      + +
      +


      +

      +

      Description

      +

      Inserts a new empty trajectory-object into the scene. +


      +

      +

      Usage

      +

      Click on Robot CreateTrajectory.png or choose RobotRobot CreateTrajectory.png Create trajectory from the top menu. +


      +

      +

      Notes

      +


      +
      +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Robot_CreateTrajectory.svg b/localwiki/Robot_CreateTrajectory.svg new file mode 100644 index 0000000..c294938 --- /dev/null +++ b/localwiki/Robot_CreateTrajectory.svg @@ -0,0 +1,128 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + [wmayer] + + + Robot_CreateTrajectory + 2011-10-10 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Robot/Gui/Resources/icons/Robot_CreateTrajectory.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Robot_Edge2Trac.html b/localwiki/Robot_Edge2Trac.html new file mode 100644 index 0000000..7f9d7a0 --- /dev/null +++ b/localwiki/Robot_Edge2Trac.html @@ -0,0 +1,85 @@ +Robot Edge2Trac

      Robot Edge2Trac

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Robot Edge2Trac.png Robot Edge2Trac

      +
      Menu location +
      Robot → Edge to trajectory +
      Workbenches +
      Robot +
      Default shortcut +
      None +
      See also +
      None +

      + +
      +


      +

      +

      Description

      +

      Insert a new object which decompose edges to a trajectory. +


      +

      +

      Usage

      +
      1. You may select edges of shapes/solids
      2. +
      3. Click on Robot Edge2Trac.png or choose RobotRobot Edge2Trac.png Edge to Trajectory... from the top menu.
      4. +
      5. A menu will pop up on the left side
      +

      Robot Edge2Trac Menu.jpg +

      In the top white box there will be displayed the name of the shape/solid present in the scene. +
      +By selecting edges they will appear with their name in the lowest white box. +
      +By clicking on Apply The entries "Edges" and "Cluster" will turn green and the numbers beside them will show how many elements were recognized. +
      +By clicking on OK you will close this dialog. +


      +

      +

      Notes

      +

      You are able to change values for this trajectory by defining a dress-up-object. +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Robot_Edge2Trac.svg b/localwiki/Robot_Edge2Trac.svg new file mode 100644 index 0000000..fea7b59 --- /dev/null +++ b/localwiki/Robot_Edge2Trac.svg @@ -0,0 +1,108 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + [wmayer] + + + Robot_Edge2Trac + 2011-10-10 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Robot/Gui/Resources/icons/Robot_Edge2Trac.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Robot_Edge2Trac_Menu.jpg b/localwiki/Robot_Edge2Trac_Menu.jpg new file mode 100644 index 0000000..6eab99f Binary files /dev/null and b/localwiki/Robot_Edge2Trac_Menu.jpg differ diff --git a/localwiki/Robot_Export.html b/localwiki/Robot_Export.html new file mode 100644 index 0000000..9bce4c9 --- /dev/null +++ b/localwiki/Robot_Export.html @@ -0,0 +1,84 @@ +Robot Export

      Robot Export

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Robot Export.png Robot Export

      +
      Menu location +
      Robot → Export trajectory +
      Workbenches +
      Robot +
      Default shortcut +
      None +
      See also +
      None +

      + +
      +


      +

      +

      Description

      +

      Export a robot program file. +
      +Export can either be a KUKA compact subroutine or a KUKA full subroutine. +


      +

      +

      Usage

      +
      1. Select robot and trajectory in the tree-view.
      2. +
      3. Choose Robot Export trjectoryRobot Export.png Kuka compact subroutine... from the top menu.
      +

      or +

      +
      1. Select robot and trajectory in the tree-view.
      2. +
      3. Choose Robot Export trjectoryRobot Export.png Kuka full subroutine... from the top menu.
      +

      A KRL file (*.src) will be created. +


      +

      +

      Notes

      +


      +
      +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Robot_Export.svg b/localwiki/Robot_Export.svg new file mode 100644 index 0000000..3c2e7a5 --- /dev/null +++ b/localwiki/Robot_Export.svg @@ -0,0 +1,170 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + [wmayer] + + + Robot_Export + 2011-10-10 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Robot/Gui/Resources/icons/Robot_Export.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Robot_InsertWaypoint.html b/localwiki/Robot_InsertWaypoint.html new file mode 100644 index 0000000..360d526 --- /dev/null +++ b/localwiki/Robot_InsertWaypoint.html @@ -0,0 +1,83 @@ +Robot InsertWaypoint

      Robot InsertWaypoint

      + +


      +


      +

      + + + + + + + + + + + + + + + + + + + + +
      +

      Robot InsertWaypoint.png Robot InsertWaypoint

      +
      Menu location +
      Robot → Insert in trajectory +
      Workbenches +
      Robot +
      Default shortcut +
      A +
      See also +
      --- +

      + +
      +


      +

      +

      Description

      +

      Insert a way-point from the current robot (tool) position into a trajectory. +


      +

      +

      Usage

      +
      1. Select robot and trajectory in the tree-view
      2. +
      3. Click on Robot InsertWaypoint.png or choose RobotRobot InsertWaypoint.png Insert in trajectory from the top menu.
      +


      +

      +

      Notes

      +

      Moving a robot is done by +

      +
      1. Selecting the robot
      2. +
      3. Switch to the "Tasks"-Panel
      4. +
      5. Drag the sliders to move robot
      +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Robot_InsertWaypoint.svg b/localwiki/Robot_InsertWaypoint.svg new file mode 100644 index 0000000..c3bf7fa --- /dev/null +++ b/localwiki/Robot_InsertWaypoint.svg @@ -0,0 +1,144 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + [wmayer] + + + Robot_InsertWaypoint + 2011-10-10 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Robot/Gui/Resources/icons/Robot_InsertWaypoint.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Robot_InsertWaypointPre.html b/localwiki/Robot_InsertWaypointPre.html new file mode 100644 index 0000000..198ad56 --- /dev/null +++ b/localwiki/Robot_InsertWaypointPre.html @@ -0,0 +1,85 @@ +Robot InsertWaypointPre

      Robot InsertWaypointPre

      + +


      +

      + + + + + + + + + + + + + + + + + + + + +
      +

      Robot InsertWaypointPre.png Robot InsertWaypointPre

      +
      Menu location +
      Robot → Insert in trajectory +
      Workbenches +
      Robot +
      Default shortcut +
      W +
      See also +
      --- +

      + +
      +


      +

      +

      Description

      +

      Inserts a waypoint from pre-selected objects into a trajectory. +


      +

      +

      Usage

      +

      Depending on the used navigation style pre-selecting may vary. +
      +For example, when using blender navigation, you can hover with the mouse cursor over an object to highlight (pre-select) it. +
      +Make sure, a trajectory is selected in the tree-view. +
      +Press W to insert this waypoint into the selected trajectory. +


      +

      +

      Notes

      +

      Selectable objects are +

      +
      • corners of solids
      • +
      • points inserted via the draft workbench
      • +
      • endpoints of sketch-elements such as lines, arcs (sketch must be visible)
      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Robot_InsertWaypointPre.svg b/localwiki/Robot_InsertWaypointPre.svg new file mode 100644 index 0000000..b3b2866 --- /dev/null +++ b/localwiki/Robot_InsertWaypointPre.svg @@ -0,0 +1,165 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [wmayer] + + + Robot_InsertWaypointPre + 2011-10-10 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Robot/Gui/Resources/icons/Robot_InsertWaypointPre.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Robot_Module.html b/localwiki/Robot_Module.html new file mode 100644 index 0000000..4ac50c2 --- /dev/null +++ b/localwiki/Robot_Module.html @@ -0,0 +1,201 @@ +Robot Module

      Robot Module

      (Redirected from Robot Module)
      + +
      KukaKR16FreeCAD.jpg
      +

      The robot workbench is a tool to simulate industrial grade Robot 6-Axis, like e.g. Kuka. +You can do the following tasks: +

      +
      • set up a simulation environment with a robot and work pieces
      • +
      • create and fill up trajectories
      • +
      • decompose features of an CAD part to a trajectory
      • +
      • simulate the robot movement and reachability
      • +
      • export the trajectory to a robot program file
      +

      You can find an example here: +Example files or try +the Robot tutorial. +

      + + +

      Tools

      +

      Here the principal commands you can use to create a robot set-up. +

      +

      Robots

      +

      The tools to create and manage the 6-Axis robots +

      + +

      Trajectories

      +

      Tools to create and manipulate trajectories. There are two kinds, the parametric and non parametric ones. +

      +

      non parametric trajectories

      + +

      parametric trajectories

      + +

      Scripting

      +

      This section is generated out of: https://github.com/FreeCAD/FreeCAD_sf_master/blob/master/src/Mod/Robot/RobotExample.py +You can use this file directly if you want. +

      Example how to use the basic robot class Robot6Axis which represents a 6-axis +industrial robot. The Robot module is dependent on Part but not on other modules. +It works mostly with the basic types Placement, Vector and Matrix. So we need +only: +

      +
      from Robot import *
      +from Part import *
      +from FreeCAD import * 
      +

      Basic robot stuff

      +

      create the robot. If you do not specify another kinematic it becomes a Puma 560 +

      +
      rob = Robot6Axis()
      +print rob 
      +

      accessing the axis and the Tcp. Axes go from 1-6 and are in degree: +

      +
      Start = rob.Tcp
      +print Start
      +print rob.Axis1 
      +

      move the first axis of the robot: +

      +
      rob.Axis1 = 5.0 
      +

      the Tcp has changed (forward kinematic) +

      +
      print rob.Tcp 
      +

      move the robot back to start position (reverse kinematic): +

      +
      rob.Tcp = Start
      +print rob.Axis1 
      +

      the same with axis 2: +

      +
      rob.Axis2 = 5.0
      +print rob.Tcp
      +rob.Tcp = Start
      +print rob.Axis2 
      +

      Waypoints: +

      +
      w = Waypoint(Placement(),name="Pt",type="LIN")
      +print w.Name,w.Type,w.Pos,w.Cont,w.Velocity,w.Base,w.Tool 
      +

      generate more. The trajectory always finds automatically a unique name for the waypoints +

      +
      l = [w]
      +for i in range(5):
      +  l.append(Waypoint(Placement(Vector(0,0,i*100),Vector(1,0,0),0),"LIN","Pt")) 
      +

      create a trajectory +

      +
      t = Trajectory(l)
      +print t
      +for i in range(7):
      +  t.insertWaypoints(Waypoint(Placement(Vector(0,0,i*100+500),Vector(1,0,0),0),"LIN","Pt")) 
      +

      see a list of all waypoints: +

      +
      print t.Waypoints
      + 
      +del rob,Start,t,l,w 
      +

      Working with the document objects

      +

      Working with the robot document objects: +first create a robot in the active document +

      +
      if(App.activeDocument() == None):App.newDocument()
      + 
      +App.activeDocument().addObject("Robot::RobotObject","Robot") 
      +

      Define the visual representation and the kinematic definition (see Robot 6-Axis and VRML Preparation for Robot Simulation for details about that) +

      +
      App.activeDocument().Robot.RobotVrmlFile = App.getResourceDir()+"Mod/Robot/Lib/Kuka/kr500_1.wrl"
      +App.activeDocument().Robot.RobotKinematicFile = App.getResourceDir()+"Mod/Robot/Lib/Kuka/kr500_1.csv" 
      +

      start positon of the Axis (only that which differ from 0) +

      +
      App.activeDocument().Robot.Axis2 = -90
      +App.activeDocument().Robot.Axis3 = 90 
      +

      retrieve the Tcp position +

      +
      pos = FreeCAD.getDocument("Unnamed").getObject("Robot").Tcp 
      +

      move the robot +

      +
      pos.move(App.Vector(-10,0,0))
      +FreeCAD.getDocument("Unnamed").getObject("Robot").Tcp = pos 
      +

      create an empty Trajectory object in the active document +

      +
      App.activeDocument().addObject("Robot::TrajectoryObject","Trajectory") 
      +

      get the Trajectory +

      +
      t = App.activeDocument().Trajectory.Trajectory 
      +

      add the actual TCP position of the robot to the trajectory +

      +
      StartTcp = App.activeDocument().Robot.Tcp
      +t.insertWaypoints(StartTcp)
      +App.activeDocument().Trajectory.Trajectory = t
      +print App.activeDocument().Trajectory.Trajectory 
      +

      insert some more Waypoints and the start point at the end again: +

      +
      for i in range(7):
      +  t.insertWaypoints(Waypoint(Placement(Vector(0,1000,i*100+500),Vector(1,0,0),i),"LIN","Pt"))
      +
      +t.insertWaypoints(StartTcp) # end point of the trajectory
      +App.activeDocument().Trajectory.Trajectory = t
      +print App.activeDocument().Trajectory.Trajectory 
      +

      Simulation

      +

      To be done..... +

      +

      Exporting the trajectory

      +

      The trajectory is exported by Python. That means for every control cabinet type there is a post-processor +Python module. Here is in detail the Kuka post-processor described +

      +
      from KukaExporter import ExportCompactSub
      +
      +ExportCompactSub(App.activeDocument().Robot,App.activeDocument().Trajectory,'D:/Temp/TestOut.src') 
      +

      and that's kind of how it's done: +

      +
      for w in App.activeDocument().Trajectory.Trajectory.Waypoints:
      +(A,B,C) = (w.Pos.Rotation.toEuler())
      +print ("LIN {X %.3f,Y %.3f,Z %.3f,A %.3f,B %.3f,C %.3f} ; %s"%(w.Pos.Base.x,w.Pos.Base.y,w.Pos.Base.z,A,B,C,w.Name)) 
      +

      Tutorials

      + +


      +

      + +


      +

      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Robot_RestoreHomePos.html b/localwiki/Robot_RestoreHomePos.html new file mode 100644 index 0000000..3ad5b76 --- /dev/null +++ b/localwiki/Robot_RestoreHomePos.html @@ -0,0 +1,81 @@ +Robot RestoreHomePos

      Robot RestoreHomePos

      + +


      +


      +

      + + + + + + + + + + + + + + + + + + + + +
      +

      Robot RestoreHomePos.png Robot RestoreHomePos

      +
      Menu location +
      Robot → Restore home position +
      Workbenches +
      Robot +
      Default shortcut +
      None +
      See also +
      None +

      + +
      +


      +

      +

      Description

      +

      Lets the selected robot move to its home position. +

      +

      Usage

      +
      1. Select robot in the tree-view or in the 3D-view
      2. +
      3. Click on Robot RestoreHomePos.png or choose RobotRobot RestoreHomePos.png Move to home from the top menu.
      +


      +

      +

      Notes

      +

      Command allows only for one robot to set its home position. +
      +If no or more than one robot is selected you will be promted to coose only one robot. +
      +If no home position has been specified via Robot_SetHomePos the position of the robot as inserted in the scene will be used as home position. +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Robot_RestoreHomePos.svg b/localwiki/Robot_RestoreHomePos.svg new file mode 100644 index 0000000..4fc3b5f --- /dev/null +++ b/localwiki/Robot_RestoreHomePos.svg @@ -0,0 +1,289 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + [wmayer] + + + Robot_RestoreHomePos + 2011-10-10 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Robot/Gui/Resources/icons/Robot_RestoreHomePos.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Robot_SetDefaultOrientation.html b/localwiki/Robot_SetDefaultOrientation.html new file mode 100644 index 0000000..a321475 --- /dev/null +++ b/localwiki/Robot_SetDefaultOrientation.html @@ -0,0 +1,72 @@ +Robot SetDefaultOrientation

      Robot SetDefaultOrientation

      + +
      +

      This documentation is not finished. Please help and contribute documentation. +

      See Draft ShapeString for good documented Command. Gui Command gives an overview over commands. And see List of Commands for other commands. +

      Go to Help FreeCAD to contribute. +

      +
      +


      +

      + + + + + + + + + + + + + + + + + + + + +
      +

      Robot SetDefaultOrientation.png Robot SetDefaultOrientation

      +
      Menu location +
      Robot → Set default orientation +
      Workbenches +
      Robot +
      Default shortcut +
      None +
      See also +
      None +

      + +
      +


      +

      +

      Description

      +

      Usage

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Robot_SetDefaultOrientation.svg b/localwiki/Robot_SetDefaultOrientation.svg new file mode 100644 index 0000000..5252505 --- /dev/null +++ b/localwiki/Robot_SetDefaultOrientation.svg @@ -0,0 +1,129 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + [wmayer] + + + Robot_SetDefaultOrientation + 2011-10-10 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Robot/Gui/Resources/icons/Robot_SetDefaultOrientation.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Robot_SetDefaultValues.html b/localwiki/Robot_SetDefaultValues.html new file mode 100644 index 0000000..3b8a68d --- /dev/null +++ b/localwiki/Robot_SetDefaultValues.html @@ -0,0 +1,86 @@ +Robot SetDefaultValues

      Robot SetDefaultValues

      + +


      +


      +

      + + + + + + + + + + + + + + + + + + + + +
      +

      Robot SetDefaultValues.png Robot SetDefaultValues

      +
      Menu location +
      Robot → Set default values +
      Workbenches +
      Robot +
      Default shortcut +
      None +
      See also +
      None +

      + +
      +


      +

      +

      Description

      +

      Set the default values for way-point creation. +


      +

      +

      Usage

      +

      Choose Robot Set default values from the top menu to define +

      +
      • speed
      • +
      • continous (mode)
      • +
      • acceleration
      +


      +

      +

      Notes

      +

      The program's default values are for +

      +
      • speed = 1 m/s
      • +
      • continous = false
      • +
      • acceleration = 1 m/s^2
      +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Robot_SetDefaultValues.svg b/localwiki/Robot_SetDefaultValues.svg new file mode 100644 index 0000000..34b88a9 --- /dev/null +++ b/localwiki/Robot_SetDefaultValues.svg @@ -0,0 +1,136 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + [wmayer] + + + Robot_SetDefaultValues + 2011-10-10 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Robot/Gui/Resources/icons/Robot_SetDefaultValues.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Robot_SetHomePos.html b/localwiki/Robot_SetHomePos.html new file mode 100644 index 0000000..774cacf --- /dev/null +++ b/localwiki/Robot_SetHomePos.html @@ -0,0 +1,83 @@ +Robot SetHomePos

      Robot SetHomePos

      + +


      +


      +

      + + + + + + + + + + + + + + + + + + + + +
      +

      Robot SetHomePos.png Robot SetHomePos

      +
      Menu location +
      Robot → Set home position +
      Workbenches +
      Robot +
      Default shortcut +
      None +
      See also +
      None +

      + +
      +


      +

      +

      Description

      +

      Sets the current position/orientation of the selected robot as home position. +


      +

      +

      Usage

      +
      1. Select robot in the tree-view or in the 3D-view
      2. +
      3. Click on Robot SetHomePos.png or choose RobotRobot SetHomePos.png Set the home position from the top menu.
      +


      +

      +

      Notes

      +

      Command allows only for one robot to set its home position. +
      +If no or more than one robot is selected you will be promted to choose only one robot. +
      +Initially, the position when the robot is inserted into the scene will be defined as home position. +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Robot_SetHomePos.svg b/localwiki/Robot_SetHomePos.svg new file mode 100644 index 0000000..72cd2d2 --- /dev/null +++ b/localwiki/Robot_SetHomePos.svg @@ -0,0 +1,292 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [wmayer] + + + Robot_SetHomePos + 2011-10-10 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Robot/Gui/Resources/icons/Robot_SetHomePos.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Robot_Simulate.html b/localwiki/Robot_Simulate.html new file mode 100644 index 0000000..9f5c124 --- /dev/null +++ b/localwiki/Robot_Simulate.html @@ -0,0 +1,87 @@ +Robot Simulate

      Robot Simulate

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Robot Simulate.png Robot Simulate

      +
      Menu location +
      Robot → Simulate a trajectory +
      Workbenches +
      Robot +
      Default shortcut +
      None +
      See also +
      None +

      + +
      +


      +

      +

      Description

      +

      Opens the simulation dialog and lets you simulate robot movement along a trajectory. +


      +

      +

      Usage

      +
      1. Select a robot and a trajectory in the tree-view
      2. +
      3. Click on Robot Simulate.png or choose RobotRobot Simulate.png Simulate a trajectory from the top menu.
      +

      This will open up a player menu in the tree-view. +

      Robot Simulation Player.jpg +

      The buttons from left to right. +

      +
      • Move to the first waypoint of the chosen trajectory
      • +
      • Move to previous waypoint
      • +
      • Stop Movement
      • +
      • Start Movement
      • +
      • Move to next waypoint
      • +
      • Move to last waypoint of chosen trajectory
      +


      +

      +

      Notes

      +


      +
      +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Robot_Simulate.svg b/localwiki/Robot_Simulate.svg new file mode 100644 index 0000000..d3e5a8b --- /dev/null +++ b/localwiki/Robot_Simulate.svg @@ -0,0 +1,170 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + [wmayer] + + + Robot_Simulate + 2011-10-10 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Robot/Gui/Resources/icons/Robot_Simulate.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Robot_Simulation_Player.jpg b/localwiki/Robot_Simulation_Player.jpg new file mode 100644 index 0000000..99e263c Binary files /dev/null and b/localwiki/Robot_Simulation_Player.jpg differ diff --git a/localwiki/Robot_TrajectoryCompound.html b/localwiki/Robot_TrajectoryCompound.html new file mode 100644 index 0000000..e5bd0a6 --- /dev/null +++ b/localwiki/Robot_TrajectoryCompound.html @@ -0,0 +1,83 @@ +Robot TrajectoryCompound

      Robot TrajectoryCompound

      + +


      +


      +

      + + + + + + + + + + + + + + + + + + + + +
      +

      Robot TrajectoryCompound.png Robot TrajectoryCompound

      +
      Menu location +
      Robot → TrajectoryCompound +
      Workbenches +
      Robot +
      Default shortcut +
      None +
      See also +
      None +

      + +
      +


      +

      +

      Description

      +

      Creates a compound out of some single trajectories. +


      +

      +

      Usage

      +
      1. Click on Robot TrajectoryCompound.png
      2. +
      3. An empty TrajectoryCompound-object will be created
      4. +
      5. Switch to the "Model"-panel
      6. +
      7. Select Trajectories/Edge2Trac/DressUp-objects in the tree-view
      8. +
      9. Switch back to "Tasks"-panel and click on OK to finish selection
      +


      +

      +

      Notes

      +


      +
      +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Robot_TrajectoryCompound.svg b/localwiki/Robot_TrajectoryCompound.svg new file mode 100644 index 0000000..0a2571e --- /dev/null +++ b/localwiki/Robot_TrajectoryCompound.svg @@ -0,0 +1,103 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + [wmayer] + + + Robot_TrajectoryCompound + 2011-10-10 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Robot/Gui/Resources/icons/Robot_TrajectoryCompound.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Robot_TrajectoryDressUp.html b/localwiki/Robot_TrajectoryDressUp.html new file mode 100644 index 0000000..542dce2 --- /dev/null +++ b/localwiki/Robot_TrajectoryDressUp.html @@ -0,0 +1,79 @@ +Robot TrajectoryDressUp

      Robot TrajectoryDressUp

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Robot TrajectoryDressUp.png Robot TrajectoryDressUp

      +
      Menu location +
      Robot → TrajectoryDressUp +
      Workbenches +
      Robot +
      Default shortcut +
      None +
      See also +
      None +

      + +
      +


      +

      +

      Description

      +

      Lets you override one or more properties of a trajectory. +


      +

      +

      Usage

      +
      1. Select trajectory or Edge2Trac-trajectory to be dressed up in the tree-view
      2. +
      3. Click on Robot TrajectoryDressUp.png or change to "Tasks"-panel and click on Robot TrajectoryDressUp.png Dress-up trajectory
      +

      You are then able to change values for +

      +
      • speed
      • +
      • acceleration
      • +
      • continous mode
      • +
      • position and orientation
      +


      +

      +

      Notes

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Robot_TrajectoryDressUp.svg b/localwiki/Robot_TrajectoryDressUp.svg new file mode 100644 index 0000000..26cb975 --- /dev/null +++ b/localwiki/Robot_TrajectoryDressUp.svg @@ -0,0 +1,104 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [wmayer] + + + Robot_TrajectoryDressUp + 2011-10-10 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Robot/Gui/Resources/icons/Robot_TrajectoryDressUp.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Robot_Tutorial_RobotSimulation.gif b/localwiki/Robot_Tutorial_RobotSimulation.gif new file mode 100644 index 0000000..f3a66b7 Binary files /dev/null and b/localwiki/Robot_Tutorial_RobotSimulation.gif differ diff --git a/localwiki/Robot_Workbench.html b/localwiki/Robot_Workbench.html new file mode 100644 index 0000000..909e9c8 --- /dev/null +++ b/localwiki/Robot_Workbench.html @@ -0,0 +1,201 @@ +Robot Workbench

      Robot Workbench

      + +
      KukaKR16FreeCAD.jpg
      +

      The robot workbench is a tool to simulate industrial grade Robot 6-Axis, like e.g. Kuka. +You can do the following tasks: +

      +
      • set up a simulation environment with a robot and work pieces
      • +
      • create and fill up trajectories
      • +
      • decompose features of an CAD part to a trajectory
      • +
      • simulate the robot movement and reachability
      • +
      • export the trajectory to a robot program file
      +

      You can find an example here: +Example files or try +the Robot tutorial. +

      + + +

      Tools

      +

      Here the principal commands you can use to create a robot set-up. +

      +

      Robots

      +

      The tools to create and manage the 6-Axis robots +

      + +

      Trajectories

      +

      Tools to create and manipulate trajectories. There are two kinds, the parametric and non parametric ones. +

      +

      non parametric trajectories

      + +

      parametric trajectories

      + +

      Scripting

      +

      This section is generated out of: https://github.com/FreeCAD/FreeCAD_sf_master/blob/master/src/Mod/Robot/RobotExample.py +You can use this file directly if you want. +

      Example how to use the basic robot class Robot6Axis which represents a 6-axis +industrial robot. The Robot module is dependent on Part but not on other modules. +It works mostly with the basic types Placement, Vector and Matrix. So we need +only: +

      +
      from Robot import *
      +from Part import *
      +from FreeCAD import * 
      +

      Basic robot stuff

      +

      create the robot. If you do not specify another kinematic it becomes a Puma 560 +

      +
      rob = Robot6Axis()
      +print rob 
      +

      accessing the axis and the Tcp. Axes go from 1-6 and are in degree: +

      +
      Start = rob.Tcp
      +print Start
      +print rob.Axis1 
      +

      move the first axis of the robot: +

      +
      rob.Axis1 = 5.0 
      +

      the Tcp has changed (forward kinematic) +

      +
      print rob.Tcp 
      +

      move the robot back to start position (reverse kinematic): +

      +
      rob.Tcp = Start
      +print rob.Axis1 
      +

      the same with axis 2: +

      +
      rob.Axis2 = 5.0
      +print rob.Tcp
      +rob.Tcp = Start
      +print rob.Axis2 
      +

      Waypoints: +

      +
      w = Waypoint(Placement(),name="Pt",type="LIN")
      +print w.Name,w.Type,w.Pos,w.Cont,w.Velocity,w.Base,w.Tool 
      +

      generate more. The trajectory always finds automatically a unique name for the waypoints +

      +
      l = [w]
      +for i in range(5):
      +  l.append(Waypoint(Placement(Vector(0,0,i*100),Vector(1,0,0),0),"LIN","Pt")) 
      +

      create a trajectory +

      +
      t = Trajectory(l)
      +print t
      +for i in range(7):
      +  t.insertWaypoints(Waypoint(Placement(Vector(0,0,i*100+500),Vector(1,0,0),0),"LIN","Pt")) 
      +

      see a list of all waypoints: +

      +
      print t.Waypoints
      + 
      +del rob,Start,t,l,w 
      +

      Working with the document objects

      +

      Working with the robot document objects: +first create a robot in the active document +

      +
      if(App.activeDocument() == None):App.newDocument()
      + 
      +App.activeDocument().addObject("Robot::RobotObject","Robot") 
      +

      Define the visual representation and the kinematic definition (see Robot 6-Axis and VRML Preparation for Robot Simulation for details about that) +

      +
      App.activeDocument().Robot.RobotVrmlFile = App.getResourceDir()+"Mod/Robot/Lib/Kuka/kr500_1.wrl"
      +App.activeDocument().Robot.RobotKinematicFile = App.getResourceDir()+"Mod/Robot/Lib/Kuka/kr500_1.csv" 
      +

      start positon of the Axis (only that which differ from 0) +

      +
      App.activeDocument().Robot.Axis2 = -90
      +App.activeDocument().Robot.Axis3 = 90 
      +

      retrieve the Tcp position +

      +
      pos = FreeCAD.getDocument("Unnamed").getObject("Robot").Tcp 
      +

      move the robot +

      +
      pos.move(App.Vector(-10,0,0))
      +FreeCAD.getDocument("Unnamed").getObject("Robot").Tcp = pos 
      +

      create an empty Trajectory object in the active document +

      +
      App.activeDocument().addObject("Robot::TrajectoryObject","Trajectory") 
      +

      get the Trajectory +

      +
      t = App.activeDocument().Trajectory.Trajectory 
      +

      add the actual TCP position of the robot to the trajectory +

      +
      StartTcp = App.activeDocument().Robot.Tcp
      +t.insertWaypoints(StartTcp)
      +App.activeDocument().Trajectory.Trajectory = t
      +print App.activeDocument().Trajectory.Trajectory 
      +

      insert some more Waypoints and the start point at the end again: +

      +
      for i in range(7):
      +  t.insertWaypoints(Waypoint(Placement(Vector(0,1000,i*100+500),Vector(1,0,0),i),"LIN","Pt"))
      +
      +t.insertWaypoints(StartTcp) # end point of the trajectory
      +App.activeDocument().Trajectory.Trajectory = t
      +print App.activeDocument().Trajectory.Trajectory 
      +

      Simulation

      +

      To be done..... +

      +

      Exporting the trajectory

      +

      The trajectory is exported by Python. That means for every control cabinet type there is a post-processor +Python module. Here is in detail the Kuka post-processor described +

      +
      from KukaExporter import ExportCompactSub
      +
      +ExportCompactSub(App.activeDocument().Robot,App.activeDocument().Trajectory,'D:/Temp/TestOut.src') 
      +

      and that's kind of how it's done: +

      +
      for w in App.activeDocument().Trajectory.Trajectory.Waypoints:
      +(A,B,C) = (w.Pos.Rotation.toEuler())
      +print ("LIN {X %.3f,Y %.3f,Z %.3f,A %.3f,B %.3f,C %.3f} ; %s"%(w.Pos.Base.x,w.Pos.Base.y,w.Pos.Base.z,A,B,C,w.Name)) 
      +

      Tutorials

      + +


      +

      + +


      +

      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Robot_Workbench.svg b/localwiki/Robot_Workbench.svg new file mode 100644 index 0000000..0869197 --- /dev/null +++ b/localwiki/Robot_Workbench.svg @@ -0,0 +1,90 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [triplus] + + + RobotWorkbench + 2016-02-26 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Robot/Gui/Resources/icons/RobotWorkbench.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Robot_project.html b/localwiki/Robot_project.html new file mode 100644 index 0000000..0fdc30f --- /dev/null +++ b/localwiki/Robot_project.html @@ -0,0 +1,78 @@ +Robot project

      Robot project

      + +

      This is the project article for the Robot project. It follows the rules of the Getting things done process. The projects are collected in the Development roadmap. +

      + + +

      Purpose and principles

      +

      This project should lay down the principal technologies for a realistic robot simulation in FreeCAD. In the first step +it targets the standard 6-axis industrial robot. +

      +

      Outcome

      +

      Robot simulation +

      Robot.jpg +

      +

      Brainstorming

      +

      Libs in field

      +
      • OROCOSlibs for inverse kinematic
      • +
      • ROBOOP targets directly to robot simulation, but seems inactive.
      • +
      • Beremiz a OpenSource PLC.
      +

      Standards for communication

      +
      • OPC UA to communicate with PLCs
      • +
      • RRS-II German standard for robot simulation communication
      +

      Middleware for comunication

      + +

      Commercial products in that field

      + +

      Knowledge

      + +

      Organizing

      +
      • Visual representation of 6-Axis robots (done)
      • +
      • Forward and inverse kinematic calculation of arbitrary robots (done)
      • +
      • RobotLib, dynamic readably robot types (work in progress)
      • +
      • Trajectory simulation (work in progress) +
        • collision simulation
        • +
        • detection of configuration changes and singularities
        • +
        • time estimation
        • +
        • used volume (planed)
      • +
      • Post processor for Kuka robots (work in progress)
      • +
      • Process and work cell control (planed)
      • +
      • Movie making out of simulation (planed)
      +

      Next actions

      +
      • Trajectory and Waypoint management.
      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Robot_tutorial.html b/localwiki/Robot_tutorial.html new file mode 100644 index 0000000..528f4a5 --- /dev/null +++ b/localwiki/Robot_tutorial.html @@ -0,0 +1,106 @@ +Robot tutorial

      Robot tutorial

      + +
      + + + + + + + + + + + + + + + + + + + + + + + + + + + +
      +

      Base ExampleCommandModel.png Tutorial

      +
      Topic +
      Robot Workbench +
      Level +
      Beginner +
      Time to complete +
      +
      Author +
      r-frank +
      FreeCAD version +
      0.16.6703 +
      Example File(s) +
      +

      + +
      +


      +

      This tutorial is here to teach you how to use the Robot Workbench to simulate a robot cell set-up. +

      +

      Before you begin

      +

      This tutorial is written for FreeCAD Version 0.16.6703 or higher. So if you don't have FreeCAD on your +computer go to the Download page and do the installation. +

      This tutorial is targeting on the use of industrial robots +and not mobile or service robots (see here). +

      +

      Setting up the scene

      +
      1. Switch to the Robot Workbench
      2. +
      3. Create a new document by choosing File New from the top menu
      4. +
      5. Insert a Kuka IR500 robot into the scene by choosing Robot Insert Robots Kuka IR500 from the top menu
      6. +
      7. Change to axonometric view by clicking on View-axometric.png
      8. +
      9. Zoom to fit all by clicking on View-zoom-all.png
      10. +
      11. Save your file ...
      +

      Setting up a trajectory

      +
      1. Switch to the Robot Workbench
      2. +
      3. Activate the model-tab in the tree view by clicking on it
      4. +
      5. Create a new trajectory by clicking on Robot CreateTrajectory.png
      6. +
      7. Select the robot in the tree view
      8. +
      9. Set home position for robot by clicking on Robot SetHomePos.png
      10. +
      11. Switch to the Task Panel
      12. +
      13. By using the sliders change robot position
      14. +
      15. When robot and trajectory are selected in tree view clicking on Robot InsertWaypoint.png will insert the way-point in the trajectory
      16. +
      17. Each way-point is shown with a yellow cross, the waypoints are connected with orange lines
      18. +
      19. Define at least three different way points and insert them in the trajectory
      +

      Simulating robot movement

      +
      1. Select robot and trajectory in tree view
      2. +
      3. Select simulation by clicking on Robot Simulate.png
      4. +
      5. Click on Play-Button I>
      6. +
      7. Watch simulation
      +

      Robot Tutorial RobotSimulation.gif +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/RoofExample.png b/localwiki/RoofExample.png new file mode 100644 index 0000000..82e942b Binary files /dev/null and b/localwiki/RoofExample.png differ diff --git a/localwiki/RoofTable.png b/localwiki/RoofTable.png new file mode 100644 index 0000000..cf66e22 Binary files /dev/null and b/localwiki/RoofTable.png differ diff --git a/localwiki/Rotate-mouse-MMB%2BRMB.svg b/localwiki/Rotate-mouse-MMB%2BRMB.svg new file mode 100644 index 0000000..16ad42f --- /dev/null +++ b/localwiki/Rotate-mouse-MMB%2BRMB.svg @@ -0,0 +1,149 @@ + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + + + + + + + 1 + 2 + + diff --git a/localwiki/Rotate-mouse-SHIFT.svg b/localwiki/Rotate-mouse-SHIFT.svg new file mode 100644 index 0000000..da1de3c --- /dev/null +++ b/localwiki/Rotate-mouse-SHIFT.svg @@ -0,0 +1,158 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + + + + + + + SHIFT + + diff --git a/localwiki/Rotate-mouse.svg b/localwiki/Rotate-mouse.svg new file mode 100644 index 0000000..b92b18f --- /dev/null +++ b/localwiki/Rotate-mouse.svg @@ -0,0 +1,149 @@ + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + + + + + + + 1 + 2 + + diff --git a/localwiki/Rotate_cursor.png b/localwiki/Rotate_cursor.png new file mode 100644 index 0000000..7f0bfce Binary files /dev/null and b/localwiki/Rotate_cursor.png differ diff --git a/localwiki/S60OutlineTransversal.png b/localwiki/S60OutlineTransversal.png new file mode 100644 index 0000000..9580ccd Binary files /dev/null and b/localwiki/S60OutlineTransversal.png differ diff --git a/localwiki/SIMTUT_05.PNG b/localwiki/SIMTUT_05.PNG new file mode 100644 index 0000000..8f4bf35 Binary files /dev/null and b/localwiki/SIMTUT_05.PNG differ diff --git a/localwiki/SSFontSelect.png b/localwiki/SSFontSelect.png new file mode 100644 index 0000000..d8e33a8 Binary files /dev/null and b/localwiki/SSFontSelect.png differ diff --git a/localwiki/STEP_project.html b/localwiki/STEP_project.html new file mode 100644 index 0000000..aba7aa7 --- /dev/null +++ b/localwiki/STEP_project.html @@ -0,0 +1,70 @@ +STEP project

      STEP project

      + +

      This template is the guideline for a FreeCAD development project. It follows the rules of the Getting Things Done (GTD) process. The projects are collected in the Development roadmap. +

      + + +

      Purpose and principles

      +

      This is a development project to find, discuss and implement a more advanced STEP i/o in FreeCAD. +

      +

      Outcome

      +
      • reading/writing complex STEP files into Assembly data definition (with color and all the additional information).
      • +
      • ....
      +

      Brainstorming

      +

      First we need to colect all the information about the matter +

      +

      general STEP

      +

      The ISO 10303 (STEP) is very important in this field. Its the only good standardized and widely discussed +and recognized definition of product structures I know of. +

      Product structure modeling Process-Data diagram.gif +

      +
      +


      +Here some links with info: +

      + +

      OCC step i/o information

      + +

      Organizing

      +

      Next actions

      +
      • collecting information and testing OCC STEP classes
      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Save.svg b/localwiki/Save.svg new file mode 100644 index 0000000..e06c4a9 --- /dev/null +++ b/localwiki/Save.svg @@ -0,0 +1,150 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [Jose Luis Cercos Pita] + + + Save + 2012-11-02 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Plot/resources/icons/Save.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Save_picture.png b/localwiki/Save_picture.png new file mode 100644 index 0000000..3f574de Binary files /dev/null and b/localwiki/Save_picture.png differ diff --git a/localwiki/Scaled_parameters.png b/localwiki/Scaled_parameters.png new file mode 100644 index 0000000..e4cbbdf Binary files /dev/null and b/localwiki/Scaled_parameters.png differ diff --git a/localwiki/Sceenshot-reversevid.jpg b/localwiki/Sceenshot-reversevid.jpg new file mode 100644 index 0000000..065efe5 Binary files /dev/null and b/localwiki/Sceenshot-reversevid.jpg differ diff --git a/localwiki/SceneOutput.png b/localwiki/SceneOutput.png new file mode 100644 index 0000000..19ab885 Binary files /dev/null and b/localwiki/SceneOutput.png differ diff --git a/localwiki/Scenegraph.gif b/localwiki/Scenegraph.gif new file mode 100644 index 0000000..2c99de1 Binary files /dev/null and b/localwiki/Scenegraph.gif differ diff --git a/localwiki/Scenegraph.html b/localwiki/Scenegraph.html new file mode 100644 index 0000000..3c74f92 --- /dev/null +++ b/localwiki/Scenegraph.html @@ -0,0 +1,62 @@ +Scenegraph

      Scenegraph

      + +

      FreeCAD is basically a collage of different powerful libraries, the most important being openCascade, for managing and constructing geometry, Coin3d to display that geometry, and Qt to put all this in a nice Graphical User Interface. +

      The geometry that appears in the 3D views of FreeCAD are rendered by the Coin3D library. Coin3D is an implementation of the OpenInventor standard. The openCascade software also provides the same functionality, but it was decided, at the very beginnings of FreeCAD, not to use the built-in openCascade viewer and rather switch to the more performant coin3D software. A good way to learn about that library is the book Open Inventor Mentor. +

      OpenInventor is actually a 3D scene description language. The scene described in openInventor is then rendered in OpenGL on your screen. Coin3D takes care of doing this, so the programmer doesn't need to deal with complex openGL calls, he just has to provide it with valid OpenInventor code. The big advantage is that openInventor is a very well-known and well documented standard. +

      One of the big jobs FreeCAD does for you is basically to translate openCascade geometry information into openInventor language. +

      OpenInventor describes a 3D scene in the form of a scenegraph, like the one below: +

      Scenegraph.gif +image from Inventor mentor +

      An openInventor scenegraph describes everything that makes part of a 3D scene, such as geometry, colors, materials, lights, etc, and organizes all that data in a convenient and clear structure. Everything can be grouped into sub-structures, allowing you to organize your scene contents pretty much the way you like. Here is an example of an openInventor file: +

      +
      #Inventor V2.0 ascii
      + 
      +Separator { 
      +    RotationXYZ {
      +       axis Z
      +       angle 0
      +    }
      +    Transform {
      +       translation 0 0 0.5
      +    }
      +    Separator {
      +       Material {
      +          diffuseColor 0.05 0.05 0.05
      +       }
      +       Transform {
      +          rotation 1 0 0 1.5708
      +          scaleFactor 0.2 0.5 0.2
      +       }
      +       Cylinder {
      +       }
      +    }
      +} 
      +

      As you can see, the structure is very simple. You use separators to organize your data into blocks, a bit like you would organize your files into folders. Each statement affects what comes next, for example the first two items of our root separator are a rotation and a translation, both will affect the next item, which is a separator. In that separator, a material is defined, and another transformation. Our cylinder will therefore be affected by both transformations, the one who was applied directly to it and the one that was applied to its parent separator. +

      We also have many other types of elements to organize our scene, such as groups, switches or annotations. We can define very complex materials for our objects, with color, textures, shading modes and transparency. We can also define lights, cameras, and even movement. It is even possible to embed pieces of scripting in openInventor files, to define more complex behaviours. +

      If you are interested in learning more about openInventor, head directly to its most famous reference, the Inventor mentor. +

      In FreeCAD, normally, we don't need to interact directly with the openInventor scenegraph. Every object in a FreeCAD document, being a mesh, a part shape or anything else, gets automatically converted to openInventor code and inserted in the main scenegraph that you see in a 3D view. That scenegraph gets updated continuously when you do modifications, add or remove objects to the document. In fact, every object (in App space) has a view provider (a corresponding object in Gui space), responsible for issuing openInventor code. +

      But there are many advantages to be able to access the scenegraph directly. For example, we can temporarily change the appearence of an object, or we can add objects to the scene that have no real existence in the FreeCAD document, such as construction geometry, helpers, graphical hints or tools such as manipulators or on-screen information. +

      FreeCAD itself features several tools to see or modify openInventor code. For example, the following python code will show the openInventor representation of a selected object: +

      +
      obj = FreeCAD.ActiveDocument.ActiveObject
      +viewprovider = obj.ViewObject
      +print viewprovider.toString() 
      +

      But we also have a python module that allows complete access to anything managed by Coin3D, such as our FreeCAD scenegraph. So, read on to Pivy. +

      + +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Screenshot-customize.jpg b/localwiki/Screenshot-customize.jpg new file mode 100644 index 0000000..084cf20 Binary files /dev/null and b/localwiki/Screenshot-customize.jpg differ diff --git a/localwiki/Screenshot-gcad.jpg b/localwiki/Screenshot-gcad.jpg new file mode 100644 index 0000000..cc2e3d3 Binary files /dev/null and b/localwiki/Screenshot-gcad.jpg differ diff --git a/localwiki/Screenshot_arch_multiwall.jpg b/localwiki/Screenshot_arch_multiwall.jpg new file mode 100644 index 0000000..8fa8f91 Binary files /dev/null and b/localwiki/Screenshot_arch_multiwall.jpg differ diff --git a/localwiki/Screenshot_arch_rebar.jpg b/localwiki/Screenshot_arch_rebar.jpg new file mode 100644 index 0000000..831f522 Binary files /dev/null and b/localwiki/Screenshot_arch_rebar.jpg differ diff --git a/localwiki/Screenshot_arch_window.jpg b/localwiki/Screenshot_arch_window.jpg new file mode 100644 index 0000000..e5c89d6 Binary files /dev/null and b/localwiki/Screenshot_arch_window.jpg differ diff --git a/localwiki/Screenshot_classbrowser.jpg b/localwiki/Screenshot_classbrowser.jpg new file mode 100644 index 0000000..917c94a Binary files /dev/null and b/localwiki/Screenshot_classbrowser.jpg differ diff --git a/localwiki/Screenshot_console.jpg b/localwiki/Screenshot_console.jpg new file mode 100644 index 0000000..125bd61 Binary files /dev/null and b/localwiki/Screenshot_console.jpg differ diff --git a/localwiki/Screenshot_draft.jpg b/localwiki/Screenshot_draft.jpg new file mode 100644 index 0000000..91e9c8f Binary files /dev/null and b/localwiki/Screenshot_draft.jpg differ diff --git a/localwiki/Screenshot_from_2017-09-02_20-01-49.png b/localwiki/Screenshot_from_2017-09-02_20-01-49.png new file mode 100644 index 0000000..c10ba3b Binary files /dev/null and b/localwiki/Screenshot_from_2017-09-02_20-01-49.png differ diff --git a/localwiki/Screenshot_inkscape.jpg b/localwiki/Screenshot_inkscape.jpg new file mode 100644 index 0000000..4bbda5f Binary files /dev/null and b/localwiki/Screenshot_inkscape.jpg differ diff --git a/localwiki/Screenshot_installer.jpg b/localwiki/Screenshot_installer.jpg new file mode 100644 index 0000000..8dc5f45 Binary files /dev/null and b/localwiki/Screenshot_installer.jpg differ diff --git a/localwiki/Screenshot_mesh.jpg b/localwiki/Screenshot_mesh.jpg new file mode 100644 index 0000000..7ba48de Binary files /dev/null and b/localwiki/Screenshot_mesh.jpg differ diff --git a/localwiki/Screenshot_pythoninterpreter.jpg b/localwiki/Screenshot_pythoninterpreter.jpg new file mode 100644 index 0000000..21c6b1d Binary files /dev/null and b/localwiki/Screenshot_pythoninterpreter.jpg differ diff --git a/localwiki/Screenshot_qcad.jpg b/localwiki/Screenshot_qcad.jpg new file mode 100644 index 0000000..bfbd77c Binary files /dev/null and b/localwiki/Screenshot_qcad.jpg differ diff --git a/localwiki/Screenshot_treeview.jpg b/localwiki/Screenshot_treeview.jpg new file mode 100644 index 0000000..d2bc3cd Binary files /dev/null and b/localwiki/Screenshot_treeview.jpg differ diff --git a/localwiki/Screenshots.html b/localwiki/Screenshots.html new file mode 100644 index 0000000..cb3dba9 --- /dev/null +++ b/localwiki/Screenshots.html @@ -0,0 +1,159 @@ +Screenshots

      Screenshots

      + +


      +Here are a few screenshots showing different parts of FreeCAD. They are not ordered in any particular timeline, so the images may differ from your actual version. See more screenshots submitted by FreeCAD users on the screenshot forum thread and on the "Show your project here!" Users Showcase forum part. +

      +

      The 0.17 release

      +

      6DPLEQ2.jpg +


      +Screenshot from 2018-01-25 20-53-18.jpg +


      +VIIC 2.jpg +


      +Truggy differential full.jpg +


      +216.png +


      +Custom extruder.jpg +


      +Wheel.JPG +


      +Axoview-r.JPG +


      +BaseStation004.JPG +


      +Drill-FreeCAD.png +


      +Drone Design Full.jpg +


      +Pic 06.jpg +


      +FreeCAD-guitar.jpg +

      +

      The 0.16 release

      +

      Hhassey.png +

      JMG.png +

      PrzemoF.png +

      Rockn.png +

      Easyw fc.png +

      R tec.jpeg +

      +

      The 0.15 release

      +

      Obijuan.png +

      Obijuan2.png +

      Gsuter.png +

      Lhf.jpg +

      Lou papet.png +

      +

      The 0.14 release

      +

      Freecad jeep.png +

      A jeep modeled by psicofil +

      Rockn house1.png +

      Rockn house2.png +

      A house made with the Arch module by rockn +

      Mesh curvature plot1.jpeg +

      Mesh curvature analysis by the Mesh module +

      Cura export.png +

      Export to external applications with python macros +

      +

      The 0.12 release

      +

      Assembly of multiple objects +

      A fully-constrained sketch revolved to create a bike rim section +

      +

      The 0.11 release

      +

      FreeCAD011.png +

      +

      The 0.10 release

      +

      Freecad010.png +

      +

      Measurement

      +

      Measurement.jpeg +

      +

      The 0.9 release

      +

      Freecad09.jpg +

      +

      STEP Data

      +

      TaskPanel.jpg +

      With loaded Robot gripper +

      +

      Robot gripper

      +

      FreeCAD Screenshot.png +

      On XP with Schenkel +

      +

      Boolean operations on Shapes

      +

      Part BooleanOperations.png +

      Boolean operations +

      +

      STEP

      +

      Screenshot-gcad.jpg +

      A screenshot showing FreeCAD importing and rendering a gCAD STEP model +

      +

      IGES

      +

      Freecad-vista01.jpg +

      FreeCAD on Windows Vista, with an IGES model from Rexroth loaded +

      +

      Fancy

      +

      Sceenshot-reversevid.jpg +

      You can customize a lot of aspects of FreeCAD! +

      +

      Boolean on Meshes

      +

      Screenshot mesh.jpg +

      Mesh boolean operations in FreeCAD +

      +

      Blender

      +

      Fcblender.jpg +

      Blender has an script to import FreeCAD files. +

      +

      Drawing Extraction

      +

      Drawing extraction.png +

      Extracting a 3D part (STEP in this case) to a SVG Drawing Extraction View. This is fully parametric, +if the part change the view follows. +

      +

      FreeCAD vs. QCad

      +

      Screenshot qcad.jpg +

      A screenshot showing how a same file gets rendered by FreeCAD and qCAD +

      +

      FreeCAD vs. Inkscape

      +

      Screenshot inkscape.jpg +

      A screenshot showing how a same file gets rendered by FreeCAD and inkscape +

      +

      Draft module

      +

      Screenshot draft.jpg +

      Freecad with the draft module loaded and a dxf drawing imported +

      +

      Preferences

      +

      Freecad-vista02.jpg +

      The preferences screen +


      +

      +

      On Ubuntu

      +

      Interface screenshot.jpg +

      The FreeCAD interface when you start it for the first time, on Ubuntu +

      +

      Windows intaller

      +

      Screenshot installer.jpg +

      Windows installer at work +

      +

      console mode

      +

      Screenshot console.jpg +

      FreeCAD runs in console mode (without gui) +

      +

      Save picture

      +

      Save picture.png +

      Dialog to save a picture with arbitrary sizes. +

      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Scripted_objects.html b/localwiki/Scripted_objects.html new file mode 100644 index 0000000..6785cf9 --- /dev/null +++ b/localwiki/Scripted_objects.html @@ -0,0 +1,504 @@ +Scripted objects

      Scripted objects

      + +

      Besides the standard object types such as annotations, meshes and parts objects, FreeCAD also offers the amazing possibility to build 100% python-scripted objects, called Python Features. Those objects will behave exactly as any other FreeCAD object, and are saved and restored automatically on file save/load. +

      One particularity must be understood, those objects are saved in FreeCAD FcStd files with python's json module. That module turns a python object as a string, allowing it to be added to the saved file. On load, the json module uses that string to recreate the original object, provided it has access to the source code that created the object. This means that if you save such a custom object and open it on a machine where the python code that generated the object is not present, the object won't be recreated. If you distribute such objects to others, you will need to distribute the python script that created it together. +

      Python Features follow the same rule as all FreeCAD features: they are separated into App and GUI parts. The app part, the Document Object, defines the geometry of our object, while its GUI part, the View Provider Object, defines how the object will be drawn on screen. The View Provider Object, as any other FreeCAD feature, is only available when you run FreeCAD in its own GUI. There are several properties and methods available to build your object. Properties must be of any of the predefined properties types that FreeCAD offers, and will appear in the property view window, so they can be edited by the user. This way, FeaturePython objects are truly and totally parametric. you can define properties for the Object and its ViewObject separately. +

      Hint: In former versions we used Python's cPickle module. However, this module executes arbitrary code and thus causes a security problem. Thus, we moved to Python's json module. +

      + + +

      Basic example

      +

      The following sample can be found in the src/Mod/TemplatePyMod/FeaturePython.py file, together with several other examples: +

      +
      '''Examples for a feature class and its view provider.'''
      +
      +import FreeCAD, FreeCADGui
      +from pivy import coin
      +
      +class Box:
      +    def __init__(self, obj):
      +        '''Add some custom properties to our box feature'''
      +        obj.addProperty("App::PropertyLength","Length","Box","Length of the box").Length=1.0
      +        obj.addProperty("App::PropertyLength","Width","Box","Width of the box").Width=1.0
      +        obj.addProperty("App::PropertyLength","Height","Box", "Height of the box").Height=1.0
      +        obj.Proxy = self
      +   
      +    def onChanged(self, fp, prop):
      +        '''Do something when a property has changed'''
      +        FreeCAD.Console.PrintMessage("Change property: " + str(prop) + "\n")
      + 
      +    def execute(self, fp):
      +        '''Do something when doing a recomputation, this method is mandatory'''
      +        FreeCAD.Console.PrintMessage("Recompute Python Box feature\n")
      +
      +class ViewProviderBox:
      +    def __init__(self, obj):
      +        '''Set this object to the proxy object of the actual view provider'''
      +        obj.addProperty("App::PropertyColor","Color","Box","Color of the box").Color=(1.0,0.0,0.0)
      +        obj.Proxy = self
      + 
      +    def attach(self, obj):
      +        '''Setup the scene sub-graph of the view provider, this method is mandatory'''
      +        self.shaded = coin.SoGroup()
      +        self.wireframe = coin.SoGroup()
      +        self.scale = coin.SoScale()
      +        self.color = coin.SoBaseColor()
      +       
      +        data=coin.SoCube()
      +        self.shaded.addChild(self.scale)
      +        self.shaded.addChild(self.color)
      +        self.shaded.addChild(data)
      +        obj.addDisplayMode(self.shaded,"Shaded");
      +        style=coin.SoDrawStyle()
      +        style.style = coin.SoDrawStyle.LINES
      +        self.wireframe.addChild(style)
      +        self.wireframe.addChild(self.scale)
      +        self.wireframe.addChild(self.color)
      +        self.wireframe.addChild(data)
      +        obj.addDisplayMode(self.wireframe,"Wireframe");
      +        self.onChanged(obj,"Color")
      + 
      +    def updateData(self, fp, prop):
      +        '''If a property of the handled feature has changed we have the chance to handle this here'''
      +        # fp is the handled feature, prop is the name of the property that has changed
      +        l = fp.getPropertyByName("Length")
      +        w = fp.getPropertyByName("Width")
      +        h = fp.getPropertyByName("Height")
      +        self.scale.scaleFactor.setValue(float(l),float(w),float(h))
      +        pass
      + 
      +    def getDisplayModes(self,obj):
      +        '''Return a list of display modes.'''
      +        modes=[]
      +        modes.append("Shaded")
      +        modes.append("Wireframe")
      +        return modes
      + 
      +    def getDefaultDisplayMode(self):
      +        '''Return the name of the default display mode. It must be defined in getDisplayModes.'''
      +        return "Shaded"
      + 
      +    def setDisplayMode(self,mode):
      +        '''Map the display mode defined in attach with those defined in getDisplayModes.\
      +                Since they have the same names nothing needs to be done. This method is optional'''
      +        return mode
      + 
      +    def onChanged(self, vp, prop):
      +        '''Here we can do something when a single property got changed'''
      +        FreeCAD.Console.PrintMessage("Change property: " + str(prop) + "\n")
      +        if prop == "Color":
      +            c = vp.getPropertyByName("Color")
      +            self.color.rgb.setValue(c[0],c[1],c[2])
      + 
      +    def getIcon(self):
      +        '''Return the icon in XPM format which will appear in the tree view. This method is\
      +                optional and if not defined a default icon is shown.'''
      +        return """
      +            /* XPM */
      +            static const char * ViewProviderBox_xpm[] = {
      +            "16 16 6 1",
      +            "   c None",
      +            ".  c #141010",
      +            "+  c #615BD2",
      +            "@  c #C39D55",
      +            "#  c #000000",
      +            "$  c #57C355",
      +            "        ........",
      +            "   ......++..+..",
      +            "   .@@@@.++..++.",
      +            "   .@@@@.++..++.",
      +            "   .@@  .++++++.",
      +            "  ..@@  .++..++.",
      +            "###@@@@ .++..++.",
      +            "##$.@@$#.++++++.",
      +            "#$#$.$$$........",
      +            "#$$#######      ",
      +            "#$$#$$$$$#      ",
      +            "#$$#$$$$$#      ",
      +            "#$$#$$$$$#      ",
      +            " #$#$$$$$#      ",
      +            "  ##$$$$$#      ",
      +            "   #######      "};
      +            """
      + 
      +    def __getstate__(self):
      +        '''When saving the document this object gets stored using Python's json module.\
      +                Since we have some un-serializable parts here -- the Coin stuff -- we must define this method\
      +                to return a tuple of all serializable objects or None.'''
      +        return None
      + 
      +    def __setstate__(self,state):
      +        '''When restoring the serialized object from document we have the chance to set some internals here.\
      +                Since no data were serialized nothing needs to be done here.'''
      +        return None
      +
      +
      +def makeBox():
      +    FreeCAD.newDocument()
      +    a=FreeCAD.ActiveDocument.addObject("App::FeaturePython","Box")
      +    Box(a)
      +    ViewProviderBox(a.ViewObject)
      +
      +makeBox() 
      +

      Available properties

      +

      Properties are the true building stones of FeaturePython objects. Through them, the user will be able to interact and modify your object. After creating a new FeaturePython object in your document ( obj=FreeCAD.ActiveDocument.addObject("App::FeaturePython","Box") ), you can get a list of the available properties by issuing: +

      +
      obj.supportedProperties() 
      +

      You will get a list of available properties: +

      +
      App::PropertyBool
      +App::PropertyBoolList
      +App::PropertyFloat
      +App::PropertyFloatList
      +App::PropertyFloatConstraint
      +App::PropertyQuantity
      +App::PropertyQuantityConstraint
      +App::PropertyAngle
      +App::PropertyDistance
      +App::PropertyLength
      +App::PropertySpeed
      +App::PropertyAcceleration
      +App::PropertyForce
      +App::PropertyPressure
      +App::PropertyInteger
      +App::PropertyIntegerConstraint
      +App::PropertyPercent
      +App::PropertyEnumeration
      +App::PropertyIntegerList
      +App::PropertyIntegerSet
      +App::PropertyMap
      +App::PropertyString
      +App::PropertyUUID
      +App::PropertyFont
      +App::PropertyStringList
      +App::PropertyLink
      +App::PropertyLinkSub
      +App::PropertyLinkList
      +App::PropertyLinkSubList
      +App::PropertyMatrix
      +App::PropertyVector
      +App::PropertyVectorList
      +App::PropertyPlacement
      +App::PropertyPlacementLink
      +App::PropertyColor
      +App::PropertyColorList
      +App::PropertyMaterial
      +App::PropertyPath
      +App::PropertyFile
      +App::PropertyFileIncluded
      +App::PropertyPythonObject
      +Part::PropertyPartShape
      +Part::PropertyGeometryList
      +Part::PropertyShapeHistory
      +Part::PropertyFilletEdges
      +Sketcher::PropertyConstraintList 
      +

      When adding properties to your custom objects, take care of this: +

      +
      • Do not use characters "<" or ">" in the properties descriptions (that would break the xml pieces in the .fcstd file)
      • +
      • Properties are stored alphabetically in a .fcstd file. If you have a shape in your properties, any property whose name comes after "Shape" in alphabetic order, will be loaded AFTER the shape, which can cause strange behaviours.
      +

      Property Type

      +

      By default the properties can be updated. It is possible to make the properties read-only, for instance in the case one wants to show the result of a method. It is also possible to hide the property. +The property type can be set using +

      +
      obj.setEditorMode("MyPropertyName", mode) 
      +

      where mode is a short int that can be set to: +

      +
       0 -- default mode, read and write
      + 1 -- read-only
      + 2 -- hidden
      +
      +

      The EditorModes are not set at FreeCAD file reload. This could to be done by the __setstate__ function. See http://forum.freecadweb.org/viewtopic.php?f=18&t=13460&start=10#p108072. By using the setEditorMode the properties are only read only in PropertyEditor. They could still be changed from python. To really make them read only the setting has to be passed directly inside the addProperty function. See http://forum.freecadweb.org/viewtopic.php?f=18&t=13460&start=20#p109709 for an example. +

      +

      Other more complex example

      +

      This example makes use of the Part Module to create an octahedron, then creates its coin representation with pivy. +

      First is the Document object itself: +

      +
      import FreeCAD, FreeCADGui, Part
      +import pivy
      +from pivy import coin
      +
      +class Octahedron:
      +  def __init__(self, obj):
      +     "Add some custom properties to our box feature"
      +     obj.addProperty("App::PropertyLength","Length","Octahedron","Length of the octahedron").Length=1.0
      +     obj.addProperty("App::PropertyLength","Width","Octahedron","Width of the octahedron").Width=1.0
      +     obj.addProperty("App::PropertyLength","Height","Octahedron", "Height of the octahedron").Height=1.0
      +     obj.addProperty("Part::PropertyPartShape","Shape","Octahedron", "Shape of the octahedron")
      +     obj.Proxy = self
      +
      +  def execute(self, fp):
      +     # Define six vetices for the shape
      +     v1 = FreeCAD.Vector(0,0,0)
      +     v2 = FreeCAD.Vector(fp.Length,0,0)
      +     v3 = FreeCAD.Vector(0,fp.Width,0)
      +     v4 = FreeCAD.Vector(fp.Length,fp.Width,0)
      +     v5 = FreeCAD.Vector(fp.Length/2,fp.Width/2,fp.Height/2)
      +     v6 = FreeCAD.Vector(fp.Length/2,fp.Width/2,-fp.Height/2)
      +     
      +     # Make the wires/faces
      +     f1 = self.make_face(v1,v2,v5)
      +     f2 = self.make_face(v2,v4,v5)
      +     f3 = self.make_face(v4,v3,v5)
      +     f4 = self.make_face(v3,v1,v5)
      +     f5 = self.make_face(v2,v1,v6)
      +     f6 = self.make_face(v4,v2,v6)
      +     f7 = self.make_face(v3,v4,v6)
      +     f8 = self.make_face(v1,v3,v6)
      +     shell=Part.makeShell([f1,f2,f3,f4,f5,f6,f7,f8])
      +     solid=Part.makeSolid(shell)
      +     fp.Shape = solid
      +
      +  # helper mehod to create the faces
      +  def make_face(self,v1,v2,v3):
      +     wire = Part.makePolygon([v1,v2,v3,v1])
      +     face = Part.Face(wire)
      +     return face 
      +

      Then, we have the view provider object, responsible for showing the object in the 3D scene: +

      +
      class ViewProviderOctahedron:
      +  def __init__(self, obj):
      +     "Set this object to the proxy object of the actual view provider"
      +     obj.addProperty("App::PropertyColor","Color","Octahedron","Color of the octahedron").Color=(1.0,0.0,0.0)
      +     obj.Proxy = self
      +
      +  def attach(self, obj):
      +     "Setup the scene sub-graph of the view provider, this method is mandatory"
      +     self.shaded = coin.SoGroup()
      +     self.wireframe = coin.SoGroup()
      +     self.scale = coin.SoScale()
      +     self.color = coin.SoBaseColor()
      +
      +     self.data=coin.SoCoordinate3()
      +     self.face=coin.SoIndexedLineSet()
      +
      +     self.shaded.addChild(self.scale)
      +     self.shaded.addChild(self.color)
      +     self.shaded.addChild(self.data)
      +     self.shaded.addChild(self.face)
      +     obj.addDisplayMode(self.shaded,"Shaded");
      +     style=coin.SoDrawStyle()
      +     style.style = coin.SoDrawStyle.LINES
      +     self.wireframe.addChild(style)
      +     self.wireframe.addChild(self.scale)
      +     self.wireframe.addChild(self.color)
      +     self.wireframe.addChild(self.data)
      +     self.wireframe.addChild(self.face)
      +     obj.addDisplayMode(self.wireframe,"Wireframe");
      +     self.onChanged(obj,"Color")
      +
      +  def updateData(self, fp, prop):
      +     "If a property of the handled feature has changed we have the chance to handle this here"
      +     # fp is the handled feature, prop is the name of the property that has changed
      +     if prop == "Shape":
      +        s = fp.getPropertyByName("Shape")
      +        self.data.point.setNum(6)
      +        cnt=0
      +        for i in s.Vertexes:
      +           self.data.point.set1Value(cnt,i.X,i.Y,i.Z)
      +           cnt=cnt+1
      +        
      +        self.face.coordIndex.set1Value(0,0)
      +        self.face.coordIndex.set1Value(1,1)
      +        self.face.coordIndex.set1Value(2,2)
      +        self.face.coordIndex.set1Value(3,-1)
      +
      +        self.face.coordIndex.set1Value(4,1)
      +        self.face.coordIndex.set1Value(5,3)
      +        self.face.coordIndex.set1Value(6,2)
      +        self.face.coordIndex.set1Value(7,-1)
      +
      +        self.face.coordIndex.set1Value(8,3)
      +        self.face.coordIndex.set1Value(9,4)
      +        self.face.coordIndex.set1Value(10,2)
      +        self.face.coordIndex.set1Value(11,-1)
      +
      +        self.face.coordIndex.set1Value(12,4)
      +        self.face.coordIndex.set1Value(13,0)
      +        self.face.coordIndex.set1Value(14,2)
      +        self.face.coordIndex.set1Value(15,-1)
      +
      +        self.face.coordIndex.set1Value(16,1)
      +        self.face.coordIndex.set1Value(17,0)
      +        self.face.coordIndex.set1Value(18,5)
      +        self.face.coordIndex.set1Value(19,-1)
      +
      +        self.face.coordIndex.set1Value(20,3)
      +        self.face.coordIndex.set1Value(21,1)
      +        self.face.coordIndex.set1Value(22,5)
      +        self.face.coordIndex.set1Value(23,-1)
      +
      +        self.face.coordIndex.set1Value(24,4)
      +        self.face.coordIndex.set1Value(25,3)
      +        self.face.coordIndex.set1Value(26,5)
      +        self.face.coordIndex.set1Value(27,-1)
      +
      +        self.face.coordIndex.set1Value(28,0)
      +        self.face.coordIndex.set1Value(29,4)
      +        self.face.coordIndex.set1Value(30,5)
      +        self.face.coordIndex.set1Value(31,-1)
      +
      +  def getDisplayModes(self,obj):
      +     "Return a list of display modes."
      +     modes=[]
      +     modes.append("Shaded")
      +     modes.append("Wireframe")
      +     return modes
      +
      +  def getDefaultDisplayMode(self):
      +     "Return the name of the default display mode. It must be defined in getDisplayModes."
      +     return "Shaded"
      +
      +  def setDisplayMode(self,mode):
      +     return mode
      +
      +  def onChanged(self, vp, prop):
      +     "Here we can do something when a single property got changed"
      +     FreeCAD.Console.PrintMessage("Change property: " + str(prop) + "\n")
      +     if prop == "Color":
      +        c = vp.getPropertyByName("Color")
      +        self.color.rgb.setValue(c[0],c[1],c[2])
      +
      +  def getIcon(self):
      +     return """
      +        /* XPM */
      +        static const char * ViewProviderBox_xpm[] = {
      +        "16 16 6 1",
      +        "    c None",
      +        ".   c #141010",
      +        "+   c #615BD2",
      +        "@   c #C39D55",
      +        "#   c #000000",
      +        "$   c #57C355",
      +        "        ........",
      +        "   ......++..+..",
      +        "   .@@@@.++..++.",
      +        "   .@@@@.++..++.",
      +        "   .@@  .++++++.",
      +        "  ..@@  .++..++.",
      +        "###@@@@ .++..++.",
      +        "##$.@@$#.++++++.",
      +        "#$#$.$$$........",
      +        "#$$#######      ",
      +        "#$$#$$$$$#      ",
      +        "#$$#$$$$$#      ",
      +        "#$$#$$$$$#      ",
      +        " #$#$$$$$#      ",
      +        "  ##$$$$$#      ",
      +        "   #######      "};
      +        """
      +
      +  def __getstate__(self):
      +     return None
      +
      +  def __setstate__(self,state):
      +     return None 
      +

      Finally, once our object and its viewobject are defined, we just need to call them (The Octahedron class and viewprovider class code could be copied in the FreeCAD python console directly): +

      +
      FreeCAD.newDocument()
      +a=FreeCAD.ActiveDocument.addObject("App::FeaturePython","Octahedron")
      +Octahedron(a)
      +ViewProviderOctahedron(a.ViewObject) 
      +

      Making objects selectable

      +

      If you want to make your object selectable, or at least part of it, by clicking on it in the viewport, you must include its coin geometry inside a SoFCSelection node. If your object has complex representation, with widgets, annotations, etc, you might want to include only a part of it in a SoFCSelection. Everything that is a SoFCSelection is constantly scanned by FreeCAD to detect selection/preselection, so it makes sense try not to overload it with unneeded scanning. This is what you would do to include a self.face from the example above: +

      +
      selectionNode = coin.SoType.fromName("SoFCSelection").createInstance()
      +selectionNode.documentName.setValue(FreeCAD.ActiveDocument.Name)
      +selectionNode.objectName.setValue(obj.Object.Name) # here obj is the ViewObject, we need its associated App Object
      +selectionNode.subElementName.setValue("Face")
      +selectNode.addChild(self.face)
      +...
      +self.shaded.addChild(selectionNode)
      +self.wireframe.addChild(selectionNode) 
      +

      Simply, you create a SoFCSelection node, then you add your geometry nodes to it, then you add it to your main node, instead of adding your geometry nodes directly. +

      +

      Working with simple shapes

      +

      If your parametric object simply outputs a shape, you don't need to use a view provider object. The shape will be displayed using FreeCAD's standard shape representation: +

      +
      import FreeCAD as App
      +import FreeCADGui
      +import FreeCAD
      +import Part
      +class Line:
      +    def __init__(self, obj):
      +        '''"App two point properties" '''
      +        obj.addProperty("App::PropertyVector","p1","Line","Start point")
      +        obj.addProperty("App::PropertyVector","p2","Line","End point").p2=FreeCAD.Vector(1,0,0)
      +        obj.Proxy = self
      +
      +    def execute(self, fp):
      +        '''"Print a short message when doing a recomputation, this method is mandatory" '''
      +        fp.Shape = Part.makeLine(fp.p1,fp.p2)
      +
      +a=FreeCAD.ActiveDocument.addObject("Part::FeaturePython","Line")
      +Line(a)
      +a.ViewObject.Proxy=0 # just set it to something different from None (this assignment is needed to run an internal notification)
      +FreeCAD.ActiveDocument.recompute() 
      +

      Same code with use ViewProviderLine +

      +
      import FreeCAD as App
      +import FreeCADGui
      +import FreeCAD
      +import Part
      +
      +class Line:
      +    def __init__(self, obj):
      +         '''"App two point properties" '''
      +         obj.addProperty("App::PropertyVector","p1","Line","Start point")
      +         obj.addProperty("App::PropertyVector","p2","Line","End point").p2=FreeCAD.Vector(100,0,0)
      +         obj.Proxy = self
      +   
      +    def execute(self, fp):
      +        '''"Print a short message when doing a recomputation, this method is mandatory" '''
      +        fp.Shape = Part.makeLine(fp.p1,fp.p2)
      +
      +class ViewProviderLine:
      +   def __init__(self, obj):
      +      ''' Set this object to the proxy object of the actual view provider '''
      +      obj.Proxy = self
      +
      +   def getDefaultDisplayMode(self):
      +      ''' Return the name of the default display mode. It must be defined in getDisplayModes. '''
      +      return "Flat Lines"
      +
      +a=FreeCAD.ActiveDocument.addObject("Part::FeaturePython","Line")
      +Line(a)
      +ViewProviderLine(a.ViewObject)
      +App.ActiveDocument.recompute() 
      +


      +

      +

      Further informations

      +

      There are a few very interesting forum threads about scripted objects: +

      - http://forum.freecadweb.org/viewtopic.php?f=22&t=13740 +

      - http://forum.freecadweb.org/viewtopic.php?t=12139 +

      - https://forum.freecadweb.org/viewtopic.php?f=18&t=13460&start=20#p109709 +

      - https://forum.freecadweb.org/viewtopic.php?f=22&t=21330 +


      +In addition to the examples presented here have a look at FreeCAD source code src/Mod/TemplatePyMod/FeaturePython.py for more examples. +

      + +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Scripting.html b/localwiki/Scripting.html new file mode 100644 index 0000000..84656e1 --- /dev/null +++ b/localwiki/Scripting.html @@ -0,0 +1,127 @@ +Scripting

      Scripting

      (Redirected from Scripting)
      + +
      150
      +

      This is the place to come if you want to have a deeper insight into FreeCAD. Here you can learn about customizing FreeCAD for your needs. +

      These pages are in early stage of development. If you can't find the information you are looking for, or have found useful information somewhere we have not linked to, then please leave a comment on the forum, or, why not? Add some more content here yourself! +

      One of the nicest features of FreeCAD is that you can script and extend it extremely far without the need to compile anything or touch the source code. All the scripting part is done in Python, a very powerful but simple programming language. With simple Python scripts, you have total access to about any part of FreeCAD. For example, you can: +

      +
      • Create and modify geometry: Is there a special object you need that's not present in the default FreeCAD installation? You can easily create a new object type, either from scratch or by adapting an existing type.
      • +
      • Create custom tools and commands: At the moment, FreeCAD already has extensive functionality, but there aren't many convenient tools and commands for the final user yet. But it is already easy to create your own sets of tools.
      • +
      • Modify the interface: The FreeCAD user interface is still very basic at this stage. But everything is there for you to extend it to your needs. You can, for example, create toolbars to put your own tools, create special panels for interacting with your tools, etc.
      • +
      • Modify the scene representation: FreeCAD has separate processes for building up and computing the geometry and displaying that geometry on your screen. You have full access to the way the scene contents are displayed on screen, therefore you can modify that representation, interact with it, or add all kinds of custom behaviours and screen widgets, like information, draggers, anchors or temporary entities.
      + + +

      Customizing FreeCAD

      + +

      Scripting in FreeCAD

      +

      General

      + +

      Modules

      +

      As the functionality of FreeCAD is separated in Modules which deal with special data types and applications. FreeCAD has built-in modules and Extension Modules (plug-ins). Once plugin modules are installed, they become availible to you as easily as the built-in modules. The modules described below are the default modules, includeed in every FreeCAD installation. +

      +
      • The Builtin modules are the principal FreeCAD modules. They contain tools for manipulating general FreeCAD configurations, documents and their contents.
      • +
      • Workbench creation shows you how to create your own workbench
      +

      Working with Meshes

      + +

      Working with Parts

      + +

      Accessing the Coin scenegraph

      + +

      Controlling the Qt interface

      + +

      Working with parametric objects

      + +

      Examples

      +
      • Code snippets : A collection of pieces of FreeCAD Python code, to serve as ingredients in your scripts...
      • +
      • Line drawing function: How to build a simple tool to draw lines
      • +
      • Dialog creation: How to construct dialogs with Qt designer, and use them in FreeCAD
      • +
      • Embedding FreeCAD: How to import FreeCAD as a Python module in other applications
      • +
      • The Draft Module adds basic 2d drawing functions to freecad. It is written entirely in Python, so it can be a good example if you want to write your own modules.
      • +
      • FreeCAD vector math library : A couple of handy functions to manipulate FreeCAD vectors. This library is also included in the Draft module.
      +

      API Functions

      +

      The complete API documentation of FreeCAD is located at http://www.freecadweb.org/api/ . It contains both C++ and Python APIs, and is not totally well formatted yet, which can be confusing when looking for python-only code. An easier to browse version can be found here. Note that it can be incomplete, since it is updated manually. For more accurate information, browse the modules directly from FreeCAD's Python console. +

      +

      Advanced modification

      + +

      Python tutorials

      +

      These are good generic tutorials, not specific to FreeCAD, that might interest you if you are totally new to python. +

      Python +

      + +

      PySide - How to create and manage FreeCAD's Qt UI interface from python +

      + +

      The following two references are PyQt specific (not PySide) but may offer some information of use: +

      + +

      Pivy - How to interact with FreeCAD's 3D scenes +

      + +

      Community projects

      +

      On the Community portal, you can find other FreeCAD-based projects run by the FreeCAD users community. If you are starting a new FreeCAD project, be sure to list it there! We also have a page with things you can do if you would like to Help FreeCAD. +


      +

      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Scripting_examples.html b/localwiki/Scripting_examples.html new file mode 100644 index 0000000..88082b5 --- /dev/null +++ b/localwiki/Scripting_examples.html @@ -0,0 +1,27 @@ +Scripting examples

      Scripting examples

      + +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Section-down.svg b/localwiki/Section-down.svg new file mode 100644 index 0000000..7fe7fec --- /dev/null +++ b/localwiki/Section-down.svg @@ -0,0 +1,95 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [WandererFan] + + + section-down + 2016-10-06 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/TechDraw/Gui/Resources/icons/actions/section-down.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + diff --git a/localwiki/Section-left.svg b/localwiki/Section-left.svg new file mode 100644 index 0000000..136d1bc --- /dev/null +++ b/localwiki/Section-left.svg @@ -0,0 +1,97 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [WandererFan] + + + section-left + 2016-10-06 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/TechDraw/Gui/Resources/icons/actions/section-left.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Section-right.svg b/localwiki/Section-right.svg new file mode 100644 index 0000000..7a1505b --- /dev/null +++ b/localwiki/Section-right.svg @@ -0,0 +1,97 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [WandererFan] + + + section-right + 2016-10-06 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/TechDraw/Gui/Resources/icons/actions/section-right.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Section-up.svg b/localwiki/Section-up.svg new file mode 100644 index 0000000..742ef6e --- /dev/null +++ b/localwiki/Section-up.svg @@ -0,0 +1,97 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [WandererFan] + + + section-up + 2016-10-06 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/TechDraw/Gui/Resources/icons/actions/section-up.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + diff --git a/localwiki/SectionCross1.png b/localwiki/SectionCross1.png new file mode 100644 index 0000000..27cefe5 Binary files /dev/null and b/localwiki/SectionCross1.png differ diff --git a/localwiki/SectionCross2.png b/localwiki/SectionCross2.png new file mode 100644 index 0000000..6eea4a0 Binary files /dev/null and b/localwiki/SectionCross2.png differ diff --git a/localwiki/SectionCross3.png b/localwiki/SectionCross3.png new file mode 100644 index 0000000..8857617 Binary files /dev/null and b/localwiki/SectionCross3.png differ diff --git a/localwiki/Segments.gif b/localwiki/Segments.gif new file mode 100644 index 0000000..a8caa7f Binary files /dev/null and b/localwiki/Segments.gif differ diff --git a/localwiki/Select-mouse.svg b/localwiki/Select-mouse.svg new file mode 100644 index 0000000..cb17f42 --- /dev/null +++ b/localwiki/Select-mouse.svg @@ -0,0 +1,126 @@ + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + + + + + + + + diff --git a/localwiki/SelectFace.png b/localwiki/SelectFace.png new file mode 100644 index 0000000..7fc8535 Binary files /dev/null and b/localwiki/SelectFace.png differ diff --git a/localwiki/Selection_API.html b/localwiki/Selection_API.html new file mode 100644 index 0000000..875ab44 --- /dev/null +++ b/localwiki/Selection_API.html @@ -0,0 +1,80 @@ +Selection API

      Selection API

      + +

      The selection submodule is part of the FreeCADGui module. Example: +

      +
      import FreeCADGui
      +sel = FreeCADGui.Selection.getSelection() 
      +
      +
      Method.png addSelection ( FreeCAD.Object )
      +
      +

      Description: Adds an object to the selection +

      Returns: +

      +
      +
      +


      +

      +
      +
      Method.png clearSelection ( [string] )
      +
      +

      Description: Clears the selection of the given document name. If no document is given the complete selection is cleared. +

      Returns: +

      +
      +
      +


      +

      +
      +
      Method.png getSelection ( [string] )
      +
      +

      Description: Returns a list of selected document objects for a given document name. If no document is given the complete selection is returned. +

      Returns: a list of document objects in the order they were selected. +

      +
      +
      +


      +

      +
      +
      Method.png getSelectionEx ( [string] )
      +
      +

      Description: Returns a list of SelectionObject for a given document name. If no document is given the complete selection is returned. Used for selecting subobjects (ex some Edges of a Face). +

      Returns: a list of SelectionObjects in the order they were selected +

      +
      +
      +


      +

      +
      +
      Method.png isSelected ( FreeCAD.Object )
      +
      +

      Description: Checks if a given object is selected +

      Returns: +

      +
      +
      +


      +

      +
      +
      Method.png removeSelection ( FreeCAD.Object )
      +
      +

      Description: Removes an object from the selection +

      Returns: +

      +
      +
      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Series.svg b/localwiki/Series.svg new file mode 100644 index 0000000..474c81d --- /dev/null +++ b/localwiki/Series.svg @@ -0,0 +1,141 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [Jose Luis Cercos Pita] + + + Series + 2012-11-02 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Plot/resources/icons/Series.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + diff --git a/localwiki/Sewing.svg b/localwiki/Sewing.svg new file mode 100644 index 0000000..06a53a3 --- /dev/null +++ b/localwiki/Sewing.svg @@ -0,0 +1,281 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + + + + + + + + diff --git a/localwiki/ShapeString_To_Sketch.gif b/localwiki/ShapeString_To_Sketch.gif new file mode 100644 index 0000000..a5cf46a Binary files /dev/null and b/localwiki/ShapeString_To_Sketch.gif differ diff --git a/localwiki/Shapebinder_flow.png b/localwiki/Shapebinder_flow.png new file mode 100644 index 0000000..16b8bcc Binary files /dev/null and b/localwiki/Shapebinder_flow.png differ diff --git a/localwiki/Shapebinder_tree.png b/localwiki/Shapebinder_tree.png new file mode 100644 index 0000000..0c7e0c7 Binary files /dev/null and b/localwiki/Shapebinder_tree.png differ diff --git a/localwiki/Ship.png b/localwiki/Ship.png new file mode 100644 index 0000000..533b3fc Binary files /dev/null and b/localwiki/Ship.png differ diff --git a/localwiki/ShipExample.png b/localwiki/ShipExample.png new file mode 100644 index 0000000..be89b2f Binary files /dev/null and b/localwiki/ShipExample.png differ diff --git a/localwiki/ShipWorkbench.svg b/localwiki/ShipWorkbench.svg new file mode 100644 index 0000000..412d96d --- /dev/null +++ b/localwiki/ShipWorkbench.svg @@ -0,0 +1,157 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [triplus] + + + ShipWorkbench + 2016-02-26 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Ship/resources/icons/ShipWorkbench.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Ship_Area.html b/localwiki/Ship_Area.html new file mode 100644 index 0000000..75deb88 --- /dev/null +++ b/localwiki/Ship_Area.html @@ -0,0 +1,78 @@ +Ship Area

      Ship Area

      + +
      +

      This documentation is not finished. Please help and contribute documentation. +

      See Draft ShapeString for good documented Command. Gui Command gives an overview over commands. And see List of Commands for other commands. +

      Go to Help FreeCAD to contribute. +

      +
      +


      +

      + + + + + + + + + + + + + + + + + + + + +
      +

      Ship Area.png Ship Area

      +
      Menu location +
      Ship design → Areas curve +
      Workbenches +
      Ship +
      Default shortcut +
      +
      See also +
      +

      + +
      +


      +


      +

      +

      Introduction

      +

      TODO +


      +


      +

      +

      Tutorials

      + +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Ship_Area.png b/localwiki/Ship_Area.png new file mode 100644 index 0000000..bd9e5bf Binary files /dev/null and b/localwiki/Ship_Area.png differ diff --git a/localwiki/Ship_AreaCurve.svg b/localwiki/Ship_AreaCurve.svg new file mode 100644 index 0000000..ebe8534 --- /dev/null +++ b/localwiki/Ship_AreaCurve.svg @@ -0,0 +1,141 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [Cercos-Pita J.L] + + + Ship_AreaCurve + 2014-02-18 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Ship/resources/icons/Ship_AreaCurve.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Ship_CapacityCurve.svg b/localwiki/Ship_CapacityCurve.svg new file mode 100644 index 0000000..c6c7161 --- /dev/null +++ b/localwiki/Ship_CapacityCurve.svg @@ -0,0 +1,255 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [J.L. Cercos-Pita] + + + Ship_CapacityCurve + 2014-12-12 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Ship/resources/icons/Ship_CapacityCurve.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Ship_GZ.svg b/localwiki/Ship_GZ.svg new file mode 100644 index 0000000..3db4bb5 --- /dev/null +++ b/localwiki/Ship_GZ.svg @@ -0,0 +1,351 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [J.L. Cercos-Pita] + + + Ship_GZ + 2014-12-12 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Ship/resources/icons/Ship_GZ.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Ship_Geometries_Examples.html b/localwiki/Ship_Geometries_Examples.html new file mode 100644 index 0000000..bb77165 --- /dev/null +++ b/localwiki/Ship_Geometries_Examples.html @@ -0,0 +1,96 @@ +Ship Geometries Examples

      Ship Geometries Examples

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Ship Load Example.png Ship Load‏‎ Example

      +
      Menu location +
      Ship design → Load‏‎ an example ship geometry +
      Workbenches +
      Ship +
      Default shortcut +
      +
      See also +
      +

      + +
      +


      +


      +

      +

      Introduction

      +

      Ship works over Ship entities, that must be created on top of provided geometry. Geometry must be a solid, or set of solids, following criteria must be taken into account: +

      +
      • All hull geometry must be provided (including symmetric bodies).
      • +
      • Starboard geometry must be included at negatives y domain.
      • +
      • Origin (0,0,0) point is the Midship section (Midpoint between after and forward perpendicular) and base line intersection.
      +


      +

      +
      Schematic view of sign criteria
      +
      Ship sign criteria
      +

      Loading Series 60 geometry

      +

      In order to help new users Ship includes a geometries examples loader, with the following to choose from: +

      +
      • Series 60 from Iowa University
      • +
      • Wigley Canonical Ship
      • +
      • Series 60 Catamaran
      • +
      • Wigley Catamaran
      +


      +

      +
      Example ship geometries loader icon.
      +
      Ship Geometries Examples loader icon
      +


      +Executing the tool (Ship design/Load an example ship geometry) a task dialogue will shown. Select Series 60 from Iowa University and press Accept. Tool loads new document with s60_IowaUniversity geometry. +


      +

      +
      Warning, before editing anything!
      +
      You are now working with the original example file.
      +
      To preserve the original unedited example, you must first save it as a new file before editing anything.
      +


      +

      +

      Tutorials

      + +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Ship_Hydrostatics.html b/localwiki/Ship_Hydrostatics.html new file mode 100644 index 0000000..086cfc6 --- /dev/null +++ b/localwiki/Ship_Hydrostatics.html @@ -0,0 +1,77 @@ +Ship Hydrostatics

      Ship Hydrostatics

      + +
      +

      This documentation is not finished. Please help and contribute documentation. +

      See Draft ShapeString for good documented Command. Gui Command gives an overview over commands. And see List of Commands for other commands. +

      Go to Help FreeCAD to contribute. +

      +
      +


      +

      + + + + + + + + + + + + + + + + + + + + +
      +

      Ship Hydrostatics.png Ship Hydrostatics

      +
      Menu location +
      Ship design → Hydrostatics +
      Workbenches +
      Ship +
      Default shortcut +
      +
      See also +
      +

      + +
      +


      +


      +

      +

      Introduction

      +

      TODO +


      +

      +

      Tutorials

      + +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Ship_Hydrostatics.svg b/localwiki/Ship_Hydrostatics.svg new file mode 100644 index 0000000..5cba0a0 --- /dev/null +++ b/localwiki/Ship_Hydrostatics.svg @@ -0,0 +1,244 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [Jose Luis Cercos-Pita] + + + Ship_Hydrostatics + 2014-05-02 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Ship/resources/icons/Ship_Hydrostatics.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Ship_Instance.svg b/localwiki/Ship_Instance.svg new file mode 100644 index 0000000..b4144fc --- /dev/null +++ b/localwiki/Ship_Instance.svg @@ -0,0 +1,319 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Ship_Load.svg b/localwiki/Ship_Load.svg new file mode 100644 index 0000000..cc165d2 --- /dev/null +++ b/localwiki/Ship_Load.svg @@ -0,0 +1,218 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [Cercos-Pita J.L] + + + Ship_Load + 2014-02-18 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Ship/resources/icons/Ship_Load.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Ship_LoadCondition.svg b/localwiki/Ship_LoadCondition.svg new file mode 100644 index 0000000..8dce3f4 --- /dev/null +++ b/localwiki/Ship_LoadCondition.svg @@ -0,0 +1,198 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + + [Jose Luis Cercos Pita] + + + Ship_LoadCondition + 2015-10-16 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Ship/resources/icons/Ship_LoadCondition.svg + + + FreeCAD LGPL2+ + + + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Ship_Loading.html b/localwiki/Ship_Loading.html new file mode 100644 index 0000000..c247aef --- /dev/null +++ b/localwiki/Ship_Loading.html @@ -0,0 +1,77 @@ +Ship Loading

      Ship Loading

      + +
      +

      This documentation is not finished. Please help and contribute documentation. +

      See Draft ShapeString for good documented Command. Gui Command gives an overview over commands. And see List of Commands for other commands. +

      Go to Help FreeCAD to contribute. +

      +
      +


      +

      + + + + + + + + + + + + + + + + + + + + +
      +

      Ship Loading.png Ship Loading

      +
      Menu location +
      Weights → Create a new loading condition +
      Workbenches +
      Ship +
      Default shortcut +
      +
      See also +
      +

      + +
      +


      +


      +

      +

      Introduction

      +

      TODO +


      +

      +

      Tutorials

      + +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Ship_Logo.svg b/localwiki/Ship_Logo.svg new file mode 100644 index 0000000..cee94a1 --- /dev/null +++ b/localwiki/Ship_Logo.svg @@ -0,0 +1,157 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [Cercos-Pita J.L] + + + Ship_Logo + 2014-02-18 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Ship/resources/icons/Ship_Logo.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Ship_Module.svg b/localwiki/Ship_Module.svg new file mode 100644 index 0000000..412d96d --- /dev/null +++ b/localwiki/Ship_Module.svg @@ -0,0 +1,157 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [triplus] + + + ShipWorkbench + 2016-02-26 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Ship/resources/icons/ShipWorkbench.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Ship_New.html b/localwiki/Ship_New.html new file mode 100644 index 0000000..cb44790 --- /dev/null +++ b/localwiki/Ship_New.html @@ -0,0 +1,109 @@ +Ship New

      Ship New

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Ship New.png Ship New‏‎

      +
      Menu location +
      Ship design → Create a new ship +
      Workbenches +
      Ship +
      Default shortcut +
      +
      See also +
      +

      + +
      +


      +


      +

      +

      Introduction

      +

      TODO +

      +

      Create ship instance

      +

      In order to create a Ship instance select s60 geometry and execute the ship creation tool (Ship design → Create a new ship). +


      +

      +
      Ship creation tool.
      +
      Ship creation tool icon
      +


      +Creating ship task dialogue and some annotations at 3D view will shown. The annotations will removed when you close Ship creation tool, so don't worry about this. +


      +Most relevant ship data must be introduced (Ship uses a progressive data introduction system, so basic operations can be performed knowing only basic ship data, more information is needed as the operations become more complex). +

      +

      Ship data

      +

      Main dimensions must be introduced here: +

      +
      • Length: Length between perpendiculars, 25.5 m for this ship.
      • +
      • Beam: Total ship beam, 3.389 m for this ship.
      • +
      • Draft: Design draft, 1.0 m for this ship.
      +


      +

      +
      Front view annotations
      +
      Length annotations.
      +


      +Usually the Length between perpendiculars depends on design draft, so if you don't know what is the length of your ship you can set draft, and fit length in order to get bow and draft intersection. +


      +

      +
      Side view annotations
      +
      Beam annotations.
      +


      +Same process is valid for Beam fit. Note that requested value is total beam, but annotation is only refered to starboard half ship. +


      +When you press Accept button program creates your new Ship instance called Ship at Tags & Attributes dialog. We don't need geometry anymore, so you can hide it. +


      +

      +
      Ship instance icon
      +
      Ship instance icon.
      +


      +From here onwards, you must have Ship selected before you execute any Ship tool. +


      +

      +

      Tutorials

      + +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Ship_Outline.html b/localwiki/Ship_Outline.html new file mode 100644 index 0000000..31d6a81 --- /dev/null +++ b/localwiki/Ship_Outline.html @@ -0,0 +1,129 @@ +Ship Outline

      Ship Outline

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Ship Outline.png Ship Outline

      +
      Menu location +
      Ship design → Outline draw +
      Workbenches +
      Ship +
      Default shortcut +
      +
      See also +
      +

      + +
      +


      +

      +

      Introduction

      +

      TODO +

      +

      Lines drawing

      +

      Ship provides a tool that makes it easy to obtain a Lines Plan from the ship lines drawing +


      +

      +
      Outline draw tool.
      +
      Lines drawing tool icon
      +


      +Lines drawing is a set of lines from section cuts in all 3 axis, that will eventually show the hull geometry in a Lines Plan. We need to provide the lines for the 3 following views: +

      +
      • Body Plan (using the Transversal Cuts)
      • +
      • Sheer Plan (using the Longitudinals Cuts)
      • +
      • Half-Breadth Plan (using the Waterlines Cuts)
      +


      +

      +

      Transversal cuts

      +

      Usually 21 transversal equidistant sections between perpendiculars must be performed. in order to do it FreeCAD provides an automatic tool in order to do it, simply select Transversal type of sections, go to Auto create box and set 21 sections, then press Create sections. +


      +

      +
      Outline draw transversal sections preview.
      +
      Outline draw transversal sections preview
      +


      +Sections table is filled, and sections preview called OutlineDraw shown. Usually more sections was added at bow and stern, where more complex curvatures are registered, in order to do it go to the end of the table, and do double click at empty item in order to edit it, pressing intro to confirm. Add following sections: +


      +

      +
      • X22 = -12.1125 m
      • +
      • X23 = 12.1125 m
      +


      +Depending hull geometry complexity, sections preview can take some time. In order to remove a section, just fill it with an empty text and press enter. +

      +

      Longitudinal cuts

      +

      Two longitudinal cuts must be added, so select Longitudinal type of sections, go to Auto create box and set 2 sections, then press Create sections. Sections table is filled, and sections preview updated. +

      +

      Waterlines

      +

      6 Waterlines between base line and design draft must be added, so select Waterlines type of sections, go to Auto create box and set 5 (Z = 0 m will not be considered, add it manually if you need it) sections, then press Create sections. Sections table is filled, and sections preview updated. +


      +Several additional waterlines must be added: +

      +
      • Z6 = 1.2 m
      • +
      • Z7 = 1.4 m
      • +
      • Z8 = 1.6 m
      • +
      • Z9 = 1.8 m
      • +
      • Z10 = 2.0 m
      +

      Perform plot

      +

      Select 1:100 scale and press Accept to let the tool to generate the 3D sections in a new object. +


      +

      +
      Resultant sections.
      +
      Resultant sections.
      +


      +In order to plot these sections you can use the Drawing workbench: +


      +

      +
      Outline draw plot.
      +
      Outline draw plot.
      +

      Tutorials

      + +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Ship_OutlineDraw.svg b/localwiki/Ship_OutlineDraw.svg new file mode 100644 index 0000000..26d0e85 --- /dev/null +++ b/localwiki/Ship_OutlineDraw.svg @@ -0,0 +1,145 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [Cercos-Pita J.L] + + + Ship_OutlineDraw + 2014-02-18 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Ship/resources/icons/Ship_OutlineDraw.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Ship_PlotGZ.html b/localwiki/Ship_PlotGZ.html new file mode 100644 index 0000000..31264c4 --- /dev/null +++ b/localwiki/Ship_PlotGZ.html @@ -0,0 +1,77 @@ +Ship PlotGZ

      Ship PlotGZ

      + +
      +

      This documentation is not finished. Please help and contribute documentation. +

      See Draft ShapeString for good documented Command. Gui Command gives an overview over commands. And see List of Commands for other commands. +

      Go to Help FreeCAD to contribute. +

      +
      +


      +

      + + + + + + + + + + + + + + + + + + + + +
      +

      Ship PlotGZ.png Ship PlotGZ

      +
      Menu location +
      Weights → GZ curve computation +
      Workbenches +
      Ship +
      Default shortcut +
      +
      See also +
      +

      + +
      +


      +


      +

      +

      Introduction

      +

      TODO +


      +

      +

      Tutorials

      + +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Ship_Tank.svg b/localwiki/Ship_Tank.svg new file mode 100644 index 0000000..7e68eaf --- /dev/null +++ b/localwiki/Ship_Tank.svg @@ -0,0 +1,229 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [J.L. Cercos-Pita] + + + Ship_Tank + 2014-12-12 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Ship/resources/icons/Ship_Tank.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Ship_TankCapacity.html b/localwiki/Ship_TankCapacity.html new file mode 100644 index 0000000..1e9f339 --- /dev/null +++ b/localwiki/Ship_TankCapacity.html @@ -0,0 +1,77 @@ +Ship TankCapacity

      Ship TankCapacity

      + +
      +

      This documentation is not finished. Please help and contribute documentation. +

      See Draft ShapeString for good documented Command. Gui Command gives an overview over commands. And see List of Commands for other commands. +

      Go to Help FreeCAD to contribute. +

      +
      +


      +

      + + + + + + + + + + + + + + + + + + + + +
      +

      Ship TankCapacity.png Ship TankCapacity

      +
      Menu location +
      Weights → Tank capacity curve +
      Workbenches +
      Ship +
      Default shortcut +
      +
      See also +
      +

      + +
      +


      +


      +

      +

      Introduction

      +

      TODO +


      +

      +

      Tutorials

      + +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Ship_TankNew.html b/localwiki/Ship_TankNew.html new file mode 100644 index 0000000..6ed1b94 --- /dev/null +++ b/localwiki/Ship_TankNew.html @@ -0,0 +1,77 @@ +Ship TankNew

      Ship TankNew

      + +
      +

      This documentation is not finished. Please help and contribute documentation. +

      See Draft ShapeString for good documented Command. Gui Command gives an overview over commands. And see List of Commands for other commands. +

      Go to Help FreeCAD to contribute. +

      +
      +


      +

      + + + + + + + + + + + + + + + + + + + + +
      +

      Ship TankNew.png Ship TankNew

      +
      Menu location +
      Weights → Create a new tank +
      Workbenches +
      Ship +
      Default shortcut +
      +
      See also +
      +

      + +
      +


      +


      +

      +

      Introduction

      +

      TODO +


      +

      +

      Tutorials

      + +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Ship_TankNew.png b/localwiki/Ship_TankNew.png new file mode 100644 index 0000000..8779ca4 Binary files /dev/null and b/localwiki/Ship_TankNew.png differ diff --git a/localwiki/Ship_Weight.html b/localwiki/Ship_Weight.html new file mode 100644 index 0000000..94386fb --- /dev/null +++ b/localwiki/Ship_Weight.html @@ -0,0 +1,77 @@ +Ship Weight

      Ship Weight

      + +
      +

      This documentation is not finished. Please help and contribute documentation. +

      See Draft ShapeString for good documented Command. Gui Command gives an overview over commands. And see List of Commands for other commands. +

      Go to Help FreeCAD to contribute. +

      +
      +


      +

      + + + + + + + + + + + + + + + + + + + + +
      +

      Ship Weight.png Ship Weight

      +
      Menu location +
      Weights → Create a new ship weight +
      Workbenches +
      Ship +
      Default shortcut +
      +
      See also +
      +

      + +
      +


      +


      +

      +

      Introduction

      +

      TODO +


      +

      +

      Tutorials

      + +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Ship_Weight.png b/localwiki/Ship_Weight.png new file mode 100644 index 0000000..7d2bfff Binary files /dev/null and b/localwiki/Ship_Weight.png differ diff --git a/localwiki/Ship_Wieght.svg b/localwiki/Ship_Wieght.svg new file mode 100644 index 0000000..377abba --- /dev/null +++ b/localwiki/Ship_Wieght.svg @@ -0,0 +1,167 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [J.L. Cercos-Pita] + + + Ship_Weight + 2014-12-12 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Ship/resources/icons/Ship_Weight.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Ship_Workbench.html b/localwiki/Ship_Workbench.html new file mode 100644 index 0000000..63ca0ce --- /dev/null +++ b/localwiki/Ship_Workbench.html @@ -0,0 +1,53 @@ +Ship Workbench

      Ship Workbench

      + + + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Simple.svg b/localwiki/Simple.svg new file mode 100644 index 0000000..07b0da6 --- /dev/null +++ b/localwiki/Simple.svg @@ -0,0 +1,111 @@ + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Situation.jpg b/localwiki/Situation.jpg new file mode 100644 index 0000000..238b9ac Binary files /dev/null and b/localwiki/Situation.jpg differ diff --git a/localwiki/SketcherCreateFilletExample.png b/localwiki/SketcherCreateFilletExample.png new file mode 100644 index 0000000..9f16e5d Binary files /dev/null and b/localwiki/SketcherCreateFilletExample.png differ diff --git a/localwiki/SketcherCreateHeptagonExample.png b/localwiki/SketcherCreateHeptagonExample.png new file mode 100644 index 0000000..de49f3b Binary files /dev/null and b/localwiki/SketcherCreateHeptagonExample.png differ diff --git a/localwiki/SketcherCreateHexagonExample.png b/localwiki/SketcherCreateHexagonExample.png new file mode 100644 index 0000000..b053420 Binary files /dev/null and b/localwiki/SketcherCreateHexagonExample.png differ diff --git a/localwiki/SketcherCreateOctagonExample.png b/localwiki/SketcherCreateOctagonExample.png new file mode 100644 index 0000000..d96ff6f Binary files /dev/null and b/localwiki/SketcherCreateOctagonExample.png differ diff --git a/localwiki/SketcherCreatePentagonExample.png b/localwiki/SketcherCreatePentagonExample.png new file mode 100644 index 0000000..0c2abe8 Binary files /dev/null and b/localwiki/SketcherCreatePentagonExample.png differ diff --git a/localwiki/SketcherCreateRectangleExample.png b/localwiki/SketcherCreateRectangleExample.png new file mode 100644 index 0000000..54615dc Binary files /dev/null and b/localwiki/SketcherCreateRectangleExample.png differ diff --git a/localwiki/SketcherCreateSlotExample.png b/localwiki/SketcherCreateSlotExample.png new file mode 100644 index 0000000..bb5ca43 Binary files /dev/null and b/localwiki/SketcherCreateSlotExample.png differ diff --git a/localwiki/SketcherCreateSquareExample.png b/localwiki/SketcherCreateSquareExample.png new file mode 100644 index 0000000..95d5134 Binary files /dev/null and b/localwiki/SketcherCreateSquareExample.png differ diff --git a/localwiki/SketcherCreateTriangleExample.png b/localwiki/SketcherCreateTriangleExample.png new file mode 100644 index 0000000..c8cd8e6 Binary files /dev/null and b/localwiki/SketcherCreateTriangleExample.png differ diff --git a/localwiki/SketcherTrimExample1.png b/localwiki/SketcherTrimExample1.png new file mode 100644 index 0000000..50a10e9 Binary files /dev/null and b/localwiki/SketcherTrimExample1.png differ diff --git a/localwiki/SketcherTrimExample2.png b/localwiki/SketcherTrimExample2.png new file mode 100644 index 0000000..9d7b902 Binary files /dev/null and b/localwiki/SketcherTrimExample2.png differ diff --git a/localwiki/SketcherTrimExample3.png b/localwiki/SketcherTrimExample3.png new file mode 100644 index 0000000..b20e077 Binary files /dev/null and b/localwiki/SketcherTrimExample3.png differ diff --git a/localwiki/SketcherWorkbech.svg b/localwiki/SketcherWorkbech.svg new file mode 100644 index 0000000..b84b018 --- /dev/null +++ b/localwiki/SketcherWorkbech.svg @@ -0,0 +1,190 @@ + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [triplus] + + + SketcherWorkbench + 2016-02-26 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Sketcher/Gui/Resources/icons/SketcherWorkbench.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + diff --git a/localwiki/Sketcher_AlterConstruction.svg b/localwiki/Sketcher_AlterConstruction.svg new file mode 100644 index 0000000..f636bb4 --- /dev/null +++ b/localwiki/Sketcher_AlterConstruction.svg @@ -0,0 +1,225 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [wmayer] + + + Sketcher_AlterConstruction + 2011-10-10 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Sketcher/Gui/Resources/icons/Sketcher_AlterConstruction.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + diff --git a/localwiki/Sketcher_AlterFillet.svg b/localwiki/Sketcher_AlterFillet.svg new file mode 100644 index 0000000..d8a77d3 --- /dev/null +++ b/localwiki/Sketcher_AlterFillet.svg @@ -0,0 +1,158 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [wmayer] + + + Sketcher_AlterFillet + 2011-10-10 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Sketcher/Gui/Resources/icons/Sketcher_Alter + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Sketcher_Arc.html b/localwiki/Sketcher_Arc.html new file mode 100644 index 0000000..b036592 --- /dev/null +++ b/localwiki/Sketcher_Arc.html @@ -0,0 +1,71 @@ +Sketcher Arc

      Sketcher Arc

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Sketcher Arc.png Sketcher Arc

      +
      Menu location +
      Sketch → Sketcher geometries → Create arc +
      Workbenches +
      Sketcher, Part Design +
      Default shortcut +
      None +
      See also +
      Sketcher Circle +

      Contents

      + +
      + +
      +


      +

      +

      Description

      +

      This tool draws an arc by picking three points: the center, the start angle along the radius, and the end angle. +

      When starting the tool, the mouse pointer changes to a white cross with a red arc icon. The coordinates of the pointer are shown beside it in blue in real time. +

      The center has been selected, dragging to set the radius‎ The center and start angle have been selected, dragging to set end angle‎ +

      +

      Usage

      +
      • Pick points on an empty area of the 3D view, or on an existing object (auto constraints must be active in TaskView).
      • +
      • Pressing ESC or clicking the right mouse button cancels the function.
      +


      +

      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Sketcher_Arc3Point.html b/localwiki/Sketcher_Arc3Point.html new file mode 100644 index 0000000..c1b823d --- /dev/null +++ b/localwiki/Sketcher_Arc3Point.html @@ -0,0 +1,74 @@ +Sketcher Arc3Point

      Sketcher Arc3Point

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Sketcher CreateArc3Point.png Sketcher CreateArc3Point

      +
      Menu location +
      Sketch → Sketcher geometries → Create Arc by three points +
      Workbenches +
      Sketcher, PartDesign +
      Default shortcut +
      +
      See also +
      +

      + +
      +


      +

      +

      Description

      +

      This tool draws an arc by picking three points: the start point, the end point and a point on the arc. +


      +

      +

      Usage

      +

      When starting the tool, the mouse pointer changes to a white cross with a red arc icon. The coordinates of the pointer are shown beside it in blue in real time. +

      +
      • Pick points on an empty area of the 3D view, or on an existing object (auto constraints must be active in TaskView).
      • +
      • Pressing ESC or clicking the right mouse button cancels the function.
      +


      +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Sketcher_ArcExample1.png b/localwiki/Sketcher_ArcExample1.png new file mode 100644 index 0000000..bb58dcd Binary files /dev/null and b/localwiki/Sketcher_ArcExample1.png differ diff --git a/localwiki/Sketcher_Arc_of_Ellipse.html b/localwiki/Sketcher_Arc_of_Ellipse.html new file mode 100644 index 0000000..0b870d8 --- /dev/null +++ b/localwiki/Sketcher_Arc_of_Ellipse.html @@ -0,0 +1,80 @@ +Sketcher Arc of Ellipse

      Sketcher Arc of Ellipse

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Sketcher CreateArcOfEllipse.png Sketcher CreateArcOfEllipse

      +
      Menu location +
      Sketch → Sketcher geometries → Create an arc of ellipse +
      Workbenches +
      Sketcher, Part Design +
      Default shortcut +
      None +
      See also +
      Sketcher Ellipse, Sketcher Arc +

      + +
      +


      +

      +

      Description

      +

      This tool draws an arc of ellipse by picking four points: the center, the end of major radius, the start point and the end point. +When starting the tool, the mouse pointer changes to a white cross with a red ellipse arc icon. Besides are coordinates shown in real time. +

      +
      The sequence of clicks is indicated by yellow arrows with numbers. C is the center, a - major diameter, b - minor diameter, F1, F2 are foci.
      +

      Usage

      +
      • Invoke the command by clicking a toolbar button, picking the menu item, or by using keyboard shortcut (needs to be assigned first in Interface Customization).
      • +
      • First click in 3D view sets ellipse center. Second click sets the first radius and orientation of the ellipse. Third click sets the other radius and the start of the arc. The fourth click sets the end of the arc.
      • +
      • After the fourth click, the arc of ellipse is created, together with a set of construction geometry aligned to it (major diameter, minor diameter, two foci). The construction geometry can be manually deleted if not needed, and recreated later. See Internal Alignment Constraint and Sketcher Show Hide Internal Geometry.
      • +
      • Pressing ESC or clicking the right mouse button cancels the function.
      +

      Peculiarities

      +
      • Major and minor axes of underlying ellipse are strict and cannot be swapped by resizing. The underlying ellipse must be rotated to swap the axes.
      • +
      • Unlike ellipse that can be constrained to become a circle, ellipse arc cannot represent an arc of circle.
      • +
      • Moving the arc of ellipse by edge is the same as moving ellipse's center.
      +

      Version

      +

      Introduced in FreeCAD v0.15.4309 +

      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Sketcher_BSplineApproximate.svg b/localwiki/Sketcher_BSplineApproximate.svg new file mode 100644 index 0000000..88f6c33 --- /dev/null +++ b/localwiki/Sketcher_BSplineApproximate.svg @@ -0,0 +1,174 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [agryson] Alexander Gryson + + + Sketcher_Create3PointCircle + 2017-02-16 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Sketcher/Gui/Resources/icons/Sketcher_Create3PointCircle.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson, [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Sketcher_BSplineComb.svg b/localwiki/Sketcher_BSplineComb.svg new file mode 100644 index 0000000..375e690 --- /dev/null +++ b/localwiki/Sketcher_BSplineComb.svg @@ -0,0 +1,142 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [agryson] Alexander Gryson + + + Sketcher_CreateBSpline + 2017-02-15 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Sketcher/Gui/Resources/icons/Sketcher_CreateBSpline.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson, [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Sketcher_BSplineDecreaseDegree.svg b/localwiki/Sketcher_BSplineDecreaseDegree.svg new file mode 100644 index 0000000..01524a9 --- /dev/null +++ b/localwiki/Sketcher_BSplineDecreaseDegree.svg @@ -0,0 +1,190 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [agryson] Alexander Gryson + + + Sketcher_Create_Periodic_BSpline + 2017-02-15 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Sketcher/Gui/Resources/icons/Sketcher_Toggle_BSpline_Information.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson, [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Sketcher_BSplineDecreaseKnotMultiplicity.svg b/localwiki/Sketcher_BSplineDecreaseKnotMultiplicity.svg new file mode 100644 index 0000000..49189f8 --- /dev/null +++ b/localwiki/Sketcher_BSplineDecreaseKnotMultiplicity.svg @@ -0,0 +1,787 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [agryson] Alexander Gryson + + + Sketcher_Create_Periodic_BSpline + 2017-02-15 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Sketcher/Gui/Resources/icons/Sketcher_Toggle_BSpline_Information.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Sketcher_BSplineDegree.svg b/localwiki/Sketcher_BSplineDegree.svg new file mode 100644 index 0000000..44a2890 --- /dev/null +++ b/localwiki/Sketcher_BSplineDegree.svg @@ -0,0 +1,175 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [agryson] Alexander Gryson + + + Sketcher_Create_Periodic_BSpline + 2017-02-15 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Sketcher/Gui/Resources/icons/Sketcher_Toggle_BSpline_Information.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson, [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Sketcher_BSplineIncreaseDegree.svg b/localwiki/Sketcher_BSplineIncreaseDegree.svg new file mode 100644 index 0000000..44f6cec --- /dev/null +++ b/localwiki/Sketcher_BSplineIncreaseDegree.svg @@ -0,0 +1,186 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [agryson] Alexander Gryson + + + Sketcher_Create_Periodic_BSpline + 2017-02-16 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Sketcher/Gui/Resources/icons/Sketcher_Toggle_BSpline_Information.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson, [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Sketcher_BSplineIncreaseKnotMultiplicity.svg b/localwiki/Sketcher_BSplineIncreaseKnotMultiplicity.svg new file mode 100644 index 0000000..353cbf6 --- /dev/null +++ b/localwiki/Sketcher_BSplineIncreaseKnotMultiplicity.svg @@ -0,0 +1,760 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [agryson] Alexander Gryson + + + Sketcher_Create_Periodic_BSpline + 2017-02-16 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Sketcher/Gui/Resources/icons/Sketcher_Toggle_BSpline_Information.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Sketcher_BSplineKnotMultiplicity.svg b/localwiki/Sketcher_BSplineKnotMultiplicity.svg new file mode 100644 index 0000000..7f5df54 --- /dev/null +++ b/localwiki/Sketcher_BSplineKnotMultiplicity.svg @@ -0,0 +1,695 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [agryson] Alexander Gryson + + + Sketcher_Create_Periodic_BSpline + 2017-02-15 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Sketcher/Gui/Resources/icons/Sketcher_Toggle_BSpline_Information.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Sketcher_BSplinePolygon.svg b/localwiki/Sketcher_BSplinePolygon.svg new file mode 100644 index 0000000..2175eb3 --- /dev/null +++ b/localwiki/Sketcher_BSplinePolygon.svg @@ -0,0 +1,126 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [Abdullah Tahiri] + + + Sketcher_Create_Periodic_BSpline + 2017-01-13 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Sketcher/Gui/Resources/icons/Sketcher_Toggle_BSpline_Information.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson, [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Sketcher_CarbonCopy.svg b/localwiki/Sketcher_CarbonCopy.svg new file mode 100644 index 0000000..6fcb9f0 --- /dev/null +++ b/localwiki/Sketcher_CarbonCopy.svg @@ -0,0 +1,244 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [wmayer] + + + Sketcher_Sketch + 2011-10-10 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Sketcher/Gui/Resources/icons/Sketcher_Sketch.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Sketcher_CarbonCopy_Constr.svg b/localwiki/Sketcher_CarbonCopy_Constr.svg new file mode 100644 index 0000000..32217a5 --- /dev/null +++ b/localwiki/Sketcher_CarbonCopy_Constr.svg @@ -0,0 +1,244 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [wmayer] + + + Sketcher_Sketch + 2011-10-10 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Sketcher/Gui/Resources/icons/Sketcher_Sketch.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Sketcher_Circle.html b/localwiki/Sketcher_Circle.html new file mode 100644 index 0000000..5b342c3 --- /dev/null +++ b/localwiki/Sketcher_Circle.html @@ -0,0 +1,71 @@ +Sketcher Circle

      Sketcher Circle

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Sketcher Circle.png Sketcher Circle

      +
      Menu location +
      Sketch → Sketcher geometries → Create circle +
      Workbenches +
      Sketcher, Part Design +
      Default shortcut +
      None +
      See also +
      Sketcher Arc +

      + +
      +


      +

      +

      Description

      +

      This tool draws a circle by picking two points: the center, and a point along the radius. +When starting the tool, the mouse pointer changes to a white cross with a red circle icon. Besides are coordinates shown in real time. +

      Sketcher CircleExample1.png +

      +

      Usage

      +
      • Pick points on an empty area of the 3D view, or on an existing object (auto constraints must be active in TaskView).
      • +
      • Pressing ESC or clicking the right mouse button cancels the function.
      +


      +

      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Sketcher_Circle3Point.html b/localwiki/Sketcher_Circle3Point.html new file mode 100644 index 0000000..1451088 --- /dev/null +++ b/localwiki/Sketcher_Circle3Point.html @@ -0,0 +1,73 @@ +Sketcher Circle3Point

      Sketcher Circle3Point

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Sketcher CreateCircle3Point.png Sketcher CreateCircle3Point

      +
      Menu location +
      Sketch → Sketcher geometries → Create circle by three points +
      Workbenches +
      Sketcher, PartDesign +
      Default shortcut +
      +
      See also +
      +

      + +
      +


      +

      +

      Description

      +

      This tool draws a circle by picking three points on the circle outline. +When starting the tool, the mouse pointer changes to a white cross with a red circle icon. +Besides are coordinates shown in real time. +


      +

      +

      Usage

      +
      • Pick points on an empty area of the 3D view, or on an existing object (auto constraints must be active in TaskView).
      • +
      • Pressing ESC or clicking the right mouse button cancels the function.
      +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Sketcher_CircleExample1.png b/localwiki/Sketcher_CircleExample1.png new file mode 100644 index 0000000..7b64160 Binary files /dev/null and b/localwiki/Sketcher_CircleExample1.png differ diff --git a/localwiki/Sketcher_Clone.html b/localwiki/Sketcher_Clone.html new file mode 100644 index 0000000..7692b8e --- /dev/null +++ b/localwiki/Sketcher_Clone.html @@ -0,0 +1,77 @@ +Sketcher Clone

      Sketcher Clone

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Sketcher Clone.png Sketcher Clone

      +
      Menu location +
      Sketch → Sketcher tools → Clone +
      Workbenches +
      Sketcher, PartDesign +
      Default shortcut +
      +
      See also +
      +

      + +
      +


      +

      +

      Description

      +

      Clones a sketcher element. +


      +

      +

      Usage

      +
      1. Select sketcher element for clone operation.
      2. +
      3. Clíck on Sketcher Clone.png or choose Sketch Sketcher toolsSketcher Clone.png Clone from the top menu.
      4. +
      5. Place clone in the 3D-View.
      +

      No extra constraints for clone-behaviour are added. +


      +

      +

      Notes

      +

      Available since FreeCAD v 0.16. +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Sketcher_Clone.svg b/localwiki/Sketcher_Clone.svg new file mode 100644 index 0000000..eea0f97 --- /dev/null +++ b/localwiki/Sketcher_Clone.svg @@ -0,0 +1,131 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [Abdullah Tahiri] + + + Sketcher_Clone + 2015-08-15 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Sketcher/Gui/Resources/icons/Sketcher_Clone.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Sketcher_CloseShape.html b/localwiki/Sketcher_CloseShape.html new file mode 100644 index 0000000..4bdc0fb --- /dev/null +++ b/localwiki/Sketcher_CloseShape.html @@ -0,0 +1,78 @@ +Sketcher CloseShape

      Sketcher CloseShape

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Sketcher CloseShape.png Sketcher CloseShape

      +
      Menu location +
      Sketch → Sketcher tools → Close Shape +
      Workbenches +
      Sketcher +
      Default shortcut +
      Shift+Ctrl+S +
      See also +
      +

      + +
      +


      +

      +

      Description

      +

      This tool can be used to make a selected contour in sketcher closed by making an endpoint of a sketcher element coincident with the endpoint of the sketcher element selected next. +

      +

      Usage

      +

      While editing a sketch, multi-select your sketcher elements in the tree-view or in the 3D-View and click on the icon or use "Sketch > Sketcher Tools > Close Shape" from the FreeCAD-Menu +or use <CTRL+Shift+S>. +

      +

      Notes

      +

      The tool will connect the elements in the order of their selection, so make sure to click and select in the correct order. +

      +

      Limitations

      +


      +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Sketcher_CloseShape.svg b/localwiki/Sketcher_CloseShape.svg new file mode 100644 index 0000000..5e46459 --- /dev/null +++ b/localwiki/Sketcher_CloseShape.svg @@ -0,0 +1,126 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [wmayer] + + + Sketcher_CloseShape + 2014-08-04 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Sketcher/Gui/Resources/icons/Sketcher_CloseShape.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Sketcher_Conic_Sections.html b/localwiki/Sketcher_Conic_Sections.html new file mode 100644 index 0000000..3e1ba7d --- /dev/null +++ b/localwiki/Sketcher_Conic_Sections.html @@ -0,0 +1,72 @@ +Sketcher Conic Sections

      Sketcher Conic Sections

      + +
      +

      This documentation is not finished. Please help and contribute documentation. +

      See Draft ShapeString for good documented Command. Gui Command gives an overview over commands. And see List of Commands for other commands. +

      Go to Help FreeCAD to contribute. +

      +
      + + + + + + + + + + + + + + + + + + + + +
      +

      Sketcher Conics.png Sketcher Conics

      +
      Menu location +
      Sketch → Sketcher geometries → Create a conic... +
      Workbenches +
      Sketcher, Part Design +
      Default shortcut +
      None +
      See also +
      Sketcher Ellipse by 3 Points, Sketcher Circle, Sketcher Arc of Ellipse +

      + +
      +


      +

      +

      Description

      +

      Version

      +

      Introduced in FreeCAD v0.15.4309 +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Sketcher_Conics.svg b/localwiki/Sketcher_Conics.svg new file mode 100644 index 0000000..9860a5f --- /dev/null +++ b/localwiki/Sketcher_Conics.svg @@ -0,0 +1,125 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [Abdullah Tahiri] + + + Sketcher_Conics + 2014-11-11 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Sketcher/Gui/Resources/icons/Sketcher_Conics.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Sketcher_Conics_Constr.svg b/localwiki/Sketcher_Conics_Constr.svg new file mode 100644 index 0000000..b14b092 --- /dev/null +++ b/localwiki/Sketcher_Conics_Constr.svg @@ -0,0 +1,125 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [Abdullah Tahiri] + + + Sketcher_Conics_Constr + 2015-05-24 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Sketcher/Gui/Resources/icons/Sketcher_Conics_Constr.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Sketcher_Conics_Ellipse_3points.svg b/localwiki/Sketcher_Conics_Ellipse_3points.svg new file mode 100644 index 0000000..de9e549 --- /dev/null +++ b/localwiki/Sketcher_Conics_Ellipse_3points.svg @@ -0,0 +1,175 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [Abdullah Tahiri] + + + Sketcher_Conics_Ellipse_3points + 2014-11-11 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Sketcher/Gui/Resources/icons/Sketcher_Conics_Ellipse_3points.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Sketcher_Conics_Ellipse_Center.svg b/localwiki/Sketcher_Conics_Ellipse_Center.svg new file mode 100644 index 0000000..38ea01c --- /dev/null +++ b/localwiki/Sketcher_Conics_Ellipse_Center.svg @@ -0,0 +1,192 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [Abdullah Tahiri] + + + Sketcher_Conics_Ellipse_Center + 2014-11-11 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Sketcher/Gui/Resources/icons/Sketcher_Conics_Ellipse_Center.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Sketcher_ConnectLines.html b/localwiki/Sketcher_ConnectLines.html new file mode 100644 index 0000000..c69f567 --- /dev/null +++ b/localwiki/Sketcher_ConnectLines.html @@ -0,0 +1,76 @@ +Sketcher ConnectLines

      Sketcher ConnectLines

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Sketcher ConnectLines.png Sketcher ConnectLines

      +
      Menu location +
      Sketch → Sketcher tools → Connect Edges +
      Workbenches +
      Sketcher +
      Default shortcut +
      Ctrl+Shift+K +
      See also +
      +

      + +
      +


      +

      +

      Description

      +

      Applies PointOnPoint-Constraints to endpoints with the same coordinates of the selected elements. +

      +

      Usage

      +

      Select the elements in the 3D-view or in the listbox on the left side of the screen and click on the icon. +

      +

      Notes

      +

      Before using this command make sure that obvious constraints (horizontal, vertical, tangential) are already applied to the elements. +Selecting the elements in a counter-clock-wise order seems to produce better results. +


      +


      +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Sketcher_ConnectLines.svg b/localwiki/Sketcher_ConnectLines.svg new file mode 100644 index 0000000..6a5b928 --- /dev/null +++ b/localwiki/Sketcher_ConnectLines.svg @@ -0,0 +1,114 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [wmayer] + + + Sketcher_ConnectLines + 2014-08-04 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Sketcher/Gui/Resources/icons/Sketcher_ConnectLines.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Sketcher_ConstrainBlock.svg b/localwiki/Sketcher_ConstrainBlock.svg new file mode 100644 index 0000000..6a77764 --- /dev/null +++ b/localwiki/Sketcher_ConstrainBlock.svg @@ -0,0 +1,525 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [wmayer] + + + Sketcher_ConstrainLock + 2011-10-10 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Sketcher/Gui/Resources/icons/Sketcher_ConstrainLock.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Sketcher_ConstrainCoincident.svg b/localwiki/Sketcher_ConstrainCoincident.svg new file mode 100644 index 0000000..6178a89 --- /dev/null +++ b/localwiki/Sketcher_ConstrainCoincident.svg @@ -0,0 +1,82 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + [wmayer] + + + Sketcher_ConstrainCoincident + 2011-10-10 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Sketcher/Gui/Resources/icons/Sketcher_ConstrainCoincident.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + diff --git a/localwiki/Sketcher_ConstrainDistance.svg b/localwiki/Sketcher_ConstrainDistance.svg new file mode 100644 index 0000000..4619685 --- /dev/null +++ b/localwiki/Sketcher_ConstrainDistance.svg @@ -0,0 +1,62 @@ + + + + + + + + + + + + + image/svg+xml + + + + + [wmayer] + + + Sketcher_ConstrainDistance + 2011-10-10 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Sketcher/Gui/Resources/icons/Sketcher_ConstrainDistance.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Sketcher_ConstrainHorizontal.svg b/localwiki/Sketcher_ConstrainHorizontal.svg new file mode 100644 index 0000000..a896a9a --- /dev/null +++ b/localwiki/Sketcher_ConstrainHorizontal.svg @@ -0,0 +1,65 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + [wmayer] + + + Sketcher_ConstrainHorizontal + 2011-10-10 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Sketcher/Gui/Resources/icons/Sketcher_ConstrainHorizontal.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + diff --git a/localwiki/Sketcher_ConstrainLock.svg b/localwiki/Sketcher_ConstrainLock.svg new file mode 100644 index 0000000..0a66995 --- /dev/null +++ b/localwiki/Sketcher_ConstrainLock.svg @@ -0,0 +1,139 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [wmayer] + + + Sketcher_ConstrainLock + 2011-10-10 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Sketcher/Gui/Resources/icons/Sketcher_ConstrainLock.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Sketcher_ConstrainLock_Driven.svg b/localwiki/Sketcher_ConstrainLock_Driven.svg new file mode 100644 index 0000000..eeb4789 --- /dev/null +++ b/localwiki/Sketcher_ConstrainLock_Driven.svg @@ -0,0 +1,140 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [Abdullah Tahiri] + + + Sketcher_ConstrainLock_Driven + 2015-05-24 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Sketcher/Gui/Resources/icons/Sketcher_ConstrainLock_Driven.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Sketcher_ConstrainParallel.svg b/localwiki/Sketcher_ConstrainParallel.svg new file mode 100644 index 0000000..35310e4 --- /dev/null +++ b/localwiki/Sketcher_ConstrainParallel.svg @@ -0,0 +1,57 @@ + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [wmayer] + + + Sketcher_ConstrainParallel + 2011-10-10 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Sketcher/Gui/Resources/icons/Sketcher_ConstrainParallel.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + diff --git a/localwiki/Sketcher_ConstrainTangent.html b/localwiki/Sketcher_ConstrainTangent.html new file mode 100644 index 0000000..1167ff2 --- /dev/null +++ b/localwiki/Sketcher_ConstrainTangent.html @@ -0,0 +1,136 @@ +Sketcher ConstrainTangent

      Sketcher ConstrainTangent

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Sketcher ConstrainTangent.png Sketcher ConstrainTangent

      +
      Menu location +
      Sketch → Sketcher constraints → Constrain tangent +
      Workbenches +
      Sketcher, PartDesign +
      Default shortcut +
      None +
      See also +
      Constraint point on object +

      + +
      +


      +

      +

      Description

      +

      Tangent Constraint makes two curves to touch each other (be tangent). Lines are treated infinite, and arcs are treated as full circles/ellipses. The constraint is also capable of connecting two curves, forcing them tangent at the joint, thus making the joint smooth. +

      +

      How to use

      +

      There are four different ways the constraint can be applied: +

      +
      1. between two curves (available not for all curves)
      2. +
      3. between two endpoints of a curve, making a smooth joint
      4. +
      5. between a curve and an endpoint of another curve
      6. +
      7. between two curves at user-defined point
      +

      To apply tangent constraint, one should the follow the steps: +

      +
      • Select two or three entities in the sketch.
      • +
      • Invoke the constraint by clicking its icon on the toolbar, or selecting the menu item, or using keyboard shortcut.
      +

      Between two curves (direct tangency)

      +

      Sketcher ConsraintTangent mode1.png +

      Two curves will be made tangent, and the point of tangency will be implicit. This mode is applied if two curves were selected. +

      Accepted selection: +

      +
      • line + line, circle, arc, ellipse, arc-of-ellipse
      • +
      • circle, arc + circle, arc
      +

      If direct tangency between selected curves is not supported (e.g. between a circle and an ellipse), a helper point will be added to sketch automatically, and tangency-via-point will be applied. +

      It is not recommended to reconstruct the point of tangency by creating a point and constraining it to lie on both curves. It will work, but the convergence will be seriously slower, jumpier, and will require about twice as many iterations to converge than normal. Use other modes of this constraint if the point of tangency is needed. +

      +

      Between two endpoints (point-to-point tangency)

      +

      Sketcher ConsraintTangent mode2.png +

      In this mode, the endpoints are made coincident, and the joint is made tangent (C1-smooth, or "sharp", depending on the placement of curves before the constraint is applied). This mode is applied when two endpoints of two curves were selected. +

      Accepted selection: +

      +
      • endpoint of line/arc/arc-of-ellipse + endpoint of line/arc/arc-of-ellipse (i.e., two endpoints of any two curves)
      +

      Between curve and endpoint (point-to-curve tangency)

      +

      Sketcher ConsraintTangent mode3.png +

      In this mode, an endpoint of one curve is constrained to lie on the other curve, and the curves are forced tangent at the point. This mode is applied when a curve and an endpoint of another curve were selected. +

      Accepted selection: +

      +
      • line, circle, arc, ellipse, arc-of-ellipse + endpoint of line/arc/arc-of-ellipse (i.e., any curve + endpoint of any curve)
      +


      +

      +

      Between two curves at point (tangent-via-point) (v0.15)

      +

      Sketcher ConsraintTangent mode4.png +

      In this mode, two curves are made tangent, and the point of tangency is tracked. This mode is applied when two curves and a point were selected. +

      Accepted selection: +

      +
      • any line/curve + any line/curve + any point
      +

      "Any point" can be a lone point, or a point of something, e.g. a center of a circle, an endpoint of an arc, or the origin. +

      For the constraint to work correctly, the point must be on both curves. So, as the constraint is invoked, the point will be automatically constrained onto both curves (helper constraints will be added, if necessary), and the curves will be forced tangent at the point. These helper constraints are plain regular constraints. They can be added manually, or deleted. +

      Compared to direct tangency, this constraint is slower, because there are more degrees of freedom involved, but if the point of tangency is needed, it is the recommended mode because it offers better convergence compared to direct tangency + point on two curves. +

      The placement of the point before the constraint is applied is a hint for the solver for where the tangency should be. With this constraint, one can constrain two ellipses to touch each other in two places. +

      +

      Scripting

      +

      Tangent Constraint can be created from macros and from the python console by using the following: +

      +
      # direct tangency
      +Sketch.addConstraint(Sketcher.Constraint('Tangent',icurve1,icurve2))
      +
      +# point-to-point tangency
      +Sketch.addConstraint(Sketcher.Constraint('Tangent',icurve1,pointpos1,icurve2,pointpos2))
      +
      +# point-to-curve tangency
      +Sketch.addConstraint(Sketcher.Constraint('Tangent',icurve1,pointpos1,icurve2))
      +
      +# tangent-via-point (plain constraint, helpers are not added automatically)
      +Sketch.addConstraint(Sketcher.Constraint('TangentViaPoint',icurve1,icurve2,geoidpoint,pointpos)) 
      +

      where: +

      +
      • Sketch is a sketch object
      • +
      • icurve1, icurve2 are two integers identifying the curves to be made tangent. The integers are indexes in the sketch (the value, returned by Sketch.addGeometry).
      • +
      • pointpos1, pointpos2 should be 1 for start point and 2 for end point.
      • +
      • geoidpoint and pointpos in TangentViaPoint are the indexes specifying the point of tangency.
      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Sketcher_ConstrainTangent.png b/localwiki/Sketcher_ConstrainTangent.png new file mode 100644 index 0000000..6778026 Binary files /dev/null and b/localwiki/Sketcher_ConstrainTangent.png differ diff --git a/localwiki/Sketcher_ConstrainVertical.svg b/localwiki/Sketcher_ConstrainVertical.svg new file mode 100644 index 0000000..bcf6f1f --- /dev/null +++ b/localwiki/Sketcher_ConstrainVertical.svg @@ -0,0 +1,68 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + [wmayer] + + + Sketcher_ConstrainVertical + 2011-10-10 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Sketcher/Gui/Resources/icons/Sketcher_ConstrainVertical.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + diff --git a/localwiki/Sketcher_ConstructionMode.html b/localwiki/Sketcher_ConstructionMode.html new file mode 100644 index 0000000..5689595 --- /dev/null +++ b/localwiki/Sketcher_ConstructionMode.html @@ -0,0 +1,93 @@ +Sketcher ConstructionMode

      Sketcher ConstructionMode

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Sketcher AlterConstruction.png Sketcher AlterConstruction

      +
      Menu location +
      Sketch → Sketcher geometries → Toggle construction line +
      Workbenches +
      Sketcher, PartDesign +
      Default shortcut +
      None +
      See also +
      None +

      + +
      +


      +

      +

      Description

      +

      This tool toggles sketch geometry from/to construction mode. It can be used on any type of geometry: line, arc or circle. +

      Sketcher Mode de Construction +

      +
      +

      Construction geometry is an important tool of the sketcher. When using a sketch for a 3D operation, construction geometry is ignored. +

      In sketch edit mode, construction geometry is shown as blue, and won't turn green when a sketch is fully constrained. Once you exit the sketch mode, construction geometry is hidden on the screen. +

      Note: starting with v0.13, construction lines can be used as rotation axis by the PartDesign Revolution feature. +

      +

      Usage

      +
      • Select one or more sketch geometry in the 3D view, then click on the tool or access it in the menu.
      +
      +

      Example

      +
      + +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Sketcher_Copy.html b/localwiki/Sketcher_Copy.html new file mode 100644 index 0000000..46faf3d --- /dev/null +++ b/localwiki/Sketcher_Copy.html @@ -0,0 +1,78 @@ +Sketcher Copy

      Sketcher Copy

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Sketcher Copy.png Sketcher Copy

      +
      Menu location +
      Sketch → Sketcher tools → Copy +
      Workbenches +
      Sketcher, PartDesign +
      Default shortcut +
      +
      See also +
      +

      + +
      +


      +

      +

      Description

      +

      Copies a sketcher element. +


      +

      +

      Usage

      +
      1. Select sketcher element for copy operation.
      2. +
      3. Clíck on Sketcher Copy.png or choose Sketch Sketcher toolsSketcher Copy.png Copy from the top menu.
      4. +
      5. Place copy in the 3D-View.
      +

      No extra constraints are added. +


      +

      +

      Notes

      +

      Available since FreeCAD v 0.16. +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Sketcher_Copy.svg b/localwiki/Sketcher_Copy.svg new file mode 100644 index 0000000..ef16d96 --- /dev/null +++ b/localwiki/Sketcher_Copy.svg @@ -0,0 +1,129 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [Abdullah Tahiri] + + + Sketcher_Copy + 2015-08-11 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Sketcher/Gui/Resources/icons/Sketcher_Copy.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Sketcher_Create3PointArc.svg b/localwiki/Sketcher_Create3PointArc.svg new file mode 100644 index 0000000..b5be853 --- /dev/null +++ b/localwiki/Sketcher_Create3PointArc.svg @@ -0,0 +1,100 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [wmayer] + + + Sketcher_Create3PointArc + 2014-03-15 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Sketcher/Gui/Resources/icons/Sketcher_Create3PointArc.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Sketcher_Create3PointArc_Constr.svg b/localwiki/Sketcher_Create3PointArc_Constr.svg new file mode 100644 index 0000000..aed5521 --- /dev/null +++ b/localwiki/Sketcher_Create3PointArc_Constr.svg @@ -0,0 +1,100 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [Abdullah Tahiri] + + + Sketcher_Create3PointArc_Constr + 2015-05-24 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Sketcher/Gui/Resources/icons/Sketcher_Create3PointArc_Constr.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Sketcher_Create3PointCircle.svg b/localwiki/Sketcher_Create3PointCircle.svg new file mode 100644 index 0000000..5d17724 --- /dev/null +++ b/localwiki/Sketcher_Create3PointCircle.svg @@ -0,0 +1,133 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [wmayer] + + + Sketcher_Create3PointCircle + 2014-03-29 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Sketcher/Gui/Resources/icons/Sketcher_Create3PointCircle.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Sketcher_Create3PointCircle_Constr.svg b/localwiki/Sketcher_Create3PointCircle_Constr.svg new file mode 100644 index 0000000..5013ede --- /dev/null +++ b/localwiki/Sketcher_Create3PointCircle_Constr.svg @@ -0,0 +1,133 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [Abdullah Tahiri] + + + Sketcher_Create3PointCircle_Constr + 2015-05-24 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Sketcher/Gui/Resources/icons/Sketcher_Create3PointCircle_Constr.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Sketcher_CreateArc.svg b/localwiki/Sketcher_CreateArc.svg new file mode 100644 index 0000000..a93bfa1 --- /dev/null +++ b/localwiki/Sketcher_CreateArc.svg @@ -0,0 +1,99 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + [wmayer] + + + Sketcher_CreateArc + 2011-10-10 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Sketcher/Gui/Resources/icons/Sketcher_CreateArc.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Sketcher_CreateArc_Constr.svg b/localwiki/Sketcher_CreateArc_Constr.svg new file mode 100644 index 0000000..a53e19a --- /dev/null +++ b/localwiki/Sketcher_CreateArc_Constr.svg @@ -0,0 +1,96 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [Abdullah Tahiri] + + + Sketcher_CreateArc_Constr + 2015-05-24 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Sketcher/Gui/Resources/icons/Sketcher_CreateArc_Constr.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Sketcher_CreateBSpline.svg b/localwiki/Sketcher_CreateBSpline.svg new file mode 100644 index 0000000..7f5707c --- /dev/null +++ b/localwiki/Sketcher_CreateBSpline.svg @@ -0,0 +1,110 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [Abdullah Tahiri] + + + Sketcher_CreateBSpline + 2017-01-07 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Sketcher/Gui/Resources/icons/Sketcher_CreateBSpline.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Sketcher_CreateBSpline_Constr.svg b/localwiki/Sketcher_CreateBSpline_Constr.svg new file mode 100644 index 0000000..42445f2 --- /dev/null +++ b/localwiki/Sketcher_CreateBSpline_Constr.svg @@ -0,0 +1,110 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [Abdullah Tahiri] + + + Sketcher_CreateBSpline_Constr + 2017-01-07 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Sketcher/Gui/Resources/icons/Sketcher_CreateBSpline_Constr.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Sketcher_CreateCircle.svg b/localwiki/Sketcher_CreateCircle.svg new file mode 100644 index 0000000..1786327 --- /dev/null +++ b/localwiki/Sketcher_CreateCircle.svg @@ -0,0 +1,96 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + [wmayer] + + + Sketcher_CreateCircle + 2011-10-10 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Sketcher/Gui/Resources/icons/Sketcher_CreateCircle.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Sketcher_CreateCircle_Constr.svg b/localwiki/Sketcher_CreateCircle_Constr.svg new file mode 100644 index 0000000..3810439 --- /dev/null +++ b/localwiki/Sketcher_CreateCircle_Constr.svg @@ -0,0 +1,97 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [Abdullah Tahiri] + + + Sketcher_CreateCircle_Constr + 2015-05-24 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Sketcher/Gui/Resources/icons/Sketcher_CreateCircle_Constr.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Sketcher_CreateEllipse.svg b/localwiki/Sketcher_CreateEllipse.svg new file mode 100644 index 0000000..bccb53f --- /dev/null +++ b/localwiki/Sketcher_CreateEllipse.svg @@ -0,0 +1,108 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [Abdullah Tahiri] + + + Sketcher_CreateEllipse + 2014-11-11 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Sketcher/Gui/Resources/icons/Sketcher_CreateEllipse.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Sketcher_CreateEllipse_3points.svg b/localwiki/Sketcher_CreateEllipse_3points.svg new file mode 100644 index 0000000..cc91e2b --- /dev/null +++ b/localwiki/Sketcher_CreateEllipse_3points.svg @@ -0,0 +1,108 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [Abdullah Tahiri] + + + Sketcher_CreateEllipse_3points + 2014-10-28 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Sketcher/Gui/Resources/icons/Sketcher_CreateEllipse_3points.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Sketcher_CreateEllipse_3points_Constr.svg b/localwiki/Sketcher_CreateEllipse_3points_Constr.svg new file mode 100644 index 0000000..64e48ba --- /dev/null +++ b/localwiki/Sketcher_CreateEllipse_3points_Constr.svg @@ -0,0 +1,103 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [Abdullah Tahiri] + + + Sketcher_CreateEllipse_3points_Constr + 2015-05-24 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Sketcher/Gui/Resources/icons/Sketcher_CreateEllipse_3points_Constr.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Sketcher_CreateEllipse_Constr.svg b/localwiki/Sketcher_CreateEllipse_Constr.svg new file mode 100644 index 0000000..51f6a74 --- /dev/null +++ b/localwiki/Sketcher_CreateEllipse_Constr.svg @@ -0,0 +1,103 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [Abdullah Tahiri] + + + Sketcher_CreateEllipse_Constr + 2015-05-24 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Sketcher/Gui/Resources/icons/Sketcher_CreateEllipse_Constr.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Sketcher_CreateFillet.svg b/localwiki/Sketcher_CreateFillet.svg new file mode 100644 index 0000000..38bb5b9 --- /dev/null +++ b/localwiki/Sketcher_CreateFillet.svg @@ -0,0 +1,111 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [wmayer] + + + Sketcher_CreateFillet + 2011-10-10 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Sketcher/Gui/Resources/icons/Sketcher_Create + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Sketcher_CreateHeptagon.svg b/localwiki/Sketcher_CreateHeptagon.svg new file mode 100644 index 0000000..c54ccdb --- /dev/null +++ b/localwiki/Sketcher_CreateHeptagon.svg @@ -0,0 +1,102 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [Johan K] + + + Sketcher_CreateHeptagon + 2014-07-27 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Sketcher/Gui/Resources/icons/Sketcher_CreateHeptagon.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Sketcher_CreateHeptagon_Constr.svg b/localwiki/Sketcher_CreateHeptagon_Constr.svg new file mode 100644 index 0000000..0204ec5 --- /dev/null +++ b/localwiki/Sketcher_CreateHeptagon_Constr.svg @@ -0,0 +1,102 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [Abdullah Tahiri] + + + Sketcher_CreateHeptagon_Constr + 2015-05-24 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Sketcher/Gui/Resources/icons/Sketcher_CreateHeptagon_Constr.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Sketcher_CreateHexagon.svg b/localwiki/Sketcher_CreateHexagon.svg new file mode 100644 index 0000000..7e50628 --- /dev/null +++ b/localwiki/Sketcher_CreateHexagon.svg @@ -0,0 +1,102 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [Johan K] + + + Sketcher_CreateHexagon + 2014-07-27 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Sketcher/Gui/Resources/icons/Sketcher_CreateHexagon.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Sketcher_CreateHexagon_Constr.svg b/localwiki/Sketcher_CreateHexagon_Constr.svg new file mode 100644 index 0000000..f367753 --- /dev/null +++ b/localwiki/Sketcher_CreateHexagon_Constr.svg @@ -0,0 +1,102 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [Abdullah Tahiri] + + + Sketcher_CreateHexagon_Constr + 2015-05-24 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Sketcher/Gui/Resources/icons/Sketcher_CreateHexagon_Constr.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Sketcher_CreateLine.svg b/localwiki/Sketcher_CreateLine.svg new file mode 100644 index 0000000..b07bbab --- /dev/null +++ b/localwiki/Sketcher_CreateLine.svg @@ -0,0 +1,86 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + [wmayer] + + + Sketcher_CreateLine + 2011-10-10 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Sketcher/Gui/Resources/icons/Sketcher_CreateLine.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Sketcher_CreateLine_Constr.svg b/localwiki/Sketcher_CreateLine_Constr.svg new file mode 100644 index 0000000..5213985 --- /dev/null +++ b/localwiki/Sketcher_CreateLine_Constr.svg @@ -0,0 +1,87 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [Abdullah Tahiri] + + + Sketcher_CreateLine_Constr + 2015-05-24 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Sketcher/Gui/Resources/icons/Sketcher_CreateLine_Constr.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Sketcher_CreateOctagon.svg b/localwiki/Sketcher_CreateOctagon.svg new file mode 100644 index 0000000..a312eb4 --- /dev/null +++ b/localwiki/Sketcher_CreateOctagon.svg @@ -0,0 +1,102 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [Johan K] + + + Sketcher_CreateOctagon + 2014-07-27 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Sketcher/Gui/Resources/icons/Sketcher_CreateOctagon.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Sketcher_CreateOctagon_Constr.svg b/localwiki/Sketcher_CreateOctagon_Constr.svg new file mode 100644 index 0000000..495f261 --- /dev/null +++ b/localwiki/Sketcher_CreateOctagon_Constr.svg @@ -0,0 +1,102 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [Abdullah Tahiri] + + + Sketcher_CreateOctagon_Constr + 2015-05-24 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Sketcher/Gui/Resources/icons/Sketcher_CreateOctagon_Constr.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Sketcher_CreatePentagon.svg b/localwiki/Sketcher_CreatePentagon.svg new file mode 100644 index 0000000..7507669 --- /dev/null +++ b/localwiki/Sketcher_CreatePentagon.svg @@ -0,0 +1,95 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [Johan K] + + + Sketcher_CreatePentagon + 2014-07-27 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Sketcher/Gui/Resources/icons/Sketcher_CreatePentagon.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Sketcher_CreatePentagon_Constr.svg b/localwiki/Sketcher_CreatePentagon_Constr.svg new file mode 100644 index 0000000..dae239a --- /dev/null +++ b/localwiki/Sketcher_CreatePentagon_Constr.svg @@ -0,0 +1,95 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [Abdullah Tahiri] + + + Sketcher_CreatePentagon_Constr + 2015-05-24 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Sketcher/Gui/Resources/icons/Sketcher_CreatePentagon_Constr.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Sketcher_CreatePoint.svg b/localwiki/Sketcher_CreatePoint.svg new file mode 100644 index 0000000..1f1ba15 --- /dev/null +++ b/localwiki/Sketcher_CreatePoint.svg @@ -0,0 +1,73 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [wmayer] + + + Sketcher_CreatePoint + 2011-10-10 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Sketcher/Gui/Resources/icons/Sketcher_CreatePoint.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Sketcher_CreatePolyline.svg b/localwiki/Sketcher_CreatePolyline.svg new file mode 100644 index 0000000..56f2485 --- /dev/null +++ b/localwiki/Sketcher_CreatePolyline.svg @@ -0,0 +1,109 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + [wmayer] + + + Sketcher_CreatePolyline + 2011-10-10 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Sketcher/Gui/Resources/icons/Sketcher_CreatePolyline.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Sketcher_CreatePolyline_Constr.svg b/localwiki/Sketcher_CreatePolyline_Constr.svg new file mode 100644 index 0000000..1951cb4 --- /dev/null +++ b/localwiki/Sketcher_CreatePolyline_Constr.svg @@ -0,0 +1,110 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [Abdullah Tahiri] + + + Sketcher_CreatePolyline_Constr + 2015-05-24 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Sketcher/Gui/Resources/icons/Sketcher_CreatePolyline_Constr.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Sketcher_CreateRectangle.svg b/localwiki/Sketcher_CreateRectangle.svg new file mode 100644 index 0000000..a2b679e --- /dev/null +++ b/localwiki/Sketcher_CreateRectangle.svg @@ -0,0 +1,80 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + [wmayer] + + + Sketcher_CreateRectangle + 2011-10-10 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Sketcher/Gui/Resources/icons/Sketcher_CreateRectangle.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Sketcher_CreateRectangle_Constr.svg b/localwiki/Sketcher_CreateRectangle_Constr.svg new file mode 100644 index 0000000..68c4941 --- /dev/null +++ b/localwiki/Sketcher_CreateRectangle_Constr.svg @@ -0,0 +1,81 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [Abdullah Tahiri] + + + Sketcher_CreateRectangle_Constr + 2015-05-24 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Sketcher/Gui/Resources/icons/Sketcher_CreateRectangle_Constr.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Sketcher_CreateRegularPolygon.svg b/localwiki/Sketcher_CreateRegularPolygon.svg new file mode 100644 index 0000000..0da402f --- /dev/null +++ b/localwiki/Sketcher_CreateRegularPolygon.svg @@ -0,0 +1,489 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [Johan K] + + + Sketcher_CreateOctagon + 2014-07-27 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Sketcher/Gui/Resources/icons/Sketcher_CreateOctagon.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + N + N + + + diff --git a/localwiki/Sketcher_CreateRegularPolygon_Constr.svg b/localwiki/Sketcher_CreateRegularPolygon_Constr.svg new file mode 100644 index 0000000..77bae88 --- /dev/null +++ b/localwiki/Sketcher_CreateRegularPolygon_Constr.svg @@ -0,0 +1,487 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [Abdullah Tahiri] + + + Sketcher_CreateOctagon_Constr + 2015-05-24 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Sketcher/Gui/Resources/icons/Sketcher_CreateOctagon_Constr.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + N + N + + diff --git a/localwiki/Sketcher_CreateSlot.svg b/localwiki/Sketcher_CreateSlot.svg new file mode 100644 index 0000000..a3f3535 --- /dev/null +++ b/localwiki/Sketcher_CreateSlot.svg @@ -0,0 +1,93 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [jriegel] + + + Sketcher_CreateSlot + 2014-04-15 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Sketcher/Gui/Resources/icons/Sketcher_CreateSlot.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Sketcher_CreateSlot_Constr.svg b/localwiki/Sketcher_CreateSlot_Constr.svg new file mode 100644 index 0000000..3ff6cda --- /dev/null +++ b/localwiki/Sketcher_CreateSlot_Constr.svg @@ -0,0 +1,93 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [Abdullah Tahiri] + + + Sketcher_CreateSlot_Constr + 2015-05-24 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Sketcher/Gui/Resources/icons/Sketcher_CreateSlot_Constr.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Sketcher_CreateSquare.svg b/localwiki/Sketcher_CreateSquare.svg new file mode 100644 index 0000000..2fc6f89 --- /dev/null +++ b/localwiki/Sketcher_CreateSquare.svg @@ -0,0 +1,102 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [Johan K] + + + Sketcher_CreateSquare + 2014-07-27 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Sketcher/Gui/Resources/icons/Sketcher_CreateSquare.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Sketcher_CreateSquare_Constr.svg b/localwiki/Sketcher_CreateSquare_Constr.svg new file mode 100644 index 0000000..f274764 --- /dev/null +++ b/localwiki/Sketcher_CreateSquare_Constr.svg @@ -0,0 +1,102 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [Abdullah Tahiri] + + + Sketcher_CreateSquare_Constr + 2015-05-24 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Sketcher/Gui/Resources/icons/Sketcher_CreateSquare_Constr.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Sketcher_CreateText.svg b/localwiki/Sketcher_CreateText.svg new file mode 100644 index 0000000..0131505 --- /dev/null +++ b/localwiki/Sketcher_CreateText.svg @@ -0,0 +1,60 @@ + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + [wmayer] + + + Sketcher_CreateText + 2011-10-10 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Sketcher/Gui/Resources/icons/Sketcher_CreateText.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + diff --git a/localwiki/Sketcher_CreateTriangle.svg b/localwiki/Sketcher_CreateTriangle.svg new file mode 100644 index 0000000..bf86420 --- /dev/null +++ b/localwiki/Sketcher_CreateTriangle.svg @@ -0,0 +1,95 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [Johan K] + + + Sketcher_CreateTriangle + 2014-07-27 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Sketcher/Gui/Resources/icons/Sketcher_CreateTriangle.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Sketcher_CreateTriangle_Constr.svg b/localwiki/Sketcher_CreateTriangle_Constr.svg new file mode 100644 index 0000000..4388fcd --- /dev/null +++ b/localwiki/Sketcher_CreateTriangle_Constr.svg @@ -0,0 +1,95 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [Abdullah Tahiri] + + + Sketcher_CreateTriangle_Constr + 2015-05-24 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Sketcher/Gui/Resources/icons/Sketcher_CreateTriangle_Constr.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Sketcher_Create_Periodic_BSpline.svg b/localwiki/Sketcher_Create_Periodic_BSpline.svg new file mode 100644 index 0000000..fc2c0de --- /dev/null +++ b/localwiki/Sketcher_Create_Periodic_BSpline.svg @@ -0,0 +1,123 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [Abdullah Tahiri] + + + Sketcher_Create_Periodic_BSpline + 2017-01-13 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Sketcher/Gui/Resources/icons/Sketcher_Create_Periodic_BSpline.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Sketcher_Create_Periodic_BSpline_Constr.svg b/localwiki/Sketcher_Create_Periodic_BSpline_Constr.svg new file mode 100644 index 0000000..a0dffd2 --- /dev/null +++ b/localwiki/Sketcher_Create_Periodic_BSpline_Constr.svg @@ -0,0 +1,123 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [Abdullah Tahiri] + + + Sketcher_Create_Periodic_BSpline_Constr + 2017-01-13 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Sketcher/Gui/Resources/icons/Sketcher_Create_Periodic_BSpline_Constr.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Sketcher_DraftLine.svg b/localwiki/Sketcher_DraftLine.svg new file mode 100644 index 0000000..b4945da --- /dev/null +++ b/localwiki/Sketcher_DraftLine.svg @@ -0,0 +1,61 @@ + + + + + + + + + + + + + image/svg+xml + + + + [wmayer] + + + Sketcher_DraftLine + 2011-10-10 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Sketcher/Gui/Resources/icons/Sketcher_DraftLine.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Sketcher_EditSketch.html b/localwiki/Sketcher_EditSketch.html new file mode 100644 index 0000000..2c7471f --- /dev/null +++ b/localwiki/Sketcher_EditSketch.html @@ -0,0 +1,71 @@ +Sketcher EditSketch

      Sketcher EditSketch

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Sketcher EditSketch.png Sketcher EditSketch

      +
      Menu location +
      Sketch → Edit sketch +
      Workbenches +
      Sketcher, PartDesign +
      Default shortcut +
      +
      See also +
      +

      + +
      +


      +

      +

      Description

      +

      This will let you edit an existing sketch. +

      +

      Usage

      +

      Right-click on a sketch in the tree view and choose "Edit Sketch" or select sketch in the tree view and choose "Sketch > Edit Sketch" from the pull-down-menu. +Choosing Leave Sketch will terminate the edit mode. +

      +

      Note

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Sketcher_EditSketch.svg b/localwiki/Sketcher_EditSketch.svg new file mode 100644 index 0000000..04b706c --- /dev/null +++ b/localwiki/Sketcher_EditSketch.svg @@ -0,0 +1,93 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [wmayer] + + + Sketcher_EditSketch + 2014-07-13 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Sketcher/Gui/Resources/icons/Sketcher_EditSketch.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Sketcher_Element_Arc_Edge.svg b/localwiki/Sketcher_Element_Arc_Edge.svg new file mode 100644 index 0000000..f696c30 --- /dev/null +++ b/localwiki/Sketcher_Element_Arc_Edge.svg @@ -0,0 +1,100 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [wmayer] + + + Sketcher_Element_Arc_Edge + 2014-08-04 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Sketcher/Gui/Resources/icons/Sketcher_Element_Arc_Edge.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Sketcher_Element_Arc_EndPoint.svg b/localwiki/Sketcher_Element_Arc_EndPoint.svg new file mode 100644 index 0000000..173e35a --- /dev/null +++ b/localwiki/Sketcher_Element_Arc_EndPoint.svg @@ -0,0 +1,100 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [wmayer] + + + Sketcher_Element_Arc_EndPoint + 2014-08-04 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Sketcher/Gui/Resources/icons/Sketcher_Element_Arc_EndPoint.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Sketcher_Element_Arc_MidPoint.svg b/localwiki/Sketcher_Element_Arc_MidPoint.svg new file mode 100644 index 0000000..3fe1ed3 --- /dev/null +++ b/localwiki/Sketcher_Element_Arc_MidPoint.svg @@ -0,0 +1,104 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [wmayer] + + + Sketcher_Element_Arc_MidPoint + 2014-08-04 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Sketcher/Gui/Resources/icons/Sketcher_Element_Arc_MidPoint.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Sketcher_Element_Arc_StartingPoint.svg b/localwiki/Sketcher_Element_Arc_StartingPoint.svg new file mode 100644 index 0000000..4f681e0 --- /dev/null +++ b/localwiki/Sketcher_Element_Arc_StartingPoint.svg @@ -0,0 +1,104 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [wmayer] + + + Sketcher_Element_Arc_StartingPoint + 2014-08-04 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Sketcher/Gui/Resources/icons/Sketcher_Element_Arc_StartingPoint.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Sketcher_Element_BSpline_Edge.svg b/localwiki/Sketcher_Element_BSpline_Edge.svg new file mode 100644 index 0000000..af5c8a0 --- /dev/null +++ b/localwiki/Sketcher_Element_BSpline_Edge.svg @@ -0,0 +1,110 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [Abdullah Tahiri] + + + Sketcher_Element_BSpline_Edge + 2017-01-07 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Sketcher/Gui/Resources/icons/Sketcher_Element_BSpline_Edge.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Sketcher_Element_BSpline_EndPoint.svg b/localwiki/Sketcher_Element_BSpline_EndPoint.svg new file mode 100644 index 0000000..da33b7a --- /dev/null +++ b/localwiki/Sketcher_Element_BSpline_EndPoint.svg @@ -0,0 +1,110 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [Abdullah Tahiri] + + + Sketcher_Element_BSpline_EndPoint + 2017-01-07 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Sketcher/Gui/Resources/icons/Sketcher_Element_BSpline_EndPoint.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Sketcher_Element_BSpline_StartPoint.svg b/localwiki/Sketcher_Element_BSpline_StartPoint.svg new file mode 100644 index 0000000..245bb89 --- /dev/null +++ b/localwiki/Sketcher_Element_BSpline_StartPoint.svg @@ -0,0 +1,114 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [Abdullah Tahiri] + + + Sketcher_Element_BSpline_StartPoint + 2017-01-07 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Sketcher/Gui/Resources/icons/Sketcher_Element_BSpline_StartPoint.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Sketcher_Element_Circle_Edge.svg b/localwiki/Sketcher_Element_Circle_Edge.svg new file mode 100644 index 0000000..e2e3840 --- /dev/null +++ b/localwiki/Sketcher_Element_Circle_Edge.svg @@ -0,0 +1,90 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [wmayer] + + + Sketcher_Element_Circle_Edge + 2014-08-04 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Sketcher/Gui/Resources/icons/Sketcher_Element_Circle_Edge.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Sketcher_Element_Circle_MidPoint.svg b/localwiki/Sketcher_Element_Circle_MidPoint.svg new file mode 100644 index 0000000..f6b4ad1 --- /dev/null +++ b/localwiki/Sketcher_Element_Circle_MidPoint.svg @@ -0,0 +1,95 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [wmayer] + + + Sketcher_Element_Circle_MidPoint + 2014-08-04 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Sketcher/Gui/Resources/icons/Sketcher_Element_Circle_MidPoint.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Sketcher_Element_Ellipse_All.svg b/localwiki/Sketcher_Element_Ellipse_All.svg new file mode 100644 index 0000000..c27ffc0 --- /dev/null +++ b/localwiki/Sketcher_Element_Ellipse_All.svg @@ -0,0 +1,446 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [Abdullah Tahiri] + + + Sketcher_Element_Ellipse_All + 2014-11-11 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Sketcher/Gui/Resources/icons/Sketcher_Element_Ellipse_All.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Sketcher_Element_Ellipse_CentrePoint.svg b/localwiki/Sketcher_Element_Ellipse_CentrePoint.svg new file mode 100644 index 0000000..f56915c --- /dev/null +++ b/localwiki/Sketcher_Element_Ellipse_CentrePoint.svg @@ -0,0 +1,97 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [Abdullah Tahiri] + + + Sketcher_Element_Ellipse_CentrePoint + 2014-11-11 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Sketcher/Gui/Resources/icons/Sketcher_Element_Ellipse_CentrePoint.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Sketcher_Element_Ellipse_Edge_1.svg b/localwiki/Sketcher_Element_Ellipse_Edge_1.svg new file mode 100644 index 0000000..15e92be --- /dev/null +++ b/localwiki/Sketcher_Element_Ellipse_Edge_1.svg @@ -0,0 +1,103 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [Abdullah Tahiri] + + + Sketcher_Element_Ellipse_Edge_1 + 2014-11-11 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Sketcher/Gui/Resources/icons/Sketcher_Element_Ellipse_Edge_1.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Sketcher_Element_Ellipse_Edge_2.svg b/localwiki/Sketcher_Element_Ellipse_Edge_2.svg new file mode 100644 index 0000000..1de2d3d --- /dev/null +++ b/localwiki/Sketcher_Element_Ellipse_Edge_2.svg @@ -0,0 +1,95 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [Abdullah Tahiri] + + + Sketcher_Element_Ellipse_Edge_2 + 2014-11-11 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Sketcher/Gui/Resources/icons/Sketcher_Element_Ellipse_Edge_2.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Sketcher_Element_Ellipse_Focus1.svg b/localwiki/Sketcher_Element_Ellipse_Focus1.svg new file mode 100644 index 0000000..c1ead81 --- /dev/null +++ b/localwiki/Sketcher_Element_Ellipse_Focus1.svg @@ -0,0 +1,389 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [Abdullah Tahiri] + + + Sketcher_Element_Ellipse_Focus1 + 2014-11-11 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Sketcher/Gui/Resources/icons/Sketcher_Element_Ellipse_ + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Sketcher_Element_Ellipse_Focus2.svg b/localwiki/Sketcher_Element_Ellipse_Focus2.svg new file mode 100644 index 0000000..343706a --- /dev/null +++ b/localwiki/Sketcher_Element_Ellipse_Focus2.svg @@ -0,0 +1,389 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [Abdullah Tahiri] + + + Sketcher_Element_Ellipse_Focus2 + 2014-11-11 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Sketcher/Gui/Resources/icons/Sketcher_Element_Ellipse_ + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Sketcher_Element_Ellipse_MajorAxis.svg b/localwiki/Sketcher_Element_Ellipse_MajorAxis.svg new file mode 100644 index 0000000..827f1e8 --- /dev/null +++ b/localwiki/Sketcher_Element_Ellipse_MajorAxis.svg @@ -0,0 +1,397 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [Abdullah Tahiri] + + + Sketcher_Element_Ellipse_MajorAxis + 2014-11-11 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Sketcher/Gui/Resources/icons/Sketcher_Element_Ellipse_MajorAxis.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Sketcher_Element_Ellipse_MinorAxis.svg b/localwiki/Sketcher_Element_Ellipse_MinorAxis.svg new file mode 100644 index 0000000..f023466 --- /dev/null +++ b/localwiki/Sketcher_Element_Ellipse_MinorAxis.svg @@ -0,0 +1,393 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [Abdullah Tahiri] + + + Sketcher_Element_Ellipse_MinorAxis + 2014-11-11 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Sketcher/Gui/Resources/icons/Sketcher_Element_Ellipse_MinorAxis.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Sketcher_Element_Elliptical_Arc_Centre_Point.svg b/localwiki/Sketcher_Element_Elliptical_Arc_Centre_Point.svg new file mode 100644 index 0000000..39952c5 --- /dev/null +++ b/localwiki/Sketcher_Element_Elliptical_Arc_Centre_Point.svg @@ -0,0 +1,105 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [Abdullah Tahiri] + + + Sketcher_Element_Elliptical_Arc_Centre_Point + 2014-11-11 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Sketcher/Gui/Resources/icons/Sketcher_Element_Elliptical_Arc_Centre_Point.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Sketcher_Element_Elliptical_Arc_Edge.svg b/localwiki/Sketcher_Element_Elliptical_Arc_Edge.svg new file mode 100644 index 0000000..f8d233e --- /dev/null +++ b/localwiki/Sketcher_Element_Elliptical_Arc_Edge.svg @@ -0,0 +1,111 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [Abdullah Tahiri] + + + Sketcher_Element_Elliptical_Arc_Edge + 2014-11-11 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Sketcher/Gui/Resources/icons/Sketcher_Element_Elliptical_Arc_Edge.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Sketcher_Element_Elliptical_Arc_End_Point.svg b/localwiki/Sketcher_Element_Elliptical_Arc_End_Point.svg new file mode 100644 index 0000000..ec7e001 --- /dev/null +++ b/localwiki/Sketcher_Element_Elliptical_Arc_End_Point.svg @@ -0,0 +1,111 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [Abdullah Tahiri] + + + Sketcher_Element_Elliptical_Arc_End_Point + 2014-11-11 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Sketcher/Gui/Resources/icons/Sketcher_Element_Elliptical_Arc_End_Point.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Sketcher_Element_Elliptical_Arc_Start_Point.svg b/localwiki/Sketcher_Element_Elliptical_Arc_Start_Point.svg new file mode 100644 index 0000000..b85271d --- /dev/null +++ b/localwiki/Sketcher_Element_Elliptical_Arc_Start_Point.svg @@ -0,0 +1,117 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [Abdullah Tahiri] + + + Sketcher_Element_Elliptical_Arc_Start_Point + 2014-11-11 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Sketcher/Gui/Resources/icons/Sketcher_Element_Elliptical_Arc_Start_Point.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Sketcher_Element_Hyperbolic_Arc_Centre_Point.svg b/localwiki/Sketcher_Element_Hyperbolic_Arc_Centre_Point.svg new file mode 100644 index 0000000..dbe5af4 --- /dev/null +++ b/localwiki/Sketcher_Element_Hyperbolic_Arc_Centre_Point.svg @@ -0,0 +1,110 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [Abdullah Tahiri] + + + Sketcher_Element_Hyperbolic_Arc_Centre_Point + 2016-09-03 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Sketcher/Gui/Resources/icons/Sketcher_Element_Hyperbolic_Arc_Centre_Point.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Sketcher_Element_Hyperbolic_Arc_Edge.svg b/localwiki/Sketcher_Element_Hyperbolic_Arc_Edge.svg new file mode 100644 index 0000000..b1604aa --- /dev/null +++ b/localwiki/Sketcher_Element_Hyperbolic_Arc_Edge.svg @@ -0,0 +1,116 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [Abdullah Tahiri] + + + Sketcher_Element_Hyperbolic_Arc_Edge + 2016-09-03 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Sketcher/Gui/Resources/icons/Sketcher_Element_Hyperbolic_Arc_Edge.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Sketcher_Element_Hyperbolic_Arc_End_Point.svg b/localwiki/Sketcher_Element_Hyperbolic_Arc_End_Point.svg new file mode 100644 index 0000000..6f28d73 --- /dev/null +++ b/localwiki/Sketcher_Element_Hyperbolic_Arc_End_Point.svg @@ -0,0 +1,112 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [Abdullah Tahiri] + + + Sketcher_Element_Hyperbolic_Arc_End_Point + 2016-09-03 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Sketcher/Gui/Resources/icons/Sketcher_Element_Hyperbolic_Arc_End_Point.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Sketcher_Element_Hyperbolic_Arc_Start_Point.svg b/localwiki/Sketcher_Element_Hyperbolic_Arc_Start_Point.svg new file mode 100644 index 0000000..56f4451 --- /dev/null +++ b/localwiki/Sketcher_Element_Hyperbolic_Arc_Start_Point.svg @@ -0,0 +1,112 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [Abdullah Tahiri] + + + Sketcher_Element_Hyperbolic_Arc_Start_Point + 2016-09-03 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Sketcher/Gui/Resources/icons/Sketcher_Element_Hyperbolic_Arc_Start_Point.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Sketcher_Element_Line_Edge.svg b/localwiki/Sketcher_Element_Line_Edge.svg new file mode 100644 index 0000000..7d97f8b --- /dev/null +++ b/localwiki/Sketcher_Element_Line_Edge.svg @@ -0,0 +1,87 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [wmayer] + + + Sketcher_Element_Line_Edge + 2014-08-04 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Sketcher/Gui/Resources/icons/Sketcher_Element_Line_Edge.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Sketcher_Element_Line_EndPoint.svg b/localwiki/Sketcher_Element_Line_EndPoint.svg new file mode 100644 index 0000000..a290529 --- /dev/null +++ b/localwiki/Sketcher_Element_Line_EndPoint.svg @@ -0,0 +1,87 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [wmayer] + + + Sketcher_Element_Line_EndPoint + 2014-08-04 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Sketcher/Gui/Resources/icons/Sketcher_Element_Line_EndPoint.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Sketcher_Element_Line_StartingPoint.svg b/localwiki/Sketcher_Element_Line_StartingPoint.svg new file mode 100644 index 0000000..a1d7fe1 --- /dev/null +++ b/localwiki/Sketcher_Element_Line_StartingPoint.svg @@ -0,0 +1,87 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [wmayer] + + + Sketcher_Element_Line_StartingPoint + 2014-08-04 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Sketcher/Gui/Resources/icons/Sketcher_Element_Line_StartingPoint.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Sketcher_Element_Parabolic_Arc_Centre_Point.svg b/localwiki/Sketcher_Element_Parabolic_Arc_Centre_Point.svg new file mode 100644 index 0000000..045ee5a --- /dev/null +++ b/localwiki/Sketcher_Element_Parabolic_Arc_Centre_Point.svg @@ -0,0 +1,110 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [Abdullah Tahiri] + + + Sketcher_Element_Parabolic_Arc_Centre_Point + 2016-12-24 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Sketcher/Gui/Resources/icons/Sketcher_Element_Parabolic_Arc_Centre_Point.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Sketcher_Element_Parabolic_Arc_Edge.svg b/localwiki/Sketcher_Element_Parabolic_Arc_Edge.svg new file mode 100644 index 0000000..d7cd820 --- /dev/null +++ b/localwiki/Sketcher_Element_Parabolic_Arc_Edge.svg @@ -0,0 +1,122 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [Abdullah Tahiri] + + + Sketcher_Element_Parabolic_Arc_Edge + 2016-12-24 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Sketcher/Gui/Resources/icons/Sketcher_Element_Parabolic_Arc_Edge.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Sketcher_Element_Parabolic_Arc_End_Point.svg b/localwiki/Sketcher_Element_Parabolic_Arc_End_Point.svg new file mode 100644 index 0000000..34fe837 --- /dev/null +++ b/localwiki/Sketcher_Element_Parabolic_Arc_End_Point.svg @@ -0,0 +1,116 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [Abdullah Tahiri] + + + Sketcher_Element_Parabolic_Arc_End_Point + 2016-12-24 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Sketcher/Gui/Resources/icons/Sketcher_Element_Parabolic_Arc_End_Point.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Sketcher_Element_Parabolic_Arc_Start_Point.svg b/localwiki/Sketcher_Element_Parabolic_Arc_Start_Point.svg new file mode 100644 index 0000000..71bba1f --- /dev/null +++ b/localwiki/Sketcher_Element_Parabolic_Arc_Start_Point.svg @@ -0,0 +1,116 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [Abdullah Tahiri] + + + Sketcher_Element_Parabolic_Arc_Start_Point + 2016-12-24 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Sketcher/Gui/Resources/icons/Sketcher_Element_Parabolic_Arc_Start_Point.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Sketcher_Element_Point_StartingPoint.svg b/localwiki/Sketcher_Element_Point_StartingPoint.svg new file mode 100644 index 0000000..cb309ea --- /dev/null +++ b/localwiki/Sketcher_Element_Point_StartingPoint.svg @@ -0,0 +1,73 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [wmayer] + + + Sketcher_Element_Point_StartingPoint + 2014-08-04 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Sketcher/Gui/Resources/icons/Sketcher_Element_Point_StartingPoint.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Sketcher_Element_SelectionTypeInvalid.svg b/localwiki/Sketcher_Element_SelectionTypeInvalid.svg new file mode 100644 index 0000000..f39a7c0 --- /dev/null +++ b/localwiki/Sketcher_Element_SelectionTypeInvalid.svg @@ -0,0 +1,132 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [wmayer] + + + Sketcher_Element_SelectionTypeInvalid + 2014-08-04 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Sketcher/Gui/Resources/icons/Sketcher_Element_SelectionTypeInvalid.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + diff --git a/localwiki/Sketcher_Ellipse.html b/localwiki/Sketcher_Ellipse.html new file mode 100644 index 0000000..2bc068d --- /dev/null +++ b/localwiki/Sketcher_Ellipse.html @@ -0,0 +1,80 @@ +Sketcher Ellipse

      Sketcher Ellipse

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Sketcher CreateEllipse.png Sketcher CreateEllipse

      +
      Menu location +
      Sketch → Sketcher geometries → Create ellipse by center +
      Workbenches +
      Sketcher, Part Design +
      Default shortcut +
      None +
      See also +
      Sketcher Ellipse by 3 Points, Sketcher Circle, Sketcher Arc of Ellipse +

      + +
      +


      +

      +

      Description

      +

      This tool draws an ellipse by picking three points: the center, the end of major radius, the minor radius. +When starting the tool, the mouse pointer changes to a white cross with a red ellipse icon. Besides are coordinates shown in real time. +

      +
      The sequence of clicks is indicated by yellow arrows with numbers. C is the center, a - major diameter, b - minor diameter, F1, F2 are foci.
      +

      Usage

      +
      • Invoke the command by clicking a toolbar button, picking the menu item, or by using keyboard shortcut (needs to be assigned first in Interface Customization).
      • +
      • First click in 3D view sets ellipse center. Second click sets the first radius and orientation of the ellipse. Third click sets the other radius (the distance from the line defined by first two clicks is the second radius).
      • +
      • After the third click, the ellipse is created, together with a set of construction geometry aligned to it (major diameter, minor diameter, two foci). The construction geometry can be manually deleted if not needed, and recreated later. See Internal Alignment Constraint and Sketcher Show Hide Internal Geometry.
      • +
      • Pressing ESC or clicking the right mouse button cancels the function.
      +

      Peculiarities

      +
      • Major and minor axes of ellipses are strict and cannot be swapped by resizing the ellipse. This is a consequence of the solver parametrization used (center (x,y), focus1 (x,y) and minor radius length (b)) and the same strict behavior of OpenCascade. The ellipse must be rotated to swap the axes.
      • +
      • Ellipse can function as a circle when its major and minor diameter lines are deleted, and one of the foci is constrained to coincide with the center. But radius constraint won't work on such a circle.
      • +
      • Moving the ellipse by edge is the same as moving ellipse's center.
      +

      Version

      +

      Introduced in FreeCAD v0.15.4309 +

      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Sketcher_Ellipse_by_3_Points.html b/localwiki/Sketcher_Ellipse_by_3_Points.html new file mode 100644 index 0000000..0137ef7 --- /dev/null +++ b/localwiki/Sketcher_Ellipse_by_3_Points.html @@ -0,0 +1,72 @@ +Sketcher Ellipse by 3 Points

      Sketcher Ellipse by 3 Points

      + +
      +

      This documentation is not finished. Please help and contribute documentation. +

      See Draft ShapeString for good documented Command. Gui Command gives an overview over commands. And see List of Commands for other commands. +

      Go to Help FreeCAD to contribute. +

      +
      + + + + + + + + + + + + + + + + + + + + +
      +

      Sketcher CreateEllipse3Point.png Sketcher CreateEllipse3Point

      +
      Menu location +
      Sketch → Sketcher geometries → Create ellipse by 3 points +
      Workbenches +
      Sketcher, Part Design +
      Default shortcut +
      None +
      See also +
      Sketcher Ellipse by center, Sketcher Circle, Sketcher Arc of Ellipse +

      + +
      +


      +

      +

      Description

      +

      Usage

      +

      Version

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Sketcher_Elliptical_Arc.svg b/localwiki/Sketcher_Elliptical_Arc.svg new file mode 100644 index 0000000..33b988e --- /dev/null +++ b/localwiki/Sketcher_Elliptical_Arc.svg @@ -0,0 +1,123 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [Abdullah Tahiri] + + + Sketcher_Elliptical_Arc + 2014-11-11 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Sketcher/Gui/Resources/icons/Sketcher_Elliptical_Arc.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Sketcher_Elliptical_Arc_Constr.svg b/localwiki/Sketcher_Elliptical_Arc_Constr.svg new file mode 100644 index 0000000..03c6b09 --- /dev/null +++ b/localwiki/Sketcher_Elliptical_Arc_Constr.svg @@ -0,0 +1,123 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [Abdullah Tahiri] + + + Sketcher_Elliptical_Arc_Constr + 2015-05-24 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Sketcher/Gui/Resources/icons/Sketcher_Elliptical_Arc_Constr.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Sketcher_Extend.svg b/localwiki/Sketcher_Extend.svg new file mode 100644 index 0000000..1ea119c --- /dev/null +++ b/localwiki/Sketcher_Extend.svg @@ -0,0 +1,38 @@ + + + + Sketcher_Extend + Created with Sketch. + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Sketcher_External.html b/localwiki/Sketcher_External.html new file mode 100644 index 0000000..d29610e --- /dev/null +++ b/localwiki/Sketcher_External.html @@ -0,0 +1,124 @@ +Sketcher External

      Sketcher External

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Sketcher External.png Sketcher External

      +
      Menu location +
      Sketch → Sketcher geometries → Sketcher External +
      Workbenches +
      Sketcher, PartDesign +
      Default shortcut +
      X +
      See also +
      ConstructionMode +

      + +
      +


      +

      +

      Description

      +

      Use Sketcher External Geometry tool, when you need to apply a constraint between sketch geometry and something outside of the sketch. It works by inserting a linked construction geometry into the sketch. The default colour of externally linked edges, is magenta. As with standard non-linked construction geometry (blue), the externally linked geometry is only visible when the sketch is in edit mode and is not directly used in the subsequent result from use of the sketch in another tool. Both types of construction geometry may be used as a reference for constraints within the sketch. +

      Sketcher ExternalEsempio1.png +

      +

      Use

      +
      • Create a new sketch, or open an existing sketch.
      • +
      • Click 'Sketcher External' button
      • +
      • Select an edge or a vertex that you want to link to in the sketch.
      • +
      • Press Esc, or select another tool to stop importing geometry into the sketch.
      +

      Selection rules

      +

      Selection rules for what objects can be imported differ drastically between FC v0.16 and FC v0.17. +

      +

      v0.17

      +
      • Only edges and vertices from objects from same coordinate system are allowed.
      +

      That is, the sketch and the object must be in same Body, or in same Part, or both outside of any Parts and Bodies. +

      For example, If the open sketch is in Body, you can use another sketch from Body as external geometry, but you can't use a sketch from Body001, or an edge from a Part Cube in the root of the project. Use Shapebinder feature to bring in a copy of the object into the coordinate system of open sketch. Then you will be able to use edges/vertices of Shapebinder object. +

      +
      • No circular dependencies are allowed.
      +

      That means, you can't link to Pocket made with this sketch. You can't link to any object that depends on the sketch. +

      Unlike in v0.16, sketch doesn't have to be on any face in order to use this tool. Links directly between sketches are possible, and encouraged, as they are more reliable. +

      +

      v0.16 and older

      +
      • You can only link to edges/vertices of the shape the sketch is mapped to.
      +

      For example. If Sketch was made on a face of Pad, you can only use edges/vertices of Pad. You can't use edges of Sketch that was used to make Pad. You can't use edges of Pad that are inherited onto a Pocket done with this sketch (you need to hide Pocket and unhide Pad to link new stuff in). +

      The sketch MUST be mapped to a face in order to use this tool. +

      +

      Appearance When Successfully Linked

      +

      A (default magenta) coloured line will be overlaid when an edge is successfully linked (the vertices will be red), and will be visible in your sketch only while your sketch is in edit mode. +

      +

      Similarity to Construction Lines

      +

      External geometry (default colour magenta) lines are similar (default colour blue) Contruction lines except in that the external geometry magenta lines are parametrically linked back to an element of the solid to which the sketch is mapped. +Construction geometry are lines that are internal to the sketch, are only visible when the sketch is in edit mode and will be used for constraint references only, and not directly for later solid operations, like Pad or Pocket. +


      +

      +

      Use Of External Geometry in a PartDesign Workbench Work Flow

      +

      In the PartDesign workbench work flow, the External Geometry tool is used to assist in the positioning of an aspect of the solid you are constructing, relative to the previous stage in its construction. PartDesign workbench is intended to produce one single solid, therefore these sketches with external geometry are used to create a new feature of that one single solid. +

      The external geometry can, for example, be used as a reference for a constraint being used to position a hole in an object at a specific location relative to an edge or vertex. +

      +

      Use Of External Geometry in a Part Workbench Work Flow

      +

      You can use any Part geometry that is in coordinate system of the sketch. It is advised to link to the earliest feature possible, as it forms a more stable link. +

      In v0.16 and older, the sketch must be mapped to a face to use this tool. Since v0.17, this limitation was lifted. +

      +

      Example

      +

      This, below, is a sketch mapped to the top face of a solid created from a Pad of a previous sketch. The magenta lines are External Geometry linked to two edges of this pre-existing Pad. +

      In this case they are used as a reference for tangency constraints with the circumferences of one circle. They are also used as the reference for a horizontal and a vertical constraint to locate the centre of the second circle relative to the end and top of the Pad. +

      Sketcher ExternalEsempio2.png +

      This is the same sketch in edit mode, with the Pad upon which it is mapped hidden. +

      Sketcher ExternalEsempio4.png +

      When the sketch edit mode is closed, External Geometry lines are not visible. +

      Sketcher ExternalEsempio3.png +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Sketcher_External.svg b/localwiki/Sketcher_External.svg new file mode 100644 index 0000000..e63967c --- /dev/null +++ b/localwiki/Sketcher_External.svg @@ -0,0 +1,122 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [logari81] + + + Sketcher_External + 2012-01-01 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Sketcher/Gui/Resources/icons/Sketcher_External.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Sketcher_ExternalEsempio1.png b/localwiki/Sketcher_ExternalEsempio1.png new file mode 100644 index 0000000..24bdf9b Binary files /dev/null and b/localwiki/Sketcher_ExternalEsempio1.png differ diff --git a/localwiki/Sketcher_ExternalEsempio2.png b/localwiki/Sketcher_ExternalEsempio2.png new file mode 100644 index 0000000..b073de6 Binary files /dev/null and b/localwiki/Sketcher_ExternalEsempio2.png differ diff --git a/localwiki/Sketcher_ExternalEsempio3.png b/localwiki/Sketcher_ExternalEsempio3.png new file mode 100644 index 0000000..69af0ae Binary files /dev/null and b/localwiki/Sketcher_ExternalEsempio3.png differ diff --git a/localwiki/Sketcher_ExternalEsempio4.png b/localwiki/Sketcher_ExternalEsempio4.png new file mode 100644 index 0000000..5855c90 Binary files /dev/null and b/localwiki/Sketcher_ExternalEsempio4.png differ diff --git a/localwiki/Sketcher_Fillet.html b/localwiki/Sketcher_Fillet.html new file mode 100644 index 0000000..9f67c16 --- /dev/null +++ b/localwiki/Sketcher_Fillet.html @@ -0,0 +1,70 @@ +Sketcher Fillet

      Sketcher Fillet

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Sketcher CreateFillet.png Sketcher CreateFillet

      +
      Menu location +
      Sketch → Sketcher geometries → Create fillet +
      Workbenches +
      Sketcher, PartDesign +
      Default shortcut +
      F +
      See also +
      None +

      + +
      +


      +

      +

      Description

      +

      This tool creates a fillet between two lines joined at one point. Activate the tool, then select both lines or click on the corner point. +

      When starting the tool, the mouse pointer changes to a white cross with a red fillet icon. It stays active so you can do multiple fillets. +

      SketcherCreateFilletExample.png +

      +

      Usage

      +
      • Pick a vertex connecting two lines; or click on two connected lines, the distance you click from the vertex will set the fillet radius.
      • +
      • Pressing ESC or clicking the right mouse button cancels or terminates the function.
      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Sketcher_Heptagon.html b/localwiki/Sketcher_Heptagon.html new file mode 100644 index 0000000..53ec5a3 --- /dev/null +++ b/localwiki/Sketcher_Heptagon.html @@ -0,0 +1,80 @@ +Sketcher Heptagon

      Sketcher Heptagon

      + +


      +

      + + + + + + + + + + + + + + + + + + + + +
      +

      Sketcher CreateHeptagon.png Sketcher CreateHeptagon

      +
      Menu location +
      Sketch → Sketcher geometries → Create heptagon +
      Workbenches +
      Sketcher, PartDesign +
      Default shortcut +
      +
      See also +
      +

      + +
      +


      +

      +

      Description

      +

      Draws an heptagon inscribed in a construction geometry circle. +When starting the tool, the mouse pointer changes to a white cross with a red hexagon icon. +The coordinates of the pointer are shown beside it in blue in real time. +


      +SketcherCreateHeptagonExample.png +


      +

      +

      Usage

      +
      • After pressing the Sketcher CreateHeptagon.png Create heptagon button, click once to set the center, then move the mouse and click a second time to set one of the vertices.
      • +
      • Pressing ESC or clicking the right mouse button cancels the function.
      +

      When editing the sketch the circumscribed circle is visible, when you close the sketch is hidden. +


      +


      +
      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Sketcher_Hexagon.html b/localwiki/Sketcher_Hexagon.html new file mode 100644 index 0000000..35fcf7c --- /dev/null +++ b/localwiki/Sketcher_Hexagon.html @@ -0,0 +1,80 @@ +Sketcher Hexagon

      Sketcher Hexagon

      + +


      +

      + + + + + + + + + + + + + + + + + + + + +
      +

      Sketcher CreateHexagon.png Sketcher CreateHexagon

      +
      Menu location +
      Sketch → Sketcher geometries → Create hexagon +
      Workbenches +
      Sketcher, PartDesign +
      Default shortcut +
      +
      See also +
      +

      + +
      +


      +

      +

      Description

      +

      Draws an hexagon inscribed in a construction geometry circle. +When starting the tool, the mouse pointer changes to a white cross with a red hexagon icon. +The coordinates of the pointer are shown beside it in blue in real time. +


      +SketcherCreateHexagonExample.png +


      +

      +

      Usage

      +
      • After pressing the Sketcher CreateHexagon.png Create hexagon button, click once to set the center, then move the mouse and click a second time to set one of the vertices.
      • +
      • Pressing ESC or clicking the right mouse button cancels the function.
      +

      When editing the sketch the circumscribed circle is visible, when you close the sketch is hidden. +


      +


      +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Sketcher_Hyperbolic_Arc.svg b/localwiki/Sketcher_Hyperbolic_Arc.svg new file mode 100644 index 0000000..cb89e04 --- /dev/null +++ b/localwiki/Sketcher_Hyperbolic_Arc.svg @@ -0,0 +1,132 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [Abdullah Tahiri] + + + Sketcher_Hyperbolic_Arc + 2016-09-03 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Sketcher/Gui/Resources/icons/Sketcher_Hyperbolic_Arc.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Sketcher_Hyperbolic_Arc_Constr.svg b/localwiki/Sketcher_Hyperbolic_Arc_Constr.svg new file mode 100644 index 0000000..c35115c --- /dev/null +++ b/localwiki/Sketcher_Hyperbolic_Arc_Constr.svg @@ -0,0 +1,132 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [Abdullah Tahiri] + + + Sketcher_Hyperbolic_Arc_Constr + 2016-09-03 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Sketcher/Gui/Resources/icons/Sketcher_Hyperbolic_Arc_Constr.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Sketcher_LeaveSketch.html b/localwiki/Sketcher_LeaveSketch.html new file mode 100644 index 0000000..b3002da --- /dev/null +++ b/localwiki/Sketcher_LeaveSketch.html @@ -0,0 +1,64 @@ +Sketcher LeaveSketch

      Sketcher LeaveSketch

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Sketcher LeaveSketch.png Sketcher LeaveSketch

      +
      Menu location +
      Sketch → Leave sketch +
      Workbenches +
      Sketcher, PartDesign +
      Default shortcut +
      None +
      See also +
      None +

      + +
      +


      +

      +

      Description

      +

      Usage

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Sketcher_LeaveSketch.svg b/localwiki/Sketcher_LeaveSketch.svg new file mode 100644 index 0000000..3f021da --- /dev/null +++ b/localwiki/Sketcher_LeaveSketch.svg @@ -0,0 +1,93 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [wmayer] + + + Sketcher_LeaveSketch + 2011-10-10 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Sketcher/Gui/Resources/icons/Sketcher_LeaveSketch.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Sketcher_Line.html b/localwiki/Sketcher_Line.html new file mode 100644 index 0000000..7109f87 --- /dev/null +++ b/localwiki/Sketcher_Line.html @@ -0,0 +1,71 @@ +Sketcher Line

      Sketcher Line

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Sketcher Line.png Sketcher Line

      +
      Menu location +
      Sketch → Sketcher geometries → Create line +
      Workbenches +
      Sketcher, Part Design +
      Default shortcut +
      L +
      See also +
      Sketcher Polyline +

      Contents

      + +
      + +
      +


      +

      +

      Description

      +

      This tool draws a line by picking two points in the 3D view. +When starting the tool, the mouse pointer changes to a white cross with a red line icon. Besides are coordinates shown in real time. +

      Sketcher LineExample1.png +

      +

      Usage

      +
      • Pick points on an empty area of the 3d view, or on an existing object (auto constraints must be active in TaskView).
      • +
      • Pressing ESC or clicking the right mouse button cancels the function.
      +


      +

      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Sketcher_LineExample1.png b/localwiki/Sketcher_LineExample1.png new file mode 100644 index 0000000..1032a2a Binary files /dev/null and b/localwiki/Sketcher_LineExample1.png differ diff --git a/localwiki/Sketcher_MapSketch.html b/localwiki/Sketcher_MapSketch.html new file mode 100644 index 0000000..5202b6e --- /dev/null +++ b/localwiki/Sketcher_MapSketch.html @@ -0,0 +1,84 @@ +Sketcher MapSketch

      Sketcher MapSketch

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Sketcher MapSketch.png Sketcher MapSketch

      +
      Menu location +
      Part Design/Sketch → Map sketch to face... +
      Workbenches +
      Sketcher, PartDesign +
      Default shortcut +
      None +
      See also +
      Create a new sketch +

      + +
      +


      +

      +

      Description

      +

      This tool maps an existing sketch onto the face of a shape. PartDesign features created from this sketch will be fused with the underlying solid for additive features (Pad, Revolution) or be subtracted from the underlying solid in case of subtractive features (Pocket, Groove). +

      Please note that this tool is not used to create new sketches. It only maps, or remaps an existing sketch to the face of a solid or a PartDesign feature. Typical use cases are: +

      +
      • The sketch was created on a standard plane (XY, XZ, YZ) and you want to map it to the face of a solid in order to build a feature upon it.
      • +
      • The sketch was mapped on a specific face of a solid but you need to map it to a different face.
      • +
      • Repairing a broken model.
      +
      Sketcher MapSketch 00.png
      +

      How to use

      +
      • Select the face of a PartDesign feature or a solid.
      • +
      • Click on the Sketcher_MapSketch Map sketch to face icon in the toolbar (or go to the PartDesign or Sketch menu depending on which workbench is active)
      • +
      • In the Select sketch dialog window that opens, select from the list the sketch to map to the face and click OK.
      • +
      • The sketch is automatically opened in edit mode.
      +

      Use when repairing a broken model

      +

      Sketcher MapSketch is often used when repairing a broken model. +

      One common use case is when the dependency graph has been broken. (You can view the dependency graph by Tools->Dependency graph.) This can happen when you delete a feature in the middle of your model tree. In the following example we will break and repair a model. +

      This is the base model. It has one pad, a pocket, and a pad inside that pocket. Note that the dependency graph is linear. +

      JschremppFCADEdit1.png +

      Now we have deleted the pocket and the sketch that created the pocket (Pocket and Sketch001). Note that the dependency graph is broken. To repair this model we want to attach Sketch002 to the top face of Pad. In the view of the model you can see that it would be easy to select the wrong face. +

      JschremppFCADEdit2.png +

      To repair the model we first change the visibility of the solids. We make Pad001 hidden and we make Pad visible. +

      JschremppFCADEdit3.png +

      Now we select the top face of Pad and then select the Map A Sketch To A Face tool. In the dialog that appears we select Sketch002. Our model is now repaired. In the model view we make Pad001 visible and Pad hidden and we can see the correct model. +

      JschremppFCADEdit4.png +

      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Sketcher_MapSketch.svg b/localwiki/Sketcher_MapSketch.svg new file mode 100644 index 0000000..859c935 --- /dev/null +++ b/localwiki/Sketcher_MapSketch.svg @@ -0,0 +1,464 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [wmayer] + + + Sketcher_MapSketch + 2012-12-03 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Sketcher/Gui/Resources/icons/Sketcher_MapSketch.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Sketcher_MapSketch_00.png b/localwiki/Sketcher_MapSketch_00.png new file mode 100644 index 0000000..f490828 Binary files /dev/null and b/localwiki/Sketcher_MapSketch_00.png differ diff --git a/localwiki/Sketcher_MergeSketch.html b/localwiki/Sketcher_MergeSketch.html new file mode 100644 index 0000000..0f1fdc6 --- /dev/null +++ b/localwiki/Sketcher_MergeSketch.html @@ -0,0 +1,69 @@ +Sketcher MergeSketch

      Sketcher MergeSketch

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Sketcher MergeSketch.png Sketcher MergeSketch

      +
      Menu location +
      Sketch → Merge sketches +
      Workbenches +
      Sketcher, PartDesign +
      Default shortcut +
      None +
      See also +
      +

      + +
      +


      +

      +

      Description

      +

      Merge two or more sketches. +


      +

      +

      Usage

      +
      1. Choose two or more sketches.
      2. +
      3. Click on Sketcher MergeSketch.png or choose SketchSketcher MergeSketch.png Merge Sketches from the top menu.
      4. +
      5. The resulting sketch will be created as a separate new object.
      +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Sketcher_MergeSketch.svg b/localwiki/Sketcher_MergeSketch.svg new file mode 100644 index 0000000..0173c76 --- /dev/null +++ b/localwiki/Sketcher_MergeSketch.svg @@ -0,0 +1,372 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [wmayer] + + + Sketcher_MergeSketch + 2014-11-26 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Sketcher/Gui/Resources/icons/Sketcher_MergeSketch.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Sketcher_Micro_Tutorial_-_Constraint_Practices.html b/localwiki/Sketcher_Micro_Tutorial_-_Constraint_Practices.html new file mode 100644 index 0000000..973593e --- /dev/null +++ b/localwiki/Sketcher_Micro_Tutorial_-_Constraint_Practices.html @@ -0,0 +1,97 @@ +Sketcher Micro Tutorial - Constraint Practices

      Sketcher Micro Tutorial - Constraint Practices

      + +
      + + + + + + + + + + + + + + + + + + + + + + + + + + + +
      +

      Base ExampleCommandModel.png Tutorial

      +
      Topic +
      Modeling +
      Level +
      Beginner +
      Time to complete +
      Less than 15 minutes +
      Author +
      Mark Stephen (Quick61) +
      FreeCAD version +
      0.15.4671 Release or greater +
      Example File(s) +
      None +

      + +
      +


      +

      +

      Welcome

      +

      Welcome. This tutorial is designed to help the new FreeCAD user become familiar with the techniques and best practices constraining a sketch. This micro tutorial is basically an enhanced copy from a post on the subject in the FreeCAD forum and placed here for more universal and convenient access. +

      +

      A Quick Explanation

      +

      There is a general rule with FreeCAD's sketcher constraints, the fewer amount of dimensional constraints, the better. It is always preferable to use a geometric constraint in place of a dimensional one if possible. This has to do with the internal workings of Sketcher's solver. +

      +

      First Approach

      +

      As an example, take a square sketch. In the first screenshot, the sketch is fully constrained, but is using only dimensional, (distance), constraints. this is OK, but overly complicated, cluttered, and more math intensive for the solver. While this is not an issue with such a simple example, it can become one with more complex sketches. +

      Constrain1.png +

      +

      A Better Way

      +

      The next screenshot is the same square, constrained using some geometric constraints. Using the horizontal and vertical geometric constraints, along with dimensional, (distance), constraints. By just using the horizontal and vertical geometric constraints, you can see the number of required dimensional constraints have been reduced. This is a better constrained sketch than the first, but is still not the optimum constraining scheme for this square. +

      Constrain2.png +

      +

      Optimum Scheme

      +

      Now, in this last screenshot, there is only 1 dimensional, (distance), constraint, with the remaining constraints being geometrical. This is the best way to constrain this sketch. While with a simple sketch like this, one way or the other is no big deal, on larger and more complex sketches, sticking to the minimum dimensions rule will prove out to be beneficial to you and your endeavors constructing geometry with sketches. The geometrical constraints used in this sketch are horizontal, vertical, equal, and symmetry. +

      Constrain3.png +

      +

      Additional Resources

      +

      Sketcher +

      Sketcher Tutorial +


      +

      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Sketcher_MirrorSketch.html b/localwiki/Sketcher_MirrorSketch.html new file mode 100644 index 0000000..b09c8aa --- /dev/null +++ b/localwiki/Sketcher_MirrorSketch.html @@ -0,0 +1,70 @@ +Sketcher MirrorSketch

      Sketcher MirrorSketch

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Sketcher MirrorSketch.png Sketcher MirrorSketch

      +
      Menu location +
      Sketch → Mirror sketch +
      Workbenches +
      Sketcher, PartDesign +
      Default shortcut +
      +
      See also +
      +

      + +
      +


      +

      +

      Description

      +

      Mirror a sketch along the x-axis, the y-axis or the origin. +


      +

      +

      Usage

      +
      1. Select sketch to be mirrored.
      2. +
      3. Click on Sketcher MirrorSketch.png or choose SketchSketcher MirrorSketch.png Mirror Sketch from the top menu.
      4. +
      5. The resulting sketch is created as a seperate new object.
      +


      +
      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Sketcher_MirrorSketch.svg b/localwiki/Sketcher_MirrorSketch.svg new file mode 100644 index 0000000..b08d6d3 --- /dev/null +++ b/localwiki/Sketcher_MirrorSketch.svg @@ -0,0 +1,263 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [Abdullah Tahiri] + + + Sketcher_MirrorSketch + 2015-08-19 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Sketcher/Gui/Resources/icons/Sketcher_MirrorSketch.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Sketcher_Module.html b/localwiki/Sketcher_Module.html new file mode 100644 index 0000000..7197c75 --- /dev/null +++ b/localwiki/Sketcher_Module.html @@ -0,0 +1,180 @@ +Sketcher Module

      Sketcher Module

      (Redirected from Sketcher Module)
      + +
      A basic, fully-constrained sketch‎
      +

      The Sketcher Workbench is used to create 2D geometries intended for use in the Part Design Workbench and other workbenches. +Generally a 2D geometry is considered the starting-point for most CAD models - a simple 2D sketch can be 'extruded' into a 3D shape, further 2D sketches can be used to create pockets in the surface of this shape and sketches can be used to define 'pads' (extrusions) on the surface of 3D objects. +Along with boolean operations, the sketcher forms the core of generative solid shape design. +

      The Sketcher workbench itself features constraints - allowing 2D shapes to be constrained to precise geometrical definitions. And a constraint solver which calculates the constrained-extent of 2D geometry and allows interactive exploration of sketch degrees-of-freedom. +

      +
      +


      +

      + + +

      Basics of constraint sketching

      +

      To explain how the Sketcher works, it may be useful to compare it to the "traditional" way of drafting. +

      +

      Traditional Drafting

      +

      The traditional way of CAD drafting inherits from the old drawing board. Orthogonal (2D) views are drawn manually and intended for producing technical drawings (also known as blueprints). Objects are drawn precisely to the intended size or dimension. If you want to draw an horizontal line 100mm in length starting at (0,0), you activate the line tool, either click on the screen or input the (0,0) coordinates for the first point, then make a second click or input the second point coordinates at (100,0). Or you will draw your line without regard to its position, and move it afterwards. When you've finished drawing your geometries, you add dimensions to them. +

      +

      Constraint Sketching

      +

      The Sketcher moves away from this logic. Objects do not need to be drawn exactly as you intend to, because they will be defined later on by constraints. Objects can be drawn loosely, and as long as they are unconstrained, can be modified. They are in effect "floating" and can be moved, stretched, rotated, scaled, and so on. This gives great flexibility in the design process. +

      +

      What are constraints?

      +

      Instead of dimensions, Constraints are used to limit the degrees of freedom of an object. For example, a line without constraints has 4 Degrees Of Freedom (abbreviated as " DOF "): it can be moved horizontally or vertically, it can be stretched, and it can be rotated. +

      Applying a horizontal or vertical constraint, or an angle constraint (relative to another line or to one of the axes), will limit its capacity to rotate, thus leaving it with 3 degrees of freedom. Locking one of its points in relation to the origin will remove another 2 degrees of freedom. And applying a dimension constraint will remove the last degree of freedom. The line is then considered fully-constrained. +

      Multiple objects can be constrained between one another. Two lines can be joined through one of their points with the coincident point constraint. An angle can be set between them, or they can be set perpendicular. A line can be tangent to an arc or a circle, and so on. A complex Sketch with multiple objects will have a number of different solutions, and making it fully-constrained means that just one of these possible solutions has been reached based on the applied constraints. +

      There are two kinds of constraints: geometric and dimensional. They are detailed in the 'The tools' section below. +

      +

      What the Sketcher is not good for

      +

      The Sketcher is not intended for producing 2D blueprints. Once sketches are used to generate a solid feature, they are automatically hidden. Constraints are only visible in Sketch edit mode. +

      If you only need to produce 2D views for print, and don't want to create 3D models, check out the Draft workbench (keep in mind though that the Draft workbench can also be useful to create 2D geometry not available in the Sketcher at this time, like B-Splines.) +

      +

      Sketching Workflow

      +

      A Sketch is always 2-dimensional (2D). To create a solid, a 2D Sketch of a single enclosed area is created and then either Padded or Revolved to add the 3rd dimension, creating a 3D solid from the 2D Sketch. +

      If the Sketch has segments that cross one another, places where a Point is not directly on a segment, or places where there are gaps between endpoints of adjacent segments, Pad or Revolve won't create a solid. The exception to this rule is that it doesn't apply to Construction (blue) Geometry. +

      Inside the enclosed area we can have smaller non-overlapping areas. These will become voids when the 3D solid is created. +

      +

      The tools

      +

      The Sketcher Workbench tools are all located in the Sketcher menu that appears when you load the Sketcher Workbench. +

      +

      Sketcher Geometries

      +

      These are tools for creating objects. +

      +
      • Sketcher CreatePoint.png Point: Draws a point.
      • +
      • Sketcher Line.png Line by 2 point: Draws a line segment from 2 points.
      • +
      • Sketcher Arc.png Arc: Draws an arc segment from center, radius, start angle and end angle.
      • +
      • Sketcher CreateArc3Point.png Arc by 3 Point: Draws an arc segment from two endpoints and another point on the circumference.
      • +
      • Sketcher Circle.png Circle: Draws a circle from center and radius.
      • +
      • Sketcher CreateCircle3Point.png Circle by 3 Point : Draws a circle from three points on the circumference.
      • +
      • Sketcher Conics.png Conic sections: +
        • Sketcher CreateEllipse.png Ellipse by center : Draws an ellipse by center point, major radius point and minor radius point. (v0.15)
        • +
        • Sketcher CreateEllipse 3points.png Ellipse by 3 points : Draws an ellipse by major diameter (2 points) and minor radius point. (v0.15)
        • +
        • Sketcher Elliptical Arc.png Arc of ellipse : Draws an arc of ellipse by center point, major radius point, starting point and ending point. (v0.15)
        • +
        • Sketcher Hyperbolic Arc.png Arc of hyperbola: Draws an arc of hyperbola. (v0.17)
        • +
        • Sketcher Parabolic Arc.png Arc of parabola: Draws an arc of parabola. (v0.17)
      • +
      • Sketcher CreatePolyline.png Polyline (multiple-point line): Draws a line made of multiple line segments. Pressing the M key while drawing a Polyline toggles between the different polyline modes.
      • +
      • Sketcher CreateRectangle.png Rectangle: Draws a rectangle from 2 opposite points.
      • +
      • Sketcher CreateTriangle.png Triangle: Draws a regular triangle inscribed in a construction geometry circle. (v0.15)
      • +
      • Sketcher CreateSquare.png Square: Draws a regular square inscribed in a construction geometry circle. (v0.15)
      • +
      • Sketcher CreatePentagon.png Pentagon: Draws a regular pentagon inscribed in a construction geometry circle. (v0.15)
      • +
      • Sketcher CreateHexagon.png Hexagon: Draws a regular hexagon inscribed in a construction geometry circle. (v0.15)
      • +
      • Sketcher CreateHeptagon.png Heptagon: Draws a regular heptagon inscribed in a construction geometry circle. (v0.15)
      • +
      • Sketcher CreateOctagon.png Octagon: Draws a regular octagon inscribed in a construction geometry circle. (v0.15)
      • +
      • Sketcher CreateSlot.png Slot: Draws an oval by selecting the center of one semicircle and an endpoint of the other semicircle.
      • +
      • Sketcher CreateFillet.png Fillet: Makes a fillet between two lines joined at one point. Select both lines or click on the corner point, then activate the tool.
      • +
      • Sketcher Trimming.png Trimming: Trims a line, circle or arc with respect to the clicked point.
      • +
      • Sketcher External.png External Geometry: Creates an edge linked to external geometry.
      • +
      • Sketcher ToggleConstruction.png Construction Mode: A construction object will be shown in blue and will not be used in a 3D geometry operation. It is only visible while editing the Sketch that contains it. Selecting existing Sketcher geometry and then clicking this tool toggles that geometry between regular and construction mode. Selecting this tool when no Sketcher geometry is selected changes the mode (regular vs. construction) in which future objects will be created.
      +

      Sketcher Constraints

      +

      Constraints are used to define lengths, set rules between sketch elements, and to lock the sketch along the vertical and horizontal axes. Some constraints require the Helper constraints +

      Not associated with numeric data +

      +
      • Constraint PointOnPoint.png Coincident: Affixes a point onto (coincident with) one or more other points.
      • +
      • Constraint PointOnObject.png Point On Object: Affixes a point onto another object such as a line, arc, or axis.
      • +
      • Constraint Vertical.png Vertical: Constrains the selected lines or polyline elements to a true vertical orientation. More than one object can be selected before applying this constraint.
      • +
      • Constraint Horizontal.png Horizontal: Constrains the selected lines or polyline elements to a true horizontal orientation. More than one object can be selected before applying this constraint.
      • +
      • Constraint Parallel.png Parallel: Constrains two or more lines parallel to one another.
      • +
      • Constraint Perpendicular.png Perpendicular: Constrains two lines perpendicular to one another, or constrains a line perpendicular to an arc endpoint.
      • +
      • Constraint Tangent.png Tangent: Creates a tangent constraint between two selected entities, or a co-linear constraint between two line segments. A line segment does not have to lie directly on an arc or circle to be constrained tangent to that arc or circle.
      • +
      • Constraint EqualLength.png Equal Length: Constrains two selected entities equal to one another. If used on circles or arcs their radii will be set equal.
      • +
      • Constraint Symmetric.png Symmetric: Constrains two points symmetrically about a line, or constrains the first two selected points symmetrically about a third selected point.
      • +
      • Sketcher ConstrainBlock.png Constrain Block: v 0.17 Basically allows to block a geometric element in place with a single constraint. I should be particularly useful to work with B-Splines. See https://forum.freecadweb.org/viewtopic.php?f=9&t=26572
      +

      Associated with numeric data +

      For these constraints you can use the expressions. The data may be taken from a spreadsheet. +

      +
      • Sketcher ConstrainLock.png Lock: Constrains the selected item by setting vertical and horizontal distances relative to the origin, thereby locking the location of that item. These constraint distances can be edited later.
      • +
      • Constraint HorizontalDistance.png Horizontal Distance: Fixes the horizontal distance between two points or line endpoints. If only one item is selected, the distance is set to the origin.
      • +
      • Constraint VerticalDistance.png Vertical Distance: Fixes the vertical distance between 2 points or line endpoints. If only one item is selected, the distance is set to the origin.
      • +
      • Constraint Length.png Length: Defines the distance of a selected line by constraining its length, or defines the distance between two points by constraining the distance between them.
      • +
      • Constraint Radius.png Radius: Defines the radius of a selected arc or circle by constraining the radius.
      • +
      • Constraint InternalAngle.png Internal Angle: Defines the internal angle between two selected lines.
      • +
      • Constraint SnellsLaw.png Snell's Law: Constrains two lines to obey a refraction law to simulate the light going through an interface. (v 0.15)
      • +
      • Constraint InternalAlignment.png Internal Alignment: Aligns selected elements to selected shape (e.g. a line to become major axis of an ellipse).
      +


      +

      +
      • Sketcher ToggleConstraint.png Toggle Constraint: Toggles the toolbar or the selected constraints to/from reference mode. v0.16
      +

      Other

      +
      • Sketcher NewSketch.png New sketch: Creates‎ a new sketch on a selected face or plane. If no face is selected while this tool is executed the user is prompted to select a plane from a pop-up window.
      + + +
      • Sketcher ViewSketch.png View sketch: Sets the model view perpendicular to the sketch plane.
      + + +
      • Validate sketch: It allows you to check if there are in the tolerance of different points and to match them.
      + +
      • Sketcher MirrorSketch.png Mirror sketch: Mirror a sketch along the x-axis, the y-axis or the origin [v 0.16]
      +


      +

      +
      • Sketcher CloseShape.png Close Shape: Creates a closed shape by applying coincident constraints to endpoints [v 0.15]
      +
      • Sketcher ConnectLines.png Connect Edges: Connect sketcher elements by applying coincident constraints to endpoints [v 0.15]
      + + + + + + + +
      • Sketcher Element Ellipse All.png Show/Hide internal geometry: Recreates missing/deletes unneeded geometry aligned to internal geometry of a selected element (applicable only to ellipse so far). [v 0.15]
      +
      • Sketcher Symmetry.png Symmetry: Copies a sketcher element symmetrical to a chosen line [v 0.16]
      +
      • Sketcher Clone.png Clone: Clones a sketcher element [v 0.16]
      +
      • Sketcher Copy.png Copy: Copies a sketcher element [v 0.16]
      + + +

      Preferences

      + +


      +

      +

      Best Practices

      +

      Every CAD user develops his own way of working over time, but there are some useful general principles to follow. +

      +
      • A series of simple sketches is easier to manage than a single complex one. For example, a first sketch can be created for the base 3D feature (either a pad or a revolve), while a second one can contain holes or cutouts (pockets). Some details can be left out, to be realized later on as 3D features. You can choose to avoid fillets in your sketch if there are too many, and add them as a 3D feature.
      • +
      • Always create a closed profile, or your sketch won't produce a solid, but rather a set of open faces. If you don't want some of the objects to be included in the solid creation, turn them to construction elements with the Construction Mode tool.
      • +
      • Use the auto constraints feature to limit the number of constraints you'll have to add manually.
      • +
      • As a general rule, apply geometric constraints first, then dimensional constraints, and lock your sketch last. But remember: rules are made to be broken. If you're having trouble manipulating your sketch, it may be useful to constrain a few objects first before completing your profile.
      • +
      • If possible, center your sketch to the origin (0,0) with the lock constraint. If your sketch is not symmetric, locate one of its points to the origin, or choose nice round numbers for the lock distances. In v0.12, external constraints (constraining the sketch to existing 3D geometry like edges or to other sketches) are not implemented. This means that to locate following sketches geometry to your first sketch, you'll need to set distances relative to your first sketch manually. A lock constraint of (25,75) from the origin is more easily remembered than (23.47,73.02).
      • +
      • If you have the possibility to choose between the Length constraint and the Horizontal or Vertical Distance constraints, prefer the latter. Horizontal and Vertical Distance constraints are computationally cheaper.
      • +
      • In general, the best constraints to use are: Horizontal and Vertical Constraints; Horizontal and Vertical Length Constraints; Point-to-Point Tangency. If possible, limit the use of these: the general Length Constraint; Edge-to-Edge Tangency; Fix Point Onto a Line Constraint; Symmetry Constraint.
      +


      +

      +

      Tutorials

      + +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Sketcher_NewSketch.html b/localwiki/Sketcher_NewSketch.html new file mode 100644 index 0000000..48e392b --- /dev/null +++ b/localwiki/Sketcher_NewSketch.html @@ -0,0 +1,82 @@ +Sketcher NewSketch

      Sketcher NewSketch

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Sketcher NewSketch.png Sketcher NewSketch

      +
      Menu location +
      Sketch → Create sketch +
      Workbenches +
      Sketcher, PartDesign +
      Default shortcut +
      None +
      See also +
      Sketcher MapSketch, Sketcher Reorient +

      + +
      +


      +

      +

      Description

      +

      This will create a new sketch. +

      +

      Usage

      +

      Clicking on the icon without a face (pre-)selected will pop up a dialog asking if the sketch should be drawn on the +

      +
      • XY-Plane
      • +
      • XZ-Plane
      • +
      • YZ-Plane
      +

      You can change an offset to any of the three planes and the side of the offset. +

      Clicking on the icon with a (pre-selected) face will cause the sketch to be mapped to the selected face. +

      +

      Note

      +

      The sketch can be re-mapped to another already existing face using the Map Sketch - Command +

      The sketch can be moved in the 3D-Space using Placement. +


      +

      +
      +


      +

      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Sketcher_NewSketch.svg b/localwiki/Sketcher_NewSketch.svg new file mode 100644 index 0000000..4d0faa5 --- /dev/null +++ b/localwiki/Sketcher_NewSketch.svg @@ -0,0 +1,299 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [wmayer] + + + Sketcher_NewSketch + 2011-10-10 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Sketcher/Gui/Resources/icons/Sketcher_NewSketch.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + diff --git a/localwiki/Sketcher_Octagon.html b/localwiki/Sketcher_Octagon.html new file mode 100644 index 0000000..e3792d5 --- /dev/null +++ b/localwiki/Sketcher_Octagon.html @@ -0,0 +1,80 @@ +Sketcher Octagon

      Sketcher Octagon

      + +


      +

      + + + + + + + + + + + + + + + + + + + + +
      +

      Sketcher CreateOctagon.png Sketcher CreateOctagon

      +
      Menu location +
      Sketch → Sketcher geometries → Create octagon +
      Workbenches +
      Sketcher, PartDesign +
      Default shortcut +
      +
      See also +
      +

      + +
      +


      +

      +

      Description

      +

      Draws an octagon inscribed in a construction geometry circle. +When starting the tool, the mouse pointer changes to a white cross with a red hexagon icon. +The coordinates of the pointer are shown beside it in blue in real time. +


      +SketcherCreateOctagonExample.png +


      +

      +

      Usage

      +
      • After pressing the Sketcher CreateOctagon.png Create octagon button, click once to set the center, then move the mouse and click a second time to set one of the vertices.
      • +
      • Pressing ESC or clicking the right mouse button cancels the function.
      +

      When editing the sketch the circumscribed circle is visible, when you close the sketch is hidden. +


      +


      +
      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Sketcher_Parabolic_Arc.svg b/localwiki/Sketcher_Parabolic_Arc.svg new file mode 100644 index 0000000..de1fe11 --- /dev/null +++ b/localwiki/Sketcher_Parabolic_Arc.svg @@ -0,0 +1,132 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [Abdullah Tahiri] + + + Sketcher_Parabolic_Arc + 2016-12-24 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Sketcher/Gui/Resources/icons/Sketcher_Parabolic_Arc.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Sketcher_Parabolic_Arc_Constr.svg b/localwiki/Sketcher_Parabolic_Arc_Constr.svg new file mode 100644 index 0000000..662121e --- /dev/null +++ b/localwiki/Sketcher_Parabolic_Arc_Constr.svg @@ -0,0 +1,132 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [Abdullah Tahiri] + + + Sketcher_Parabolic_Arc_Constr + 2016-12-24 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Sketcher/Gui/Resources/icons/Sketcher_Parabolic_Arc_Constr.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Sketcher_Pentagon.html b/localwiki/Sketcher_Pentagon.html new file mode 100644 index 0000000..603c0c3 --- /dev/null +++ b/localwiki/Sketcher_Pentagon.html @@ -0,0 +1,80 @@ +Sketcher Pentagon

      Sketcher Pentagon

      + +


      +

      + + + + + + + + + + + + + + + + + + + + +
      +

      Sketcher CreatePentagon.png Sketcher CreatePentagon

      +
      Menu location +
      Sketch → Sketcher geometries → Create pentagon +
      Workbenches +
      Sketcher, PartDesign +
      Default shortcut +
      +
      See also +
      +

      + +
      +


      +

      +

      Description

      +

      Draws a pentagon inscribed in a construction geometry circle. +When starting the tool, the mouse pointer changes to a white cross with a red hexagon icon. +The coordinates of the pointer are shown beside it in blue in real time. +


      +SketcherCreatePentagonExample.png +


      +

      +

      Usage

      +
      • After pressing the Sketcher CreatePentagon.png Create pentagon button, click once to set the center, then move the mouse and click a second time to set one of the vertices.
      • +
      • Pressing ESC or clicking the right mouse button cancels the function.
      +

      When editing the sketch the circumscribed circle is visible, when you close the sketch is hidden. +


      +


      +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Sketcher_Point.html b/localwiki/Sketcher_Point.html new file mode 100644 index 0000000..7d59803 --- /dev/null +++ b/localwiki/Sketcher_Point.html @@ -0,0 +1,77 @@ +Sketcher Point

      Sketcher Point

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Sketcher Point.png Sketcher Point

      +
      Menu location +
      Sketch → Sketcher geometries → Create point +
      Workbenches +
      Sketcher, PartDesign +
      Default shortcut +
      None +
      See also +
      None +

      + +
      +


      +

      +

      Description

      +

      The Point tool creates a point in the current sketch, which can be used for constructing geometry elements. The point is always an construction element and does not show up in the 3D-view. +

      Point in the sketcher +

      +
      +

      How to use

      +
      • Click on the button Sketcher Point.png Create a point in the sketch, to activate the function.
      • +
      • Clicking in the sketch creates a point.
      • +
      • Pressing ESC or clicking the right mouse button cancels the function.
      +

      Options

      +

      A mode to snap to the grid can be set in the Sketcher_Preferences. The point snaps then to the grid, if it has less than 25% grid distance to a grid line. +The snap mode does not fix them to the grid. The points can be moved with the mouse or constraints to other locations. +

      +

      Limitations

      +

      The created point is not available outside of the sketch. In case a point is needed in the 3D-view, use the PartDesign_Point for a datum point or the Part_Point instead. +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Sketcher_Polyline.html b/localwiki/Sketcher_Polyline.html new file mode 100644 index 0000000..bd76701 --- /dev/null +++ b/localwiki/Sketcher_Polyline.html @@ -0,0 +1,82 @@ +Sketcher Polyline

      Sketcher Polyline

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Sketcher CreatePolyline.png Sketcher CreatePolyline

      +
      Menu location +
      Sketch → Sketcher geometries → Create polyline +
      Workbenches +
      Sketcher, PartDesign +
      Default shortcut +
      None +
      See also +
      Sketcher Line +

      + +
      +


      +

      +

      Description

      +

      This tool works like the Sketcher Line tool, but creates continuous line segments connected by their vertices. +When starting the tool, the mouse pointer changes to a white cross with a red polyline icon. The coordinates of the pointer are shown beside it in blue in real time. +

      Three points where chosen, drag an click to add further points +

      +

      Usage

      +

      The polyline always starts with a straight line segment: click - move the mouse - click. Move the mouse again. After placing the first line segment, the Sketcher polyline tool has multiple modes that can be toggled with the M key. For example you can draw tangent or perpendicular arcs following a line or arc segment. Repeatedly pressing the M key toggles through these different modes: +

      +
      1. Press the M key: the new segment is a line which is perpendicular to the previous segment.
      2. +
      3. Press the M key again: the new segment is a line which is tangential to the previous segment.
      4. +
      5. Press the M key again: the new segment is an arc which is tangential to the previous segment.
      6. +
      7. Press the M key again: the new segment is an arc which is perpendicular (left) to the previous segment.
      8. +
      9. Press the M key again: the new segment is an arc which is perpendicular(right) to the previous segment.
      10. +
      11. Press the M key again: You are again in the state where you started; the line is only connected with a coincidence to the previous segment.
      +
      • While in any of the arc modes, holding down the CTRL key (MacOS: CMD key) and moving the cursor causes the arc to snap by increments of 45 degrees, relative to the previously created polyline segment (v0.18).
      • +
      • Pick points on an empty area of the 3D view, or on an existing object (auto constraints must be active in TaskView).
      • +
      • Pressing ESC or clicking the right mouse button before closing the polyline to a loop ends the current polyline and you can continue with a new one. Pressing ESC or clicking the right mouse button again ends the polyline function.
      • +
      • Pressing ESC or clicking the right mouse button after closing the polyline to a loop ends the polyline function.
      +
      +


      +

      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Sketcher_PolylineExample1.png b/localwiki/Sketcher_PolylineExample1.png new file mode 100644 index 0000000..c8b75da Binary files /dev/null and b/localwiki/Sketcher_PolylineExample1.png differ diff --git a/localwiki/Sketcher_Preferences.html b/localwiki/Sketcher_Preferences.html new file mode 100644 index 0000000..2de26fa --- /dev/null +++ b/localwiki/Sketcher_Preferences.html @@ -0,0 +1,27 @@ +Sketcher Preferences

      Sketcher Preferences

      + +

      The preferences screen of the Sketcher are found in the Preferences window (Menu Edit → Preferences → Sketcher). +

      +

      General

      +

      Preference Sketcher Tab 01.png +

      +
      +

      Colors

      +

      Preference Sketcher Tab 02.png +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Sketcher_ProfilesHexagon1.svg b/localwiki/Sketcher_ProfilesHexagon1.svg new file mode 100644 index 0000000..52c5b34 --- /dev/null +++ b/localwiki/Sketcher_ProfilesHexagon1.svg @@ -0,0 +1,102 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [wmayer] + + + Sketcher_ProfilesHexagon1 + 2014-06-04 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Sketcher/Gui/Resources/icons/Sketcher_ProfilesHexagon1.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Sketcher_Rectangle.html b/localwiki/Sketcher_Rectangle.html new file mode 100644 index 0000000..1283708 --- /dev/null +++ b/localwiki/Sketcher_Rectangle.html @@ -0,0 +1,71 @@ +Sketcher Rectangle

      Sketcher Rectangle

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Sketcher CreateRectangle.png Sketcher CreateRectangle

      +
      Menu location +
      Sketch → Sketcher geometries → Create rectangle +
      Workbenches +
      Sketcher, PartDesign +
      Default shortcut +
      R +
      See also +
      Sketcher Polyline +

      + +
      +


      +

      +

      Description

      +

      This tool draws a rectangle by picking two opposite points. +When starting the tool, the mouse pointer changes to a white cross with a red rectangle icon. +The coordinates of the pointer are shown beside it in blue in real time. +

      SketcherCreateRectangleExample.png +

      +

      Usage

      +
      • After pressing the 'Create Rectangle' button, click once to set the first corner, then move the mouse and click a second time to set the opposite corner.
      • +
      • Pressing ESC or clicking the right mouse button cancels the function.
      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Sketcher_Rectangle.png b/localwiki/Sketcher_Rectangle.png new file mode 100644 index 0000000..bc5fcdc Binary files /dev/null and b/localwiki/Sketcher_Rectangle.png differ diff --git a/localwiki/Sketcher_RectangularArray.html b/localwiki/Sketcher_RectangularArray.html new file mode 100644 index 0000000..a94c560 --- /dev/null +++ b/localwiki/Sketcher_RectangularArray.html @@ -0,0 +1,80 @@ +Sketcher RectangularArray

      Sketcher RectangularArray

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Sketcher RectangularArray.png Sketcher RectangularArray

      +
      Menu location +
      Sketch → Sketcher tools → Rectangular Array +
      Workbenches +
      Sketcher, PartDesign +
      Default shortcut +
      +
      See also +
      +

      + +
      +


      +

      +

      Description

      +

      Creates an array of selected sketcher elements. +

      +

      Usage

      +
      1. Select sketcher element(s) in Tasks-Panel or in 3D-View.
      2. +
      3. Click on Sketcher RectangularArray.png or choose Sketch Sketcher toolsSketcher RectangularArray.png RectangularArray from the top menu.
      4. +
      5. A menu will pop up asking you for the different options of the array.
      6. +
      7. Select endpoint for operation in 3D-View.
      +


      +Sketcher RectangularArray Options.jpg +
      +Array options +

      +

      Notes

      +

      Available since FreeCAD v 0.16. +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Sketcher_RectangularArray.svg b/localwiki/Sketcher_RectangularArray.svg new file mode 100644 index 0000000..c70bf1f --- /dev/null +++ b/localwiki/Sketcher_RectangularArray.svg @@ -0,0 +1,200 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [Abdullah Tahiri] + + + Sketcher_RectangularArray + 2015-08-13 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Sketcher/Gui/Resources/icons/Sketcher_RectangularArray.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Sketcher_RectangularArray_Options.jpg b/localwiki/Sketcher_RectangularArray_Options.jpg new file mode 100644 index 0000000..d41e59a Binary files /dev/null and b/localwiki/Sketcher_RectangularArray_Options.jpg differ diff --git a/localwiki/Sketcher_Reorient.html b/localwiki/Sketcher_Reorient.html new file mode 100644 index 0000000..5deb9a0 --- /dev/null +++ b/localwiki/Sketcher_Reorient.html @@ -0,0 +1,73 @@ +Sketcher Reorient

      Sketcher Reorient

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Sketcher Reorient.png Sketcher Reorient

      +
      Menu location +
      Part design → Reorient sketch +
      Workbenches +
      Sketcher, PartDesign +
      Default shortcut +
      None +
      See also +
      Map sketch, New Sketch +

      + +
      +


      +

      +

      Description

      +

      Allows you to detach a sketch from a face and attach it to one of the main planes (with an offset). +

      +

      Use

      +
      1. Select the sketch to be re-oriented in the tree-view
      2. +
      3. Choose Sketch Reorient sketch from the top menu
      4. +
      5. A menu will pop up and ask you if you want to detach the sketch from its face
      6. +
      7. Selecting Yes will give you the same menu as in Sketch New Sketch
      8. +
      9. You can attach the sketch to one of the main planes
      10. +
      11. You also have the possibility to add a positive or negative offset
      +

      Note

      +
      • When selecting Cancel in the second menu the sketch is simply detached from its face.
      • +
      • As long as no sketch is selected, the command is greyed out.
      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Sketcher_SelectConflictingConstraints.html b/localwiki/Sketcher_SelectConflictingConstraints.html new file mode 100644 index 0000000..f87b899 --- /dev/null +++ b/localwiki/Sketcher_SelectConflictingConstraints.html @@ -0,0 +1,77 @@ +Sketcher SelectConflictingConstraints

      Sketcher SelectConflictingConstraints

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Sketcher SelectConflictingConstraints.png Sketcher SelectConflictingConstraints

      +
      Menu location +
      Sketch → Sketcher tools → Select Conflicting Constraints +
      Workbenches +
      Sketcher, PartDesign +
      Default shortcut +
      Shift+Ctrl+E +
      See also +
      +

      + +
      +


      +

      +

      Description

      +

      Selects the conflicting constraints of a sketch. +


      +

      +

      Use

      +
      1. Enter edit mode of sketch.
      2. +
      3. Choose Sketch Sketcher toolsSketcher SelectConflictingConstraints.png Select Conflicting Constraints from the top menu.
      4. +
      5. The conflicting constraints of the sketch will be selected.
      +


      +

      +

      Notes

      +

      Available since FreeCAD v 0.15. +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Sketcher_SelectConflictingConstraints.svg b/localwiki/Sketcher_SelectConflictingConstraints.svg new file mode 100644 index 0000000..cef8438 --- /dev/null +++ b/localwiki/Sketcher_SelectConflictingConstraints.svg @@ -0,0 +1,93 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [Abdullah Tahiri] + + + Sketcher_SelectConflictingConstraints + 2014-09-15 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Sketcher/Gui/Resources/icons/Sketcher_SelectConflictingConstraints.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Sketcher_SelectConstraints.html b/localwiki/Sketcher_SelectConstraints.html new file mode 100644 index 0000000..c407456 --- /dev/null +++ b/localwiki/Sketcher_SelectConstraints.html @@ -0,0 +1,77 @@ +Sketcher SelectConstraints

      Sketcher SelectConstraints

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Sketcher SelectConstraints.png Sketcher SelectConstraints

      +
      Menu location +
      Sketch → Sketcher tools → Select Constraints +
      Workbenches +
      Sketcher +
      Default shortcut +
      Shift+Ctrl+C +
      See also +
      +

      + +
      +


      +

      +

      Description

      +

      Selects the constraints of a sketcher element. +


      +

      +

      Use

      +
      1. Select sketcher element in the Tasks-Panel or in the 3D-View.
      2. +
      3. Click on Sketcher SelectConstraints.png or choose Sketch Sketcher toolsSketcher SelectConstraints.png Select Constraints from the top menu.
      4. +
      5. The associated constraints will be highlighted in the Tasks-Panel.
      +


      +

      +

      Notes

      +

      Does not work with Point-on-Object constraints. +Available since FreeCAD v 0.15. +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Sketcher_SelectConstraints.svg b/localwiki/Sketcher_SelectConstraints.svg new file mode 100644 index 0000000..9770cf2 --- /dev/null +++ b/localwiki/Sketcher_SelectConstraints.svg @@ -0,0 +1,441 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [wmayer] + + + Sketcher_SelectConstraints + 2014-08-04 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Sketcher/Gui/Resources/icons/Sketcher_SelectConstraints.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Sketcher_SelectElementsAssociatedWithConstraints.html b/localwiki/Sketcher_SelectElementsAssociatedWithConstraints.html new file mode 100644 index 0000000..8e2fcaf --- /dev/null +++ b/localwiki/Sketcher_SelectElementsAssociatedWithConstraints.html @@ -0,0 +1,77 @@ +Sketcher SelectElementsAssociatedWithConstraints

      Sketcher SelectElementsAssociatedWithConstraints

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Sketcher SelectElementsAssociatedWithConstraints.png Sketcher SelectElementsAssociatedWithConstraints

      +
      Menu location +
      Sketch → Sketcher tools → Select Elements Associated with constraints +
      Workbenches +
      Sketcher, PartDesign +
      Default shortcut +
      Shift+Ctrl+E +
      See also +
      +

      + +
      +


      +

      +

      Description

      +

      Select sketcher Elements associated with constraints. +


      +

      +

      Use

      +
      1. Select constraint in the Tasks-Panel or in the 3D-View.
      2. +
      3. Click on Sketcher SelectElementsAssociatedWithConstraints.png or choose Sketch Sketcher toolsSketcher SelectElementsAssociatedWithConstraints.png Select Elements associated with constraints from the top menu.
      4. +
      5. The associated sketcher element(s) will be highlighted in the Tasks-Panel.
      +


      +

      +

      Notes

      +


      +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Sketcher_SelectElementsAssociatedWithConstraints.svg b/localwiki/Sketcher_SelectElementsAssociatedWithConstraints.svg new file mode 100644 index 0000000..d4f5acd --- /dev/null +++ b/localwiki/Sketcher_SelectElementsAssociatedWithConstraints.svg @@ -0,0 +1,139 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [Abdullah Tahiri] + + + Sketcher_SelectElementsAssociatedWithConstraints + 2014-09-15 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Sketcher/Gui/Resources/icons/Sketcher_SelectElementsAssociatedWithConstraints.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Sketcher_SelectHorizontalAxis.html b/localwiki/Sketcher_SelectHorizontalAxis.html new file mode 100644 index 0000000..7d44ae6 --- /dev/null +++ b/localwiki/Sketcher_SelectHorizontalAxis.html @@ -0,0 +1,77 @@ +Sketcher SelectHorizontalAxis

      Sketcher SelectHorizontalAxis

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Sketcher SelectHorizontalAxis.png Sketcher SelectHorizontalAxis

      +
      Menu location +
      Sketch → Sketcher tools → Select Horizontal Axis +
      Workbenches +
      Sketcher +
      Default shortcut +
      Shift+Ctrl+H +
      See also +
      +

      + +
      +


      +

      +

      Description

      +

      Selects the horizontal axis of a sketch. +


      +

      +

      Use

      +
      1. Enter edit mode of sketch.
      2. +
      3. Choose Sketch Sketcher toolsSketcher SelectHorizontalAxis.png Select Horizontal Axis from the top menu.
      4. +
      5. The horizontal axis of the sketch will be selected.
      +


      +

      +

      Notes

      +

      Available since FreeCAD v 0.15. +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Sketcher_SelectHorizontalAxis.svg b/localwiki/Sketcher_SelectHorizontalAxis.svg new file mode 100644 index 0000000..6acdc28 --- /dev/null +++ b/localwiki/Sketcher_SelectHorizontalAxis.svg @@ -0,0 +1,101 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [wmayer] + + + Sketcher_SelectHorizontalAxis + 2014-08-04 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Sketcher/Gui/Resources/icons/Sketcher_SelectHorizontalAxis.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Sketcher_SelectOrigin.html b/localwiki/Sketcher_SelectOrigin.html new file mode 100644 index 0000000..b5bc6a4 --- /dev/null +++ b/localwiki/Sketcher_SelectOrigin.html @@ -0,0 +1,76 @@ +Sketcher SelectOrigin

      Sketcher SelectOrigin

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Sketcher SelectOrigin.png Sketcher SelectOrigin

      +
      Menu location +
      Sketch → Sketcher tools → Select Origin +
      Workbenches +
      Sketcher +
      Default shortcut +
      Shift+Ctrl+O +
      See also +
      +

      + +
      +


      +

      +

      Description

      +

      Selects the origin of a sketch. +


      +

      +

      Use

      +
      1. Enter edit mode of sketch.
      2. +
      3. Choose Sketch Sketcher toolsSketcher SelectOrigin.png Select Origin from the top menu.
      4. +
      5. The origin of the sketch will be selected.
      +


      +

      +

      Notes

      +

      Available since FreeCAD v 0.15. +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Sketcher_SelectOrigin.svg b/localwiki/Sketcher_SelectOrigin.svg new file mode 100644 index 0000000..b84be50 --- /dev/null +++ b/localwiki/Sketcher_SelectOrigin.svg @@ -0,0 +1,100 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [wmayer] + + + Sketcher_SelectOrigin + 2014-08-04 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Sketcher/Gui/Resources/icons/Sketcher_SelectOrigin.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Sketcher_SelectRedundantConstraints.html b/localwiki/Sketcher_SelectRedundantConstraints.html new file mode 100644 index 0000000..c22def9 --- /dev/null +++ b/localwiki/Sketcher_SelectRedundantConstraints.html @@ -0,0 +1,77 @@ +Sketcher SelectRedundantConstraints

      Sketcher SelectRedundantConstraints

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Sketcher SelectRedundantConstraints.png Sketcher SelectRedundantConstraints

      +
      Menu location +
      Sketch → Sketcher tools → Select Redundant Constraints +
      Workbenches +
      Sketcher, PartDesign +
      Default shortcut +
      Shift+Ctrl+R +
      See also +
      +

      + +
      +


      +

      +

      Description

      +

      Selects the redundant constraints of a sketch. +


      +

      +

      Use

      +
      1. Enter edit mode of sketch.
      2. +
      3. Choose Sketch Sketcher toolsSketcher SelectRedundantConstraints.png Select Redundant Constraints from the top menu.
      4. +
      5. The redundant constraints of the sketch will be selected.
      +


      +

      +

      Notes

      +

      Available since FreeCAD v 0.15. +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Sketcher_SelectRedundantConstraints.svg b/localwiki/Sketcher_SelectRedundantConstraints.svg new file mode 100644 index 0000000..4794f4e --- /dev/null +++ b/localwiki/Sketcher_SelectRedundantConstraints.svg @@ -0,0 +1,93 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [Abdullah Tahiri] + + + Sketcher_SelectRedundantConstraints + 2014-09-15 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Sketcher/Gui/Resources/icons/Sketcher_SelectRedundantConstraints.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Sketcher_SelectVerticalAxis.html b/localwiki/Sketcher_SelectVerticalAxis.html new file mode 100644 index 0000000..30f0875 --- /dev/null +++ b/localwiki/Sketcher_SelectVerticalAxis.html @@ -0,0 +1,77 @@ +Sketcher SelectVerticalAxis

      Sketcher SelectVerticalAxis

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Sketcher SelectVerticalAxis.png Sketcher SelectVerticalAxis

      +
      Menu location +
      Sketch → Sketcher tools → Select Vertical Axis +
      Workbenches +
      Sketcher +
      Default shortcut +
      Shift+Ctrl+V +
      See also +
      +

      + +
      +


      +

      +

      Description

      +

      Selects the vertical axis of a sketch. +


      +

      +

      Use

      +
      1. Enter edit mode of sketch.
      2. +
      3. Choose Sketch Sketcher toolsSketcher SelectVerticalAxis.png Select Vertical Axis from the top menu.
      4. +
      5. The vertical axis of the sketch will be selected.
      +


      +

      +

      Notes

      +

      Available since FreeCAD v 0.15. +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Sketcher_SelectVerticalAxis.svg b/localwiki/Sketcher_SelectVerticalAxis.svg new file mode 100644 index 0000000..210f30d --- /dev/null +++ b/localwiki/Sketcher_SelectVerticalAxis.svg @@ -0,0 +1,101 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [wmayer] + + + Sketcher_SelectVerticalAxis + 2014-08-04 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Sketcher/Gui/Resources/icons/Sketcher_SelectVerticalAxis.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Sketcher_Show_Hide_Internal_Geometry.html b/localwiki/Sketcher_Show_Hide_Internal_Geometry.html new file mode 100644 index 0000000..7daad93 --- /dev/null +++ b/localwiki/Sketcher_Show_Hide_Internal_Geometry.html @@ -0,0 +1,77 @@ +Sketcher Show Hide Internal Geometry

      Sketcher Show Hide Internal Geometry

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Sketcher RestoreInternalAlignmentGeometry.png Sketcher RestoreInternalAlignmentGeometry

      +
      Menu location +
      Sketch → Sketcher tools → Show/hide internal geometry +
      Workbenches +
      Sketcher, PartDesign +
      Default shortcut +
      Ctrl+Shift+E +
      See also +
      Ellipse, Internal Alignment Constraint +

      + +
      +


      +

      +

      Description

      +

      The command deletes unused elements aligned to internal geometry, or recreates the missing ones. +

      +

      Usage

      +
      • Select an element of a sketch that supports internal alignment (currently only Ellipse/Arc).
      • +
      • Invoke the command by clicking a toolbar button, picking the menu item or using the keyboard shortcut.
      +

      If there are free alignment places for the selected element, new construction geometry is created and aligned to the available places. If all alignment places are occupied, the unused internal geometry is deleted (the element is treated as unused if it is not constrained to anything else). +

      +

      Example

      +

      Create a new ellipse. New ellipses are always fully-packed. You'll see an ellipse and a bunch of construction geometry: major diameter, minor diameter, foci. +

      Select minor diameter line and hit DEL. The diameter is gone, but the ellipse remains. How do we get the diameter back? +

      Select the ellipse and invoke the Sketcher_RestoreInternalAlignmentGeometry command. The diameter is restored. +

      Now, constrain the major diameter of the ellipse to some length. Select the ellipse and invoke the Sketcher_RestoreInternalAlignmentGeometry command. Minor diameter and foci are deleted, but the major diameter is kept, because it participates in other constraints. Ellipse's center remains too, because it is inherent, like center of a circle. +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Sketcher_Sketch.svg b/localwiki/Sketcher_Sketch.svg new file mode 100644 index 0000000..fe307e0 --- /dev/null +++ b/localwiki/Sketcher_Sketch.svg @@ -0,0 +1,218 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [wmayer] + + + Sketcher_Sketch + 2011-10-10 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Sketcher/Gui/Resources/icons/Sketcher_Sketch.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + diff --git a/localwiki/Sketcher_Slot.html b/localwiki/Sketcher_Slot.html new file mode 100644 index 0000000..b4254eb --- /dev/null +++ b/localwiki/Sketcher_Slot.html @@ -0,0 +1,73 @@ +Sketcher Slot

      Sketcher Slot

      + +


      +

      + + + + + + + + + + + + + + + + + + + + +
      +

      Sketcher CreateSlot.png Sketcher CreateSlot

      +
      Menu location +
      Sketch → Sketcher geometries → Create slot +
      Workbenches +
      Sketcher, PartDesign +
      Default shortcut +
      +
      See also +
      +

      + +
      +


      +

      +

      Description

      +

      Draws a slot by selecting the center of one semicircle and an endpoint of the other semicircle. +When starting the tool, the mouse pointer changes to a white cross with a red slot icon. +The coordinates of the pointer are shown beside it in blue in real time. +


      +SketcherCreateSlotExample.png +

      +

      Usage

      +
      • After pressing the Sketcher CreateSlot.png Create slot button, click once to set the center of one semicircle, then move the mouse and click a second time to set endpoint of the other semicircle.
      • +
      • Pressing ESC or clicking the right mouse button cancels the function.
      +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Sketcher_Square.html b/localwiki/Sketcher_Square.html new file mode 100644 index 0000000..320603d --- /dev/null +++ b/localwiki/Sketcher_Square.html @@ -0,0 +1,80 @@ +Sketcher Square

      Sketcher Square

      + +


      +

      + + + + + + + + + + + + + + + + + + + + +
      +

      Sketcher CreateSquare.png Sketcher CreateSquare

      +
      Menu location +
      Sketch → Sketcher geometries → Create square +
      Workbenches +
      Sketcher, PartDesign +
      Default shortcut +
      +
      See also +
      +

      + +
      +


      +

      +

      Description

      +

      Draws a square inscribed in a construction geometry circle. +When starting the tool, the mouse pointer changes to a white cross with a red hexagon icon. +The coordinates of the pointer are shown beside it in blue in real time. +


      +SketcherCreateSquareExample.png +


      +

      +

      Usage

      +
      • After pressing the Sketcher CreateSquare.png Create square button, click once to set the center, then move the mouse and click a second time to set one of the vertices.
      • +
      • Pressing ESC or clicking the right mouse button cancels the function.
      +

      When editing the sketch the circumscribed circle is visible, when you close the sketch is hidden. +


      +


      +
      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Sketcher_SwitchVirtualSpace.svg b/localwiki/Sketcher_SwitchVirtualSpace.svg new file mode 100644 index 0000000..2f2da30 --- /dev/null +++ b/localwiki/Sketcher_SwitchVirtualSpace.svg @@ -0,0 +1,336 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [wmayer] + + + Sketcher_MergeSketch + 2014-11-26 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Sketcher/Gui/Resources/icons/Sketcher_MergeSketch.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Sketcher_Symmetry.html b/localwiki/Sketcher_Symmetry.html new file mode 100644 index 0000000..8fdfb2b --- /dev/null +++ b/localwiki/Sketcher_Symmetry.html @@ -0,0 +1,78 @@ +Sketcher Symmetry

      Sketcher Symmetry

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Sketcher Symmetry.png Sketcher Symmetry

      +
      Menu location +
      Sketch → Sketcher tools → Symmetry +
      Workbenches +
      Sketcher, PartDesign +
      Default shortcut +
      +
      See also +
      +

      + +
      +


      +

      +

      Description

      +

      Copies a sketcher element symmetrical to a chosen line. +


      +

      +

      Usage

      +
      1. Select arc/line/rectangle to be copied and line for copy operation.
      2. +
      3. Choose Sketch Sketcher toolsSketcher Symmetry.png Symmetry from the top menu.
      4. +
      5. Chosen element will be copied symetrical to the chosen second element.
      +

      No extra symmetry constraint will be added. +


      +

      +

      Notes

      +

      Available since FreeCAD v 0.16. +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Sketcher_Symmetry.svg b/localwiki/Sketcher_Symmetry.svg new file mode 100644 index 0000000..8908bb5 --- /dev/null +++ b/localwiki/Sketcher_Symmetry.svg @@ -0,0 +1,149 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [Abdullah Tahiri] + + + Sketcher_Symmetry + 2015-08-11 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Sketcher/Gui/Resources/icons/Sketcher_Symmetry.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Sketcher_ToggleConstraint.html b/localwiki/Sketcher_ToggleConstraint.html new file mode 100644 index 0000000..d9a25e4 --- /dev/null +++ b/localwiki/Sketcher_ToggleConstraint.html @@ -0,0 +1,67 @@ +Sketcher ToggleConstraint

      Sketcher ToggleConstraint

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Sketcher ToggleConstraint.png Sketcher ToggleConstraint

      +
      Menu location +
      Sketch → Sketcher constraints → Toggle reference/driving constraint +
      Workbenches +
      Sketcher, PartDesign +
      Default shortcut +
      +
      See also +
      Toggle Construction +

      + +
      +


      +

      +

      Description

      +

      v0.16 +

      +

      Usage

      +

      Example

      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Sketcher_ToggleConstraint.svg b/localwiki/Sketcher_ToggleConstraint.svg new file mode 100644 index 0000000..6bd1b41 --- /dev/null +++ b/localwiki/Sketcher_ToggleConstraint.svg @@ -0,0 +1,187 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [Abdullah Tahiri] + + + Sketcher_ToggleConstraint + 2015-05-26 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Sketcher/Gui/Resources/icons/Sketcher_ToggleConstraint.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Sketcher_ToggleConstraint_Driven.svg b/localwiki/Sketcher_ToggleConstraint_Driven.svg new file mode 100644 index 0000000..9c00775 --- /dev/null +++ b/localwiki/Sketcher_ToggleConstraint_Driven.svg @@ -0,0 +1,91 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [Abdullah Tahiri] + + + Sketcher_Toggle_Constraint_Driven + 2015-05-24 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Sketcher/Gui/Resources/icons/Sketcher_Toggle_Constraint_Driven.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + diff --git a/localwiki/Sketcher_ToggleConstraint_Driving.svg b/localwiki/Sketcher_ToggleConstraint_Driving.svg new file mode 100644 index 0000000..72003f8 --- /dev/null +++ b/localwiki/Sketcher_ToggleConstraint_Driving.svg @@ -0,0 +1,88 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [Abdullah Tahiri] + + + Sketcher_Toggle_Constraint_Driving + 2015-05-24 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Sketcher/Gui/Resources/icons/Sketcher_Toggle_Constraint_Driving.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + diff --git a/localwiki/Sketcher_ToggleConstruction.html b/localwiki/Sketcher_ToggleConstruction.html new file mode 100644 index 0000000..855265e --- /dev/null +++ b/localwiki/Sketcher_ToggleConstruction.html @@ -0,0 +1,67 @@ +Sketcher ToggleConstruction

      Sketcher ToggleConstruction

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Sketcher ToggleConstruction.png Sketcher ToggleConstruction

      +
      Menu location +
      Sketch → Sketcher geometries → Toggle construction geometry +
      Workbenches +
      Sketcher, PartDesign +
      Default shortcut +
      C,M +
      See also +
      Toggle Constraint +

      + +
      +


      +

      +

      Description

      +

      v0.16 +

      +

      Usage

      +

      Example

      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Sketcher_ToggleConstruction.svg b/localwiki/Sketcher_ToggleConstruction.svg new file mode 100644 index 0000000..c94a38b --- /dev/null +++ b/localwiki/Sketcher_ToggleConstruction.svg @@ -0,0 +1,87 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [Abdullah Tahiri] + + + Sketcher_ToggleConstruction + 2015-05-24 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Sketcher/Gui/Resources/icons/Sketcher_ToggleConstruction.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Sketcher_ToggleNormal.svg b/localwiki/Sketcher_ToggleNormal.svg new file mode 100644 index 0000000..48f3b66 --- /dev/null +++ b/localwiki/Sketcher_ToggleNormal.svg @@ -0,0 +1,88 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [Abdullah Tahiri] + + + Sketcher_ToggleNormal + 2015-05-24 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Sketcher/Gui/Resources/icons/Sketcher_ToggleNormal.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Sketcher_Triangle.html b/localwiki/Sketcher_Triangle.html new file mode 100644 index 0000000..bc14933 --- /dev/null +++ b/localwiki/Sketcher_Triangle.html @@ -0,0 +1,82 @@ +Sketcher Triangle

      Sketcher Triangle

      + +


      +

      + + + + + + + + + + + + + + + + + + + + +
      +

      Sketcher CreateTriangle.png Sketcher CreateTriangle

      +
      Menu location +
      Sketch → Sketcher geometries → Create equilateral triangle +
      Workbenches +
      Sketcher, PartDesign +
      Default shortcut +
      +
      See also +
      +

      + +
      +


      +

      +

      Description

      +

      Draws a equilateral triangle inscribed in a construction geometry circle. +When starting the tool, the mouse pointer changes to a white cross with a red hexagon icon. +The coordinates of the pointer are shown beside it in blue in real time. +


      +SketcherCreateTriangleExample.png +


      +

      +

      Usage

      +
      • Press the Sketcher CreateTriangle.png Create equilateral triangle button,
      • +
      • Click once to set the center,
      • +
      • Move the mouse and click a second time to set one of the vertices.
      • +
      • Pressing ESC or clicking the right mouse button cancels the function.
      +

      When editing the sketch the circumscribed circle is visible, when you close the sketch is hidden. +


      +


      +
      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Sketcher_Trimming.html b/localwiki/Sketcher_Trimming.html new file mode 100644 index 0000000..b9f01f1 --- /dev/null +++ b/localwiki/Sketcher_Trimming.html @@ -0,0 +1,76 @@ +Sketcher Trimming

      Sketcher Trimming

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Sketcher Trimming.png Sketcher Trimming

      +
      Menu location +
      Sketch → Sketcher geometries → Trim edge +
      Workbenches +
      Sketcher, PartDesign +
      Default shortcut +
      T +
      See also +
      None +

      + +
      +


      +

      +

      Description

      +

      This tool trims a line or circle to the nearest overlapping line. +

      SketcherTrimExample1.png +

      SketcherTrimExample2.png +

      SketcherTrimExample3.png +


      +

      +

      Use

      +

      To use the tool click the 'Trim Edge' button, then click on the line segment that you want to trim. +The line segment will be trimmed to the nearest overlapping line(s). +


      +

      +
      +


      +

      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Sketcher_Trimming.svg b/localwiki/Sketcher_Trimming.svg new file mode 100644 index 0000000..f3f6e79 --- /dev/null +++ b/localwiki/Sketcher_Trimming.svg @@ -0,0 +1,95 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [wmayer] + + + Sketcher_Trimming + 2011-10-10 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Sketcher/Gui/Resources/icons/Sketcher_Trimming.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Sketcher_Tutorial.html b/localwiki/Sketcher_Tutorial.html new file mode 100644 index 0000000..c9058f2 --- /dev/null +++ b/localwiki/Sketcher_Tutorial.html @@ -0,0 +1,271 @@ +Sketcher Tutorial

      Sketcher Tutorial

      + +
      + + + + + + + + + + + + + + + + + + + + + + + + + + + +
      +

      Base ExampleCommandModel.png Tutorial

      +
      Topic +
      Sketcher +
      Level +
      Beginner +
      Time to complete +
      +
      Author +
      Ulrich +
      FreeCAD version +
      +
      Example File(s) +
      +

      + +
      +


      +

      +

      Introduction

      +

      The Sketcher is a tool to generate 2D-objects for usage in parts design. The sketcher is different to traditional drawing tools. A way to show the difference is the construction of a triangle. A triangle is fully defined by 3 values, which can be any from the following list: side length, angle, height, area. The one exception is three angles, which will not define the size. +

      In order to construct a triangle from 3 lengths in the traditional way, the following has to be done: +

      +
      • draw the base line
      • +
      • make two circles with a radius given by the other two side lengths, or alternatively calculate the coordinates of the third vertex
      • +
      • draw the missing two sides from the endpoints of the base line to the crossing point of the two circles or the calculated vertex.
      +

      Traditional triangle.png +

      The wikipedia:Triangle page shows a collection of formulas to calculate the missing information in order to draw a triangle from the minimum specification. Those are needed, if the triangle has to be defined by pre-calculated coordinates. +

      The Sketcher is different. The formulas and the above helper constructions are not needed. In order to understand the difference, it is best to construct a triangle by yourself. +

      +

      First sketch: a triangle

      +

      An open document is needed in order to make a sketch. When there is no open document, a new one will be created by clicking on Document-new.png The sketcher workbench has to be selected: +

      Workbench select sketcher.png +

      A new sketch will be created by clicking at Sketcher NewSketch.png. A dialog appears, where the orientation of the new sketch in the 3D-space can be selected. It doesn't matter in this case, so the xy-plane can be confirmed. A new empty sketch will be created and opened in edit mode. A grid with a coordinate system will be shown with a red point at the origin. +

      In the Sketcher it is ok to draw an arbitrary triangle with the Sketcher CreatePolyline.pngpolyline tool and define its properties in a later step. Each click in the drawing plane sets a vertex. The triangle needs to be closed. So for the last line a click is needed on the first created vertex. A red point should be visible near the mouse pointer before clicking. +

      Closed triangle with pointer small.png +

      This will make sure that the last vertex is identical to the first one and the profile is closed. Those symbols that appear beneath the drawing pointer do indicate auto-constraints. They are set automatically at clicking at this location. The red dot beneath the drawing pointer indicates a coincidence constraint between two vertices, i.e. the vertices of this different drawing elements are constrained to an identical location. +

      The created triangle is flexible. A vertex can be touched with the mouse and dragged around. The sides of the triangle follow the vertex. The same can be done with a line. +

      Each length of the side is now easily defined by selecting it with the mouse: selected item turns into green. When clicking on theConstraint Length.png length tool, a dialog opens and the desired length can be put in. The picture below shows a triangle with side lengths set to 35 mm, 27 mm and 25 mm. The baseline was set horizontally by selecting it and clicking on the horizontal constraint toolConstraint Horizontal.png. +


      +Sketcher triangle3 small.png +

      These length-definitions are called constraints. Constraints are used to define a fixed design from the flexible geometric input. The sketcher provides all constraints needed to define any kind of triangle. Only the area can not be used to define one. So the created triangle can be redefined by changing the value of a constraint or by deleting constraints and add other ones. Here comes a list of triangles with other given properties. It is no problem to turn the just created triangle into one of these. +

      +
      • One or two angles given: Two sides of the triangle needs to be selected. A click on Constraint InternalAngle.png opens a dialog to define the angle.
      +

      Triangel angle small.png +

      +
      • Right triangle: Two sides of the triangle needs to be selected. A click onConstraint Perpendicular.png sets a right angle between the two sides.
      +

      Right triangle sketcher.png +

      +
      • Equilateral: One side has to be set to a defined length. Then all sides needs to be selected. A click onConstraint EqualLength.png defines two equal length constrains in order to give all sides the same length.
      +

      Triangle equilateral small.png +

      +
      • Isoscales triangle (two identical length) with given height: Select first the two sides with the equal length. A click on Constraint Symmetric.png sets a equality between the two sides. Then select the base line and the top vertex and click the Constraint Length.png length tool.
      +

      Triangle isosceles small.png +

      Constraints can be selected by clicking on the symbol or by clicking in the constraint-list. They can be deleted or in case of constraints with a value edited after a double click. A given triangle can be later changed into another type of triangle by editing or changing the constraints. The sketcher is a part of the parametric FreeCAD-modelling approach. What you have created, can be easily changed at a later time, if for example a variant of the design is needed. +

      The above shown triangles have white lines. This is an indication that the sketch has some degrees of freedom left. It can be tested by dragging on some lines or points. If the line or point moves, this item is not fully defined. A sketch with no degrees of freedom left turns green. +

      The isoscele triangle is missing the length setting for the base line and it can move and rotate freely in the sketcher drawing plane. +

      If the triangle properties are defined, it still needed to be fixed in the drawing plane. The sketcher drawing plane has a coordinate system. The origin of the coordinate system is visible as the red dot in the center of the pink x-axis and light-green y-axis. The easiest way to fix it, is selecting a vertex and clicking at Constraint Lock.png. This adds a horizontal and a vertical distance from the vertex to the origin of the coordinate system. The triangle may still have an degree of freedom for rotation. So one sides needs a horizontal or vertical constraint or an defined angle to one of the coordinate system axes. The next picture shows a fully constraint sketch. All lines and vertices have now a green color. +

      Sketcher triangle3 fc small.png +

      +

      More about Constraints

      +

      The sketcher does not know the triangle formulas from the wikipedia. Instead it sets up a system of equation for the 2-dimensional coordinates based on the given constraints. This system of equations is then solved numerically. +

      In this way a wide variety of geometric problem can be solved. But there is also a disadvantage. If the set of equations has multiple solutions, we may get something totally different from what we expect. This is especially annoying, if the same design should be used for different dimensions. The typical symptom is, that after a change of a length constraint, the sketch flips to something totally different. A simple example is the division of a distance into three equal partitions. The following picture shows three lines in a row with equality and parallel constraint set. The total distance is set to 10 mm. +

      Dimension partitions parallel.png +

      This works well, as long as only larger distances are put in. When the distance is reduced above a certain ratio, the lines are folding together. So we do not get any more a third of the given distance but the distance itself or two third of it. Some lines of our row have changed their orientation. This gives still a valid solution for the set of constraints, but is not what was intended. So following image of the same sketch shows this. The length constraint was set to 1000 mm and then reduced to 5 mm. +

      Dimension partitions flipped.png +

      The solution is to define an angle of 180° between the partition lines as replacement of the parallel constraint. The 180°-constraint has only one solution. The sketch is now robust against large changes of the distance. It has to be said, that also a 0°-constraint serves for the same purpose, where appropriate. +

      Constraint180 600x400.png +

      The 180°-constraint is a solution for a lot of problems. Some older versions of FreeCAD have problems to show the 180°-constraint in the sketcher plane. In most of the cases the 180°-arc is not shown as expected in the sketcher drawing plane. This is a known issue for FreeCAD before version 14.3613. +

      In case of several incremental dimensions in a straight line, it may be advisable to draw a zig-zag-line first and then set the 180°-constraints. This helps, not forgetting one, or setting one twice. +


      +


      +The following table shows some constraints combinations for the definition of a simple elbow. The combination was tested by enlarging the 10 mm length horizontal dimension to greater values until the elbow flips its orientation. The table documents for each shown constraint combination the changed length where the flipping occurs. +

      + + + + + + + + + + + + + + + + + + + +
      Constraints Combination +Remarks +
      +

      Elbow equality horizontal vertical.png +

      +
      +

      Definition of length: Equality constraint for definition of length

      +Definition of orientation: horizontal and vertical constraints

      +Flips at 51 mm +

      +
      +

      Elbow fix point onto object 52mm.png +

      +
      +

      Definition of length: Equality constraint for definition of vertical length, arc for definition of horizontal length.

      +Definition of orientation: two points for definition of orientation of horizontal line and vertical constraints

      +Flips at 52 mm +

      +
      +

      Elbow equality perpendicular vertical.png +

      +
      +

      Definition of length: Equality constraint for definition of length

      +Definition of orientation: horizontal line perpendicular to Y-axis and vertical line with vertical constraint

      +Flips at 51 mm +

      +
      +

      Elbow dimension length 82 mm.png +

      +
      +

      Definition of length: Horizontal length defined with the general length constraint. Equality constraint for definition of vertical length.

      +Definition of orientation: horizontal and vertical constraints

      +Flips at 82 mm

      +Definition of length: Horizontal length defined with the horizontal length constraint. Equality constraint for definition of vertical length.

      +Definition of orientation: horizontal and vertical constraints

      +The horizontal line does not flip at a test of 10 km, but the vertical line was flipped!

      +

      +
      +

      Elbow equality 90°to vertical.png +

      +
      +

      Definition of length: Equality constraint for definition of length

      +Definition of orientation: horizontal line 90°-angle to vertical line and vertical line with vertical constraint

      +Flips not, tested up to 10 km +

      +
      +

      The test showed the following: larger changes of dimension constraints may cause a flipping of some lines of the sketch due to multiple solutions of the underlying system of equations. The only constraints that do preserve the orientation of the elements they are applied to, are the angle constraint and the horizontal and vertical dimension constraints. +The differences between the other constraints regarding maintaining orientation are minor. +

      Recommendation: Use angle constraints and horizontal and vertical dimension constraints at critical places in order to make a sketch robust against dimension changes. +

      +

      Problematic combination of constraints

      +

      Sometimes two or more constraints define the same property. An example can be made of two connected lines, where the connection point is the center point of a symmetry constraint for the endpoints of the lines. Those lines now have equal length and are parallel. All this is the consequence of the symmetry constraint. +

      What happens, if those two lines already have an equality constraint and a parallel constraint and the symmetry constraint is added too? Now the parallel property is defined by two constraints and the equal length is also defined by two constraints. In principle the underlying system of equations should have a solution. But there may be numerical problems. This can be tested by trying to move the lines. In most cases the lines are frozen, even if the sketcher still reports several degrees of freedom. +

      The above case shows a problem that seems to be difficult to solve for the sketcher programmers. So the user has to take care, to avoid such situations. Sketches with redundant constraints do behave unexpected and problematic. Symptoms of those redundant constraints are the above frozen state or reported redundant constraints after modifying a different object in the sketch. +

      In general the sketcher gives a warning, when redundant constraints are detected. But this detection mechanism seems not to work in all cases. When the problem is recognized, it can be avoided by just deleting the redundant constraints. Sometimes it is necessary to choose a different combination of constraints. +

      The following cases are sources for redundant constraints: +

      +
      • An equality constraint for two radii of the same arc
      • +
      • An symmetry constraint for two radii of the same arc
      • +
      • A symmetry constraint in combination with parallel, equality and or perpendicular constraints
      +

      A different problematic case are parallels with an intersection point in infinity. It is possible to set a 180°-constraint for two parallel lines without an intersection point. This is not recommended. An angle to an other line or axis should be used instead. +


      +A different problem is the change of orientation of angles. This can happen if, angle changes above 180° are made. Doing this in smaller steps avoid the problem. +

      +

      Construction Lines - Step by Step Example

      +

      In the first part was shown, that helper constructions are not necessary for the triangle. But nevertheless the sketcher provides construction geometry, which is useful for more complex problems. Any line can be converted to a construction line with the Sketcher AlterConstruction.png button. The construction lines are shown in the sketch as blue lines. They can be used for constraints in the same way as other lines, but are not shown and not used when the sketch is closed. +

      Giving the task to make a rectangle with the side length having the golden ratio. Wikipedia shows how to construct two lines with a length ratio of the golden ratio. +

      Goldener Schnitt Konstr beliebt.svg +

      The sketcher is a perfect tool to construct a rectangle with the golden ratio for the side length. The size of the rectangle can be later changed without making a new construction. The construction steps for the golden ratio according to Wikipedia are: +

      +
      1. Having a line segment AB, construct a perpendicular BC at point B, with BC half the length of AB. Draw the hypotenuse AC.
      2. +
      3. Draw an arc with center C and radius BC. This arc intersects the hypotenuse AC at point D.
      4. +
      5. Draw an arc with center A and radius AD. This arc intersects the original line segment AB at point S. Point S divides the original segment AB into line segments AS and SB with lengths in the golden ratio.
      +


      +

      Here is a step by step explanation, how this can be done. +

      +
      • Make a new sketch as explained at the triangle example.
      • +
      • Draw a rectangle in the sketch. Use the button Sketcher Rectangle.png The following picture shows the rectangle. FreeCAD did add horizontal and vertical constraints to the rectangle. This rectangle can not be rotated.
      +

      Step1 rectangle 600x400.png +

      The rectangle should stay in the center of the coordinate system. To achieve this, a symmetry constraint is added to a horizontal line. This is done by selecting first the two vertices of the horizontal line and then the vertical axis of the coordinate system. The symmetry constraint is added by clicking on the button Constraint Symmetric.png. The same is done for a vertical line, but instead now the horizontal axis is selected as symmetry axis. The picture below shows the result. The rectangle stays now at the center and can only be resized but not moved. +

      Step2 rectangle with symmetry 600x400.png +

      This was the preparation for the rectangle. The top horizontal line should be the distance AS of the golden ration construction. An additional line is needed to represent the SB-distance. It is drawn a little bit skewed as shown below. This avoids the auto-constraining to horizontal. This line should instead be constrained later with a 180°-angle, in order to avoid the existence of multiple solutions to the constructed constrain-combination. If the line is drawn with an horizontal constrained, the sketcher will complain later at adding the 180°-angle constrained. The horizontal constrained has to be removed in such a case. The picture shows how to add an angle-constraint by selecting two lines and clicking at Constraint InternalAngle.png. After adding a line, it is often advisable to drag at the line with the mouse. This will easily show, if a line is not attached to the other drawn elements. If a line is not connected right to the other lines, problems may arise in later steps of the part construction. +

      Step3 making SB 600x400.png +

      The last line is not part of the rectangle. It is therefore necessary to convert it into a construction line. Selecting the line and clicking at the Sketcher AlterConstruction.png button does the conversion. +

      Step4 make SB construction line 600x400.png +

      The line has now a blue color as visible below. The recipe from Wikipedia for the golden ratio requires a line half of the distance AB. In order to get a reference point for this, an additional vertex is set at the line with the Sketcher Point.png tool. This is shown below. +

      Step5 helper vertex.png +

      The reference point should stay at the center of the distance AB. This will be achieved by selecting first the two endpoints of the distance AB and third selecting the center point. When all three points are selected in the right sequence, the symmetry constraint can be set at clicking at the Constraint Symmetric.png button, as shown below. +

      Step6 symmetry setting.png +

      The Picture below shows already the second side BC of the construction triangle. This line was drawn as described above and converted to a construction line. This line must have a vertical constraint as visible in the picture. This can be easily achieved by drawing the line nearly vertical. If the line is nearly vertical a vertical constraint symbol is shown and set by the Sketcher when finishing the line at this state. +

      The line BC must have half of the length of AB. There is only a reference point available for this purpose, so the equality constraint can not be used. The equality constraint would need a line with this length as reference, which is not available in the construction. Therefore the classical arc is used to define the length BC. The picture below shows the drawing of the arc. The arc-tool [[Image:|24px]] is used. First the center point is set at B. The point should be visible beneath the arc-tool at clicking at B. Often the arc-tool has not has to be not directly over the target point but a little beneath, in order to get the coincidence point visible. Second the radius of the arc is defined by setting the next point at the reference point. The last point of the arc is set in the neighborhood of the point C. It is important, that the first two points are fixed to C and the center point. This should be tested with dragging at the arc after finishing it. +

      Step7 arc defining BC.png +

      In order to define the length of BC, the line must end at the arc. This will be done by setting a coincidence constraint between the last arc point and the C point as shown below. Both points have to be selected and the create a coincidence button Constraint PointOnPoint.png has to be clicked. +

      Step8 arc BC finishing.png +

      The next picture shows the ready triangle. The hypotenuse AC is already drawn and converted to a construction line. +

      Step9 triangle ready.png +

      Now step 2 of the Wikipedia recipe has to be constructed. A second arc has to be drawn with the center point at C and the starting point at B. The last point should be end at the hypotenuse as shown in the picture below. +

      Step10 second arc.png +

      The drawn arc was converted to a construction line. Now step 3 of the Wikipedia recipe starts with drawing the last arc as shown in the picture below. The radius of this arc has to be defined with the above constructed point on the hypotenuse. The last point will usually not end at a corner of the rectangle. But this is not a problem, as it will be fixed later. The last point may set as shown below. +

      Step11 last arc.png +

      Now the final step has to be made, in order to made the horizontal line of the rectangle equal to the distance AS. This is shown below by setting a coincidence constraint between the end of the last arc and the corner of the rectangle. +

      Step12 define ratio.png +

      Now the vertical line has to be made the length of the distance SC. Setting an equality constraint by selecting the button Constraint EqualLength.png as shown below, will do this. +

      Step12 define rectangle.png +

      The next picture shows the rectangle with a side length ratio equal to the golden ratio. The rectangle should have only left one degree of freedom. So at dragging at it, it should only change its size but not move. If a certain size of one side is needed, a length constraint can be added to this side. Other wise the sketch is ready and can be closed. Only a rectangle should than be visible in the FreeCAD window. +

      Step14 rectangle with golden ratio.png +


      +

      +

      Exercise: resilient sketch

      +

      The above example introduced construction lines. Now some important things to make resilient sketches are discussed. Here is an exercise to get some practice at working with the sketcher. The goal is to make a sketch for something like a special frame as shown below. +

      Frame erxercise pad.png +

      There should be only three dimensions needed to define the frame. In order to make changing dimensions easier, the constraints can be renamed to something memorable. Just select the constraint in the list view and press <F2>. The constraint can be named for example to "Thickness". +The drawing below shows the dimensions. The peak at the right side should have two times the wall thickness. +

      Frame exercise dimensions.png +

      The sketch should look as intended also after changing the key dimensions for example to 2000 mm and back to 30. You may need to use angle constraints at certain places to reach this goal. The picture below shows a sketch, which was not robust against such changes. It is unusable now. In order to get the original state back, the undo-button 32px can be used. +

      Frame erxercise failed sketch.png +

      The above sketch is unusable for the Part-Design Workbench. Only Profile without intersecting lines are allowed. Construction lines may intersect. Those are not used for making solids. +


      +One of the main usage of the Sketcher is the construction of parts in the Part-Design-workbench. The already existing geometry can be used similar to construction lines. As this tutorial takes its focus more on the basic sketcher functionality, have a look here for usage of external geometry: Sketcher External +


      +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Sketcher_Validate.html b/localwiki/Sketcher_Validate.html new file mode 100644 index 0000000..a6930bd --- /dev/null +++ b/localwiki/Sketcher_Validate.html @@ -0,0 +1,61 @@ +Sketcher Validate

      Sketcher Validate

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Sketcher Validate.png Sketcher Validate

      +
      Menu location +
      Sketcher → Validate sketch +
      Workbenches +
      Sketcher, PartDesign +
      Default shortcut +
      None +
      See also +
      None +

      Contents

      + +
      + +
      +


      +


      +

      +
      Sketcher Validate it.png
      +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Sketcher_Validate.png b/localwiki/Sketcher_Validate.png new file mode 100644 index 0000000..782eb4d Binary files /dev/null and b/localwiki/Sketcher_Validate.png differ diff --git a/localwiki/Sketcher_Validate_it.png b/localwiki/Sketcher_Validate_it.png new file mode 100644 index 0000000..e73de4a Binary files /dev/null and b/localwiki/Sketcher_Validate_it.png differ diff --git a/localwiki/Sketcher_ViewSketch.html b/localwiki/Sketcher_ViewSketch.html new file mode 100644 index 0000000..f2a200f --- /dev/null +++ b/localwiki/Sketcher_ViewSketch.html @@ -0,0 +1,71 @@ +Sketcher ViewSketch

      Sketcher ViewSketch

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Sketcher ViewSketch.png Sketcher ViewSketch

      +
      Menu location +
      Sketch → View sketch +
      Workbenches +
      Sketcher, PartDesign +
      Default shortcut +
      None +
      See also +
      None +

      + +
      +


      +

      +

      Description

      +

      This tool sets the model view perpendicular to the sketch plane. It is useful when the user has changed the model view orientation to examine another aspect of the model and wants to return to a view normal to the sketch. +

      +

      Usage

      +

      While in sketch edit mode, either +

      +
      • Click on the View sketch iconView Sketch icon in the Sketcher or Part Design toolbar, or
      • +
      • go to the Sketcher → View sketch menu.
      +


      +

      +
      +


      +

      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Sketcher_ViewSketch.svg b/localwiki/Sketcher_ViewSketch.svg new file mode 100644 index 0000000..bf13e80 --- /dev/null +++ b/localwiki/Sketcher_ViewSketch.svg @@ -0,0 +1,353 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [wmayer] + + + Sketcher_ViewSketch + 2012-12-03 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Sketcher/Gui/Resources/icons/Sketcher_ViewSketch.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Sketcher_Workbench.html b/localwiki/Sketcher_Workbench.html new file mode 100644 index 0000000..d33b50b --- /dev/null +++ b/localwiki/Sketcher_Workbench.html @@ -0,0 +1,180 @@ +Sketcher Workbench

      Sketcher Workbench

      + +
      A basic, fully-constrained sketch‎
      +

      The Sketcher Workbench is used to create 2D geometries intended for use in the Part Design Workbench and other workbenches. +Generally a 2D geometry is considered the starting-point for most CAD models - a simple 2D sketch can be 'extruded' into a 3D shape, further 2D sketches can be used to create pockets in the surface of this shape and sketches can be used to define 'pads' (extrusions) on the surface of 3D objects. +Along with boolean operations, the sketcher forms the core of generative solid shape design. +

      The Sketcher workbench itself features constraints - allowing 2D shapes to be constrained to precise geometrical definitions. And a constraint solver which calculates the constrained-extent of 2D geometry and allows interactive exploration of sketch degrees-of-freedom. +

      +
      +


      +

      + + +

      Basics of constraint sketching

      +

      To explain how the Sketcher works, it may be useful to compare it to the "traditional" way of drafting. +

      +

      Traditional Drafting

      +

      The traditional way of CAD drafting inherits from the old drawing board. Orthogonal (2D) views are drawn manually and intended for producing technical drawings (also known as blueprints). Objects are drawn precisely to the intended size or dimension. If you want to draw an horizontal line 100mm in length starting at (0,0), you activate the line tool, either click on the screen or input the (0,0) coordinates for the first point, then make a second click or input the second point coordinates at (100,0). Or you will draw your line without regard to its position, and move it afterwards. When you've finished drawing your geometries, you add dimensions to them. +

      +

      Constraint Sketching

      +

      The Sketcher moves away from this logic. Objects do not need to be drawn exactly as you intend to, because they will be defined later on by constraints. Objects can be drawn loosely, and as long as they are unconstrained, can be modified. They are in effect "floating" and can be moved, stretched, rotated, scaled, and so on. This gives great flexibility in the design process. +

      +

      What are constraints?

      +

      Instead of dimensions, Constraints are used to limit the degrees of freedom of an object. For example, a line without constraints has 4 Degrees Of Freedom (abbreviated as " DOF "): it can be moved horizontally or vertically, it can be stretched, and it can be rotated. +

      Applying a horizontal or vertical constraint, or an angle constraint (relative to another line or to one of the axes), will limit its capacity to rotate, thus leaving it with 3 degrees of freedom. Locking one of its points in relation to the origin will remove another 2 degrees of freedom. And applying a dimension constraint will remove the last degree of freedom. The line is then considered fully-constrained. +

      Multiple objects can be constrained between one another. Two lines can be joined through one of their points with the coincident point constraint. An angle can be set between them, or they can be set perpendicular. A line can be tangent to an arc or a circle, and so on. A complex Sketch with multiple objects will have a number of different solutions, and making it fully-constrained means that just one of these possible solutions has been reached based on the applied constraints. +

      There are two kinds of constraints: geometric and dimensional. They are detailed in the 'The tools' section below. +

      +

      What the Sketcher is not good for

      +

      The Sketcher is not intended for producing 2D blueprints. Once sketches are used to generate a solid feature, they are automatically hidden. Constraints are only visible in Sketch edit mode. +

      If you only need to produce 2D views for print, and don't want to create 3D models, check out the Draft workbench (keep in mind though that the Draft workbench can also be useful to create 2D geometry not available in the Sketcher at this time, like B-Splines.) +

      +

      Sketching Workflow

      +

      A Sketch is always 2-dimensional (2D). To create a solid, a 2D Sketch of a single enclosed area is created and then either Padded or Revolved to add the 3rd dimension, creating a 3D solid from the 2D Sketch. +

      If the Sketch has segments that cross one another, places where a Point is not directly on a segment, or places where there are gaps between endpoints of adjacent segments, Pad or Revolve won't create a solid. The exception to this rule is that it doesn't apply to Construction (blue) Geometry. +

      Inside the enclosed area we can have smaller non-overlapping areas. These will become voids when the 3D solid is created. +

      +

      The tools

      +

      The Sketcher Workbench tools are all located in the Sketcher menu that appears when you load the Sketcher Workbench. +

      +

      Sketcher Geometries

      +

      These are tools for creating objects. +

      +
      • Sketcher CreatePoint.png Point: Draws a point.
      • +
      • Sketcher Line.png Line by 2 point: Draws a line segment from 2 points.
      • +
      • Sketcher Arc.png Arc: Draws an arc segment from center, radius, start angle and end angle.
      • +
      • Sketcher CreateArc3Point.png Arc by 3 Point: Draws an arc segment from two endpoints and another point on the circumference.
      • +
      • Sketcher Circle.png Circle: Draws a circle from center and radius.
      • +
      • Sketcher CreateCircle3Point.png Circle by 3 Point : Draws a circle from three points on the circumference.
      • +
      • Sketcher Conics.png Conic sections: +
        • Sketcher CreateEllipse.png Ellipse by center : Draws an ellipse by center point, major radius point and minor radius point. (v0.15)
        • +
        • Sketcher CreateEllipse 3points.png Ellipse by 3 points : Draws an ellipse by major diameter (2 points) and minor radius point. (v0.15)
        • +
        • Sketcher Elliptical Arc.png Arc of ellipse : Draws an arc of ellipse by center point, major radius point, starting point and ending point. (v0.15)
        • +
        • Sketcher Hyperbolic Arc.png Arc of hyperbola: Draws an arc of hyperbola. (v0.17)
        • +
        • Sketcher Parabolic Arc.png Arc of parabola: Draws an arc of parabola. (v0.17)
      • +
      • Sketcher CreatePolyline.png Polyline (multiple-point line): Draws a line made of multiple line segments. Pressing the M key while drawing a Polyline toggles between the different polyline modes.
      • +
      • Sketcher CreateRectangle.png Rectangle: Draws a rectangle from 2 opposite points.
      • +
      • Sketcher CreateTriangle.png Triangle: Draws a regular triangle inscribed in a construction geometry circle. (v0.15)
      • +
      • Sketcher CreateSquare.png Square: Draws a regular square inscribed in a construction geometry circle. (v0.15)
      • +
      • Sketcher CreatePentagon.png Pentagon: Draws a regular pentagon inscribed in a construction geometry circle. (v0.15)
      • +
      • Sketcher CreateHexagon.png Hexagon: Draws a regular hexagon inscribed in a construction geometry circle. (v0.15)
      • +
      • Sketcher CreateHeptagon.png Heptagon: Draws a regular heptagon inscribed in a construction geometry circle. (v0.15)
      • +
      • Sketcher CreateOctagon.png Octagon: Draws a regular octagon inscribed in a construction geometry circle. (v0.15)
      • +
      • Sketcher CreateSlot.png Slot: Draws an oval by selecting the center of one semicircle and an endpoint of the other semicircle.
      • +
      • Sketcher CreateFillet.png Fillet: Makes a fillet between two lines joined at one point. Select both lines or click on the corner point, then activate the tool.
      • +
      • Sketcher Trimming.png Trimming: Trims a line, circle or arc with respect to the clicked point.
      • +
      • Sketcher External.png External Geometry: Creates an edge linked to external geometry.
      • +
      • Sketcher ToggleConstruction.png Construction Mode: A construction object will be shown in blue and will not be used in a 3D geometry operation. It is only visible while editing the Sketch that contains it. Selecting existing Sketcher geometry and then clicking this tool toggles that geometry between regular and construction mode. Selecting this tool when no Sketcher geometry is selected changes the mode (regular vs. construction) in which future objects will be created.
      +

      Sketcher Constraints

      +

      Constraints are used to define lengths, set rules between sketch elements, and to lock the sketch along the vertical and horizontal axes. Some constraints require the Helper constraints +

      Not associated with numeric data +

      +
      • Constraint PointOnPoint.png Coincident: Affixes a point onto (coincident with) one or more other points.
      • +
      • Constraint PointOnObject.png Point On Object: Affixes a point onto another object such as a line, arc, or axis.
      • +
      • Constraint Vertical.png Vertical: Constrains the selected lines or polyline elements to a true vertical orientation. More than one object can be selected before applying this constraint.
      • +
      • Constraint Horizontal.png Horizontal: Constrains the selected lines or polyline elements to a true horizontal orientation. More than one object can be selected before applying this constraint.
      • +
      • Constraint Parallel.png Parallel: Constrains two or more lines parallel to one another.
      • +
      • Constraint Perpendicular.png Perpendicular: Constrains two lines perpendicular to one another, or constrains a line perpendicular to an arc endpoint.
      • +
      • Constraint Tangent.png Tangent: Creates a tangent constraint between two selected entities, or a co-linear constraint between two line segments. A line segment does not have to lie directly on an arc or circle to be constrained tangent to that arc or circle.
      • +
      • Constraint EqualLength.png Equal Length: Constrains two selected entities equal to one another. If used on circles or arcs their radii will be set equal.
      • +
      • Constraint Symmetric.png Symmetric: Constrains two points symmetrically about a line, or constrains the first two selected points symmetrically about a third selected point.
      • +
      • Sketcher ConstrainBlock.png Constrain Block: v 0.17 Basically allows to block a geometric element in place with a single constraint. I should be particularly useful to work with B-Splines. See https://forum.freecadweb.org/viewtopic.php?f=9&t=26572
      +

      Associated with numeric data +

      For these constraints you can use the expressions. The data may be taken from a spreadsheet. +

      +
      • Sketcher ConstrainLock.png Lock: Constrains the selected item by setting vertical and horizontal distances relative to the origin, thereby locking the location of that item. These constraint distances can be edited later.
      • +
      • Constraint HorizontalDistance.png Horizontal Distance: Fixes the horizontal distance between two points or line endpoints. If only one item is selected, the distance is set to the origin.
      • +
      • Constraint VerticalDistance.png Vertical Distance: Fixes the vertical distance between 2 points or line endpoints. If only one item is selected, the distance is set to the origin.
      • +
      • Constraint Length.png Length: Defines the distance of a selected line by constraining its length, or defines the distance between two points by constraining the distance between them.
      • +
      • Constraint Radius.png Radius: Defines the radius of a selected arc or circle by constraining the radius.
      • +
      • Constraint InternalAngle.png Internal Angle: Defines the internal angle between two selected lines.
      • +
      • Constraint SnellsLaw.png Snell's Law: Constrains two lines to obey a refraction law to simulate the light going through an interface. (v 0.15)
      • +
      • Constraint InternalAlignment.png Internal Alignment: Aligns selected elements to selected shape (e.g. a line to become major axis of an ellipse).
      +


      +

      +
      • Sketcher ToggleConstraint.png Toggle Constraint: Toggles the toolbar or the selected constraints to/from reference mode. v0.16
      +

      Other

      +
      • Sketcher NewSketch.png New sketch: Creates‎ a new sketch on a selected face or plane. If no face is selected while this tool is executed the user is prompted to select a plane from a pop-up window.
      + + +
      • Sketcher ViewSketch.png View sketch: Sets the model view perpendicular to the sketch plane.
      + + +
      • Validate sketch: It allows you to check if there are in the tolerance of different points and to match them.
      + +
      • Sketcher MirrorSketch.png Mirror sketch: Mirror a sketch along the x-axis, the y-axis or the origin [v 0.16]
      +


      +

      +
      • Sketcher CloseShape.png Close Shape: Creates a closed shape by applying coincident constraints to endpoints [v 0.15]
      +
      • Sketcher ConnectLines.png Connect Edges: Connect sketcher elements by applying coincident constraints to endpoints [v 0.15]
      + + + + + + + +
      • Sketcher Element Ellipse All.png Show/Hide internal geometry: Recreates missing/deletes unneeded geometry aligned to internal geometry of a selected element (applicable only to ellipse so far). [v 0.15]
      +
      • Sketcher Symmetry.png Symmetry: Copies a sketcher element symmetrical to a chosen line [v 0.16]
      +
      • Sketcher Clone.png Clone: Clones a sketcher element [v 0.16]
      +
      • Sketcher Copy.png Copy: Copies a sketcher element [v 0.16]
      + + +

      Preferences

      + +


      +

      +

      Best Practices

      +

      Every CAD user develops his own way of working over time, but there are some useful general principles to follow. +

      +
      • A series of simple sketches is easier to manage than a single complex one. For example, a first sketch can be created for the base 3D feature (either a pad or a revolve), while a second one can contain holes or cutouts (pockets). Some details can be left out, to be realized later on as 3D features. You can choose to avoid fillets in your sketch if there are too many, and add them as a 3D feature.
      • +
      • Always create a closed profile, or your sketch won't produce a solid, but rather a set of open faces. If you don't want some of the objects to be included in the solid creation, turn them to construction elements with the Construction Mode tool.
      • +
      • Use the auto constraints feature to limit the number of constraints you'll have to add manually.
      • +
      • As a general rule, apply geometric constraints first, then dimensional constraints, and lock your sketch last. But remember: rules are made to be broken. If you're having trouble manipulating your sketch, it may be useful to constrain a few objects first before completing your profile.
      • +
      • If possible, center your sketch to the origin (0,0) with the lock constraint. If your sketch is not symmetric, locate one of its points to the origin, or choose nice round numbers for the lock distances. In v0.12, external constraints (constraining the sketch to existing 3D geometry like edges or to other sketches) are not implemented. This means that to locate following sketches geometry to your first sketch, you'll need to set distances relative to your first sketch manually. A lock constraint of (25,75) from the origin is more easily remembered than (23.47,73.02).
      • +
      • If you have the possibility to choose between the Length constraint and the Horizontal or Vertical Distance constraints, prefer the latter. Horizontal and Vertical Distance constraints are computationally cheaper.
      • +
      • In general, the best constraints to use are: Horizontal and Vertical Constraints; Horizontal and Vertical Length Constraints; Point-to-Point Tangency. If possible, limit the use of these: the general Length Constraint; Edge-to-Edge Tangency; Fix Point Onto a Line Constraint; Symmetry Constraint.
      +


      +

      +

      Tutorials

      + +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Sketcher_helper_constraint.html b/localwiki/Sketcher_helper_constraint.html new file mode 100644 index 0000000..e42fcbb --- /dev/null +++ b/localwiki/Sketcher_helper_constraint.html @@ -0,0 +1,41 @@ +Sketcher helper constraint

      Sketcher helper constraint

      + +

      Overview

      +
      Example of a helper constraint (Constraint5 - point on circle) for a tangent constraint (Constraint6; in tangent-via-point mode). Only one helper constraint is used in this case, since the point of tangency is the endpoint of ellipse's major diameter, which inherently lies on the ellipse.
      +

      Helper constraint is a regular sketcher constraint that is needed as a part of a more complex constraint, but is exposed in user interface to assist dealing with redundancy. For example, for Snell's Law constraint, the two lines that represent rays of light need to be connected (coincident constraint), and the joint must lie on the interface (Point On Object constraint). +

      Helper constraints are added automatically when they are needed. The decision for if they are needed is currently made by evaluating the helper constraint error for current state of geometry (this may change in future versions). If the error is small enough, the constraint is considered to be unnecessary, and is not added. In some cases, this logic can lead to errors (the constraint can be satisfied by accident, which can easily happen when Sketcher Grid Snapping is on). +

      If this happens (a helper constraint is missing, and the required conditions is not satisfied otherwise), the complex constraint will be broken. It will do something, but the actual behavior is undefined. Such a broken constraint can be repaired by adding the missing helper constraint manually. +

      Helper constraints are currently required for: +

      + +

      Scripting

      +

      When constraints requiring helpers are added from Python, no helper constraints are automatically added. One can replicate the automatic decision-making of the UI commands in a script by testing the following functions, specifically added for the purpose and used in the UI routines: +

      +
      Sketch.isPointOnCurve(icurve,x,y) 
      +

      isPointOnCurve tests if a virtual point, given by sketch coordinates x,y (float values), happens to satisfy a virtual point-on-object constraint - i.e. lies on curve specified by curve index icurve. Returns True if the point is on curve, and False if it doesn't. +

      +
      Sketch.calculateConstraintError(iconstr) 
      +

      calculateConstraintError evaluates an error function of a constraint specified by its index iconstr in the sketch. If there is only one error function in the constraint, the return value is the signed return value of the error function. If there is more than one error function associated with the constraint (i.e. the constraint removes more than one degree of freedom), the return value is the RMS of all the error functions (always positive). +

      +

      Version

      +

      Helper constraints were introduced in v0.15.4387 +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Sketcher_project.html b/localwiki/Sketcher_project.html new file mode 100644 index 0000000..0df17b2 --- /dev/null +++ b/localwiki/Sketcher_project.html @@ -0,0 +1,122 @@ +Sketcher project

      Sketcher project

      + +

      This is the FreeCAD Sketcher development project. It follows the rules of the Getting things done process. The projects are collected in the Development roadmap. +


      +

      + + +

      Purpose and principles

      +

      This is a software development project aimed to implement a Constraint Sketcher capabilities. Its about +implementing some Gui elements and the binding to the constraint solver. +

      The development steps are planed here and tracked in the Issue tracking system to get a well formed Change Log. +

      +

      Outcome

      +

      Brainstorming

      +

      In order to improve the solving performance of the sketcher, a graph-based partitioning of the constraints system can take place. The set of the constraints and the set of the unknown parameters can be represented in a bipartite graph with constraints corresponding to left nodes and unknowns to right nodes. DONE +

      A simple but often very useful preprocessing step is to recognize any disjoint subgroups so that they can be treated separately in the solver. DONE +

      Moreover one could reduce the number of the unknown parameters that are taken into account in the solution. At the beginning of a solution it should be checked which constraints are not already satisfied. By graph analysis one could find a minimum set of unknown parameters that should be taken into account in order to satisfy all unsatisfied constraints. +

      Going one step further, rigid sub-parts of a sketch could be detected and reduced to 3 degrees of freedom (x,y,rotation). +

      +

      Organizing

      +

      Next actions

      +

      For 0.14: +

      +
      1. Mouse Dragging for multiple selection
      2. +
      3. List of Geometries in the task panel (similar to the list of Constraints)
      4. +
      5. Add a popup menu option to convert a coincident points constraint to tangency constraints
      6. +
      7. Polygon tool (convenience)
      8. +
      9. Update wiki documentation on Symmetry constraint and Polyline tool (m-key)
      +


      +Idea Brainstorm: +

      User Interface : +

      +
      1. Full Screen Grid (Units aware)
      2. +
      3. Smarter Auto-constraints: +
        1. Algorithm only considers geometry that is on the screen to increase performance and improve selection
        2. +
        3. Prevent constraint conflicts
      4. +
      5. Hint Lines: horizontal, vertical, perpendicular, tangent constraints?
      6. +
      7. Overhaul of constraint icons by merging into one SoNode +
        1. Merge into one SoNode to improve performance
        2. +
        3. Remove need for ray pick to increase performance
        4. +
        5. Share texture memory more efficiently.
        6. +
        7. Improve algorithm for preventing overlap
        8. +
        9. Tool Bar for toggling constraint visuals independently
      8. +
      9. Datum Label Improvements: +
        1. Radius label can be positioned at any angle
        2. +
        3. Remove need for storing in SoImage which isn't needed any more
      10. +
      11. Fix Grid Edge
      12. +
      13. Auto constraints whilst dragging (Point on Point, Point on Line Coincident)?
      14. +
      15. Highlight entities or zoom to over constrained area of sketch
      16. +
      17. Related to part design (transparent support objects)
      18. +
      19. Implement Sketch Plane Feature with introduction of Assembly module
      20. +
      21. Improve Point Selection by implementing new custom node.
      22. +
      23. Construction lines use dashes instead of solid lines.
      +


      +For 0.13: +

      +
      1. support for arc/arc and arc/circle in the tangent constraint - DONE [logari81]
      2. +
      3. support for arcs in the perpendicular constraint - DONE [logari81]
      4. +
      5. zoom-independent arrows (symmetry constraint) / dimension lines - DONE [mrlukeparry]
      6. +
      7. external geometry / constraints - DONE [logari81]
      8. +
      9. box selection - DONE [mrlukeparry]
      10. +
      11. mouse dragging of multiple selection - SKIPPED for 0.14
      12. +
      13. better constrainess diagnostics (Issue #691)- DONE [logari81]
      14. +
      15. list of Geometries in the task panel (similar to the list of Constraints) - SKIPPED for 0.14
      16. +
      17. support for points as construction geometry - DONE [logari81]
      18. +
      19. add a popup menu option to convert a coincident points constraint to tangency constraints - SKIPPED for 0.14
      20. +
      21. make symmetry constraint to work with symmetry points instead of symmetry lines (useful e.g. for midpoint definition) - DONE [logari81]
      +


      +For 0.12: +

      +
      1. constraint parameters (datums) editable in the 3D view DONE [jriegel]
      2. +
      3. synchronization between listwidgetview selection - 3D view selection - DONE [wmayer]
      4. +
      5. avoid overlapping of constraints symbols DONE - [mrlukeparry] +
        1. make constraints symbols smaller, selectable and avoid overlapping when zooming out DONE - [mrlukeparry]
        2. +
        3. create constraint icons for 3D Inventor view DONE - [mrlukeparry]
        4. +
        5. make datum text size dependant on zoom DONE - [mrlukeparry]
        6. +
        7. make datum text easier to select DONE - [mrlukeparry]
        8. +
        9. Prevent text overlap on Datum Labels DONE - [mrlukeparry]
      6. +
      7. testing the new solver in stand alone mode
      8. +
      9. external constraints (having constraints with references outside the sketch, some edge of the 3D model e.g.) 0.13 [jriegel]
      10. +
      11. auto-constraining DONE [jriegel] +
        1. auto-constraint for perpendicular DONE - [mrlukeparry]
      12. +
      13. visualize tangency constraints DONE - [mrlukeparry]
      14. +
      15. visualize point to line distance constraints and point to point distance constraints DONE - [logari81]
      16. +
      17. add indexes to the constraints symbols in 3D view in order to distinguish between constraints of the same kind DONE - [mrlukeparry]
      18. +
      19. radius constraint (including visualization) DONE - [logari81]
      20. +
      21. angle constraint (including visualization) DONE - [logari81]
      22. +
      23. implement a fillet tool in the sketcher DONE [mrlukeparry] +
        1. provide a method of setting fillet radius (Issue #437)
      24. +
      25. implement a trim/extend tool in the sketcher DONE [logari81] +
        1. implement an extend tool SKIPPED [logari81]
        2. +
        3. trim support on arcs DONE [mrlukeparry]
      26. +
      27. equal lengths constraint (including visualization) DONE - [logari81]
      28. +
      29. constrainess diagnostics - degree of freedom counting DONE - [logari81]
      30. +
      31. symmetry constraint (including visualization) DONE - [logari81]
      32. +
      33. implement point on object constraint DONE - [mrlukeparry]
      34. +
      35. Make Snap-Grid less 'greedy' DONE [mrlukeparry]
      36. +
      37. Wiki page for the Sketcher Workbench DONE [normandc]
      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Sketcher_triangle3_fc_small.png b/localwiki/Sketcher_triangle3_fc_small.png new file mode 100644 index 0000000..04e19b8 Binary files /dev/null and b/localwiki/Sketcher_triangle3_fc_small.png differ diff --git a/localwiki/Sketcher_triangle3_small.png b/localwiki/Sketcher_triangle3_small.png new file mode 100644 index 0000000..a97e5a0 Binary files /dev/null and b/localwiki/Sketcher_triangle3_small.png differ diff --git a/localwiki/Sketcher_tutorial.html b/localwiki/Sketcher_tutorial.html new file mode 100644 index 0000000..551c2bc --- /dev/null +++ b/localwiki/Sketcher_tutorial.html @@ -0,0 +1,187 @@ +Sketcher tutorial

      Sketcher tutorial

      + +
      + + + + + + + + + + + + + + + + + + + + + + + + + + + +
      +

      Base ExampleCommandModel.png Tutorial

      +
      Topic +
      Sketcher +
      Level +
      Beginner +
      Time to complete +
      10 minutes +
      Author +
      Drei +
      FreeCAD version +
      0.16 or above +
      Example File(s) +
      +

      + +
      +


      +

      +

      Introduction

      +

      This tutorial is meant to introduce the reader to the basic workflow of the Sketcher Workbench. We will be creating a sketch similar to the one shown below. +

      Sketcher tutorial result.png +

      The Sketcher workbench exists as a standalone module, but it is also accessible from within the PartDesign Workbench when it is required to create a profile. +


      +

      +

      Requirements

      +
      • FreeCAD version 0.16 or above
      +

      Procedure

      +

      Creating a Sketch

      +
      1. Create a new document
      2. +
      3. Switch to the Sketcher Workbench by using the drop-down menu or by clicking on View menu > Workbench > Sketcher.
      4. +
      5. Select Sketcher NewSketch.png New sketch
      6. +
      7. You should see a dialog that prompts you to choose sketch orientation and provide an offset. We will not be using offset, and we will use the default plane
      8. +
      9. Click OK and we can start to construct the sketch
      +

      We are now inside the Sketcher environment. Within it, we're able to make use of the majority of the tools that are available in this workbench. +

      In the Combo View, expand the option Edit controls and make sure Autoconstraints are enabled. +

      +

      Creating geometry

      +
      Sketcher construction geometry
      +

      Construction geometry is used as guides for the creation of complex profiles. To access it, we need to enable Construction mode . +

      +
      1. Select Sketcher ToggleConstruction.png Construction Mode
      2. +
      3. Select Sketcher Line.png Line by 2 point
      4. +
      5. Approach the origin point in the sketch, the point should highlight and near your cursor this icon Constraint PointOnPoint.png will appear.
      6. +
      7. Select the point and extend the line diagonally up to an arbitrary length.
      8. +
      9. Repeat this procedure until you've created five construction lines. Be sure to keep all of them diagonal.
      10. +
      11. To exit construction mode, simply click again on Sketcher ToggleConstruction.png Construction Mode
      +
      Sketcher geometry
      +

      Sketcher geometry is used to create the closed profiles required to perform 3D operations in the PartDesign workbench. +

      +
      1. Select Sketcher Circle.png Circle
      2. +
      3. Position its centerpoint on the origin of the sketch.
      4. +
      5. Extend the circumference to an arbitrary length.
      +


      +

      +
      1. Select Sketcher Arc.png Arc
      2. +
      3. Approach the endpoint of one of the construction lines.
      4. +
      5. Set the centerpoint' of the arc to be coincident with the endpoint.
      6. +
      7. Select an arbitrary location of your cursor to be set as the beginning of the arc, by clicking once.
      8. +
      9. Extend the arc an arbitrary amount, making sure the circumference opens outward (the empty space is facing towards the circle you created earlier).
      10. +
      11. Repeat these steps for each construction line.
      +


      +

      +
      1. Create an arc between each pair of the previous arcs, with their circumference pointing towards the circle.
      +

      We have now created the basic elements for our profile. +

      +

      Constraints

      +

      Constraints are used to constrain the Degrees of Freedom of points and curves within sketcher. +

      +
      Geometric Constraints
      +

      They are used to establish relations between points and curves without the use of dimensions. +

      +
      1. Select all five construction lines.
      2. +
      3. Select Constraint EqualLength.png Equal Length
      +


      +

      +
      1. Select all five arcs centered on an endpoint of a line.
      2. +
      3. Select Constraint EqualLength.png Equal Length
      4. +
      5. Repeat for all five arcs that are not centered on an endpoint.
      +


      +

      +
      1. Select the construction line that is closest to the vertical axis.
      2. +
      3. Select Constraint Vertical.png Vertical
      +


      +

      +
      1. Select the endpoint of an arc and the endpoint closest to it.
      2. +
      3. Select Constraint Tangent.png Tangent
      4. +
      5. Repeat for each endpoint, until a closed profile is created.
      +

      As of this step, we have now created a closed profile that can be adjusted with the desired dimensions. +


      +

      +
      Datum Constraints
      +

      These are used to specify the distance between points in a particular direction and the dimensions of curves. +

      +
      1. Select the vertically constrained construction line.
      2. +
      3. Select Constraint VerticalDistance.png Vertical Distance
      4. +
      5. Set the length to 30 mm.
      +


      +

      +
      1. Select the vertical construction line and the line closest to it
      2. +
      3. Select Constraint InternalAngle.png Internal Angle
      4. +
      5. Set the angle to 72°
      6. +
      7. Repeat the same procedure for each pair of adjacent lines.
      +


      +

      +
      1. Select one of the arcs centered on the endpoint of a line.
      2. +
      3. Select Constraint Radius.png Radius
      4. +
      5. Set the radius to 8 mm.
      6. +
      7. Do the same for an arc not centered on an endpoint. Set the radius to 11 mm.
      8. +
      9. Set the center circle radius to 10 mm.
      +

      You should end up with a fully constrained sketch. It can be comfirmed by noticing the change in color of all curves. +

      We are now finished with the basic workflow for the Sketcher Module. +

      +

      Further Reading

      + +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Sketchfab.svg b/localwiki/Sketchfab.svg new file mode 100644 index 0000000..52ec0b2 --- /dev/null +++ b/localwiki/Sketchfab.svg @@ -0,0 +1,133 @@ + + + +image/svg+xml \ No newline at end of file diff --git a/localwiki/Sketchfab_exporter.jpg b/localwiki/Sketchfab_exporter.jpg new file mode 100644 index 0000000..35b2e79 Binary files /dev/null and b/localwiki/Sketchfab_exporter.jpg differ diff --git a/localwiki/Snap_Angle.svg b/localwiki/Snap_Angle.svg new file mode 100644 index 0000000..cac2c63 --- /dev/null +++ b/localwiki/Snap_Angle.svg @@ -0,0 +1,700 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + Snap_Angle + + Mon Mar 12 17:20:03 2012 -0300 + + + [Yorik van Havre] + + + + + FreeCAD LGPL2+ + + + + + FreeCAD + + + FreeCAD/src/Mod/Draft/Resources/icons/Snap_Angle.svg + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + [agryson] Alexander Gryson + + + Four dots equally spaced around the circumference of a circle + + + dot + circle + dots + + + + + + diff --git a/localwiki/Snap_Center.svg b/localwiki/Snap_Center.svg new file mode 100644 index 0000000..4604065 --- /dev/null +++ b/localwiki/Snap_Center.svg @@ -0,0 +1,259 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + Snap_Center + + Mon Mar 12 17:20:03 2012 -0300 + + + [Yorik van Havre] + + + + + FreeCAD LGPL2+ + + + + + FreeCAD + + + FreeCAD/src/Mod/Draft/Resources/icons/Snap_Center.svg + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + [agryson] Alexander Gryson + + + A concentric circle and dot + + + dot + circle + concentric + + + + + + diff --git a/localwiki/Snap_Dimensions.svg b/localwiki/Snap_Dimensions.svg new file mode 100644 index 0000000..b29b574 --- /dev/null +++ b/localwiki/Snap_Dimensions.svg @@ -0,0 +1,481 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + Snap_Dimensions + + Tue Sep 17 23:07:04 2013 -0300 + + + [Yorik van Havre] + + + + + FreeCAD LGPL2+ + + + + + FreeCAD + + + FreeCAD/src/Mod/Draft/Resources/icons/Snap_Dimensions.svg + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + [agryson] Alexander Gryson + + + Square with one missing corner and numbers by the remaining sides. + + + line + lines + square + numbers + measure + + + + + + diff --git a/localwiki/Snap_Endpoint.svg b/localwiki/Snap_Endpoint.svg new file mode 100644 index 0000000..a2d9b61 --- /dev/null +++ b/localwiki/Snap_Endpoint.svg @@ -0,0 +1,192 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + Snap_Endpoint + + Mon Mar 12 17:20:03 2012 -0300 + + + [Yorik van Havre] + + + + + FreeCAD LGPL2+ + + + + + FreeCAD + + + FreeCAD/src/Mod/Draft/Resources/icons/Snap_Endpoint.svg + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + [agryson] Alexander Gryson + + + + + line + endpoint + + + + line with bulge at one endpoint + + + + diff --git a/localwiki/Snap_Extension.svg b/localwiki/Snap_Extension.svg new file mode 100644 index 0000000..2a1d763 --- /dev/null +++ b/localwiki/Snap_Extension.svg @@ -0,0 +1,542 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + Snap_Extension + + Mon Mar 12 17:20:03 2012 -0300 + + + [Yorik van Havre] + + + + + FreeCAD LGPL2+ + + + + + FreeCAD + + + FreeCAD/src/Mod/Draft/Resources/icons/Snap_Extension.svg + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + [agryson] Alexander Gryson + + + Three dots or circles in a horizontal sequence simiar to an ellipsis + + + circle + circles + dot + dots + ellipsis + + + + + + diff --git a/localwiki/Snap_Grid.svg b/localwiki/Snap_Grid.svg new file mode 100644 index 0000000..5b689d0 --- /dev/null +++ b/localwiki/Snap_Grid.svg @@ -0,0 +1,271 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + Snap_Grid + + Mon Mar 12 17:20:03 2012 -0300 + + + [Yorik van Havre] + + + + + FreeCAD LGPL2+ + + + + + FreeCAD + + + FreeCAD/src/Mod/Draft/Resources/icons/Snap_Grid.svg + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + [agryson] Alexander Gryson + + + Four mutually intersecting lines in a grid like pattern similar to a hash or pound sign + + + hash + pound + grid + intersection + + + + + + diff --git a/localwiki/Snap_Intersection.svg b/localwiki/Snap_Intersection.svg new file mode 100644 index 0000000..74e209f --- /dev/null +++ b/localwiki/Snap_Intersection.svg @@ -0,0 +1,206 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + Snap_Intersection + + Mon Mar 12 17:20:03 2012 -0300 + + + [Yorik van Havre] + + + + + FreeCAD LGPL2+ + + + + + FreeCAD + + + FreeCAD/src/Mod/Draft/Resources/icons/Snap_Intersection.svg + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + [agryson] Alexander Gryson + + + + + cross + multiply + multiplication + intersection + + + An angled cross, similar to a multiplication sign + + + + diff --git a/localwiki/Snap_Lock.svg b/localwiki/Snap_Lock.svg new file mode 100644 index 0000000..8180740 --- /dev/null +++ b/localwiki/Snap_Lock.svg @@ -0,0 +1,259 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + Snap_Lock + + Mon Mar 12 17:20:03 2012 -0300 + + + [Yorik van Havre] + + + + + FreeCAD LGPL2+ + + + + + FreeCAD + + + FreeCAD/src/Mod/Draft/Resources/icons/Snap_Lock.svg + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + [agryson] Alexander Gryson + + + A locked lock + + + lock + locked + + + + + + diff --git a/localwiki/Snap_Midpoint.svg b/localwiki/Snap_Midpoint.svg new file mode 100644 index 0000000..681ad34 --- /dev/null +++ b/localwiki/Snap_Midpoint.svg @@ -0,0 +1,202 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + Snap_Midpoint + + Mon Mar 12 17:20:03 2012 -0300 + + + [Yorik van Havre] + + + + + FreeCAD LGPL2+ + + + + + FreeCAD + + + FreeCAD/src/Mod/Draft/Resources/icons/Snap_Midpoint.svg + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + [agryson] Alexander Gryson + + + A line at an angle with a bulbous center + + + line + midpoint + + + + + + diff --git a/localwiki/Snap_Near.svg b/localwiki/Snap_Near.svg new file mode 100644 index 0000000..8fff6eb --- /dev/null +++ b/localwiki/Snap_Near.svg @@ -0,0 +1,211 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + Snap_Near + + Fri Mar 16 18:29:56 2012 -0300 + + + [Yorik van Havre] + + + + + FreeCAD LGPL2+ + + + + + FreeCAD + + + FreeCAD/src/Mod/Draft/Resources/icons/Snap_Near.svg + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + [agryson] Alexander Gryson + + + A dot or circle above and to the right of a line at a slight angle + + + line + circle + dot + + + + + + diff --git a/localwiki/Snap_Ortho.svg b/localwiki/Snap_Ortho.svg new file mode 100644 index 0000000..e54eaa2 --- /dev/null +++ b/localwiki/Snap_Ortho.svg @@ -0,0 +1,318 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + Snap_Ortho + + Mon Mar 12 17:20:03 2012 -0300 + + + [Yorik van Havre] + + + + + FreeCAD LGPL2+ + + + + + FreeCAD + + + FreeCAD/src/Mod/Draft/Resources/icons/Snap_Ortho.svg + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + [agryson] Alexander Gryson + + + Crosshair like symbol + + + cross + orthogonal + plus + + + + + + diff --git a/localwiki/Snap_Parallel.svg b/localwiki/Snap_Parallel.svg new file mode 100644 index 0000000..678fbc5 --- /dev/null +++ b/localwiki/Snap_Parallel.svg @@ -0,0 +1,228 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + Snap_Parallel + + Mon Mar 12 17:20:03 2012 -0300 + + + [Yorik van Havre] + + + + + FreeCAD LGPL2+ + + + + + FreeCAD + + + FreeCAD/src/Mod/Draft/Resources/icons/Snap_Parallel.svg + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + [agryson] Alexander Gryson + + + Two parallel lines at a slight angle + + + line + lines + parallel + + + + + + diff --git a/localwiki/Snap_Perpendicular.svg b/localwiki/Snap_Perpendicular.svg new file mode 100644 index 0000000..bffd483 --- /dev/null +++ b/localwiki/Snap_Perpendicular.svg @@ -0,0 +1,166 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + Snap_Perpendicular + + Mon Mar 12 17:20:03 2012 -0300 + + + [Yorik van Havre] + + + + + FreeCAD LGPL2+ + + + + + FreeCAD + + + FreeCAD/src/Mod/Draft/Resources/icons/Snap_Perpendicular.svg + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + [agryson] Alexander Gryson + + + Perpindicular symbol + + + perpindicular + + + + + + diff --git a/localwiki/Snap_Special.svg b/localwiki/Snap_Special.svg new file mode 100644 index 0000000..5d851f6 --- /dev/null +++ b/localwiki/Snap_Special.svg @@ -0,0 +1,250 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + Snap_Special + + Mon Aug 22 13:49:54 2016 -0300 + + + [Yorik van Havre] + + + + + FreeCAD LGPL2+ + + + + + FreeCAD + + + FreeCAD/src/Mod/Draft/Resources/icons/Snap_Special.svg + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + [agryson] Alexander Gryson + + + Cube with circle in front of the lower left corner + + + cube + circle + + + + + + diff --git a/localwiki/Snap_WorkingPlane.svg b/localwiki/Snap_WorkingPlane.svg new file mode 100644 index 0000000..a25a5e8 --- /dev/null +++ b/localwiki/Snap_WorkingPlane.svg @@ -0,0 +1,238 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + Snap_WorkingPlane + + Fri Mar 7 15:58:51 2014 -0300 + + + [Yorik van Havre] + + + + + FreeCAD LGPL2+ + + + + + FreeCAD + + + FreeCAD/src/Mod/Draft/Resources/icons/Snap_WorkingPlane.svg + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + [agryson] Alexander Gryson + + + Square with small circe in lower left corner + + + plane + square + circle + + + + + + diff --git a/localwiki/Snells_law2_witheq.svg b/localwiki/Snells_law2_witheq.svg new file mode 100644 index 0000000..1b3a4d1 --- /dev/null +++ b/localwiki/Snells_law2_witheq.svg @@ -0,0 +1,441 @@ + + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + P + Q + O + + interface + normal + θ + 1 + 2 + 2 + n + 1 + n + 2 + v + 1 + v + θ + + + + diff --git a/localwiki/Solid.svg b/localwiki/Solid.svg new file mode 100644 index 0000000..b70303a --- /dev/null +++ b/localwiki/Solid.svg @@ -0,0 +1,103 @@ + + + + + + + + + + image/svg+xml + + + + + Pablo Gil + + + + + SVG + template + + + + + + + + + diff --git a/localwiki/Source_Code_Management.html b/localwiki/Source_Code_Management.html new file mode 100644 index 0000000..d7e75b1 --- /dev/null +++ b/localwiki/Source_Code_Management.html @@ -0,0 +1,273 @@ +Source Code Management

      Source Code Management

      (Redirected from Source Code Management)
      + +

      Our main source code management tool is git. This article explains how to use it and how some general rules apply in the case of FreeCAD. You are highly advised to learn how git works first (there are a lot of tutorials and docs available for git on the internet) before working with the FreeCAD source code. +

      There are also many good graphical clients to git, such as git-cola, that make the whole process of managing git repositories easier. FYI there also exists a cursory intro to Developing FreeCAD with GitKraken. +

      + + +

      Source Code Access

      +

      Everybody can access and get a copy of the FreeCAD source code, but only the FreeCAD project managers have write access to it. You can get a copy of the code, study it and modify it as you wish, but if you make a change that you wish to see included in the official source code, you need to ask for a pull request on the pull requests section of the FreeCAD forum. +

      +
      NOTE +

      In all examples below, "GITHUB_USERNAME" represents your GitHub user account. +

      +
      +


      +

      +

      Official GitHub Repo

      +

      An easy way to start with the FreeCAD source code is using the official FreeCAD repository at +https://github.com/FreeCAD/FreeCAD +

      +

      Setting your git username

      +

      Users should commit to their project repository using their GitHub username. +If that is not already set globally, you can set it locally for the current Git repository like this: +

      +
      git config user.name "YOUR NAME"
      +git config user.email "GITHUB_USERNAME@users.noreply.github.com"
      +
      +

      You can now use some combination of "git add" and "git commit" commands to create one or more +commits in your local repository. +

      +

      A note about Remotes

      +

      Please read some background to help you understand better the difference between what origin and upstream mean in the context of git. This section explains how to set the correct upstream and origin remote git repos. +Essentially: +

      + +

      This is important to understand because if you git clone directly from upstream then confusingly, your origin will be listed as https://github.com/FreeCAD/FreeCAD.git +So, based on the above, there are 2 main ways to setup your git environment: +

      + +

      We recommend the 1st method for the reason mentioned above. +

      +

      1st Method: Fork on GitHub and clone your fork locally

      +
      Important Note +

      You will need to re-configure 'remote upstream' as mentioned above in "A note about Remotes" +

      +
      +

      This method is the recommended way since it takes less steps. You will essentially fork the FreeCAD repo on your own GitHub account and then clone said GitHub fork locally. Then you will set your upstream repo in git. The procedure is as follows: +

      +
        +
      1. Sign up for a GitHub account if you don't already have one
      2. +
      3. Go to the FreeCAD repo: https://github.com/FreeCAD/FreeCAD
      4. +
      5. In the top right of the page find and press the "Fork" button (this will essentially git clone the official FreeCAD repo to your personal GitHub repo: https://github.com/GITHUB_USERNAME/FreeCAD.git)
      6. +
      7. On your machine, clone your newly created FreeCAD fork by opening a terminal and typing: +
        git clone https://github.com/GITHUB_USERNAME/FreeCAD.git
      8. +
      9. Once the clone process is complete, now set your upstream remote repo (see "A note about Remotes"). Find out what and where your remote git repositories are set to. Type git remote -v and the output should look similiar to: +
         [foo@bar FreeCAD]$ git remote -v
        +     originhttps://github.com/GITHUB_USERNAME/FreeCAD.git (fetch)
        +     originhttps://github.com/GITHUB_USERNAME/FreeCAD.git (push)
      10. +
      11. Great. Now set your upstream repo +
        [foo@bar FreeCAD]$ git remote add upstream https://github.com/FreeCAD/FreeCAD.git
      12. +
      13. Check your remotes again, they should look similiar to this: +
         [foo@bar FreeCAD]$ git remote -v
        +    originhttps://github.com/GITHUB_USERNAME/FreeCAD.git (fetch)
        +    originhttps://github.com/GITHUB_USERNAME/FreeCAD.git (push)
        +    upstreamhttps://github.com/FreeCAD/FreeCAD.git (fetch)
        +    upstreamhttps://github.com/FreeCAD/FreeCAD.git (push)
      14. + +
      15. Now we can start developing. Please refer to "Git Development Process"
      16. +
      +

      2nd Method: Clone Official FreeCAD git repo to your local machine

      +
      Important Note +

      You will need to re-configure both 'remote origin' and 'remote upstream' please refer to above "A note about Remotes" +

      +
      +

      This method of setuping your git environment takes a few more steps then the 1st method. You will clone the FC git repo directly to your local machine and then alter your remotes via the terminal. The procedure is as follows: +

      +
        +
      1. Clone the FreeCAD code with git: +
        git clone https://github.com/FreeCAD/FreeCAD.git
      2. +
      3. Create an account on a public git server (GitHub, GitLab, etc... for our purposes we're assuming it's GitHub)
      4. +
      5. Find out what and where your remote git repositories are set to: +
        git remote -v
      6. +
      7. This will return something that looks like the following: +
        [foo@bar FreeCAD]$ git remote -v
        +    origin https://github.com/FreeCAD/FreeCAD.git (fetch)
        +    origin https://github.com/FreeCAD/FreeCAD.git (push)
      8. +
      9. As was explained above in "A note about Remotes" you need to modify these remote git repo addresses.
        +So first set up your origin remote: +
        [foo@bar FreeCAD]$ git remote add origin https://github.com/GITHUB_USERNAME/FreeCAD.git
      10. +
      11. Then we set up our upstream remote: +
        [foo@bar FreeCAD]$ git remote add upstream https://github.com/FreeCAD/FreeCAD.git
      12. +
      13. Check your remotes again, they should look similiar to this: +
         [foo@bar FreeCAD]$ git remote -v
        +    originhttps://github.com/GITHUB_USERNAME/FreeCAD.git (fetch)
        +    originhttps://github.com/GITHUB_USERNAME/FreeCAD.git (push)
        +    upstreamhttps://github.com/FreeCAD/FreeCAD.git (fetch)
        +    upstreamhttps://github.com/FreeCAD/FreeCAD.git (push)
      14. +
      15. Now we can start developing. Please refer to "Git Development Process"
      16. +
      +

      Git Development Process

      +

      First of all NEVER DEVELOP ON THE master BRANCH! +Instead, create a local branch for development. You can learn in more depth by reading Git-Branching-Basic-Branching-and-Merging chapter on git-scm. Below is a summary: +

      +

      Branching

      +

      An important feature of Git is that it is extremely easy to work with branches and merge +them together. Best practices recommend to create a new branch whenever you want to work +on a new feature. Creating a branch is done with: +

      +
      git branch myNewBranch
      +git checkout myNewBranch
      +
      +

      or you can combine both git branch && git checkout together by using the -b flag +

      +
      git checkout -b myNewBranch
      +
      +

      How do you know which branch you are currently using? Easy, type: +

      +
      git branch
      +
      +

      Committing

      +

      Once you did some work, you commit them with: +

      +
      git commit -a
      +

      Unlike SVN, you need to specifically tell which files to commit (or all with the +-a option). Your text editor will open to allow you to write a commit message.
      +Please read more about Writing good commit messages in the below section. +

      +

      Publishing your work on your GitHub repository

      +
      Important Note +

      If you have code you wish to see merged into the FreeCAD source code, please post a note in the Pull Request section of the FreeCAD forum +

      +
      +

      After you're correctly branched made some modifications to your local branch and commit them 'locally', you can push your repository to your remote git server (in this example we're assuming GitHub). This opens your branch to the public and allows the main developers to review and integrate your branch into master. +

      +
      git push  <REMOTENAME> <BRANCHNAME> 
      +git push origin my-branch
      +
      +

      For further info on this subject please read https://help.github.com/articles/pushing-to-a-remote/ +

      +

      Writing good commit messages

      +

      You should try to work in small chunks. If you cannot summarize your changes in one +sentence, then it has probably been too long since you have made a commit. It is also +important that you have helpful and useful descriptions of your work. For commit messages, +FreeCAD has adopted a format mentioned in book Pro Git (see #Further Reading). +

      +
      Short (50 chars or less) summary of changes
      +
      +More detailed explanatory text, if necessary.  Wrap it to about 72
      +characters or so.  In some contexts, the first line is treated as the
      +subject of an email and the rest of the text as the body.  The blank
      +line separating the summary from the body is critical (unless you omit
      +the body entirely); tools like rebase can get confused if you run the
      +two together.
      +
      +Further paragraphs come after blank lines. 
      +
      + - Bullet points are okay, too
      +
      + - Typically a hyphen or asterisk is used for the bullet, preceded by a
      +   single space, with blank lines in between, but conventions vary here
      +
      +

      If you are doing a lot of related work, it has been suggested +here +that one should make as many commits large or small as makes sense for what you are working +on using the short one sentence commit messages. When you want to merge, do a +

      +
      git log master..BRANCH
      +

      and use the output as a basis for your quality commit message. +Then when you merge to master use the --squash option and commit with your quality commit message. +This will allow you to be very liberal with your commits and help to provide a good level of detail +in commit messages without so many distinct descriptions. +

      +

      Advanced git operations

      +

      Resolving Merge Conflicts

      + +

      Applying patches via git

      +

      Git has the capability to merge patches/diffs. To read more about this read the following reference: https://www.drupal.org/node/1399218 +

      +
      • Useful tip: Just add .diff or .patch at the end of the URL for a GitHub commit page, Pull Request, or Compare View and it'll show you the plaintext view of that page. Example:
      +

      Regular GitHub page: +https://github.com/FreeCAD/FreeCAD/commit/c476589652a0f67b544735740e20ff702e8d0621 +

      'Diffed' GitHub page: +https://github.com/FreeCAD/FreeCAD/commit/c476589652a0f67b544735740e20ff702e8d0621.diff +

      'Patched' GitHub page: +https://github.com/FreeCAD/FreeCAD/commit/c476589652a0f67b544735740e20ff702e8d0621.patch +

      +

      Apply a patch via curl

      +
      curl https://github.com/FreeCAD/FreeCAD/commit/c476589652a0f67b544735740e20ff702e8d0621.patch | git apply -
      +
      +

      Creating patches from git

      +

      There are times when one may need to create a patch instead of submitting a PR. The following workflow explains how to do this: +

      +
        +
      1. Make sure you are in the correct branch (i.e. not the master branch) by checking with +
        git branch -v
      2. +
      3. Create the patch: we do this by using the git format-patch command which we patch against the master branch and redirect to STDOUT. We create the patch in the directory outside of the source build (in order not to pollute the source dir itself, this is optional as you can decide the location wherever you want the patch to be created) +
        git format-patch master --stdout > ../patch.name.patch
      4. +
      +

      What is the latest FreeCAD Dev Revision

      +

      There are 2 ways to do this: +

      +
      • 1st method: In your cloned git directory type:
      +
      git rev-list --count master
      +
      + +

      Alternative repositories

      +

      The beauty of git is that everybody can clone a project, and start modifying the code. Several frequent collaborators of the FreeCAD project have their own git repository, where they build up their work before it is ready to be included in the official source code, or simply where they experiment new ideas. In certain cases, you might want to clone your FreeCAD code from one of these, instead of the official repos, to benefit from the changes their users did. +

      Be warned, though, that this is at your own risk, and only the official repository above is fully guaranteed to work and contain clean code. +

      It is also possible to attach several remote repositories to a same local FreeCAD git code, using the "git remote" command. This is useful to keep in sync with the master code branch, but keep an eye on the work of different developers. +

      +

      Using git in a Graphical User Interface

      + +

      Further reading

      + +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Source_code_management.html b/localwiki/Source_code_management.html new file mode 100644 index 0000000..80ed9e5 --- /dev/null +++ b/localwiki/Source_code_management.html @@ -0,0 +1,273 @@ +Source code management

      Source code management

      + +

      Our main source code management tool is git. This article explains how to use it and how some general rules apply in the case of FreeCAD. You are highly advised to learn how git works first (there are a lot of tutorials and docs available for git on the internet) before working with the FreeCAD source code. +

      There are also many good graphical clients to git, such as git-cola, that make the whole process of managing git repositories easier. FYI there also exists a cursory intro to Developing FreeCAD with GitKraken. +

      + + +

      Source Code Access

      +

      Everybody can access and get a copy of the FreeCAD source code, but only the FreeCAD project managers have write access to it. You can get a copy of the code, study it and modify it as you wish, but if you make a change that you wish to see included in the official source code, you need to ask for a pull request on the pull requests section of the FreeCAD forum. +

      +
      NOTE +

      In all examples below, "GITHUB_USERNAME" represents your GitHub user account. +

      +
      +


      +

      +

      Official GitHub Repo

      +

      An easy way to start with the FreeCAD source code is using the official FreeCAD repository at +https://github.com/FreeCAD/FreeCAD +

      +

      Setting your git username

      +

      Users should commit to their project repository using their GitHub username. +If that is not already set globally, you can set it locally for the current Git repository like this: +

      +
      git config user.name "YOUR NAME"
      +git config user.email "GITHUB_USERNAME@users.noreply.github.com"
      +
      +

      You can now use some combination of "git add" and "git commit" commands to create one or more +commits in your local repository. +

      +

      A note about Remotes

      +

      Please read some background to help you understand better the difference between what origin and upstream mean in the context of git. This section explains how to set the correct upstream and origin remote git repos. +Essentially: +

      + +

      This is important to understand because if you git clone directly from upstream then confusingly, your origin will be listed as https://github.com/FreeCAD/FreeCAD.git +So, based on the above, there are 2 main ways to setup your git environment: +

      + +

      We recommend the 1st method for the reason mentioned above. +

      +

      1st Method: Fork on GitHub and clone your fork locally

      +
      Important Note +

      You will need to re-configure 'remote upstream' as mentioned above in "A note about Remotes" +

      +
      +

      This method is the recommended way since it takes less steps. You will essentially fork the FreeCAD repo on your own GitHub account and then clone said GitHub fork locally. Then you will set your upstream repo in git. The procedure is as follows: +

      +
        +
      1. Sign up for a GitHub account if you don't already have one
      2. +
      3. Go to the FreeCAD repo: https://github.com/FreeCAD/FreeCAD
      4. +
      5. In the top right of the page find and press the "Fork" button (this will essentially git clone the official FreeCAD repo to your personal GitHub repo: https://github.com/GITHUB_USERNAME/FreeCAD.git)
      6. +
      7. On your machine, clone your newly created FreeCAD fork by opening a terminal and typing: +
        git clone https://github.com/GITHUB_USERNAME/FreeCAD.git
      8. +
      9. Once the clone process is complete, now set your upstream remote repo (see "A note about Remotes"). Find out what and where your remote git repositories are set to. Type git remote -v and the output should look similiar to: +
         [foo@bar FreeCAD]$ git remote -v
        +     originhttps://github.com/GITHUB_USERNAME/FreeCAD.git (fetch)
        +     originhttps://github.com/GITHUB_USERNAME/FreeCAD.git (push)
      10. +
      11. Great. Now set your upstream repo +
        [foo@bar FreeCAD]$ git remote add upstream https://github.com/FreeCAD/FreeCAD.git
      12. +
      13. Check your remotes again, they should look similiar to this: +
         [foo@bar FreeCAD]$ git remote -v
        +    originhttps://github.com/GITHUB_USERNAME/FreeCAD.git (fetch)
        +    originhttps://github.com/GITHUB_USERNAME/FreeCAD.git (push)
        +    upstreamhttps://github.com/FreeCAD/FreeCAD.git (fetch)
        +    upstreamhttps://github.com/FreeCAD/FreeCAD.git (push)
      14. + +
      15. Now we can start developing. Please refer to "Git Development Process"
      16. +
      +

      2nd Method: Clone Official FreeCAD git repo to your local machine

      +
      Important Note +

      You will need to re-configure both 'remote origin' and 'remote upstream' please refer to above "A note about Remotes" +

      +
      +

      This method of setuping your git environment takes a few more steps then the 1st method. You will clone the FC git repo directly to your local machine and then alter your remotes via the terminal. The procedure is as follows: +

      +
        +
      1. Clone the FreeCAD code with git: +
        git clone https://github.com/FreeCAD/FreeCAD.git
      2. +
      3. Create an account on a public git server (GitHub, GitLab, etc... for our purposes we're assuming it's GitHub)
      4. +
      5. Find out what and where your remote git repositories are set to: +
        git remote -v
      6. +
      7. This will return something that looks like the following: +
        [foo@bar FreeCAD]$ git remote -v
        +    origin https://github.com/FreeCAD/FreeCAD.git (fetch)
        +    origin https://github.com/FreeCAD/FreeCAD.git (push)
      8. +
      9. As was explained above in "A note about Remotes" you need to modify these remote git repo addresses.
        +So first set up your origin remote: +
        [foo@bar FreeCAD]$ git remote add origin https://github.com/GITHUB_USERNAME/FreeCAD.git
      10. +
      11. Then we set up our upstream remote: +
        [foo@bar FreeCAD]$ git remote add upstream https://github.com/FreeCAD/FreeCAD.git
      12. +
      13. Check your remotes again, they should look similiar to this: +
         [foo@bar FreeCAD]$ git remote -v
        +    originhttps://github.com/GITHUB_USERNAME/FreeCAD.git (fetch)
        +    originhttps://github.com/GITHUB_USERNAME/FreeCAD.git (push)
        +    upstreamhttps://github.com/FreeCAD/FreeCAD.git (fetch)
        +    upstreamhttps://github.com/FreeCAD/FreeCAD.git (push)
      14. +
      15. Now we can start developing. Please refer to "Git Development Process"
      16. +
      +

      Git Development Process

      +

      First of all NEVER DEVELOP ON THE master BRANCH! +Instead, create a local branch for development. You can learn in more depth by reading Git-Branching-Basic-Branching-and-Merging chapter on git-scm. Below is a summary: +

      +

      Branching

      +

      An important feature of Git is that it is extremely easy to work with branches and merge +them together. Best practices recommend to create a new branch whenever you want to work +on a new feature. Creating a branch is done with: +

      +
      git branch myNewBranch
      +git checkout myNewBranch
      +
      +

      or you can combine both git branch && git checkout together by using the -b flag +

      +
      git checkout -b myNewBranch
      +
      +

      How do you know which branch you are currently using? Easy, type: +

      +
      git branch
      +
      +

      Committing

      +

      Once you did some work, you commit them with: +

      +
      git commit -a
      +

      Unlike SVN, you need to specifically tell which files to commit (or all with the +-a option). Your text editor will open to allow you to write a commit message.
      +Please read more about Writing good commit messages in the below section. +

      +

      Publishing your work on your GitHub repository

      +
      Important Note +

      If you have code you wish to see merged into the FreeCAD source code, please post a note in the Pull Request section of the FreeCAD forum +

      +
      +

      After you're correctly branched made some modifications to your local branch and commit them 'locally', you can push your repository to your remote git server (in this example we're assuming GitHub). This opens your branch to the public and allows the main developers to review and integrate your branch into master. +

      +
      git push  <REMOTENAME> <BRANCHNAME> 
      +git push origin my-branch
      +
      +

      For further info on this subject please read https://help.github.com/articles/pushing-to-a-remote/ +

      +

      Writing good commit messages

      +

      You should try to work in small chunks. If you cannot summarize your changes in one +sentence, then it has probably been too long since you have made a commit. It is also +important that you have helpful and useful descriptions of your work. For commit messages, +FreeCAD has adopted a format mentioned in book Pro Git (see #Further Reading). +

      +
      Short (50 chars or less) summary of changes
      +
      +More detailed explanatory text, if necessary.  Wrap it to about 72
      +characters or so.  In some contexts, the first line is treated as the
      +subject of an email and the rest of the text as the body.  The blank
      +line separating the summary from the body is critical (unless you omit
      +the body entirely); tools like rebase can get confused if you run the
      +two together.
      +
      +Further paragraphs come after blank lines. 
      +
      + - Bullet points are okay, too
      +
      + - Typically a hyphen or asterisk is used for the bullet, preceded by a
      +   single space, with blank lines in between, but conventions vary here
      +
      +

      If you are doing a lot of related work, it has been suggested +here +that one should make as many commits large or small as makes sense for what you are working +on using the short one sentence commit messages. When you want to merge, do a +

      +
      git log master..BRANCH
      +

      and use the output as a basis for your quality commit message. +Then when you merge to master use the --squash option and commit with your quality commit message. +This will allow you to be very liberal with your commits and help to provide a good level of detail +in commit messages without so many distinct descriptions. +

      +

      Advanced git operations

      +

      Resolving Merge Conflicts

      + +

      Applying patches via git

      +

      Git has the capability to merge patches/diffs. To read more about this read the following reference: https://www.drupal.org/node/1399218 +

      +
      • Useful tip: Just add .diff or .patch at the end of the URL for a GitHub commit page, Pull Request, or Compare View and it'll show you the plaintext view of that page. Example:
      +

      Regular GitHub page: +https://github.com/FreeCAD/FreeCAD/commit/c476589652a0f67b544735740e20ff702e8d0621 +

      'Diffed' GitHub page: +https://github.com/FreeCAD/FreeCAD/commit/c476589652a0f67b544735740e20ff702e8d0621.diff +

      'Patched' GitHub page: +https://github.com/FreeCAD/FreeCAD/commit/c476589652a0f67b544735740e20ff702e8d0621.patch +

      +

      Apply a patch via curl

      +
      curl https://github.com/FreeCAD/FreeCAD/commit/c476589652a0f67b544735740e20ff702e8d0621.patch | git apply -
      +
      +

      Creating patches from git

      +

      There are times when one may need to create a patch instead of submitting a PR. The following workflow explains how to do this: +

      +
        +
      1. Make sure you are in the correct branch (i.e. not the master branch) by checking with +
        git branch -v
      2. +
      3. Create the patch: we do this by using the git format-patch command which we patch against the master branch and redirect to STDOUT. We create the patch in the directory outside of the source build (in order not to pollute the source dir itself, this is optional as you can decide the location wherever you want the patch to be created) +
        git format-patch master --stdout > ../patch.name.patch
      4. +
      +

      What is the latest FreeCAD Dev Revision

      +

      There are 2 ways to do this: +

      +
      • 1st method: In your cloned git directory type:
      +
      git rev-list --count master
      +
      + +

      Alternative repositories

      +

      The beauty of git is that everybody can clone a project, and start modifying the code. Several frequent collaborators of the FreeCAD project have their own git repository, where they build up their work before it is ready to be included in the official source code, or simply where they experiment new ideas. In certain cases, you might want to clone your FreeCAD code from one of these, instead of the official repos, to benefit from the changes their users did. +

      Be warned, though, that this is at your own risk, and only the official repository above is fully guaranteed to work and contain clean code. +

      It is also possible to attach several remote repositories to a same local FreeCAD git code, using the "git remote" command. This is useful to keep in sync with the master code branch, but keep an eye on the work of different developers. +

      +

      Using git in a Graphical User Interface

      + +

      Further reading

      + +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/SpNav-PanLR.svg b/localwiki/SpNav-PanLR.svg new file mode 100644 index 0000000..b883552 --- /dev/null +++ b/localwiki/SpNav-PanLR.svg @@ -0,0 +1,766 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + Lapo Calamandrei + + + + + + media + stop + playback + video + music + + + + + Jakub Steiner + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/SpNav-PanUD.svg b/localwiki/SpNav-PanUD.svg new file mode 100644 index 0000000..c27023b --- /dev/null +++ b/localwiki/SpNav-PanUD.svg @@ -0,0 +1,749 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + Lapo Calamandrei + + + + + + media + stop + playback + video + music + + + + + Jakub Steiner + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/SpNav-Roll.svg b/localwiki/SpNav-Roll.svg new file mode 100644 index 0000000..89407ea --- /dev/null +++ b/localwiki/SpNav-Roll.svg @@ -0,0 +1,737 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + Lapo Calamandrei + + + + + + media + stop + playback + video + music + + + + + Jakub Steiner + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/SpNav-Spin.svg b/localwiki/SpNav-Spin.svg new file mode 100644 index 0000000..130d18e --- /dev/null +++ b/localwiki/SpNav-Spin.svg @@ -0,0 +1,736 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + Lapo Calamandrei + + + + + + media + stop + playback + video + music + + + + + Jakub Steiner + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/SpNav-Tilt.svg b/localwiki/SpNav-Tilt.svg new file mode 100644 index 0000000..24b908b --- /dev/null +++ b/localwiki/SpNav-Tilt.svg @@ -0,0 +1,736 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + Lapo Calamandrei + + + + + + media + stop + playback + video + music + + + + + Jakub Steiner + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/SpNav-Zoom.svg b/localwiki/SpNav-Zoom.svg new file mode 100644 index 0000000..191375b --- /dev/null +++ b/localwiki/SpNav-Zoom.svg @@ -0,0 +1,743 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + Lapo Calamandrei + + + + + + media + stop + playback + video + music + + + + + Jakub Steiner + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Spaceball_button.svg b/localwiki/Spaceball_button.svg new file mode 100644 index 0000000..ef4e7d1 --- /dev/null +++ b/localwiki/Spaceball_button.svg @@ -0,0 +1,245 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + + + + + + + + + + + diff --git a/localwiki/Spinning.html b/localwiki/Spinning.html new file mode 100644 index 0000000..a87cc85 --- /dev/null +++ b/localwiki/Spinning.html @@ -0,0 +1,28 @@ +Spinning

      Spinning

      + +

      Spinning is the ability of FreeCAD to display a dynamic rotation of the modell without user interaction. +


      +

      +

      Usage

      +

      Spinning is by default enabled. To enable or disable spinning go to the Edit→Preferences menu, change to the Display settings and click on Enable animation. +

      To make a 3D-object spin, rotate it with the mouse and release the mouse buttons before stopping the mouse motion. The object then continues with its rotation. +

      +

      View Turntable

      +

      Another way to put in rotation an object is use Tools -> View turntable... command +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/SpiralDefault_it.png b/localwiki/SpiralDefault_it.png new file mode 100644 index 0000000..c471ca7 Binary files /dev/null and b/localwiki/SpiralDefault_it.png differ diff --git a/localwiki/Spiral_x45_it.png b/localwiki/Spiral_x45_it.png new file mode 100644 index 0000000..1a6d698 Binary files /dev/null and b/localwiki/Spiral_x45_it.png differ diff --git a/localwiki/Spiral_y45_it.png b/localwiki/Spiral_y45_it.png new file mode 100644 index 0000000..d246e5f Binary files /dev/null and b/localwiki/Spiral_y45_it.png differ diff --git a/localwiki/Splash011.png b/localwiki/Splash011.png new file mode 100644 index 0000000..04e09c1 Binary files /dev/null and b/localwiki/Splash011.png differ diff --git a/localwiki/Splash013.jpg b/localwiki/Splash013.jpg new file mode 100644 index 0000000..d125e21 Binary files /dev/null and b/localwiki/Splash013.jpg differ diff --git a/localwiki/Splash_screen.html b/localwiki/Splash_screen.html new file mode 100644 index 0000000..f92b6db --- /dev/null +++ b/localwiki/Splash_screen.html @@ -0,0 +1,20 @@ +Splash screen

      Splash screen

      + +

      The splash screen is an image that appears during the startup of FreeCAD. You can disable the splash screen in the Preferences Menu of FreeCAD by removing the option "Enable splash screen at startup". +


      +

      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Splashscreen010.png b/localwiki/Splashscreen010.png new file mode 100644 index 0000000..845ec50 Binary files /dev/null and b/localwiki/Splashscreen010.png differ diff --git a/localwiki/Splashscreen012.png b/localwiki/Splashscreen012.png new file mode 100644 index 0000000..e3e85b7 Binary files /dev/null and b/localwiki/Splashscreen012.png differ diff --git a/localwiki/Splashscreen09.png b/localwiki/Splashscreen09.png new file mode 100644 index 0000000..969d1ef Binary files /dev/null and b/localwiki/Splashscreen09.png differ diff --git a/localwiki/Splineextrudeloft.png b/localwiki/Splineextrudeloft.png new file mode 100644 index 0000000..a1bb05a Binary files /dev/null and b/localwiki/Splineextrudeloft.png differ diff --git a/localwiki/Spreadsheet.svg b/localwiki/Spreadsheet.svg new file mode 100644 index 0000000..f15eab6 --- /dev/null +++ b/localwiki/Spreadsheet.svg @@ -0,0 +1,64 @@ + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [Eivind Kvedalen] + + + Spreadsheet + 2013-09-29 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Spreadsheet/Gui/Resources/icons/Spreadsheet.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + diff --git a/localwiki/SpreadsheetAlias.svg b/localwiki/SpreadsheetAlias.svg new file mode 100644 index 0000000..50e451c --- /dev/null +++ b/localwiki/SpreadsheetAlias.svg @@ -0,0 +1,68 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [Eivind Kvedalen] + + + SpreadsheetAlias + 2015-09-30 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Spreadsheet/Gui/Resources/icons/SpreadsheetAlias.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + diff --git a/localwiki/SpreadsheetAlignBottom.svg b/localwiki/SpreadsheetAlignBottom.svg new file mode 100644 index 0000000..e4408a0 --- /dev/null +++ b/localwiki/SpreadsheetAlignBottom.svg @@ -0,0 +1,62 @@ + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [Eivind Kvedalen] + + + SpreadsheetAlignBottom + 2013-09-29 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Spreadsheet/Gui/Resources/icons/SpreadsheetAlignBottom.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + diff --git a/localwiki/SpreadsheetAlignCenter.svg b/localwiki/SpreadsheetAlignCenter.svg new file mode 100644 index 0000000..ea0f6fe --- /dev/null +++ b/localwiki/SpreadsheetAlignCenter.svg @@ -0,0 +1,64 @@ + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [Eivind Kvedalen] + + + SpreadsheetAlignCenter + 2013-09-29 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Spreadsheet/Gui/Resources/icons/SpreadsheetAlignCenter.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + diff --git a/localwiki/SpreadsheetAlignLeft.svg b/localwiki/SpreadsheetAlignLeft.svg new file mode 100644 index 0000000..0068da7 --- /dev/null +++ b/localwiki/SpreadsheetAlignLeft.svg @@ -0,0 +1,64 @@ + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [Eivind Kvedalen] + + + SpreadsheetAlignLeft + 2013-09-29 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Spreadsheet/Gui/Resources/icons/SpreadsheetAlignLeft.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + diff --git a/localwiki/SpreadsheetAlignRight.svg b/localwiki/SpreadsheetAlignRight.svg new file mode 100644 index 0000000..8ea3df1 --- /dev/null +++ b/localwiki/SpreadsheetAlignRight.svg @@ -0,0 +1,64 @@ + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [Eivind Kvedalen] + + + SpreadsheetAlignRight + 2013-09-29 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Spreadsheet/Gui/Resources/icons/SpreadsheetAlignRight.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + diff --git a/localwiki/SpreadsheetAlignTop.svg b/localwiki/SpreadsheetAlignTop.svg new file mode 100644 index 0000000..a66bb52 --- /dev/null +++ b/localwiki/SpreadsheetAlignTop.svg @@ -0,0 +1,62 @@ + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [Eivind Kvedalen] + + + SpreadsheetAlignTop + 2013-09-29 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Spreadsheet/Gui/Resources/icons/SpreadsheetAlignTop.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + diff --git a/localwiki/SpreadsheetAlignVCenter.svg b/localwiki/SpreadsheetAlignVCenter.svg new file mode 100644 index 0000000..0792618 --- /dev/null +++ b/localwiki/SpreadsheetAlignVCenter.svg @@ -0,0 +1,62 @@ + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [Eivind Kvedalen] + + + SpreadsheetAlignVCenter + 2013-09-29 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Spreadsheet/Gui/Resources/icons/SpreadsheetAlignVCenter.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + diff --git a/localwiki/SpreadsheetCellPropDialog.png b/localwiki/SpreadsheetCellPropDialog.png new file mode 100644 index 0000000..ab7ebe1 Binary files /dev/null and b/localwiki/SpreadsheetCellPropDialog.png differ diff --git a/localwiki/SpreadsheetController.svg b/localwiki/SpreadsheetController.svg new file mode 100644 index 0000000..9961410 --- /dev/null +++ b/localwiki/SpreadsheetController.svg @@ -0,0 +1,66 @@ + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [Eivind Kvedalen] + + + SpreadsheetController + 2013-09-29 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Spreadsheet/Gui/Resources/icons/SpreadsheetController.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + diff --git a/localwiki/SpreadsheetExport.svg b/localwiki/SpreadsheetExport.svg new file mode 100644 index 0000000..17c264f --- /dev/null +++ b/localwiki/SpreadsheetExport.svg @@ -0,0 +1,183 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + Jakub Steiner + + + + + hdd + hard drive + save + io + store + + + + + http://jimmac.musichall.cz + SpreadsheetExport + 2013-09-29 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Spreadsheet/Gui/Resources/icons/SpreadsheetExport.svg + + + FreeCAD LGPL2+ + + + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/SpreadsheetImport.svg b/localwiki/SpreadsheetImport.svg new file mode 100644 index 0000000..d7c7aab --- /dev/null +++ b/localwiki/SpreadsheetImport.svg @@ -0,0 +1,152 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + 2005-01-31 + + + Jakub Steiner + + + + http://jimmac.musichall.cz + Active state - when files are being dragged to + + + Novell, Inc. + + + SpreadsheetImport + http://www.freecadweb.org/wiki/index.php?title=Artwork + FreeCAD/src/Mod/Spreadsheet/Gui/Resources/icons/SpreadsheetImport.svg + + + FreeCAD LGPL2+ + + + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/SpreadsheetMergeCells.svg b/localwiki/SpreadsheetMergeCells.svg new file mode 100644 index 0000000..2ec1fec --- /dev/null +++ b/localwiki/SpreadsheetMergeCells.svg @@ -0,0 +1,87 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [Eivind Kvedalen] + + + SpreadsheetMergeCells + 2013-09-29 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Spreadsheet/Gui/Resources/icons/SpreadsheetMergeCells.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/SpreadsheetSplitCell.svg b/localwiki/SpreadsheetSplitCell.svg new file mode 100644 index 0000000..f6350cb --- /dev/null +++ b/localwiki/SpreadsheetSplitCell.svg @@ -0,0 +1,102 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [Eivind Kvedalen] + + + SpreadsheetSplitCell + 2013-09-29 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Spreadsheet/Gui/Resources/icons/SpreadsheetSplitCell.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/SpreadsheetStyleBold.svg b/localwiki/SpreadsheetStyleBold.svg new file mode 100644 index 0000000..160f442 --- /dev/null +++ b/localwiki/SpreadsheetStyleBold.svg @@ -0,0 +1,338 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + Bold + 2006-01-04 + + + Lapo Calamandrei + + + http://tango-project.org + + + text + a + bold + write + letter + + + + + + Andreas Nilsson + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/SpreadsheetStyleItalic.svg b/localwiki/SpreadsheetStyleItalic.svg new file mode 100644 index 0000000..6bb54c2 --- /dev/null +++ b/localwiki/SpreadsheetStyleItalic.svg @@ -0,0 +1,107 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + Italic + 2006-01-04 + + + Lapo Calamandrei + + + http://tango-project.org + + + text + a + italic + cursive + write + letter + + + + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Spreadsheet/Gui/Resources/icons/SpreadsheetStyleItalic.svg + + + FreeCAD LGPL2+ + + + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/SpreadsheetStyleUnderline.svg b/localwiki/SpreadsheetStyleUnderline.svg new file mode 100644 index 0000000..26d53f1 --- /dev/null +++ b/localwiki/SpreadsheetStyleUnderline.svg @@ -0,0 +1,141 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + Format Text - Underlined + + + + Lapo Calamandrei + + + http://tango-project.org + + + text + a + strikeout + strike-out + write + letter + strike-though + + + + + + jakub Steiner, [agryson] Alexander Gryson + + + 2013-09-29 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Spreadsheet/Gui/Resources/icons/SpreadsheetStyleUnderline.svg + + + FreeCAD LGPL2+ + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/SpreadsheetWorkbench.svg b/localwiki/SpreadsheetWorkbench.svg new file mode 100644 index 0000000..85c337b --- /dev/null +++ b/localwiki/SpreadsheetWorkbench.svg @@ -0,0 +1,64 @@ + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [triplus] + + + SpreadsheetWorkbench + 2016-02-26 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Spreadsheet/Gui/Resources/icons/SpreadsheetWorkbench.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + diff --git a/localwiki/Spreadsheet_CSV.html b/localwiki/Spreadsheet_CSV.html new file mode 100644 index 0000000..8b7b33c --- /dev/null +++ b/localwiki/Spreadsheet_CSV.html @@ -0,0 +1,26 @@ +Spreadsheet CSV

      Spreadsheet CSV

      + +

      The CSV format (Comma-Separated Values) is a plain-text format to exchange spreadsheet data. It can usually be imported and exported by any spreadsheet application such as LibreOffice or Microsoft Excel. Reading and writing to csv format is done with python's built-in csv module. +

      +

      Importing

      +

      Importing a .csv file into FreeCAD creates a spreadsheet object, then fills it with the values from the file. +

      +

      Exporting

      +

      Exporting a spreadsheet object to a .csv file simply writes all the values of the spreadsheet object. Functions, such as "=A3+B5" are written as functions, not resulting values. +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Spreadsheet_Controller.html b/localwiki/Spreadsheet_Controller.html new file mode 100644 index 0000000..b60f75b --- /dev/null +++ b/localwiki/Spreadsheet_Controller.html @@ -0,0 +1,92 @@ +Spreadsheet Controller

      Spreadsheet Controller

      + +
      This tool has been deprecated in version 0.15 because of the switch to the new C++-based spreadsheet workbench. This functionality will be reintroduced at a later time.
      +


      +

      + + + + + + + + + + + + + + + + + + + + +
      +

      Spreadsheet Controller.png Spreadsheet Controller

      +
      Menu location +
      Spreadsheet → Controller +
      Workbenches +
      Spreadsheet +
      Default shortcut +
      None +
      See also +
      None +

      + +
      +


      +

      +

      Description

      +

      This tool adds a new cell controller object to a selected spreadsheet object. The controller can then extract certain values from certain objects in the active document, and fill a cells range of the host spreadsheet with these values. +

      +

      How to use

      +
      1. Select an existing spreadsheet object
      2. +
      3. Press the Spreadsheet Controller.png Spreadsheet Controller button
      4. +
      5. Adjust the needed properties
      +

      Options

      +
      • As soon as the needed properties are set, and objects corresponding to the filter properties are found, the values of the host spreadsheet are filled. There is no way to undo this operation at the moment.
      • +
      • The best way to set the properties of a cell controller object is to start from the bottom, setting the filter options first, and finishing with the starting cell. This way, you won't write to the spreadsheet before all the needed settings are set.
      +

      Properties

      +
      • DATABase Cell: The cell address to start automatic filling (ex: A5)
      • +
      • DATADirection: Specifies if the values will fill cells horizontally or vertically from the starting cell
      • +
      • DATAData: If "Data Type" is set to "Get Property", you can indicate here a property of the filtered objects to be retrieved. You can specify nested properties by using a dot (ex: Shape.Volume)
      • +
      • DATAData Type: Specifies if you want to retrieve a property of the filtered objects, or to count them
      • +
      • DATAFilter: A pattern to look for in the label or type of the objects in the document. For example, setting this value to "Struct" will get all objects containing Struct in their name, such as Structure001
      • +
      • DATAFilter Type: Specifies if the filter must be applied to the object label or type.
      +

      Scripting

      +

      Spreadsheets can be created from python scripts and macros using the makeSpreadsheetController() function: +

      +
       import Spreadsheet
      + mySpreadsheet = Spreadsheet.makeSpreadsheet()
      + controller = Spreadsheet.makeSpreadsheetController(mySpreadsheet)
      +

      Limitations

      +
      • This tool is not available below FreeCAd version 0.14
      • +
      • Currently it is not possible to undo the changes that a controller does to its host spreadsheet.
      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Spreadsheet_Create.html b/localwiki/Spreadsheet_Create.html new file mode 100644 index 0000000..c7f3263 --- /dev/null +++ b/localwiki/Spreadsheet_Create.html @@ -0,0 +1,95 @@ +Spreadsheet Create

      Spreadsheet Create

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Spreadsheet Create.png Spreadsheet Create

      +
      Menu location +
      Spreadsheet → Create +
      Workbenches +
      Spreadsheet +
      Default shortcut +
      None +
      See also +
      None +

      + +
      +


      +

      +

      Description

      +

      This tool adds a new spreadsheet object to the active document. The spreadsheet can then be edited with standard FreeCAD editing methods (right-clicking it in the tree view or using the Std Edit command. +

      +

      How to use

      +
      1. Press the Spreadsheet Create.png Spreadsheet Create button
      2. +
      3. Press the Std Edit.png Std Edit button to edit the spreadsheet contents
      4. +
      5. Edit the contents of the cells
      6. +
      7. Close the spreadsheet editor tab when you are finished, the values are saved automatically as you type them
      +

      Options

      +
      • Cell contents can be edited by double-clicking them, or using the edit line on top of the editor
      • +
      • The values are saved on-the-fly and stored in the FreeCAD document
      • +
      • You can enter text, numbers, or formulas, by starting your entry with the = character. Only simple arithmetic (+, -, * and /) and parenthesis are supported at the moment. Example: =B4*2 will show the contents of the B4 cell multiplied by 2.
      • +
      • You can insert values automatically retrieved from the model by using a Cell controller object
      • +
      • Spreadsheet objects can be imported and exported to the csv format
      +

      Scripting

      +

      Spreadsheets can be created from python scripts and macros using the makeSpreadsheet() function: +

      +
       import Spreadsheet
      + mySpreadsheet = Spreadsheet.makeSpreadsheet()
      +

      The contents of the spreadsheet can then be manipulated like this: +

      +
       mySpreadsheet.Proxy.A1 = "my text"
      + print mySpreadsheet.Proxy.A1
      +

      Spreadsheet objects can also be created purely in the python space, with no existence in the FreeCAD document. These won't be saved when you close the FreeCAD file, so it is only meant for temporary purposes: +

      +
       import Spreadsheet
      + myPySpreadsheet = Spreadsheet.Spreadsheet()
      + myPySpreadsheet.A1 = "my other text"
      + print myPySpreadsheet.A1
      +

      Limitations

      +
      • This tool is not available below FreeCAd version 0.14
      • +
      • The maximum size of a spreadsheet is currently limited to 26x256 cells (columns between A and Z and rows between 1 and 256)
      • +
      • Columns between A and ZZ and rows between 1 and 16384 available in version 0.17
      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Spreadsheet_Module.html b/localwiki/Spreadsheet_Module.html new file mode 100644 index 0000000..d67dbda --- /dev/null +++ b/localwiki/Spreadsheet_Module.html @@ -0,0 +1,162 @@ +Spreadsheet Module

      Spreadsheet Module

      (Redirected from Spreadsheet Module)
      + +

      available in version 0.15 +The spreadsheet workbench allows you to create and edit spreadsheets, perform calculations, and retrieve data from a model, and export its data to other spreadsheet applications such as LibreOffice or Microsoft Excel. +


      +Spreadsheet screenshot.jpg +


      +

      + + +

      Supported Functions

      +

      The spreadsheet provides the following functions taking one or two arguments: abs, acos, asin, atan, atan2, cos, cosh, exp, log, log10, mod, pow, sin, sinh, sqrt, tan, tanh +

      Trigonometric functions use degrees as its default unit; supplying rad allows to use radians. +

      The additional functions: ceil, floor, trunc, and round are available in FreeCAD available in version 0.16 +


      +The following aggregate functions are supported: average, count, max, min, stddev, sum. +

      Aggregate functions can take one or more arguments, separated by comma or semicolon. Arguments may include ranges (two cells separated by a colon), e.g =average(B1:B8) +

      The constants pi and e are predefined. +

      The conditional statement works like this: = condition ? resultTrue : resultFalse +

      The condition is defined as an expression that evaluates to either 0 (for false) or non-zero for true. The following comparison operators are defined: ==, !=, >, <, >=, and <=. +

      The conditional statement has actually a bug regarding nested conditional statements. Only the true-result may have another conditional statement. Parentheses are removed after confirming the expression. Trying to put a nested conditional statement in the false-result results in wrong set parentheses with a different result after a saving and reopening of the document. +

      Formulas are written as follows: =A2+A3 +

      Noteː Cell-references have to be written with capital letters. +

      +

      Reference To CAD-Data

      +

      It is possible to use data from the construction in the spreadsheet. +The following table shows some examples assuming the model has a feature named "Cube" (note that this is the internal name of the feature, not the user assigned Label): +

      + + + + + + + + + + + + + + + + + + + + + + + + +
      CAD-Data +Call in Spreadsheet +Result +
      Parametric Length of a Part-Workbench Cube +=Cube.Length +Length with units mm +
      Volume of the Cube +=Cube.Shape.Volume +Volume in mm³ without units +
      Type of the Cube-shape +=Cube.Shape.ShapeType +String: Solid +
      Label of the Cube +=Cube.Label +String: Cube +
      x-coordinate of center of mass of the Cube +=Cube.Shape.CenterOfMass.x +x-coordinate in mm without units +
      +

      Cell Properties

      +

      The properties of a spreadsheet cell can be edited with a right-click on a cell. The following +dialog pops up: +

      SpreadsheetCellPropDialog.png +

      It has several tabs. The following properties can be changed: +

      +
      • Text color and background color
      • +
      • Text horizontal and vertical alignment
      • +
      • Text style: bold, italic, underline
      • +
      • Display unit for this cell. Please read the section below.
      • +
      • Define an alias-name for this cell. This alias-name can be used in cell formulas and also in FreeCADExpressions available in version 0.16
      +


      +The expressions are explained here: Expressions +

      +

      Spreadsheet Data in Expressions

      +

      The usage of spreadsheet data in other parts of FreeCAD requires a fully defined name. Because it is possible to have +more than one spreadsheet in a document, the spreadsheet name together with the cell name or alias is required. +The following pictures showing the usage of an alias "number" from a spreadsheet "MySheet" in an expression +in the PartDesign Workbench. +Expression usage1.png +

      Typing an "M" shows a list of available names. The arrow-buttons allow to select "MySheet". +

      Expression usage2.png +

      Typing an "n" shows now the list of available alias names in MySheet starting with "n". +The "number" can be selected with the down-arrow-button. +Once a valid name with a usable content is given, the result field will present the calculated length. +

      Expression usage3.png +

      +

      Units

      +

      The Spreadsheet uses units. If a number has a unit, this unit will be used in all calculations. +The multiplication of two length with the unit mm gives an area with the unit mm². +

      You can switch the length-unit from mm to inch in the dialog, you get with a right-click on a cell. +The cell will now show the length in inches. The value used for calculations does not change. +The results of a formula using this value do not change, when the shown unit of an input was changed. The result +is still calculated from the length in mm. +

      A number without a unit cannot be changed in a number with unit by the cell properties dialog. +One can put in a unit string, that will also be shown, but the cell still contains only a number without unit. +

      Sometime it is desirably to get rid of a unit. This can only to be done by multiplying with 1 with a reciprocal unit. +

      +

      Importing and exporting

      +

      Sheets can be imported and exported to the csv format which can also be read and written by most other spreadsheet applications such as Microsoft Excel or LibreOffice Calc. When importing files into FreeCAD, the delimiter (the character that is used to separate columns) must be the TAB character (this can be set when exporting from other applications). +

      Spreadsheets in Excel-format "xlsx" can be imported into a FreeCAD document. Excel-spreadsheets can also be opened by FreeCAD. In this case +a new document with a spreadsheet inside is created. Supported are the following features: +

      +
      • all functions that are also available in the FreeCAD spreadsheet. Other functions do give an error in the corresponding cell after the import.
      • +
      • Alias names for cells
      • +
      • More than one table in the Excel-sheet. In this case more FreeCAD spreadsheets are created.
      +

      Other functionality is not imported into the FreeCAD spreadsheet. The Excel-import is available in version 0.17 +of FreeCAD. +

      +

      Current Limitations

      +

      It is not possible providing data for a geometry, for example a length, in a spreadsheet and retrieving in the same spreadsheet the volume of the +resulting shape. This will create a circular reference. This is a design decision. However, it is possible to use two different spreadsheets: one as data-source +for geometry and another for reporting geometry-data. +

      It is not possible to select and copy multiple cells. Only the content of a cell from the input field can be copied and paste into the input field of another cell. +

      For FreeCAD earlier versions see Spreadsheet legacy +


      +

      +

      Scripting Basics

      +
      import Spreadsheet
      +sheet = App.ActiveDocument.addObject("Spreadsheet::Sheet")
      +sheet.Label = "Dimensions" 
      + +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Spreadsheet_PropertyController.html b/localwiki/Spreadsheet_PropertyController.html new file mode 100644 index 0000000..5bd5693 --- /dev/null +++ b/localwiki/Spreadsheet_PropertyController.html @@ -0,0 +1,86 @@ +Spreadsheet PropertyController

      Spreadsheet PropertyController

      + +
      This tool has been deprecated in version 0.15 because of the switch to the new C++-based spreadsheet workbench. This functionality will be reintroduced at a later time.
      +


      +

      + + + + + + + + + + + + + + + + + + + + +
      +

      Spreadsheet PropertyController.png Spreadsheet PropertyController

      +
      Menu location +
      Spreadsheet → Property Controller +
      Workbenches +
      Spreadsheet +
      Default shortcut +
      None +
      See also +
      Spreadsheet Controller +

      + +
      +


      +

      +

      Description

      +

      This tool adds a new property controller object to a selected spreadsheet object. The controller can then manage a certain property of a certain object, and update it with the value of a cell from the spreadsheet, whenever that cell changes. +

      +

      How to use

      +
      1. Select an existing spreadsheet object
      2. +
      3. Press the Spreadsheet PropertyController.png Property Controller button
      4. +
      5. Adjust the needed properties
      +

      Properties

      +
      • DATATarget Type: The type of item to control: a property of the target object, or a datum-based constraint if the target object is a sketch
      • +
      • DATATarget Object: The object to be controlled
      • +
      • DATATarget Property: The name of the property to control, or the number of the datum-based constraint
      • +
      • DATACell: The cell from the host spreadsheet to take the value from
      +

      Scripting

      +

      Spreadsheets can be created from python scripts and macros using the makeSpreadsheetPropertyController() function: +

      +
       import Spreadsheet
      + mySpreadsheet = Spreadsheet.makeSpreadsheet()
      + controller = Spreadsheet.makeSpreadsheetPropertyController(mySpreadsheet)
      +

      Limitations

      +
      • This tool is not available below FreeCAD version 0.14
      • +
      • Currently it is not possible to undo the changes that a controller does to its controlled object.
      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Spreadsheet_Workbench.html b/localwiki/Spreadsheet_Workbench.html new file mode 100644 index 0000000..c089d3f --- /dev/null +++ b/localwiki/Spreadsheet_Workbench.html @@ -0,0 +1,162 @@ +Spreadsheet Workbench

      Spreadsheet Workbench

      + +

      available in version 0.15 +The spreadsheet workbench allows you to create and edit spreadsheets, perform calculations, and retrieve data from a model, and export its data to other spreadsheet applications such as LibreOffice or Microsoft Excel. +


      +Spreadsheet screenshot.jpg +


      +

      + + +

      Supported Functions

      +

      The spreadsheet provides the following functions taking one or two arguments: abs, acos, asin, atan, atan2, cos, cosh, exp, log, log10, mod, pow, sin, sinh, sqrt, tan, tanh +

      Trigonometric functions use degrees as its default unit; supplying rad allows to use radians. +

      The additional functions: ceil, floor, trunc, and round are available in FreeCAD available in version 0.16 +


      +The following aggregate functions are supported: average, count, max, min, stddev, sum. +

      Aggregate functions can take one or more arguments, separated by comma or semicolon. Arguments may include ranges (two cells separated by a colon), e.g =average(B1:B8) +

      The constants pi and e are predefined. +

      The conditional statement works like this: = condition ? resultTrue : resultFalse +

      The condition is defined as an expression that evaluates to either 0 (for false) or non-zero for true. The following comparison operators are defined: ==, !=, >, <, >=, and <=. +

      The conditional statement has actually a bug regarding nested conditional statements. Only the true-result may have another conditional statement. Parentheses are removed after confirming the expression. Trying to put a nested conditional statement in the false-result results in wrong set parentheses with a different result after a saving and reopening of the document. +

      Formulas are written as follows: =A2+A3 +

      Noteː Cell-references have to be written with capital letters. +

      +

      Reference To CAD-Data

      +

      It is possible to use data from the construction in the spreadsheet. +The following table shows some examples assuming the model has a feature named "Cube" (note that this is the internal name of the feature, not the user assigned Label): +

      + + + + + + + + + + + + + + + + + + + + + + + + +
      CAD-Data +Call in Spreadsheet +Result +
      Parametric Length of a Part-Workbench Cube +=Cube.Length +Length with units mm +
      Volume of the Cube +=Cube.Shape.Volume +Volume in mm³ without units +
      Type of the Cube-shape +=Cube.Shape.ShapeType +String: Solid +
      Label of the Cube +=Cube.Label +String: Cube +
      x-coordinate of center of mass of the Cube +=Cube.Shape.CenterOfMass.x +x-coordinate in mm without units +
      +

      Cell Properties

      +

      The properties of a spreadsheet cell can be edited with a right-click on a cell. The following +dialog pops up: +

      SpreadsheetCellPropDialog.png +

      It has several tabs. The following properties can be changed: +

      +
      • Text color and background color
      • +
      • Text horizontal and vertical alignment
      • +
      • Text style: bold, italic, underline
      • +
      • Display unit for this cell. Please read the section below.
      • +
      • Define an alias-name for this cell. This alias-name can be used in cell formulas and also in FreeCADExpressions available in version 0.16
      +


      +The expressions are explained here: Expressions +

      +

      Spreadsheet Data in Expressions

      +

      The usage of spreadsheet data in other parts of FreeCAD requires a fully defined name. Because it is possible to have +more than one spreadsheet in a document, the spreadsheet name together with the cell name or alias is required. +The following pictures showing the usage of an alias "number" from a spreadsheet "MySheet" in an expression +in the PartDesign Workbench. +Expression usage1.png +

      Typing an "M" shows a list of available names. The arrow-buttons allow to select "MySheet". +

      Expression usage2.png +

      Typing an "n" shows now the list of available alias names in MySheet starting with "n". +The "number" can be selected with the down-arrow-button. +Once a valid name with a usable content is given, the result field will present the calculated length. +

      Expression usage3.png +

      +

      Units

      +

      The Spreadsheet uses units. If a number has a unit, this unit will be used in all calculations. +The multiplication of two length with the unit mm gives an area with the unit mm². +

      You can switch the length-unit from mm to inch in the dialog, you get with a right-click on a cell. +The cell will now show the length in inches. The value used for calculations does not change. +The results of a formula using this value do not change, when the shown unit of an input was changed. The result +is still calculated from the length in mm. +

      A number without a unit cannot be changed in a number with unit by the cell properties dialog. +One can put in a unit string, that will also be shown, but the cell still contains only a number without unit. +

      Sometime it is desirably to get rid of a unit. This can only to be done by multiplying with 1 with a reciprocal unit. +

      +

      Importing and exporting

      +

      Sheets can be imported and exported to the csv format which can also be read and written by most other spreadsheet applications such as Microsoft Excel or LibreOffice Calc. When importing files into FreeCAD, the delimiter (the character that is used to separate columns) must be the TAB character (this can be set when exporting from other applications). +

      Spreadsheets in Excel-format "xlsx" can be imported into a FreeCAD document. Excel-spreadsheets can also be opened by FreeCAD. In this case +a new document with a spreadsheet inside is created. Supported are the following features: +

      +
      • all functions that are also available in the FreeCAD spreadsheet. Other functions do give an error in the corresponding cell after the import.
      • +
      • Alias names for cells
      • +
      • More than one table in the Excel-sheet. In this case more FreeCAD spreadsheets are created.
      +

      Other functionality is not imported into the FreeCAD spreadsheet. The Excel-import is available in version 0.17 +of FreeCAD. +

      +

      Current Limitations

      +

      It is not possible providing data for a geometry, for example a length, in a spreadsheet and retrieving in the same spreadsheet the volume of the +resulting shape. This will create a circular reference. This is a design decision. However, it is possible to use two different spreadsheets: one as data-source +for geometry and another for reporting geometry-data. +

      It is not possible to select and copy multiple cells. Only the content of a cell from the input field can be copied and paste into the input field of another cell. +

      For FreeCAD earlier versions see Spreadsheet legacy +


      +

      +

      Scripting Basics

      +
      import Spreadsheet
      +sheet = App.ActiveDocument.addObject("Spreadsheet::Sheet")
      +sheet.Label = "Dimensions" 
      + +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Spreadsheet_legacy.html b/localwiki/Spreadsheet_legacy.html new file mode 100644 index 0000000..e086b34 --- /dev/null +++ b/localwiki/Spreadsheet_legacy.html @@ -0,0 +1,29 @@ +Spreadsheet legacy

      Spreadsheet legacy

      + +

      The spreadsheet workbench allows you to create and edit spreadsheets, perform calculations, and retrieve data from a model, and export its contents to other spreadsheet applications such as LibreOffice or Microsoft Excel. The spreadsheet workbench features an internal editor, that allows you to edit the spreadsheet contents. +


      +Arch tutorial 53.jpg +

      +

      Tools

      + +

      File formats

      + + +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Spreadsheet_screenshot.jpg b/localwiki/Spreadsheet_screenshot.jpg new file mode 100644 index 0000000..b326c6a Binary files /dev/null and b/localwiki/Spreadsheet_screenshot.jpg differ diff --git a/localwiki/Spring_00.gif b/localwiki/Spring_00.gif new file mode 100644 index 0000000..3c07e83 Binary files /dev/null and b/localwiki/Spring_00.gif differ diff --git a/localwiki/Square.svg b/localwiki/Square.svg new file mode 100644 index 0000000..8cd2b7f --- /dev/null +++ b/localwiki/Square.svg @@ -0,0 +1,118 @@ + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Staeubli_important_points.png b/localwiki/Staeubli_important_points.png new file mode 100644 index 0000000..87fecd3 Binary files /dev/null and b/localwiki/Staeubli_important_points.png differ diff --git a/localwiki/Standard_Menu.html b/localwiki/Standard_Menu.html new file mode 100644 index 0000000..68723a7 --- /dev/null +++ b/localwiki/Standard_Menu.html @@ -0,0 +1,54 @@ +Standard Menu

      Standard Menu

      + +


      + File     Edit     View     Tools     Macro     Workbench     Measure     Windows     Help +

      +

      Overview

      +

      The standard FreeCAD menu allows access to functions which are used in all workbenches. Your menu may look slightly different depending on your desktop environment (KDE, Gnome, Windows, OS X, etc). +

      +

      File

      +

      The File option provides functions related to input and output, such as Open, Print, Export, etc. +

      +

      Edit

      +

      The Edit option provides functions related to changing the model, such as Copy, Paste, etc. +

      +

      View

      +

      The View option provides functions related to the display of the model, such as which panels to show, Zoom, etc. +

      +

      Tools

      +

      The Tools option provides functions for debugging models and customizing FreeCAD's behaviour. +

      +

      Macro

      +

      The Macro option provides functions related to the recording and execution of groups of FreeCAD commands. +

      +

      Workbench

      +

      The Workbench option provides functions related to the workbench in use. It contains functions specific to the current workbench. +

      +

      Measure

      +

      The Measure option provides functions related to the Delta and/or 3D distances. This menu appears only in the Part Workbench. +

      +

      Windows

      +

      The Windows option allows for switching between and arranging open FreeCAD windows. +

      +

      Help

      +

      The Help option provides access to the FreeCAD help system and provides information about your FreeCAD installation. +


      +

      + +


      +

      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/StartWorkbench.svg b/localwiki/StartWorkbench.svg new file mode 100644 index 0000000..c5583b6 --- /dev/null +++ b/localwiki/StartWorkbench.svg @@ -0,0 +1,182 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [triplus] + + + StartWorkbench + 2016-02-26 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Start/Gui/Resources/icons/StartWorkbench.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + arrow + right + + + Arrow pointing towards the right + + + + + + + + diff --git a/localwiki/Start_Workbench.html b/localwiki/Start_Workbench.html new file mode 100644 index 0000000..e57e547 --- /dev/null +++ b/localwiki/Start_Workbench.html @@ -0,0 +1,35 @@ +Start Workbench

      Start Workbench

      + +
      +

      This documentation is not finished. Please help and contribute documentation. +

      See Draft ShapeString for good documented Command. Gui Command gives an overview over commands. And see List of Commands for other commands. +

      Go to Help FreeCAD to contribute. +

      +
      +


      +From Getting started: +


      +When you start FreeCAD for the first time, you are presented with the start center: +


      +

      +
      Startcenter.jpg
      +


      +

      The Start Center allows you to quickly jump to one of the most common workbenches, open one of the recent files, or see the latest news from the FreeCAD world. You can change the default workbench in the preferences. +

      ToDo +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Start_up_and_Configuration.html b/localwiki/Start_up_and_Configuration.html new file mode 100644 index 0000000..3b8da35 --- /dev/null +++ b/localwiki/Start_up_and_Configuration.html @@ -0,0 +1,347 @@ +Start up and Configuration

      Start up and Configuration

      + +

      This page shows the different ways to start FreeCAD and the most important configuration features. +

      + + +

      Starting FreeCAD from the Command line

      +

      FreeCAD can be started normally by double-clicking on its desktop icon or selecting it from the start menu, but it can also be started directly from the command line. This allows you to change some of the default startup options. +

      +

      Command line options

      +

      The command line options are subject to frequent changes.Ttherefore, it is a good idea to check the current options by typing: +

      +
      FreeCAD --help
      +
      +

      From the response you can read the possible parameters: +

      +
      Usage:
      +FreeCAD [options] File1 File2 .....
      +Allowed options:  
      +
      +Generic options:
      + -v [ --version ]      print version string
      + -h [ --help ]         print help message
      + -c [ --console ]      start in console mode
      + --response-file arg   can be specified with '@name', too
      +
      +
      Configuration:
      + -l [ --write-log ] arg    write a log file to default location(Run FreeCAD --h to see default location)
      + --log-file arg            Unlike to --write-log this allows to log to an arbitrary file
      + -u [ --user-cfg] arg      User config file to load/save user settings
      + -s [ --system-cfg] arg    System config file to load/save system settings
      + -t [ --run-test ] arg     test level
      + -M [ --module-path ] arg  additional module paths
      + -P [ --python-path ] arg  additional python paths 
      +
      +

      EX: (Windows) +

      +
      "C:\Program Files\FreeCAD 0.14\bin\FreeCAD.exe" -M "N:\FreeCAD\Mod\Draft" -M "N:\FreeCAD\Mod\Part" -M "N:\FreeCAD\Mod\Drawing" -u "N:\FreeCAD\Config\user.cfg" -s "N:\FreeCAD\Config\system.cfg" 
      +


      +

      +

      Response and config files

      +

      FreeCAD can read some of these options from a config file. This file must be in the bin path and must be named FreeCAD.cfg. Be aware that options specified in the command line override the config file! +

      Some operating systems have a very low limit of characters on the command line. The common way to work around those limitations is using response files. A response file is just a configuration file which uses the same syntax as the command line. If the command line specifies a response file, it's loaded and parsed in addition to the command line: +

      +
      FreeCAD @ResponseFile.txt 
      +

      or: +

      +
      FreeCAD --response-file=ResponseFile.txt 
      +

      Hidden options

      +

      There are a couple of options not visible to the user. These options are e.g. the X-Window parameters parsed by the Windows system: +

      +
      • -display - Sets the X display (default is $DISPLAY).
      • +
      • -geometry - Sets the client geometry of the first window that is shown.
      • +
      • -fn or -font - Defines the application font. The font should be specified using an X logical font description.
      • +
      • -bg or -background - Sets the default background color and an application palette (light and dark shades are calculated).
      • +
      • -fg or -foreground - Sets the default foreground color.
      • +
      • -btn or -button - Sets the default button color.
      • +
      • -name - Sets the application name.
      • +
      • -title - Sets the application title.
      • +
      • -visual - Forces the application to use a TrueColor visual on an 8-bit display.
      • +
      • -ncols - Limits the number of colors allocated in the color cube on an 8-bit display, if the application is using the QApplication::ManyColor color specification. If count is 216 then a 6x6x6 color cube is used (i.e. 6 levels of red, 6 of green, and 6 of blue); for other values, a cube approximately proportional to a 2x3x1 cube is used.
      • +
      • -cmap - Causes the application to install a private color map on an 8-bit display.
      +

      Running FreeCAD without Graphical User Interface

      +

      FreeCAD is usually built with two executables: a GUI capable one called FreeCAD, and a command line only FreeCADCmd. +FreeCAD can be used in console mode using the "-c" switch, this is the default behaviour of FreeCADCmd: +

      +
      FreeCAD -c
      +
      +

      from the command line. In console mode, no user interface will be displayed, and you will be presented with a python interpreter prompt. From that python prompt, you have the same functionality as the python interpreter that runs inside the FreeCAD GUI, and normal access to all modules and plugins of FreeCAD, excepted the FreeCADGui module. Be aware that modules that depend on FreeCADGui might also be unavailable. +

      Python scripts/FreeCAD macro files can be specified as command line arguments to either of the executables mentioned above. +

      +

      The Config set

      +

      On every Startup FreeCAD examines its surrounding and the command line parameters. It builds up a configuration set which holds the essence of the runtime information. This information is later used to determine the place where to save user data or log files. It is also very important for post postmortem analyzes. Therefore it is saved in the log file. +

      +

      User related information

      + + + + + + + + + + + + + + + + + + + + + + + + + + +
      User config entries +
      Config var name Synopsis Example M$ Example Posix (Linux) +
      UserAppData Path where FreeCAD stores User Related application data. C:\Documents and Settings\username\Application Data\FreeCAD /home/username/.FreeCAD +
      UserParameter File where FreeCAD stores User Related application data. C:\Documents and Settings\username\Application Data\FreeCAD\user.cfg /home/username/.FreeCAD/user.cfg +
      SystemParameter File where FreeCAD stores Application Related data. C:\Documents and Settings\username\Application Data\FreeCAD\system.cfg /home/username/.FreeCAD/system.cfg +
      UserHomePath Home path of the current user C:\Documents and Settings\username\My Documents /home/username +
      +

      Command line arguments

      + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
      User config entries +
      Config var name Synopsis Example +
      LoggingFile 1 if the logging is switched on 1 +
      LoggingFileName File name where the log is placed C:\Documents and Settings\username\Application Data\FreeCAD\FreeCAD.log +
      RunMode This indicates how the main loop will work. "Script" means that the given script is called and then exit. "Cmd" runs the command line interpreter. "Internal" runs an internal script. "Gui" enters the Gui event loop. "Module" loads a given python module. "Cmd" +
      FileName Meaning depends on the RunMode +
      ScriptFileName Meaning depends on the RunMode +
      Verbose Verbosity level of FreeCAD "" or "strict" +
      OpenFileCount Holds the number of files opened through command line arguments "12" +
      AdditionalModulePathsHolds the additional Module paths given in the cmd line "extraModules/" +
      +

      System related

      + + + + + + + + + + + + + + + + +
      User config entries +
      Config var name Synopsis Example M$ Example Posix (Linux) +
      AppHomePath Path where FreeCAD is installed c:/Progam Files/FreeCAD_0.7 /user/local/FreeCAD_0.7 +
      PythonSearchPath Holds a list of paths which python search modules. This is at startup can change during execution +
      +

      Some libraries need to call system environment variables. Sometimes when there is a problem with a FreeCAD installation, it is because some environment variable is absent or set wrongly. Therefore, some important variables get duplicated in the Config and saved in the log file. +

      Python related environment variables: +

      +
      • PYTHONPATH
      • +
      • PYTHONHOME
      • +
      • TCL_LIBRARY
      • +
      • TCLLIBPATH
      +

      OpenCascade related environment variables: +

      +
      • CSF_MDTVFontDirectory
      • +
      • CSF_MDTVTexturesDirectory
      • +
      • CSF_UnitsDefinition
      • +
      • CSF_UnitsLexicon
      • +
      • CSF_StandardDefaults
      • +
      • CSF_PluginDefaults
      • +
      • CSF_LANGUAGE
      • +
      • CSF_SHMessage
      • +
      • CSF_XCAFDefaults
      • +
      • CSF_GraphicShr
      • +
      • CSF_IGESDefaults
      • +
      • CSF_STEPDefaults
      +

      System related environment variables: +

      +
      • PATH
      +

      Build related information

      +

      The table below shows the available information about the Build version. Most of it comes from the Subversion repository. This stuff is needed to exactly rebuild a version! +

      + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
      User config entries +
      Config var name Synopsis Example +
      BuildVersionMajor Major Version number of the Build. Defined in src/Build/Version.h.in 0 +
      BuildVersionMinor Minor Version number of the Build. Defined in src/Build/Version.h.in 7 +
      BuildRevision SVN Repository Revision number of the src in the Build. Generated by SVN 356 +
      BuildRevisionRange Range of different changes 123-356 +
      BuildRepositoryURL Repository URL https://free-cad.svn.sourceforge.net/svnroot/free-cad/trunk/src +
      BuildRevisionDate Date of the above Revision 2007/02/03 22:21:18 +
      BuildScrClean Indicates if the source was changed after checkout Src modified +
      BuildScrMixed Src not mixed +
      +

      Branding related

      +

      These Config entries are related to the branding mechanism of FreeCAD. See Branding for more details. +

      + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
      User config entries +
      Config var name Synopsis Example +
      ExeName Name of the build Executable file. Can differ from FreeCAD if a different main.cpp is used. FreeCAD.exe +
      ExeVersion Over all Version shows up at start time V0.7 +
      AppIcon Icon which is used for the Executable, shows in Application MainWindow. "FCIcon" +
      ConsoleBanner Banner which is prompted in console mode +
      SplashPicture Name of the Icon used for the Splash Screen "FreeCADSplasher" +
      SplashAlignment Alignment of the Text in the Splash dialog "Bottom" or "Left" +
      SplashTextColor Color of the splasher Text "#000000" +
      StartWorkbench Name of the Workbench which get started automatically after Startup "Part design" +
      HiddenDockWindow List of dockwindows (separated by a semicolon) which will be disabled "Property editor" +
      + +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Std_About.html b/localwiki/Std_About.html new file mode 100644 index 0000000..c7e37eb --- /dev/null +++ b/localwiki/Std_About.html @@ -0,0 +1,62 @@ +Std About

      Std About

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Std About.png Std About

      +
      Menu location +
      Help → About FreeCAD +
      Workbenches +
      All +
      Default shortcut +
      None +
      See also +
      ... +

      Contents

      + +
      + +
      +


      +

      Provides all information on the used version of FreeCAD. +

      When a request for help on the forum, it is imperative to give information about your installation. +

      Click on "Copy to Clipboard" and paste the information into your post. +


      +Std About en.png +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Std_About_en.png b/localwiki/Std_About_en.png new file mode 100644 index 0000000..68935d2 Binary files /dev/null and b/localwiki/Std_About_en.png differ diff --git a/localwiki/Std_Alignment.html b/localwiki/Std_Alignment.html new file mode 100644 index 0000000..2c9f922 --- /dev/null +++ b/localwiki/Std_Alignment.html @@ -0,0 +1,94 @@ +Std Alignment

      Std Alignment

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Std Alignment.png Std Alignment

      +
      Menu location +
      Edit → Alignment... +
      Workbenches +
      All +
      Default shortcut +
      None +
      See also +
      Placement +

      + +
      +


      +


      +

      +

      Description

      +

      This function allows you to position and orientate two selected shapes, by aligning two or more selected points, on each of those two different shapes, with each other. It works in all workbenches. +

      The Alignment tool requires only one pair of reference points, however in most cases correct orientation and positioning will require 3 reference points. +

      +

      Example

      +

      This is the example project before objects have been aligned +

      Std Alignment1.png +

      To Align the objects start by Multi-selecting two objects only. The first object selected will be the fixed object. The second object selected will be moved by the Alignment tool. +

      After you have multi-selected two objects, start the Alignment tool from the Edit menu → Alignment .... +

      +A double window will appear, showing a view of each of the selected objects. The window on the left will show the movable object and the window on the right will show the fixed object.
      +


      +

      Select one or more pairs of points in the two views, that you want the Alignment tool to make coincide. +

      Std Alignment2.png +

      +
      +


      +

      Right mouse click in either windows to access the context menu. From the context menu you can +

      +
      1. remove the last pair of points,
      2. +
      3. run and then close the Alignment tool,
      4. +
      5. cancel the Alignment operation and close the Alignment tool
      6. +
      7. or syncronise views. If ticked, this will synchronise pan/rotate/zoom of the views in the double windows, with each other.
      +

      Std Alignment3.png +

      +
      +


      +

      After running the Alignment tool several times, the project could be made to look like this: +

      Std Alignment4.png +

      +
      +


      +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Std_Alignment3.png b/localwiki/Std_Alignment3.png new file mode 100644 index 0000000..bf9d8ac Binary files /dev/null and b/localwiki/Std_Alignment3.png differ diff --git a/localwiki/Std_Axis.svg b/localwiki/Std_Axis.svg new file mode 100644 index 0000000..ba9cdea --- /dev/null +++ b/localwiki/Std_Axis.svg @@ -0,0 +1,225 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [wmayer] + + + Sketcher_Sketch + 2011-10-10 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Sketcher/Gui/Resources/icons/Sketcher_Sketch.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Std_BoxSelection.html b/localwiki/Std_BoxSelection.html new file mode 100644 index 0000000..c963d55 --- /dev/null +++ b/localwiki/Std_BoxSelection.html @@ -0,0 +1,75 @@ +Std BoxSelection

      Std BoxSelection

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Std BoxSelection.png Std BoxSelection

      +
      Menu location +
      Edit → Box Selection +
      Workbenches +
      All +
      Default shortcut +
      Maiusc+B +
      See also +
      Fit Selection +

      + +
      +


      +

      +

      Description

      +

      Allows you to select objects in the 3D view by dragging a box. +

      +

      Use

      +

      Choose EditStd BoxSelection.png Box selection from the top menu.
      +Dragging the box from left to right will only select the objects completely inside the box.
      +Dragging the box from right to left will also select objects touching or crossing the border of the box. +

      +

      Limitations

      +


      +

      +

      Notes

      +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Std_ClippingPlane.html b/localwiki/Std_ClippingPlane.html new file mode 100644 index 0000000..58bd7af --- /dev/null +++ b/localwiki/Std_ClippingPlane.html @@ -0,0 +1,106 @@ +Std ClippingPlane

      Std ClippingPlane

      + +


      +


      +

      + + + + + + + + + + + + + + + + + + + + +
      +

      Std ClippingPlane.png Std ClippingPlane

      +
      Menu location +
      View → Clipping plane‏‎ +
      Workbenches +
      All +
      Default shortcut +
      +
      See also +
      +

      + +
      +


      +


      +A clipping plane is a plane that divides the object space in two half spaces. All object parts in one half space are visible, parts in the other half space are invisible. The objects look like sliced and interiour details become visible. The clipping plane is activated by the ViewClipping plane menu. +


      +

      +

      Show non hollow solid

      +

      Solids are shown hollow if Clipping Plane is activated. +To show a non hollow solid a work around could be used. Change the Lighting of the solids View Object from Two Side to One Side and the inne part of the solid will be totally black. +

      Another possibility would be to leave the Lightning Two Sided and change the color of the inner solid by activating Menue Edit --> Preferences --> Display Enable backlight color. But with this the shading effect will be still there. +See Forum Thread http://forum.freecadweb.org/viewtopic.php?f=3&t=4371&start=20#p94850 +


      +

      ToDoFreeCAD 0.13 version and latest +

      +

      Set a standard plane

      +
      piani standard
      +

      Option

      +
      • Offset: Offset
      • +
      • Flip: reverses the view direction
      +
      +

      Set a definite plane

      +
      piano personalizzato
      +
      +


      +

      +
      Obsolete Version +


      +Selezione dell'oggetto +Commutare la posizione del piano +Scalare il piano +Spostare il piano +Separare il piano dall'oggetto
      +Verificare la posizione dell'oggetto +

      +
      +


      +


      +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Std_ClippingPlane.png b/localwiki/Std_ClippingPlane.png new file mode 100644 index 0000000..782eb4d Binary files /dev/null and b/localwiki/Std_ClippingPlane.png differ diff --git a/localwiki/Std_Close.html b/localwiki/Std_Close.html new file mode 100644 index 0000000..7a132fe --- /dev/null +++ b/localwiki/Std_Close.html @@ -0,0 +1,60 @@ +Std Close

      Std Close

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Std Close.png Std Close

      +
      Menu location +
      File → Close +
      Workbenches +
      All +
      Default shortcut +
      Ctrl+W +
      See also +
      CloseAll +

      Contents

      + +
      + +
      +


      +


      +Closes the current document +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Std_Close.png b/localwiki/Std_Close.png new file mode 100644 index 0000000..782eb4d Binary files /dev/null and b/localwiki/Std_Close.png differ diff --git a/localwiki/Std_CloseAll.html b/localwiki/Std_CloseAll.html new file mode 100644 index 0000000..6357a85 --- /dev/null +++ b/localwiki/Std_CloseAll.html @@ -0,0 +1,74 @@ +Std CloseAll

      Std CloseAll

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Std CloseAll.png Std_CloseAll

      +
      Menu location +
      File → Close All +
      Workbenches +
      All +
      Default shortcut +
      ... +
      See also +
      Close, Save As... e Save +

      + +
      +


      +

      +

      Description

      +

      Closes all open documents. +

      +

      Use

      +

      Choose File Close All from the top menu. +

      +

      Limitations

      +


      +

      +

      Notes

      +


      +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Std_CloseAll.png b/localwiki/Std_CloseAll.png new file mode 100644 index 0000000..782eb4d Binary files /dev/null and b/localwiki/Std_CloseAll.png differ diff --git a/localwiki/Std_CommandLine.html b/localwiki/Std_CommandLine.html new file mode 100644 index 0000000..b67bca8 --- /dev/null +++ b/localwiki/Std_CommandLine.html @@ -0,0 +1,80 @@ +Std CommandLine

      Std CommandLine

      + +
      +

      This documentation is not finished. Please help and contribute documentation. +

      See Draft ShapeString for good documented Command. Gui Command gives an overview over commands. And see List of Commands for other commands. +

      Go to Help FreeCAD to contribute. +

      +
      +


      +

      + + + + + + + + + + + + + + + + + + + + +
      +

      Std CommandLine.png Std CommandLine

      +
      Menu location +
      +
      Workbenches +
      +
      Default shortcut +
      None +
      See also +
      Start up and Configuration +

      + +
      +


      +

      +

      Description

      +

      ToDo +

      +

      Starting FreeCAD from the Command line

      +

      FreeCAD can be started normally, by double-clicking on its desktop icon or selecting it from the start menu, but it can also be started directly from the command line. +

      +

      Start up and Configuration

      +

      See Start up and Configuration +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Std_Copy.html b/localwiki/Std_Copy.html new file mode 100644 index 0000000..2210059 --- /dev/null +++ b/localwiki/Std_Copy.html @@ -0,0 +1,70 @@ +Std Copy

      Std Copy

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Std Copy.png Std Copy

      +
      Menu location +
      Edit → Copy +
      Workbenches +
      All +
      Default shortcut +
      Ctrl+C +
      See also +
      Paste, Duplicate Selection +

      + +
      +


      +

      +

      Description

      +

      The Copy command is involved in replicating Document objects. It places the currently selected objects into the "clipboard" for later use by the Paste command. Objects may be copied between Documents. +

      +

      How to use

      +
      1. Select the Object(s) to be replicated.
      2. +
      3. Press the Copy icon, ctrl + C keys or use menu choices Edit → Copy.
      +

      Limitations

      +
      • In general, it is not possible to copy FreeCAD objects into other applications, or copy objects from other applications into a FreeCAD document.
      +

      More

      + +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Std_Cut.html b/localwiki/Std_Cut.html new file mode 100644 index 0000000..afb53f1 --- /dev/null +++ b/localwiki/Std_Cut.html @@ -0,0 +1,67 @@ +Std Cut

      Std Cut

      + +
      +

      This documentation is not finished. Please help and contribute documentation. +

      See Draft ShapeString for good documented Command. Gui Command gives an overview over commands. And see List of Commands for other commands. +

      Go to Help FreeCAD to contribute. +

      +
      +


      +

      + + + + + + + + + + + + + + + + + + + + +
      +

      Std Cut.png Std Cut

      +
      Menu location +
      Edit → Cut +
      Workbenches +
      All +
      Default shortcut +
      Ctrl+X +
      See also +
      Copy, Paste, Delete +

      Contents

      + +
      + +
      +


      +


      +ToDo. +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Std_DebugInto.html b/localwiki/Std_DebugInto.html new file mode 100644 index 0000000..9e91bf2 --- /dev/null +++ b/localwiki/Std_DebugInto.html @@ -0,0 +1,66 @@ +Std DebugInto

      Std DebugInto

      + +
      +

      This documentation is not finished. Please help and contribute documentation. +

      See Draft ShapeString for good documented Command. Gui Command gives an overview over commands. And see List of Commands for other commands. +

      Go to Help FreeCAD to contribute. +

      +
      +


      +

      + + + + + + + + + + + + + + + + + + + + +
      +

      Std DebugInto.png Std DebugInto

      +
      Menu location +
      Macro → Step into +
      Workbenches +
      All +
      Default shortcut +
      F11 +
      See also +
      +

      Contents

      + +
      + +
      +


      +

      ToDo. +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Std_DebugMacro.html b/localwiki/Std_DebugMacro.html new file mode 100644 index 0000000..43c3ede --- /dev/null +++ b/localwiki/Std_DebugMacro.html @@ -0,0 +1,66 @@ +Std DebugMacro

      Std DebugMacro

      + +
      +

      This documentation is not finished. Please help and contribute documentation. +

      See Draft ShapeString for good documented Command. Gui Command gives an overview over commands. And see List of Commands for other commands. +

      Go to Help FreeCAD to contribute. +

      +
      +


      +

      + + + + + + + + + + + + + + + + + + + + +
      +

      Std DebugMacro.png Std DebugMacro

      +
      Menu location +
      Macro → Debug Macro +
      Workbenches +
      All +
      Default shortcut +
      F6 +
      See also +
      +

      Contents

      + +
      + +
      +


      +

      ToDo. +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Std_DebugOver.html b/localwiki/Std_DebugOver.html new file mode 100644 index 0000000..c6c9065 --- /dev/null +++ b/localwiki/Std_DebugOver.html @@ -0,0 +1,67 @@ +Std DebugOver

      Std DebugOver

      + +
      +

      This documentation is not finished. Please help and contribute documentation. +

      See Draft ShapeString for good documented Command. Gui Command gives an overview over commands. And see List of Commands for other commands. +

      Go to Help FreeCAD to contribute. +

      +
      +


      +

      + + + + + + + + + + + + + + + + + + + + +
      +

      Std DebugOver.png Std DebugOver

      +
      Menu location +
      Macro → Debug Over +
      Workbenches +
      All +
      Default shortcut +
      F10 +
      See also +
      +

      Contents

      + +
      + +
      +


      +


      +ToDo. +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Std_DebugStop.html b/localwiki/Std_DebugStop.html new file mode 100644 index 0000000..0b551a7 --- /dev/null +++ b/localwiki/Std_DebugStop.html @@ -0,0 +1,66 @@ +Std DebugStop

      Std DebugStop

      + +
      +

      This documentation is not finished. Please help and contribute documentation. +

      See Draft ShapeString for good documented Command. Gui Command gives an overview over commands. And see List of Commands for other commands. +

      Go to Help FreeCAD to contribute. +

      +
      +


      +

      + + + + + + + + + + + + + + + + + + + + +
      +

      Std DebugStop.png Std DebugStop

      +
      Menu location +
      Macro → Debug Stop +
      Workbenches +
      All +
      Default shortcut +
      Maiusc+F6 +
      See also +
      +

      Contents

      + +
      + +
      +


      +

      ToDo. +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Std_DebugToggle.html b/localwiki/Std_DebugToggle.html new file mode 100644 index 0000000..38a7b0f --- /dev/null +++ b/localwiki/Std_DebugToggle.html @@ -0,0 +1,66 @@ +Std DebugToggle

      Std DebugToggle

      + +
      +

      This documentation is not finished. Please help and contribute documentation. +

      See Draft ShapeString for good documented Command. Gui Command gives an overview over commands. And see List of Commands for other commands. +

      Go to Help FreeCAD to contribute. +

      +
      +


      +

      + + + + + + + + + + + + + + + + + + + + +
      +

      Std DebugToggle.png Std DebugToggle

      +
      Menu location +
      Macro → Toggle breakpoint +
      Workbenches +
      All +
      Default shortcut +
      F9 +
      See also +
      +

      Contents

      + +
      + +
      +


      +

      ToDo. +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Std_Delete.html b/localwiki/Std_Delete.html new file mode 100644 index 0000000..096b8fa --- /dev/null +++ b/localwiki/Std_Delete.html @@ -0,0 +1,59 @@ +Std Delete

      Std Delete

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Std Delete.png Std Delete

      +
      Menu location +
      Edit → Delete +
      Workbenches +
      All +
      Default shortcut +
      None +
      See also +
      None +

      Contents

      + +
      + +
      +


      +

      This command deletes the selected object(s). If no object is selected, nothing is done. +

      Selected object(s) can be deleted from the document by pressing DEL, from the menu item Edit → Delete, or from the Tree View context menu. All Delete operations can be undone and redone. +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Std_DependencyGraph.html b/localwiki/Std_DependencyGraph.html new file mode 100644 index 0000000..207bfd4 --- /dev/null +++ b/localwiki/Std_DependencyGraph.html @@ -0,0 +1,124 @@ +Std DependencyGraph

      Std DependencyGraph

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Std DependencyGraph.png Std DependencyGraph

      +
      Menu location +
      Tools → Dependency graph... +
      Workbenches +
      All +
      Default shortcut +
      None +
      See also +
      +

      + +
      +


      +


      +

      +

      Description

      +

      The Dependency graph displays the dependencies between objects in the active document as a graph. As opposed to the Model tree, objects are listed in reverse chronological order, with the first created object at the bottom. +

      It can be useful in analyzing a FreeCAD document and locating forks in a tree. The dependency graph layout will depend on which workbench was used to create the objects in the document. For example, in FreeCAD 0.16, a model exclusively made in the PartDesign workbench should display a linear dependency graph with a single vertical branch. A model made with Part operations will have many branches, but for a single part they will join up at the top after Boolean operations. If they don't, it means that they are separate objects. +

      The dependency graph is purely a visualization tool, therefore it cannot be edited; it automatically updates if changes are made to the model. +

      DependencyGraph1.png +

      +
      +


      +

      +

      Installation

      +

      To use the Dependency graph, a third-party software named Graphviz needs to be installed first. If you do not have it pre-installed or it is installed in an unconventional location, FreeCAD will display the following dialogue: +

      +
      FreeCAD-0.17-missing-Graphviz-error-dialogue.png
      +

      Windows

      +

      Download the graphviz-2.xx.msi installer from the Graphviz Download page and launch it to install it. +

      +

      Mac/OSX

      +

      You can install graphviz using Homebrew: +

      +
      $ brew install graphviz 
      +

      This installs the graphviz binaries under /usr/local/bin. Unfortunately we can't navigate directly there from the file dialog that comes up from FreeCAD->Tools->Dependency graph. +When you get the file selection dialog use the keys Cmd+Shift+G to get an input field for the path. Enter +

      +
      /usr/local/bin 
      +

      and confirm the input field and the file selection dialog. +

      In case the Graphviz binaries are installed in a non-standard location try to find the program with the command +

      +
      $ type dot 
      +

      It will output something like +

      +
      dot is /usr/local/bin/dot 
      +

      And therefore you can tell FreeCAD to look in that directory. +

      +

      Linux

      +

      On most Linux distributions (Debian/Ubuntu, Fedora, OpenSUSE), you just need to install the graphviz package from the repositories. However, similarly to MacOSX, in cases where the Graphviz binaries are installed in a non-standard location, try to find the program with the command: +

      +
      $ type dot 
      +

      It may output something like +

      +
      dot is /usr/local/bin/dot 
      +

      And therefore you can point FreeCAD to look in that directory. +

      +

      Configuration

      +

      You shouldn't need any configuration of FreeCAD preferences. If FreeCAD cannot find the utility "dot" (from the Graphviz package) then a dialog comes up and asks the user for its path: set the path to the folder that contains the "dot" executable, do not select the executable itself. FreeCAD then tries to start the utility again and in case it succeeds the value is written automatically to the user parameters. +

      +

      How to use

      +
      1. Go to the Tools → Dependency graph... menu
      2. +
      3. A new tab titled Dependency graph opens over the main area of the FreeCAD window.
      4. +
      5. Use the mouse scroll wheel to zoom in / zoom out.
      6. +
      7. Use the horizontal slider at the bottom of the screen to pan the view sideways.
      +

      Save/Export

      +

      You can save/export the displayed dependency graph as an image file. While the Dependency graph tab is in the foreground: +

      +
      • Just choose FileSave As to save the graph as a picture (PNG/BMP/GIF/JPG), a vector graphic (SVG) or as a pdf-file (PDF).
      • +
      • FileExport or ToolsSave picture will NOT work.
      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Std_DependencyGraph.png b/localwiki/Std_DependencyGraph.png new file mode 100644 index 0000000..782eb4d Binary files /dev/null and b/localwiki/Std_DependencyGraph.png differ diff --git a/localwiki/Std_DlgMacroExecute.html b/localwiki/Std_DlgMacroExecute.html new file mode 100644 index 0000000..cdf2ea8 --- /dev/null +++ b/localwiki/Std_DlgMacroExecute.html @@ -0,0 +1,66 @@ +Std DlgMacroExecute

      Std DlgMacroExecute

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Std DlgMacroExecute.png Std DlgMacroExecute

      +
      Menu location +
      Macros → Execute macro +
      Workbenches +
      All +
      Default shortcut +
      CTRL+F6 +
      See also +
      Execute Direct +

      + +
      +


      +

      +

      Description

      +

      This function executes the macro selected or active in the editor. It is accessible via Macro → Execute macro, or via Std DlgMacroExecute.png Execute macro button in the macro toolbar Macros toolbar.jpg. +

      +

      Utilization

      +

      When you enter in Std DlgMacroExecuteDirect.png Macros..., the button Std DlgMacroExecute.png Execute macro turn green Menu Std DlgMacroExecute fr 02.png. Click this button to run the macro. +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Std_DlgMacroExecuteDirect.html b/localwiki/Std_DlgMacroExecuteDirect.html new file mode 100644 index 0000000..85c4cf4 --- /dev/null +++ b/localwiki/Std_DlgMacroExecuteDirect.html @@ -0,0 +1,67 @@ +Std DlgMacroExecuteDirect

      Std DlgMacroExecuteDirect

      + +
      +

      This documentation is not finished. Please help and contribute documentation. +

      See Draft ShapeString for good documented Command. Gui Command gives an overview over commands. And see List of Commands for other commands. +

      Go to Help FreeCAD to contribute. +

      +
      +


      +

      + + + + + + + + + + + + + + + + + + + + +
      +

      Std DlgMacroExecuteDirect.png Std DlgMacroExecuteDirect

      +
      Menu location +
      Macro → Execute macro +
      Workbenches +
      All +
      Default shortcut +
      Ctrl+F6 +
      See also +
      +

      + +
      +


      +


      +

      ToDo +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Std_DlgMacroExecuteDirect.svg b/localwiki/Std_DlgMacroExecuteDirect.svg new file mode 100644 index 0000000..bd7db3b --- /dev/null +++ b/localwiki/Std_DlgMacroExecuteDirect.svg @@ -0,0 +1,88 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Std_DlgMacroRecord.html b/localwiki/Std_DlgMacroRecord.html new file mode 100644 index 0000000..c8c1ff2 --- /dev/null +++ b/localwiki/Std_DlgMacroRecord.html @@ -0,0 +1,86 @@ +Std DlgMacroRecord

      Std DlgMacroRecord

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Std DlgMacroRecord.png Std DlgMacroRecord

      +
      Menu location +
      Macro → Macro recording ... +
      Workbenches +
      All +
      Default shortcut +
      None +
      See also +
      Execute macro +

      + +
      +


      +

      +

      Description

      +

      This function records a macro, all operations you made in 3D space. +

      It is accessible via Macro → Macro recording ..., or via Std DlgMacroRecord.png Macro recording button in the macro toolbar Macros toolbar.jpg. +

      +

      Utilization

      +

      Start the function with one of these methods before. The following window appears: +

      + + + +
      Macro recording + +
      • Macro name : Enter the name of the new macro.
      • +
      • Macro path : Path macro library. To change the path, click ... .
      • +
      • Record : Record the macro. Starts recording of everything that is done later.
        The button Std DlgMacroStop.png Stop the macro recording session in the macros toolbar Macros toolbar.jpg turn green Std DlgMacroStop 02.png.
      • +
      • Stop : Stop recording the macro.
      • +
      • Cancel : Cancels and closes the window.
      +
      +


      +Once completed click Std DlgMacroStop 02.png Stop the macro recording session to stop recording the macro. +

      The macro can be called through Macro → Macros..., or with the Std DlgMacroExecuteDirect.png Execute this macro button in the macro toolbar to be executed or modified as you want +

      +

      Example

      +

      Click the button Std DlgMacroRecord.png enter a name for the macro and validate, open a document, create a cube, change the color stop the macro with the button Std DlgMacroStop 02.png. +

      The macro is available in your macros directory. +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Std_DlgMacroStop.html b/localwiki/Std_DlgMacroStop.html new file mode 100644 index 0000000..8bafe5f --- /dev/null +++ b/localwiki/Std_DlgMacroStop.html @@ -0,0 +1,68 @@ +Std DlgMacroStop

      Std DlgMacroStop

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Std DlgMacroStop.png Std DlgMacroStop

      +
      Menu location +
      Macro → Macro Stop +
      Workbenches +
      All +
      Default shortcut +
      None +
      See also +
      ... +

      + +
      +


      +

      +

      Description

      +

      This function stops recording a macro. It is accessible via Macro → Macro Stop, or by clicking the Std DlgMacroStop.png Stop the macro recording session in the macros toolbar Macros toolbar.jpg. +

      +

      Utilization

      +

      When you start a Std DlgMacroRecord.png Recording the macro button Std DlgMacroStop.png Stop the macro recording session in the macros toolbar turn green 20px‎. +

      Click on Std DlgMacroStop 02.png green square, to stop recording. The macro file is closed and automatically saved to disk in the expected location. +

      The macro can be called through Macro → Macros..., or with the Std DlgMacroExecuteDirect.png Execute this macro button in the macro toolbar to be executed or modified as you want +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Std_DlgMacroStop_02.png b/localwiki/Std_DlgMacroStop_02.png new file mode 100644 index 0000000..c139a65 Binary files /dev/null and b/localwiki/Std_DlgMacroStop_02.png differ diff --git a/localwiki/Std_DlgParameter.html b/localwiki/Std_DlgParameter.html new file mode 100644 index 0000000..9e1abf3 --- /dev/null +++ b/localwiki/Std_DlgParameter.html @@ -0,0 +1,74 @@ +Std DlgParameter

      Std DlgParameter

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Std DlgParameter.png Std DlgParameter

      +
      Menu location +
      Tools → Parameter +
      Workbenches +
      All +
      Default shortcut +
      +
      See also +
      +

      + +
      +


      +

      +

      Description

      +

      Allows you to access and alter parameters/preferences of the different functions and workbenches. +

      +

      Use

      +

      Choose Tools Edit parameters... from the top menu. +

      Parameter Editor.jpg +

      +

      Limitations

      +


      +

      +

      Notes

      +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Std_DlgParameter.svg b/localwiki/Std_DlgParameter.svg new file mode 100644 index 0000000..a6183e8 --- /dev/null +++ b/localwiki/Std_DlgParameter.svg @@ -0,0 +1,396 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + Jakub Steiner + + + http://jimmac.musichall.cz + + Preferences System + + + preferences + settings + control panel + tweaks + system + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Std_DlgPreferences.html b/localwiki/Std_DlgPreferences.html new file mode 100644 index 0000000..a08509f --- /dev/null +++ b/localwiki/Std_DlgPreferences.html @@ -0,0 +1,74 @@ +Std DlgPreferences

      Std DlgPreferences

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Std DlgPreferences.png Std DlgPreferences

      +
      Menu location +
      Edit → Preferences +
      Workbenches +
      All +
      Default shortcut +
      +
      See also +
      +

      + +
      +


      +

      +

      Description

      +

      Allows you to change preferences of the different workbenches. +

      +

      Use

      +

      Choose Edit Preferences from the top menu. +

      DlgPreferences.jpg +

      +

      Limitations

      +

      Some workbench-preferences can only be accessed when the specific workbench has been used at least once.
      +

      +

      Notes

      +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Std_DuplicateSelection.html b/localwiki/Std_DuplicateSelection.html new file mode 100644 index 0000000..5159452 --- /dev/null +++ b/localwiki/Std_DuplicateSelection.html @@ -0,0 +1,70 @@ +Std DuplicateSelection

      Std DuplicateSelection

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Std DuplicateSelection.png Std DuplicateSelection

      +
      Menu location +
      Edit → Copy +
      Workbenches +
      All +
      Default shortcut +
      +
      See also +
      Copy, Paste +

      + +
      +


      +

      +

      Description

      +

      The Duplicate Selection command is a short-cut for the Copy+Paste commands. It creates replicas of the currently selected objects into the current document. +

      +

      How to use

      +
      1. Select the objects to be duplicated.
      2. +
      3. Use menu choice Edit → Duplicate Selection.
      +

      Limitations

      +

      More

      + +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Std_Edit.html b/localwiki/Std_Edit.html new file mode 100644 index 0000000..bfc32a8 --- /dev/null +++ b/localwiki/Std_Edit.html @@ -0,0 +1,83 @@ +Std Edit

      Std Edit

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Std Edit.png Std Edit

      +
      Menu location +
      Edit → Toggle Editmode +
      Workbenches +
      All +
      Default shortcut +
      None +
      See also +
      ... +

      Contents

      + +
      + +
      +


      +


      +

      +

      Synopsis

      +

      This command allows to enter or leave the edit mode of a selected object. An object +must be either selected (then it enters edit mode) or in edit mode (then it leaves edit mode) +for this command to work. +

      The behaviour that occurs when entering edit mode depends on the object type. Some object types +don't define any edit mode behaviour, in that case the standard behaviour (a transform widget) +is used. +

      You can also perform the same action by double-clicking an object in the Tree View. +

      +

      Scripting

      +

      This enters edit mode of a determined object: +

      +
      FreeCADGui.ActiveDocument.setEdit("myObjectName",0)
      +
      +

      This closes the edit mode: +

      +
      FreeCADGui.ActiveDocument.resetEdit()
      +
      +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Std_Edit.svg b/localwiki/Std_Edit.svg new file mode 100644 index 0000000..77cb3ce --- /dev/null +++ b/localwiki/Std_Edit.svg @@ -0,0 +1,213 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Std_Edit_Menu.html b/localwiki/Std_Edit_Menu.html new file mode 100644 index 0000000..9f18743 --- /dev/null +++ b/localwiki/Std_Edit_Menu.html @@ -0,0 +1,34 @@ +Std Edit Menu

      Std Edit Menu

      + +

      Edit +


      +Std Undo.png Undo reverses the last command. +

      Std Redo.png Redo reapplies the last command reversed by Undo. +

      Std Cut.png Cut places selected objects onto the clipboard and deletes them. +

      Std Copy.png Copy places selected objects onto the clipboard. +

      Std Paste.png Paste moves the contents of the clipboard to the current document. +

      Std DuplicateSelection.png Duplicate Selection is a shortcut for Copy + Paste. +

      Std Refresh.png Refresh redraws the display. +

      Std BoxSelection.png Box Selection allows selecting all objects in a rectangular area. +

      Std SelectAll.png Select All selects all objects in the current document. +

      Std Delete.png Delete deletes the current selection. +

      Placement... opens the Placement dialog for the selected object. +

      Alignment... opens the Alignment dialog for the selected objects. +

      Std Edit.png Toggle Edit Mode turns Edit Mode on or off for the selected objects. +

      Std DlgPreferences.png Preferences opens the user Preferences dialog. +

      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Std_Exit.html b/localwiki/Std_Exit.html new file mode 100644 index 0000000..605a895 --- /dev/null +++ b/localwiki/Std_Exit.html @@ -0,0 +1,75 @@ +Std Exit

      Std Exit

      + +


      +

      + + + + + + + + + + + + + + + + + + + + +
      +

      Std Exit.png Std Exit

      +
      Menu location +
      File → Exit +
      Workbenches +
      All +
      Default shortcut +
      Alt+F4 +
      See also +
      Std Open,Std Import +

      + +
      +


      +

      +

      Description

      +

      Closes the FreeCAD application. +

      +

      Use

      +

      Choose FileStd Exit.png Exit from the top menu. +

      +

      Limitations

      +


      +

      +

      Notes

      +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Std_Exit.png b/localwiki/Std_Exit.png new file mode 100644 index 0000000..290cc4e Binary files /dev/null and b/localwiki/Std_Exit.png differ diff --git a/localwiki/Std_Export.html b/localwiki/Std_Export.html new file mode 100644 index 0000000..8c93bf1 --- /dev/null +++ b/localwiki/Std_Export.html @@ -0,0 +1,66 @@ +Std Export

      Std Export

      + +
      +

      This documentation is not finished. Please help and contribute documentation. +

      See Draft ShapeString for good documented Command. Gui Command gives an overview over commands. And see List of Commands for other commands. +

      Go to Help FreeCAD to contribute. +

      +
      +


      +

      + + + + + + + + + + + + + + + + + + + + +
      +

      Std Export.png Std Export

      +
      Menu location +
      File → Export +
      Workbenches +
      All +
      Default shortcut +
      Ctrl+E +
      See also +
      Import +

      Contents

      + +
      + +
      +


      +

      ToDo. +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Std_File_Menu.html b/localwiki/Std_File_Menu.html new file mode 100644 index 0000000..f605d97 --- /dev/null +++ b/localwiki/Std_File_Menu.html @@ -0,0 +1,37 @@ +Std File Menu

      Std File Menu

      + +


      +File +

      New creates a new FreeCAD document. +

      Open opens an existing FreeCAD document file. +

      Close closes the current document. +

      Close All closes all open documents. +

      Save write the current document to disk. +

      Save As writes the current document to disk under a new name. +

      Save a Copy v 0.16 +

      Revert v 0.16 +

      Import reads a file from another application into the current document. +

      Export writes the current document to a file for use in another application. +

      Merge project adds the objects in a FreeCAD file to the current document. +

      Project Information add/update project metadata - author, revision date, etc. +

      Print prints the contents of the current document window. +

      Print Preview displays a print image of the current document window on screen. +

      Export PDF writes the current document window to a PDF file. +

      Recent Files is a short cut for opening a recently used document file. +

      Exit shuts down FreeCAD. +

      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Std_FreeCADWebsite.html b/localwiki/Std_FreeCADWebsite.html new file mode 100644 index 0000000..cc8e340 --- /dev/null +++ b/localwiki/Std_FreeCADWebsite.html @@ -0,0 +1,67 @@ +Std FreeCADWebsite

      Std FreeCADWebsite

      + +
      +

      This documentation is not finished. Please help and contribute documentation. +

      See Draft ShapeString for good documented Command. Gui Command gives an overview over commands. And see List of Commands for other commands. +

      Go to Help FreeCAD to contribute. +

      +
      +


      +

      + + + + + + + + + + + + + + + + + + + + +
      +

      Std FreeCADWebsite.png Std FreeCADWebsite

      +
      Menu location +
      Help → FreeCADWebsite‏‎ +
      Workbenches +
      All +
      Default shortcut +
      +
      See also +
      +

      Contents

      + +
      + +
      +


      +


      +ToDo +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Std_FreezeViews.html b/localwiki/Std_FreezeViews.html new file mode 100644 index 0000000..85dedbe --- /dev/null +++ b/localwiki/Std_FreezeViews.html @@ -0,0 +1,67 @@ +Std FreezeViews

      Std FreezeViews

      + +
      +

      This documentation is not finished. Please help and contribute documentation. +

      See Draft ShapeString for good documented Command. Gui Command gives an overview over commands. And see List of Commands for other commands. +

      Go to Help FreeCAD to contribute. +

      +
      +


      +

      + + + + + + + + + + + + + + + + + + + + +
      +

      Std FreezeViews.png Std FreezeViews

      +
      Menu location +
      View → Freeze display‏‎ +
      Workbenches +
      All +
      Default shortcut +
      +
      See also +
      +

      Contents

      + +
      + +
      +


      +


      +ToDo +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Std_Group.html b/localwiki/Std_Group.html new file mode 100644 index 0000000..e418200 --- /dev/null +++ b/localwiki/Std_Group.html @@ -0,0 +1,110 @@ +Std Group

      Std Group

      + +


      +

      + + + + + + + + + + + + + + + + + + + + +
      +

      Std Group.png Std Group

      +
      Menu location +
      Tree View → Right click on the document name +
      Workbenches +
      All +
      Default shortcut +
      +
      See also +
      Draft SelectGroup, Draft AddToGroup +

      + +
      +


      +

      +

      Description

      +

      This command lets you create a group in the tree view. +
      +It can be used for organizing the structure of your model. +

      +

      Use

      +

      Right-click on the name of your FreeCAD-document in the tree-view and choose "create group". +
      +A group will be created automatically and give the icon of a directory and an automatically chosen name. +
      +You can rename the group by right-clicking on the group and choosing "rename" or using "F2" on your keyboard. +
      +Push FreeCAD-objects into the group or pull them out of the group by clicking on the desired object, +
      +keep left-mouse button pressed and using drag&drop-style to drag the object to desired new location. +
      +As long as there is a "circle with a diagonal line"-sign below the cursor you can't drop your object here. +
      +As soon as the sign changes to a "plus"-symbol it is possible to drop your object here. +
      +

      +
      1. Right click on active document or on existing group in the Tree View and select Create Group...
      2. +
      3. Drag-n-drop objects into the group
      +


      +Group with objects.png +

      +

      Options

      +
      • To rename the group select a group and press F2, or right click a group and select Rename
      +

      Properties

      +
      • DATALabel: Name of the group
      +

      Scripting

      +

      Following command adds new group to the active document: +

      +
      App.ActiveDocument.addObject("App::DocumentObjectGroup","Group") 
      +

      Limitations

      +

      Command needs an open FreeCAD-document to work. +

      +

      Links

      + +

      Notes

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Std_Help.html b/localwiki/Std_Help.html new file mode 100644 index 0000000..6190980 --- /dev/null +++ b/localwiki/Std_Help.html @@ -0,0 +1,83 @@ +Std Help

      Std Help

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Std Help.png Std Help

      +
      Menu location +
      Help → Help‏‎ +
      Workbenches +
      All +
      Default shortcut +
      F1 +
      See also +
      +

      + +
      +


      +

      +

      Description

      +

      Access help on various aspects of the program. +

      +

      Use

      +

      Choose Help from the top menu.
      +You may get more information about:
      +

      +
      • Help: Opens the offline help-file (only available with stable release)
      • +
      • FreeCAD Website: Opens the FreeCAD-Website in your standard browser application
      • +
      • Users documentation: Opens the user hub on the FreeCAD-wiki in your standard browser application
      • +
      • Python scripting documentation: Opens the power users hub on the FreeCAD-wiki in your standard browser application
      • +
      • Automatic python modules documentaton: Opens the python-index of modules in your standard browser application
      • +
      • FreeCAD forum: Opens the freecad forum in your standard browser application
      • +
      • FreeCAD FAQ: Opens the FreeCAD-FAQ-page in your standard browser application
      • +
      • About FreeCAD: Opens a window displaying information about your FreeCAD-version
      • +
      • What's this: allows you to get an instant tool tip on specific FreeCAD functions
      +

      Limitations

      +


      +

      +

      Notes

      +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Std_Help_Menu.html b/localwiki/Std_Help_Menu.html new file mode 100644 index 0000000..c42125a --- /dev/null +++ b/localwiki/Std_Help_Menu.html @@ -0,0 +1,31 @@ +Std Help Menu

      Std Help Menu

      + + + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Std_Import.html b/localwiki/Std_Import.html new file mode 100644 index 0000000..3329702 --- /dev/null +++ b/localwiki/Std_Import.html @@ -0,0 +1,61 @@ +Std Import

      Std Import

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Std Import.png Std Import

      +
      Menu location +
      File → Import +
      Workbenches +
      All +
      Default shortcut +
      CTRL+I +
      See also +
      Std Open... +

      Contents

      + +
      + +
      +


      +

      Adds the content of a file from another application to the current document. A number of file formats are supported: *.IGES, *.STEP, *.BREP, *.STL, *.OBJ, *.PLY, etc. +

      When loading, the file is added to the current (already open) project. If you want to load a new file in a new window, use the Open command. +

      FreeCAD Project files have the extension "FCStd". For more information on the internal structure of FreeCAD project files, read the FCStd file format article. +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Std_Macro_Menu.html b/localwiki/Std_Macro_Menu.html new file mode 100644 index 0000000..d66e4d6 --- /dev/null +++ b/localwiki/Std_Macro_Menu.html @@ -0,0 +1,30 @@ +Std Macro Menu

      Std Macro Menu

      + +

      Macro +


      +Macro recording opens a dialog for recording a new macro. +

      Stop macro recording ends the current macro recording session. +

      Macros... select and execute a stored macro. +

      Execute macro executes the macro currently in the macro editor. +

      Debug macro starts debug session for the macro currently in the macro editor. +

      Stop debugging ends the debugging session. +

      Step over +

      Step into +

      Toggle breakpoint +


      +

      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Std_MeasureAngular.html b/localwiki/Std_MeasureAngular.html new file mode 100644 index 0000000..5d55a7b --- /dev/null +++ b/localwiki/Std_MeasureAngular.html @@ -0,0 +1,70 @@ +Std MeasureAngular

      Std MeasureAngular

      + +
      +

      This documentation is not finished. Please help and contribute documentation. +

      See Draft ShapeString for good documented Command. Gui Command gives an overview over commands. And see List of Commands for other commands. +

      Go to Help FreeCAD to contribute. +

      +
      +


      +

      + + + + + + + + + + + + + + + + + + + + +
      +

      Std MeasureAngular.png Std MeasureAngular

      +
      Menu location +
      Measure → Measure Angular‏‎ +
      Workbenches +
      Part +
      Default shortcut +
      +
      See also +
      +

      + +
      +


      +


      +

      +

      Measure Angular

      +

      MeasureAngular1.PNG +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Std_MeasureClearAll.html b/localwiki/Std_MeasureClearAll.html new file mode 100644 index 0000000..fa417f5 --- /dev/null +++ b/localwiki/Std_MeasureClearAll.html @@ -0,0 +1,67 @@ +Std MeasureClearAll

      Std MeasureClearAll

      + +
      +

      This documentation is not finished. Please help and contribute documentation. +

      See Draft ShapeString for good documented Command. Gui Command gives an overview over commands. And see List of Commands for other commands. +

      Go to Help FreeCAD to contribute. +

      +
      +


      +

      + + + + + + + + + + + + + + + + + + + + +
      +

      Std MeasureClearAll.png Std MeasureClearAll

      +
      Menu location +
      Measure → Clear All‎ +
      Workbenches +
      Part +
      Default shortcut +
      +
      See also +
      +

      Contents

      + +
      + +
      +


      +


      +ToDo +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Std_MeasureDistance.html b/localwiki/Std_MeasureDistance.html new file mode 100644 index 0000000..b516c3b --- /dev/null +++ b/localwiki/Std_MeasureDistance.html @@ -0,0 +1,83 @@ +Std MeasureDistance

      Std MeasureDistance

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Std MeasureDistance.png Std MeasureDistance

      +
      Menu location +
      View → Measure distance‏‎ +
      Workbenches +
      All +
      Default shortcut +
      +
      See also +
      +

      + +
      +


      +

      +

      Introduction

      +

      This tool measures and displays the absolute distance between two points in 3D space. +

      +

      Use

      +
      1. Click on Std MeasureDistance.png or choose ToolsStd MeasureDistance.png Measure Distance from the top menu.
      2. +
      3. Select first point in 3D view.
      4. +
      5. Select second point in 3D view.
      6. +
      7. The absolute distance between the two points will be calculated and displayed in the 3D view.
      8. +
      9. A distance object will be created in the tree view.
      +

      Limitations

      +

      The tool lets you only select points by clicking in the 3D view. +You can't use the snap tools from the draft workbench to allow specific selecting of special points. +

      +

      Notes

      +

      For more possibilities concerning measuring/dimensioning you can use +

      +
      1. the Measure-Tools from part workbench
      2. +
      3. the Draft Dimension-Tool from draft workbench
      4. +
      5. the Arch Survey-Tool from arch workbench
      +


      +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Std_MeasureLinear.html b/localwiki/Std_MeasureLinear.html new file mode 100644 index 0000000..1668757 --- /dev/null +++ b/localwiki/Std_MeasureLinear.html @@ -0,0 +1,75 @@ +Std MeasureLinear

      Std MeasureLinear

      + +
      +

      This documentation is not finished. Please help and contribute documentation. +

      See Draft ShapeString for good documented Command. Gui Command gives an overview over commands. And see List of Commands for other commands. +

      Go to Help FreeCAD to contribute. +

      +
      +


      +

      + + + + + + + + + + + + + + + + + + + + +
      +

      Std MeasureLinear.png Std MeasureLinear

      +
      Menu location +
      Measure → Measure Linear‏‎ +
      Workbenches +
      Part +
      Default shortcut +
      +
      See also +
      +

      + +
      +


      +


      +

      +

      Measure Linear 3D

      +
      MeasureLinear3D1.png
      +


      +


      +

      +

      Measure Linear Delta

      +
      MeasureLinearDelta1.PNG
      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Std_MeasureToggle3D.html b/localwiki/Std_MeasureToggle3D.html new file mode 100644 index 0000000..624cef4 --- /dev/null +++ b/localwiki/Std_MeasureToggle3D.html @@ -0,0 +1,67 @@ +Std MeasureToggle3D

      Std MeasureToggle3D

      + +
      +

      This documentation is not finished. Please help and contribute documentation. +

      See Draft ShapeString for good documented Command. Gui Command gives an overview over commands. And see List of Commands for other commands. +

      Go to Help FreeCAD to contribute. +

      +
      +


      +

      + + + + + + + + + + + + + + + + + + + + +
      +

      Std MeasureToggle3D.png Std MeasureToggle3D

      +
      Menu location +
      Measure → Toggle 3D‏‎ +
      Workbenches +
      Part +
      Default shortcut +
      +
      See also +
      +

      Contents

      + +
      + +
      +


      +


      +ToDo +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Std_MeasureToggleAll.html b/localwiki/Std_MeasureToggleAll.html new file mode 100644 index 0000000..b91b043 --- /dev/null +++ b/localwiki/Std_MeasureToggleAll.html @@ -0,0 +1,70 @@ +Std MeasureToggleAll

      Std MeasureToggleAll

      + +
      +

      This documentation is not finished. Please help and contribute documentation. +

      See Draft ShapeString for good documented Command. Gui Command gives an overview over commands. And see List of Commands for other commands. +

      Go to Help FreeCAD to contribute. +

      +
      +


      +

      + + + + + + + + + + + + + + + + + + + + +
      +

      Std MeasureToggleAll.png Std MeasureToggleAll

      +
      Menu location +
      Measure → Toggle All‏‎ +
      Workbenches +
      Part +
      Default shortcut +
      +
      See also +
      +

      + +
      +


      +


      +

      +

      Toggle Measure

      +

      MeasureLinear3DandDelta1.PNG +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Std_MeasureToggleDelta.html b/localwiki/Std_MeasureToggleDelta.html new file mode 100644 index 0000000..845cfe0 --- /dev/null +++ b/localwiki/Std_MeasureToggleDelta.html @@ -0,0 +1,67 @@ +Std MeasureToggleDelta

      Std MeasureToggleDelta

      + +
      +

      This documentation is not finished. Please help and contribute documentation. +

      See Draft ShapeString for good documented Command. Gui Command gives an overview over commands. And see List of Commands for other commands. +

      Go to Help FreeCAD to contribute. +

      +
      +


      +

      + + + + + + + + + + + + + + + + + + + + +
      +

      Std MeasureToggleDelta.png Std MeasureToggleDelta

      +
      Menu location +
      Measure → Toggle Delta‏‎ +
      Workbenches +
      Part +
      Default shortcut +
      +
      See also +
      +

      Contents

      + +
      + +
      +


      +


      +ToDo +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Std_Measure_Menu.html b/localwiki/Std_Measure_Menu.html new file mode 100644 index 0000000..99dee97 --- /dev/null +++ b/localwiki/Std_Measure_Menu.html @@ -0,0 +1,33 @@ +Std Measure Menu

      Std Measure Menu

      + +


      + Measure +

      Do not confuse this menu with the tool Std MeasureDistance.png Distance +

      Std MeasureLinear.png Measure Linear allows you to make linear measurements +


      +Std MeasureAngular.png Measure Angular allows you to make angular measurements +


      +Std MeasureClearAll.png Clear All Clears all measurements +


      +Std MeasureToggleAll.png Toggle All shows or hides all measurements +


      +Std MeasureToggle3D.png Toggle 3D shows or hides 3D measurements +


      +Std MeasureToggleDelta.png Toggle Delta shows or hides Delta measurements +


      +

      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Std_MergeProject.html b/localwiki/Std_MergeProject.html new file mode 100644 index 0000000..5742258 --- /dev/null +++ b/localwiki/Std_MergeProject.html @@ -0,0 +1,74 @@ +Std MergeProject

      Std MergeProject

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Std MergeProject.png Std MergeProject

      +
      Menu location +
      File → Merge project +
      Workbenches +
      All +
      Default shortcut +
      +
      See also +
      +

      + +
      +


      +

      +

      Description

      +

      Merges another FreeCAD-project into the current one. +

      +

      Use

      +
      1. Choose File Merge project... from the top menu.
      2. +
      3. A dialog will pop up asking you for the filename and location of the FreeCAD-project to be merged into the current one.
      +

      Limitations

      +

      Since the names of the features/objects in the merged project will be changed to
      +match the scheme in the existing project, links to external geometry may get lost. +

      +

      Notes

      +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Std_New.html b/localwiki/Std_New.html new file mode 100644 index 0000000..c0c153c --- /dev/null +++ b/localwiki/Std_New.html @@ -0,0 +1,59 @@ +Std New

      Std New

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Std New.png Std New

      +
      Menu location +
      File → New +
      Workbenches +
      All +
      Default shortcut +
      Ctrl+N +
      See also +
      Std Open,Std Import +

      Contents

      + +
      + +
      +


      +


      +Creates a new empty document. FreeCAD can also be configured to create automatically a new empty document on startup, by checking the appropriate setting in Edit → Preferences → General → Document tab. +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Std_OnlineHelp.html b/localwiki/Std_OnlineHelp.html new file mode 100644 index 0000000..7a00a0c --- /dev/null +++ b/localwiki/Std_OnlineHelp.html @@ -0,0 +1,67 @@ +Std OnlineHelp

      Std OnlineHelp

      + +
      +

      This documentation is not finished. Please help and contribute documentation. +

      See Draft ShapeString for good documented Command. Gui Command gives an overview over commands. And see List of Commands for other commands. +

      Go to Help FreeCAD to contribute. +

      +
      +


      +

      + + + + + + + + + + + + + + + + + + + + +
      +

      Std OnlineHelp.png Std OnlineHelp

      +
      Menu location +
      Help → FreeCAD Website‏‎ +
      Workbenches +
      All +
      Default shortcut +
      +
      See also +
      +

      Contents

      + +
      + +
      +


      +


      +

      ToDo. +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Std_OnlineHelpPython.html b/localwiki/Std_OnlineHelpPython.html new file mode 100644 index 0000000..f1fa17b --- /dev/null +++ b/localwiki/Std_OnlineHelpPython.html @@ -0,0 +1,67 @@ +Std OnlineHelpPython

      Std OnlineHelpPython

      + +
      +

      This documentation is not finished. Please help and contribute documentation. +

      See Draft ShapeString for good documented Command. Gui Command gives an overview over commands. And see List of Commands for other commands. +

      Go to Help FreeCAD to contribute. +

      +
      +


      +

      + + + + + + + + + + + + + + + + + + + + +
      +

      Std OnlineHelpPython.png Std OnlineHelpPython

      +
      Menu location +
      Help → Online-help → Python Website +
      Workbenches +
      All +
      Default shortcut +
      +
      See also +
      +

      Contents

      + +
      + +
      +


      +


      +ToDo +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Std_OnlineHelpWebsite.html b/localwiki/Std_OnlineHelpWebsite.html new file mode 100644 index 0000000..68690f3 --- /dev/null +++ b/localwiki/Std_OnlineHelpWebsite.html @@ -0,0 +1,67 @@ +Std OnlineHelpWebsite

      Std OnlineHelpWebsite

      + +
      +

      This documentation is not finished. Please help and contribute documentation. +

      See Draft ShapeString for good documented Command. Gui Command gives an overview over commands. And see List of Commands for other commands. +

      Go to Help FreeCAD to contribute. +

      +
      +


      +

      + + + + + + + + + + + + + + + + + + + + +
      +

      Std OnlineHelpWebsite.png Std OnlineHelpWebsite

      +
      Menu location +
      Help → Online-help → FreeCAD Website +
      Workbenches +
      All +
      Default shortcut +
      +
      See also +
      +

      Contents

      + +
      + +
      +


      +


      +ToDo +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Std_Open.html b/localwiki/Std_Open.html new file mode 100644 index 0000000..ac4b8d3 --- /dev/null +++ b/localwiki/Std_Open.html @@ -0,0 +1,60 @@ +Std Open

      Std Open

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Std Open.png Std Open

      +
      Menu location +
      File → Open +
      Workbenches +
      All +
      Default shortcut +
      Ctrl+O +
      See also +
      Std Save,Std Import +

      Contents

      + +
      + +
      +


      +

      Opens and loads project files into FreeCAD's workspace and depending on the installed extension modules further file types are supported such as *.IGES, *.STEP, *.BREP, *.STL, *.OBJ, *.PLY, etc. +

      When loading files always a new document gets created. If you want to load a file into an existing document use the Std_Import instead. +

      FreeCAD project files have the extension "FCStd". To get more information about the internal layout of FreeCAD projects files read the article File Format FCStd. +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Std_OrthographicCamera.html b/localwiki/Std_OrthographicCamera.html new file mode 100644 index 0000000..20b8840 --- /dev/null +++ b/localwiki/Std_OrthographicCamera.html @@ -0,0 +1,81 @@ +Std OrthographicCamera

      Std OrthographicCamera

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Std OrthographicCamera.png Std OrthographicCamera

      +
      Menu location +
      View → Orthographic view +
      Workbenches +
      All +
      Default shortcut +
      O +
      See also +
      Perspective View +

      + +
      +


      +

      +

      Description

      +

      Puts the camera in orthographic view mode.
      +Orthographic is (according to Wikipedia):
      +... a means of representing a three-dimensional object in two dimensions... +

      Bascially, Orthographic is a fixed depth. You can't zoom in or out. There is no distance from the camera.
      +Perspective has depth. You can zoom in and out. You can judge distances. Cameras can be distanced from the scene.
      +Simply put, orthographic is what would happen if you squished everything in the scene (along the cameras view axis)
      +and stuck it right against the camera. +

      Orthographic Perspective.gif +

      Perspective on the left, Orthographic on the right +

      +

      Use

      +

      Choose ViewView-isometric.png Orthographic view from the top menu. +

      +

      Limitations

      +


      +

      +

      Notes

      +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Std_Panels.html b/localwiki/Std_Panels.html new file mode 100644 index 0000000..c6f22ed --- /dev/null +++ b/localwiki/Std_Panels.html @@ -0,0 +1,81 @@ +Std Panels

      Std Panels

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Std Panels.png Std Panels

      +
      Menu location +
      View → Panels‏‎ → option +
      Workbenches +
      All +
      Default shortcut +
      +
      See also +
      +

      + +
      +


      +

      +

      Description

      +

      Switches the different dock panels on/off. +

      +

      Use

      +

      Choose View Panels and then the panel of your choice from the top menu.
      +Activated panels will get a check mark in front of their name in the menu.
      +The panels that can be activated are: +

      +
      • Report view
      • +
      • Tree view
      • +
      • Property view
      • +
      • Section view
      • +
      • Combo View
      • +
      • Python console
      +

      Limitations

      +


      +

      +

      Notes

      +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Std_Panels.png b/localwiki/Std_Panels.png new file mode 100644 index 0000000..782eb4d Binary files /dev/null and b/localwiki/Std_Panels.png differ diff --git a/localwiki/Std_Part-tree-active.png b/localwiki/Std_Part-tree-active.png new file mode 100644 index 0000000..d8d7e3a Binary files /dev/null and b/localwiki/Std_Part-tree-active.png differ diff --git a/localwiki/Std_Part-tree.png b/localwiki/Std_Part-tree.png new file mode 100644 index 0000000..628b477 Binary files /dev/null and b/localwiki/Std_Part-tree.png differ diff --git a/localwiki/Std_Part.html b/localwiki/Std_Part.html new file mode 100644 index 0000000..6585eef --- /dev/null +++ b/localwiki/Std_Part.html @@ -0,0 +1,109 @@ +Std Part

      Std Part

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Std Part.png Std Part

      +
      Menu location +
      None +
      Workbenches +
      All +
      Default shortcut +
      None +
      See also +
      Std Group, PartDesign Body +

      + +
      +


      +

      +

      Description

      +

      Part is a general purpose container that keeps together a group of objects so that they can be moved as a unit. Part can contain most if not any FreeCAD object such as PartDesign Bodies, Part workbench objects, Mesh objects, etc. +

      Part provides a local coordinate system to which sketches and other objects can be attached. +

      Part is found in the Structure toolbar that is displayed in all workbenches. +

      available in version 0.17 +

      Std Part-tree.pngStd Part example.png +

      +

      Example uses

      +
      • As an assembly container that groups objects to be manufactured separately then glued or screwed together, like a wooden table.
      • +
      • When importing a STEP assembly in FreeCAD, the main assembly and its sub-assemblies are Part containers.
      • +
      • A part that is composed of multiple non-fused components, like a ball bearing.
      +

      Active Status

      +

      A FreeCAD document can contain multiple Parts. Only one Part can be active at a time. An active Part will be displayed in the tree with a light blue background color. +

      +
      Std Part-tree-active.png
      +

      Origin

      +

      The Origin consists of the three standard axes (X, Y, Z) and three standard planes (XY, XZ and YZ). Sketches can be attached to these planes. All elements inside the Part are referenced to the Part's Origin; which means that the Part can be moved and rotated in reference to the global coordinate system without affecting the placement of elements inside it. +

      +
      PartDesign Body tree-02.png
      +

      Visibility Management

      +

      The Part's visibility supersedes the visibility of any object it contains. If the Part is hidden, the objects it contains will be hidden as well, even if their visibility is set to true. Multiple objects inside a Part can be visible at a time. +

      +

      How to use

      +
      • Press the Std Part.png Create part button in the toolbar. The Part automatically becomes active.
      • +
      • Double-click the Part in the Model tree to activate or deactivate it.
      • +
      • To add objects to a Part, drag & drop them over the Part in the Model tree.
      • +
      • To remove objects from a Part, drag & drop them out of the Part and on the document label at the top of the Model tree.
      +

      Properties

      +
      • DATAId: ID (Part number) of the item. This field is optional.
      • +
      • DATALicense: the license under which the part is released.
      • +
      • DATALicense URL: the Web address where the terms license can be found.
      • +
      • DATAPlacement: specifies the orientation and position of the Part in the 3D space. See Placement.
      • +
      • DATALabel: the Label is the name given to the operation. This name can be changed at your convenience.
      • +
      • DATAGroup: lists the referenced objects.
      +

      Limitations

      +
      • Even when a Part is active, newly created objects are not placed inside the Part, but at the bottom of the tree. Simply drag & drop them over the Part.
      • +
      • A Part has no shape. It is therefore not possible to apply most 3D operations on a Part, such as Part Booleans.
      • +
      • At this time, Draft Snaps do not work on selected Part containers or on objects inside a Part container.
      • +
      • Redactor's note: at this time, it is unclear whether the Part's active status serves a purpose.
      +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Std_Part_example.png b/localwiki/Std_Part_example.png new file mode 100644 index 0000000..10f0e5a Binary files /dev/null and b/localwiki/Std_Part_example.png differ diff --git a/localwiki/Std_Paste.html b/localwiki/Std_Paste.html new file mode 100644 index 0000000..41d08ef --- /dev/null +++ b/localwiki/Std_Paste.html @@ -0,0 +1,71 @@ +Std Paste

      Std Paste

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Std Paste.png Std_Paste

      +
      Menu location +
      Edit → Paste +
      Workbenches +
      All +
      Default shortcut +
      Ctrl+V +
      See also +
      Copy, Duplicate Selection +

      + +
      +


      +

      +

      Description

      +

      The Paste command is involved in replicating Document objects. It places the current "clipboard" contents into the current document. Objects may be copy/pasted between Documents. +

      +

      How to use

      +
      1. Make the target Document active by clicking on it in the Project tab or Document window.
      2. +
      3. Press the Paste icon, ctrl + V keys or use menu choices Edit → Paste.
      +

      Limitations

      +
      • In general, it is not possible to paste FreeCAD objects into other applications, or paste objects from other applications into a FreeCAD document.
      +

      More

      + +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Std_PerspectiveCamera.html b/localwiki/Std_PerspectiveCamera.html new file mode 100644 index 0000000..1519642 --- /dev/null +++ b/localwiki/Std_PerspectiveCamera.html @@ -0,0 +1,76 @@ +Std PerspectiveCamera

      Std PerspectiveCamera

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Std PerspectiveCamera.png Std PerspectiveCamera

      +
      Menu location +
      View → Perspective view‏‎ +
      Workbenches +
      All +
      Default shortcut +
      P +
      See also +
      Orthographic view +

      + +
      +


      +

      +

      Description

      +

      Puts the camera in perspective view mode.
      +Perspective has depth while Orthographic is a fixed depth . You can zoom in and out. You can judge distances. Cameras can be distanced from the scene.
      +

      Orthographic Perspective.gif +

      Perspective on the left, Orthographic on the right +

      +

      Use

      +

      Choose ViewView-perspective.svg Perspective view from the top menu. +

      +

      Limitations

      +


      +

      +

      Notes

      +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Std_Placement.html b/localwiki/Std_Placement.html new file mode 100644 index 0000000..1ca1b96 --- /dev/null +++ b/localwiki/Std_Placement.html @@ -0,0 +1,76 @@ +Std Placement

      Std Placement

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Std Placement.png Std Placement

      +
      Menu location +
      Edit → Placement...‏‎ +
      Workbenches +
      All +
      Default shortcut +
      +
      See also +
      Tasks Placement, Placement +

      + +
      +


      +


      +

      +

      Description

      +

      Placement is how FreeCAD specifies the location and attitude (orientation) of an object in space. Placement can be specified in multiple forms and manipulated via scripting, the Properties panel or the Edit → Placement... dialog. +


      +

      +

      Use

      +
      • Short description +
        • Select an object in the tree view.
        • +
        • In the Edit menu, select Placements...
        • +
        • Change the parameters for the translation or rotation, according to the desired action.
        • +
        • Click OK or Apply
      • +
      • For a full description see Tasks Placement and Placement
      +

      Links and Example

      +

      A practical example of using this command is in the tutorial Aeroplane. +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Std_Plane.svg b/localwiki/Std_Plane.svg new file mode 100644 index 0000000..e194fcd --- /dev/null +++ b/localwiki/Std_Plane.svg @@ -0,0 +1,206 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [wmayer] + + + Sketcher_Sketch + 2011-10-10 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Sketcher/Gui/Resources/icons/Sketcher_Sketch.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + diff --git a/localwiki/Std_Print.html b/localwiki/Std_Print.html new file mode 100644 index 0000000..b26f5f5 --- /dev/null +++ b/localwiki/Std_Print.html @@ -0,0 +1,67 @@ +Std Print

      Std Print

      + +
      +

      This documentation is not finished. Please help and contribute documentation. +

      See Draft ShapeString for good documented Command. Gui Command gives an overview over commands. And see List of Commands for other commands. +

      Go to Help FreeCAD to contribute. +

      +
      +


      +

      + + + + + + + + + + + + + + + + + + + + +
      +

      Std Print.png Std Print

      +
      Menu location +
      File → Print... +
      Workbenches +
      All +
      Default shortcut +
      Ctrl+P +
      See also +
      Print Preview... +

      Contents

      + +
      + +
      +


      +


      +ToDo. +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Std_PrintPdf.html b/localwiki/Std_PrintPdf.html new file mode 100644 index 0000000..fe07ac7 --- /dev/null +++ b/localwiki/Std_PrintPdf.html @@ -0,0 +1,66 @@ +Std PrintPdf

      Std PrintPdf

      + +
      +

      This documentation is not finished. Please help and contribute documentation. +

      See Draft ShapeString for good documented Command. Gui Command gives an overview over commands. And see List of Commands for other commands. +

      Go to Help FreeCAD to contribute. +

      +
      +


      +

      + + + + + + + + + + + + + + + + + + + + +
      +

      Std PrintPdf.png Std PrintPdf

      +
      Menu location +
      File → PrintPdf +
      Workbenches +
      All +
      Default shortcut +
      +
      See also +
      File Export +

      Contents

      + +
      + +
      +


      +

      ToDo. +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Std_PrintPreview.html b/localwiki/Std_PrintPreview.html new file mode 100644 index 0000000..28b0a49 --- /dev/null +++ b/localwiki/Std_PrintPreview.html @@ -0,0 +1,69 @@ +Std PrintPreview

      Std PrintPreview

      + +
      +

      This documentation is not finished. Please help and contribute documentation. +

      See Draft ShapeString for good documented Command. Gui Command gives an overview over commands. And see List of Commands for other commands. +

      Go to Help FreeCAD to contribute. +

      +
      +


      +

      + + + + + + + + + + + + + + + + + + + + +
      +

      Std PrintPreview.png Std PrintPreview

      +
      Menu location +
      File → Print Preview +
      Workbenches +
      All +
      Default shortcut +
      Ctrl+P +
      See also +
      File Print +

      Contents

      + +
      + +
      +


      +


      +ToDo. +

      +
      PrintPreview1.png
      +
      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Std_ProjectInfo.html b/localwiki/Std_ProjectInfo.html new file mode 100644 index 0000000..8deb9fe --- /dev/null +++ b/localwiki/Std_ProjectInfo.html @@ -0,0 +1,88 @@ +Std ProjectInfo

      Std ProjectInfo

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Std ProjectInfo.png Std ProjectInfo

      +
      Menu location +
      File → Project Info +
      Workbenches +
      All +
      Default shortcut +
      +
      See also +
      +

      + +
      +


      +

      +

      Description

      +

      Provides information on the project. +

      +

      Use

      +

      Choose File Project Information... from the top menu +
      +Then following information can be entered in a window: +

      +
      • Name: (Initially the file name will be inserted here)
      • +
      • Path: (Initially the path to the saved file will be entered here)
      • +
      • UUID: a checksum created by FreeCAD will be entered here
      • +
      • Created by: initially blank, can be entered manually
      • +
      • Creation date: creation date and time of the file will be filled in here
      • +
      • Last modified by: initially blank, can be entered manually
      • +
      • Last modification date: will be filled in by FreeCAD
      • +
      • Company: initially blank, can be entered manually
      • +
      • License Information: choose License per pull-down-menu, Standard is "All rights reserved"
      • +
      • License URL: Standard is the link to the wikipedia-"All rights reserved"-page. Can be overwritten.
      • +
      • Comment: initially blank, can be entered manually
      +

      Notes

      +


      +
      +

      +

      Limitations

      +


      +
      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Std_PythonConsole.html b/localwiki/Std_PythonConsole.html new file mode 100644 index 0000000..e777de9 --- /dev/null +++ b/localwiki/Std_PythonConsole.html @@ -0,0 +1,79 @@ +Std PythonConsole

      Std PythonConsole

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Std PythonConsole.png Std PythonConsole

      +
      Menu location +
      View → Panels → Python console +
      Workbenches +
      All +
      Default shortcut +
      None +
      See also +
      +

      + +
      +


      +

      +

      Description

      +

      Gives you an extra window showing and accepting python commands. +

      +

      Use

      +

      Choose View Panels Python console from the top menu.
      +If you use a command inside the FreeCAD-GUI which was programmed with python
      +the python-command will be shown in this window.
      +You can also type in python commands to be executed by FreeCAD. +

      +

      Limitations

      +


      +

      +

      Notes

      +

      FreeCAD comes pre-bundled with a built in python-interpreter.
      +To find out the version number choose Help About FreeCAD Copy to clipboard.
      +Paste the data in a text editor to see the version of the built-in python interpreter. +
      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Std_PythonConsole.png b/localwiki/Std_PythonConsole.png new file mode 100644 index 0000000..782eb4d Binary files /dev/null and b/localwiki/Std_PythonConsole.png differ diff --git a/localwiki/Std_PythonWebsite.html b/localwiki/Std_PythonWebsite.html new file mode 100644 index 0000000..52ba34a --- /dev/null +++ b/localwiki/Std_PythonWebsite.html @@ -0,0 +1,67 @@ +Std PythonWebsite

      Std PythonWebsite

      + +
      +

      This documentation is not finished. Please help and contribute documentation. +

      See Draft ShapeString for good documented Command. Gui Command gives an overview over commands. And see List of Commands for other commands. +

      Go to Help FreeCAD to contribute. +

      +
      +


      +

      + + + + + + + + + + + + + + + + + + + + +
      +

      Std PythonWebsite.png Std PythonWebsite

      +
      Menu location +
      Help → Python Website‏‎ +
      Workbenches +
      All +
      Default shortcut +
      +
      See also +
      +

      Contents

      + +
      + +
      +


      +


      +ToDo +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Std_RecentFiles.html b/localwiki/Std_RecentFiles.html new file mode 100644 index 0000000..153557b --- /dev/null +++ b/localwiki/Std_RecentFiles.html @@ -0,0 +1,70 @@ +Std RecentFiles

      Std RecentFiles

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Std RecentFiles.png Std RecentFiles

      +
      Menu location +
      File → Recent files +
      Workbenches +
      All +
      Default shortcut +
      +
      See also +
      Open, Import +

      + +
      +


      +


      +

      +

      Description

      +

      Move your mouse over this button expands a list showing the last used documents, including those saved. +


      +

      +

      Use

      +
      • Select a document in the list.
      +

      The document is opened and inserted into the project. +

      The number of recent files to list can be set in the menu Edit → Preferences → General → General → Main Window. +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Std_Redo.html b/localwiki/Std_Redo.html new file mode 100644 index 0000000..6753a7b --- /dev/null +++ b/localwiki/Std_Redo.html @@ -0,0 +1,72 @@ +Std Redo

      Std Redo

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Std Redo.png Std Redo

      +
      Menu location +
      Edit → Redo‏‎ +
      Workbenches +
      All +
      Default shortcut +
      Maiusc+Ctrl+Z +
      See also +
      Undo +

      + +
      +


      +

      +

      Description

      +

      Redoes a previously undone operation. +

      +

      Use

      +
      1. Click on Std Redo.png or choose EditStd Redo.png Redo from the top menu.
      +

      Limitations

      +


      +

      +

      Notes

      +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Std_Refresh.html b/localwiki/Std_Refresh.html new file mode 100644 index 0000000..8ff8c10 --- /dev/null +++ b/localwiki/Std_Refresh.html @@ -0,0 +1,75 @@ +Std Refresh

      Std Refresh

      + +


      +

      + + + + + + + + + + + + + + + + + + + + +
      +

      Std Refresh.png Std_Refresh

      +
      Menu location +
      Edit → Refresh +
      Workbenches +
      All +
      Default shortcut +
      F5 or Ctrl+R +
      See also +
      ... +

      + +
      +


      +


      +

      +

      Description

      +

      When used, this command recomputes all altered components on the screen and refreshes the display. +

      +

      How to use

      +

      Press F5 or Ctrl+R or click on the icon Std Refresh.png. +

      +

      Limitations

      +

      FreeCAD will only allow Refresh when (according to the program's opinion) an alteration of a component happened. +Then the grayed-out Refresh-Icon will become blue. +To force a manual recompute you could use the macro Force Recompute +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Std_Refresh.png b/localwiki/Std_Refresh.png new file mode 100644 index 0000000..d5f45e5 Binary files /dev/null and b/localwiki/Std_Refresh.png differ diff --git a/localwiki/Std_Revert.html b/localwiki/Std_Revert.html new file mode 100644 index 0000000..069236c --- /dev/null +++ b/localwiki/Std_Revert.html @@ -0,0 +1,68 @@ +Std Revert

      Std Revert

      + +
      +

      This documentation is not finished. Please help and contribute documentation. +

      See Draft ShapeString for good documented Command. Gui Command gives an overview over commands. And see List of Commands for other commands. +

      Go to Help FreeCAD to contribute. +

      +
      +


      +

      + + + + + + + + + + + + + + + + + + + + +
      +

      Std Revert.png Std Revert

      +
      Menu location +
      File → Revert +
      Workbenches +
      All +
      Default shortcut +
      +
      See also +
      +

      Contents

      + +
      + +
      +


      +


      +ToDo. +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Std_Revert.png b/localwiki/Std_Revert.png new file mode 100644 index 0000000..782eb4d Binary files /dev/null and b/localwiki/Std_Revert.png differ diff --git a/localwiki/Std_RotateLeft.html b/localwiki/Std_RotateLeft.html new file mode 100644 index 0000000..97106c3 --- /dev/null +++ b/localwiki/Std_RotateLeft.html @@ -0,0 +1,67 @@ +Std RotateLeft

      Std RotateLeft

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Std RotateLeft.png Std_RotateLeft

      +
      Menu location +
      {{{MenuLocation}}} +
      Workbenches +
      All +
      Default shortcut +
      None +
      See also +
      ... +

      Contents

      + +
      + +
      +


      +Synopsis +ToDo. +

      +
      +

      This documentation is not finished. Please help and contribute documentation. +

      See Draft ShapeString for good documented Command. Gui Command gives an overview over commands. And see List of Commands for other commands. +

      Go to Help FreeCAD to contribute. +

      +
      +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Std_RotateRight.html b/localwiki/Std_RotateRight.html new file mode 100644 index 0000000..0df15ab --- /dev/null +++ b/localwiki/Std_RotateRight.html @@ -0,0 +1,67 @@ +Std RotateRight

      Std RotateRight

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Std RotateRight.png Std_RotateRight

      +
      Menu location +
      {{{MenuLocation}}} +
      Workbenches +
      All +
      Default shortcut +
      None +
      See also +
      ... +

      Contents

      + +
      + +
      +


      +Synopsis +ToDo. +

      +
      +

      This documentation is not finished. Please help and contribute documentation. +

      See Draft ShapeString for good documented Command. Gui Command gives an overview over commands. And see List of Commands for other commands. +

      Go to Help FreeCAD to contribute. +

      +
      +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Std_Save.html b/localwiki/Std_Save.html new file mode 100644 index 0000000..441c78f --- /dev/null +++ b/localwiki/Std_Save.html @@ -0,0 +1,74 @@ +Std Save

      Std Save

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Std Save.png Std Save

      +
      Menu location +
      File → Save +
      Workbenches +
      All +
      Default shortcut +
      Crtl+S +
      See also +
      Save as... +

      Contents

      + +
      + +
      +


      +

      The Save command stores the active document of the current project to a file. If there are other documents in the project, they are not saved. +

      The first time a document is saved, a dialog to define the path and file name will appear. +


      +

      +
      FileSaveAs.png
      +
      +


      +

      The name assigned to the document to save it also becomes the name used for the root in the document tree structure. +

      Subsequent Save commands automatically use the path and file name defined in the first save. To save the file in a +different location, or assign to it a new name, you must use the Save As command. +

      When you try to close a modified document, or exit FreeCAD with modified documents in use, you will receive a warning: +

      +
      UnsavedDocument.png
      +
      +


      +

      You can define a default location for opening and saving files using the menu Tools → Edit Parameters → BaseApp → Preferences → General → FileOpenSavePath. +

      +
      FileOpenSavePath.png
      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Std_SaveAs.html b/localwiki/Std_SaveAs.html new file mode 100644 index 0000000..9c1fdae --- /dev/null +++ b/localwiki/Std_SaveAs.html @@ -0,0 +1,73 @@ +Std SaveAs

      Std SaveAs

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Std SaveAs.png Std SaveAs

      +
      Menu location +
      File → Save as... +
      Workbenches +
      All +
      Default shortcut +
      Maius+Crtl+S +
      See also +
      Save +

      + +
      +


      +

      +

      Description

      +

      Saves the active document under a new file name. +

      +

      Use

      +

      Choose FileStd SaveAs.png Save As... from the top menu. +

      +

      Limitations

      +


      +

      +

      Notes

      +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Std_SaveaCopy.html b/localwiki/Std_SaveaCopy.html new file mode 100644 index 0000000..f5f528e --- /dev/null +++ b/localwiki/Std_SaveaCopy.html @@ -0,0 +1,74 @@ +Std SaveaCopy

      Std SaveaCopy

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Std SaveaCopy.png Std SaveaCopy

      +
      Menu location +
      File → Save a Copy... +
      Workbenches +
      All +
      Default shortcut +
      C +
      See also +
      Save, Save as... +

      + +
      +


      +

      +

      Description

      +

      Saves a copy of the actual document under a new file name. +

      +

      Use

      +

      Choose File Save a Copy... from the top menu. +

      +

      Limitations

      +


      +

      +

      Notes

      +


      +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Std_SaveaCopy.png b/localwiki/Std_SaveaCopy.png new file mode 100644 index 0000000..782eb4d Binary files /dev/null and b/localwiki/Std_SaveaCopy.png differ diff --git a/localwiki/Std_SceneInspector.html b/localwiki/Std_SceneInspector.html new file mode 100644 index 0000000..936a0fc --- /dev/null +++ b/localwiki/Std_SceneInspector.html @@ -0,0 +1,67 @@ +Std SceneInspector

      Std SceneInspector

      + +
      +

      This documentation is not finished. Please help and contribute documentation. +

      See Draft ShapeString for good documented Command. Gui Command gives an overview over commands. And see List of Commands for other commands. +

      Go to Help FreeCAD to contribute. +

      +
      +


      +

      + + + + + + + + + + + + + + + + + + + + +
      +

      Std SceneInspector.png Std SceneInspector

      +
      Menu location +
      Tools → Scene inspector‏‎ +
      Workbenches +
      All +
      Default shortcut +
      +
      See also +
      +

      Contents

      + +
      + +
      +


      +


      +ToDo. +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Std_SelectAll.html b/localwiki/Std_SelectAll.html new file mode 100644 index 0000000..64accb2 --- /dev/null +++ b/localwiki/Std_SelectAll.html @@ -0,0 +1,73 @@ +Std SelectAll

      Std SelectAll

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Std SelectAll.png Std SelectAll

      +
      Menu location +
      Edit → Select All +
      Workbenches +
      All +
      Default shortcut +
      ... +
      See also +
      ... +

      + +
      +


      +

      +

      Description

      +

      Selects all objects in the tree view in the active document. +

      +

      Use

      +

      Choose EditStd SelectAll.png Select all from the top menu. +

      +

      Limitations

      +


      +

      +

      Notes

      +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Std_SetAppearance.html b/localwiki/Std_SetAppearance.html new file mode 100644 index 0000000..4b3cf3a --- /dev/null +++ b/localwiki/Std_SetAppearance.html @@ -0,0 +1,66 @@ +Std SetAppearance

      Std SetAppearance

      + +
      +

      This documentation is not finished. Please help and contribute documentation. +

      See Draft ShapeString for good documented Command. Gui Command gives an overview over commands. And see List of Commands for other commands. +

      Go to Help FreeCAD to contribute. +

      +
      +


      +

      + + + + + + + + + + + + + + + + + + + + +
      +

      Std SetAppearance.png Std SetAppearance

      +
      Menu location +
      View → Set Appearance +
      Workbenches +
      All +
      Default shortcut +
      +
      See also +
      Set Colors +

      Contents

      + +
      + +
      +


      +

      ToDo. +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Std_SetColors.html b/localwiki/Std_SetColors.html new file mode 100644 index 0000000..d7c6dca --- /dev/null +++ b/localwiki/Std_SetColors.html @@ -0,0 +1,48 @@ +Std SetColors

      Std SetColors

      + +
      +

      This documentation is not finished. Please help and contribute documentation. +

      See Draft ShapeString for good documented Command. Gui Command gives an overview over commands. And see List of Commands for other commands. +

      Go to Help FreeCAD to contribute. +

      +
      +


      +

      +

      Change the color of the faces

      +

      This feature allows you to define a color for each face or surface of an object. +

      +
      Avvio della funzione
      +

      In the tree view: +

      +
      • +
      • +
      +
      +

      In Set colors per face: +

      +
      Finestra Imposta colore per faccia
      +
      +

      Nella finestra viene mostrato il numero della faccia. +

      +
      • Cliccare sul rettangolo sottostante (campione di colore) per visualizzare lo spettro dei colori.
      • +
      • Selezionare il colore desiderato.
      • +
      • Procedere eventualmente per altre facce e poi conferemare.
      +
      +

      Per ripristinare i colori di defualt usare il pulsante Imposta al valore predefinito oppure Shape color della scheda Vista +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Std_SetColors1_it.png b/localwiki/Std_SetColors1_it.png new file mode 100644 index 0000000..db23f9c Binary files /dev/null and b/localwiki/Std_SetColors1_it.png differ diff --git a/localwiki/Std_SetColors2_it.png b/localwiki/Std_SetColors2_it.png new file mode 100644 index 0000000..b75da7d Binary files /dev/null and b/localwiki/Std_SetColors2_it.png differ diff --git a/localwiki/Std_TipOfTheDay.html b/localwiki/Std_TipOfTheDay.html new file mode 100644 index 0000000..05b9706 --- /dev/null +++ b/localwiki/Std_TipOfTheDay.html @@ -0,0 +1,64 @@ +Std TipOfTheDay

      Std TipOfTheDay

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Std TipOfTheDay.png Std_TipOfTheDay

      +
      Menu location +
      {{{MenuLocation}}} +
      Workbenches +
      All +
      Default shortcut +
      None +
      See also +
      ... +

      Contents

      + +
      + +
      +


      +Synopsis +ToDo. +


      +

      +
      +

      This documentation is not finished. Please help and contribute documentation. +

      See Draft ShapeString for good documented Command. Gui Command gives an overview over commands. And see List of Commands for other commands. +

      Go to Help FreeCAD to contribute. +

      +
      + + + +
      + +
      +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Std_ToggleVisibility.html b/localwiki/Std_ToggleVisibility.html new file mode 100644 index 0000000..69a87d7 --- /dev/null +++ b/localwiki/Std_ToggleVisibility.html @@ -0,0 +1,74 @@ +Std ToggleVisibility

      Std ToggleVisibility

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Std ToggleVisibility.png Std ToggleVisibility

      +
      Menu location +
      View → Visibility → Select Option ‏‎ +
      Workbenches +
      All +
      Default shortcut +
      Space +
      See also +
      +

      + +
      +


      +

      +

      Description

      +

      Toggles the visibility of objects. +

      +

      Use

      +
      1. Select object(s) in the tree view.
      2. +
      3. Rigth-Click on object and select "Toggle Visibility" choose View Visibility Toggle Visibilty from the top menu.
      4. +
      5. Using space to toggle visibity on/off is also possible
      +

      Limitations

      +


      +

      +

      Notes

      +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Std_Tool1.svg b/localwiki/Std_Tool1.svg new file mode 100644 index 0000000..597cdcb --- /dev/null +++ b/localwiki/Std_Tool1.svg @@ -0,0 +1,232 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Std_Tool10.svg b/localwiki/Std_Tool10.svg new file mode 100644 index 0000000..b2d7200 --- /dev/null +++ b/localwiki/Std_Tool10.svg @@ -0,0 +1,237 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Std_Tool11.svg b/localwiki/Std_Tool11.svg new file mode 100644 index 0000000..6c14079 --- /dev/null +++ b/localwiki/Std_Tool11.svg @@ -0,0 +1,237 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Std_Tool12.svg b/localwiki/Std_Tool12.svg new file mode 100644 index 0000000..e09150f --- /dev/null +++ b/localwiki/Std_Tool12.svg @@ -0,0 +1,242 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Std_Tool2.svg b/localwiki/Std_Tool2.svg new file mode 100644 index 0000000..58db6c7 --- /dev/null +++ b/localwiki/Std_Tool2.svg @@ -0,0 +1,232 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Std_Tool3.svg b/localwiki/Std_Tool3.svg new file mode 100644 index 0000000..ead04f2 --- /dev/null +++ b/localwiki/Std_Tool3.svg @@ -0,0 +1,232 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Std_Tool4.svg b/localwiki/Std_Tool4.svg new file mode 100644 index 0000000..adfe2c8 --- /dev/null +++ b/localwiki/Std_Tool4.svg @@ -0,0 +1,232 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Std_Tool5.svg b/localwiki/Std_Tool5.svg new file mode 100644 index 0000000..63f0281 --- /dev/null +++ b/localwiki/Std_Tool5.svg @@ -0,0 +1,232 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Std_Tool6.svg b/localwiki/Std_Tool6.svg new file mode 100644 index 0000000..31e895b --- /dev/null +++ b/localwiki/Std_Tool6.svg @@ -0,0 +1,232 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Std_Tool7.svg b/localwiki/Std_Tool7.svg new file mode 100644 index 0000000..da7dfbd --- /dev/null +++ b/localwiki/Std_Tool7.svg @@ -0,0 +1,232 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Std_Tool8.svg b/localwiki/Std_Tool8.svg new file mode 100644 index 0000000..fc0e0be --- /dev/null +++ b/localwiki/Std_Tool8.svg @@ -0,0 +1,232 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Std_Tool9.svg b/localwiki/Std_Tool9.svg new file mode 100644 index 0000000..e1899f4 --- /dev/null +++ b/localwiki/Std_Tool9.svg @@ -0,0 +1,232 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Std_Tools_Menu.html b/localwiki/Std_Tools_Menu.html new file mode 100644 index 0000000..789774c --- /dev/null +++ b/localwiki/Std_Tools_Menu.html @@ -0,0 +1,30 @@ +Std Tools Menu

      Std Tools Menu

      + +


      +Tools +


      +Edit parameters allows many of the settings that control FreeCAD to be changed. It does not set parameters for a model. +

      Std ViewScreenShot.png Save picture takes a snapshot of the current 3D window. +

      Scene inspector displays details of the Open Inventor representation of the 3D window. +

      Dependency graph shows how the various features in a model are related. +

      Project utility assists in repairing damaged project files. +

      View turntable displays a rotating view of model in the 3D window. +

      Units Calculator provides quick conversions between measurement systems, ex mm to inches. +

      Customize allows menus, shortcut keys and toolbars to be modified. +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Std_Undo.html b/localwiki/Std_Undo.html new file mode 100644 index 0000000..daee424 --- /dev/null +++ b/localwiki/Std_Undo.html @@ -0,0 +1,74 @@ +Std Undo

      Std Undo

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Std Undo.png Std Undo

      +
      Menu location +
      Edit → Undo +
      Workbenches +
      All +
      Default shortcut +
      Ctrl+Z +
      See also +
      Redo +

      + +
      +


      +

      +

      Description

      +

      Undoes exactly one action. +

      +

      Use

      +

      Click on Std Undo.png or choose EditStd Undo.png Undo from the top menu.
      +Click ont black down-arrow on the right side of the icon to get a list of max 12 actions to choose from. +

      +

      Limitations

      +


      +

      +

      Notes

      +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Std_UnitsCalculator.html b/localwiki/Std_UnitsCalculator.html new file mode 100644 index 0000000..25e03aa --- /dev/null +++ b/localwiki/Std_UnitsCalculator.html @@ -0,0 +1,73 @@ +Std UnitsCalculator

      Std UnitsCalculator

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Std UnitsCalculator.png Std_UnitsCalculator

      +
      Menu location +
      Tools -> Unit calculator... +
      Workbenches +
      All +
      Default shortcut +
      None +
      See also +
      ... +

      + +
      +


      +

      Opens the unit calculator dialog, which allow to transform Quantities into different units. +

      +

      Synopsis

      +

      The first field defines a value and a corresponding unit (what kind of units get recognized you can see in the Quantity description). In the second field you specify the resulting unit. The third field present the result. Pressing return in field one or two will add the result of the calculation to the log area for later usage. +

      If one of the fields get red in the background means an error occourd. Either the parser gets and error in the unit expression or the source and target unit do not fit. Hovering over an red input field shows you the error string. +

      The Copy button copies the result into the Clipboard, so you can use it in any other dialog of FreeCAD. +

      The dialog is a non-modal dialog and can stay open as long as you want. It do not block the rest of FreeCAD. +

      +

      Dialog

      +

      Units Calculator it.png +

      The Dialog with the three fields and the log area. +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Std_ViewBoxZoom.html b/localwiki/Std_ViewBoxZoom.html new file mode 100644 index 0000000..6fa3e0f --- /dev/null +++ b/localwiki/Std_ViewBoxZoom.html @@ -0,0 +1,74 @@ +Std ViewBoxZoom

      Std ViewBoxZoom

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Std ViewBoxZoom.png Std ViewBoxZoom

      +
      Menu location +
      View → Zoom +
      Workbenches +
      All +
      Default shortcut +
      +
      See also +
      +

      + +
      +


      +

      +

      Description

      +

      Allows you to zoom to the extents of a box specified in the 3D view. +

      +

      Use

      +

      Choose View ZoomStd ViewBoxZoom.png Box zoom from the top menu.
      +Then specify the box to zoom to in the 3D view. +

      +

      Limitations

      +


      +

      +

      Notes

      +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Std_ViewCreate.html b/localwiki/Std_ViewCreate.html new file mode 100644 index 0000000..1963c02 --- /dev/null +++ b/localwiki/Std_ViewCreate.html @@ -0,0 +1,67 @@ +Std ViewCreate

      Std ViewCreate

      + +
      +

      This documentation is not finished. Please help and contribute documentation. +

      See Draft ShapeString for good documented Command. Gui Command gives an overview over commands. And see List of Commands for other commands. +

      Go to Help FreeCAD to contribute. +

      +
      +


      +

      + + + + + + + + + + + + + + + + + + + + +
      +

      Std ViewCreate.png Std ViewCreate

      +
      Menu location +
      View → Create new view‏‎ +
      Workbenches +
      All +
      Default shortcut +
      +
      See also +
      +

      Contents

      + +
      + +
      +


      +


      +ToDo +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Std_ViewDockUndockFullscreen.html b/localwiki/Std_ViewDockUndockFullscreen.html new file mode 100644 index 0000000..61d33f0 --- /dev/null +++ b/localwiki/Std_ViewDockUndockFullscreen.html @@ -0,0 +1,68 @@ +Std ViewDockUndockFullscreen

      Std ViewDockUndockFullscreen

      + +
      +

      This documentation is not finished. Please help and contribute documentation. +

      See Draft ShapeString for good documented Command. Gui Command gives an overview over commands. And see List of Commands for other commands. +

      Go to Help FreeCAD to contribute. +

      +
      +


      +


      +

      + + + + + + + + + + + + + + + + + + + + +
      +

      Std ViewDockUndockFullscreen.png Std ViewDockUndockFullscreen

      +
      Menu location +
      View → Document window‏‎ +
      Workbenches +
      All +
      Default shortcut +
      +
      See also +
      +

      + +
      +


      +


      +ToDo +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Std_ViewExamples.html b/localwiki/Std_ViewExamples.html new file mode 100644 index 0000000..d416f83 --- /dev/null +++ b/localwiki/Std_ViewExamples.html @@ -0,0 +1,64 @@ +Std ViewExamples

      Std ViewExamples

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Std ViewExamples.png Std_ViewExamples

      +
      Menu location +
      {{{MenuLocation}}} +
      Workbenches +
      All +
      Default shortcut +
      None +
      See also +
      ... +

      Contents

      + +
      + +
      +


      +Synopsis +ToDo. +


      +

      +
      +

      This documentation is not finished. Please help and contribute documentation. +

      See Draft ShapeString for good documented Command. Gui Command gives an overview over commands. And see List of Commands for other commands. +

      Go to Help FreeCAD to contribute. +

      +
      + + + +
      + +
      +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Std_ViewFitAll.html b/localwiki/Std_ViewFitAll.html new file mode 100644 index 0000000..d14dffa --- /dev/null +++ b/localwiki/Std_ViewFitAll.html @@ -0,0 +1,74 @@ +Std ViewFitAll

      Std ViewFitAll

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Std ViewFitAll.png Std ViewFitAll

      +
      Menu location +
      View → Standard views‏‎ → FitAll +
      Workbenches +
      All +
      Default shortcut +
      +
      See also +
      Fit Selection +

      + +
      +


      +

      +

      Description

      +

      Zooms outwards until all visible objects in the active document are shown in the 3D view. +

      +

      Use

      +

      Click on Std ViewFitAll.png or choose View Standard viewsStd ViewFitAll.png Fit all from the top menu.
      +The command is also available by right clicking in the 3D view (and having nothing pre-selected). +

      +

      Limitations

      +


      +

      +

      Notes

      +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Std_ViewFitSelection.html b/localwiki/Std_ViewFitSelection.html new file mode 100644 index 0000000..4c61d54 --- /dev/null +++ b/localwiki/Std_ViewFitSelection.html @@ -0,0 +1,74 @@ +Std ViewFitSelection

      Std ViewFitSelection

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Std ViewFitSelection.png Std ViewFitSelection

      +
      Menu location +
      View → Fit Selection +
      Workbenches +
      All +
      Default shortcut +
      +
      See also +
      +

      + +
      +


      +

      +

      Description

      +

      Zooms until all in the tree view selected objects are shown in the 3D view. +

      +

      Use

      +

      Click on Std ViewFitSelection.png or choose View Standard viewsStd ViewFitSelection.png Fit selection from the top menu.
      +Command is also available by right-clicking in the 3D view (and having nothing pre-selected). +

      +

      Limitations

      +


      +

      +

      Notes

      +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Std_ViewIvIssueCamPos.html b/localwiki/Std_ViewIvIssueCamPos.html new file mode 100644 index 0000000..6558b80 --- /dev/null +++ b/localwiki/Std_ViewIvIssueCamPos.html @@ -0,0 +1,76 @@ +Std ViewIvIssueCamPos

      Std ViewIvIssueCamPos

      + +
      +

      This documentation is not finished. Please help and contribute documentation. +

      See Draft ShapeString for good documented Command. Gui Command gives an overview over commands. And see List of Commands for other commands. +

      Go to Help FreeCAD to contribute. +

      +
      +


      +

      + + + + + + + + + + + + + + + + + + + + +
      +

      Std ViewIvIssueCamPos.png Std ViewIvIssueCamPos

      +
      Menu location +
      View → Stereo → Issue camera position +
      Workbenches +
      All +
      Default shortcut +
      +
      See also +
      +

      + +
      +


      +


      +

      +

      Description

      +

      CameraPosition1_it.png +

      +

      Use

      +

      Limitations

      +

      Notes

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Std_ViewIvIssueCamPos.png b/localwiki/Std_ViewIvIssueCamPos.png new file mode 100644 index 0000000..fbcbbcc Binary files /dev/null and b/localwiki/Std_ViewIvIssueCamPos.png differ diff --git a/localwiki/Std_ViewIvStereo.html b/localwiki/Std_ViewIvStereo.html new file mode 100644 index 0000000..e9331ea --- /dev/null +++ b/localwiki/Std_ViewIvStereo.html @@ -0,0 +1,68 @@ +Std ViewIvStereo

      Std ViewIvStereo

      + +


      +

      + + + + + + + + + + + + + + + + + + + + +
      +

      Std ViewIvStereo.png Std ViewIvStereo

      +
      Menu location +
      View → Stereo‏‎ → option +
      Workbenches +
      All +
      Default shortcut +
      +
      See also +
      +

      + +
      +


      +


      +

      +

      Description

      +

      This tool allows stereoscopic vision of objects in the work area. +

      Select the desired mode. Stereo Off restores normal vision. +

      The distance between your eyes for the stereo mode can set in Preferences . +

      Stereo menu also contains command to know the data of Camera Position and other characteristics. +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Std_ViewScreenShot.html b/localwiki/Std_ViewScreenShot.html new file mode 100644 index 0000000..6febf25 --- /dev/null +++ b/localwiki/Std_ViewScreenShot.html @@ -0,0 +1,125 @@ +Std ViewScreenShot

      Std ViewScreenShot

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Std ViewScreenShot.png Std ViewScreenShot

      +
      Menu location +
      Tools → Save picture... +
      Workbenches +
      All +
      Default shortcut +
      None +
      See also +
      ... +

      + +
      +


      +


      +

      +

      Synopsis

      +

      This command opens a dialog to save the current content of the 3D view to +a file. It can save to various image formats. Additionally, you can change the +aspect ratio and the resolution of the screen shot using the "Options" +button to get access to more parameters. +

      This command can also use the image comment field of some image formats, like PNG or JPEG +to save MIBA information along with the picture. +


      +

      +

      Image formats

      +

      FreeCAD uses the QT built-in image types and some QT plugins in the bin/imageformats directory +to save pictures. So how many and what formats you can choose depends on your platform. +

      +

      Dialog

      +

      Save picture.png +


      +

      +
      Image Size
      +

      The image size parameters are set to the screen size of the active 3D view. But you can change it to any value you like. Some OpenGL drivers don't allow renderings greater then 8000 pixels. It depends on your system. +

      With the four buttons you can change the aspect to a certain value. +

      +
      Image background
      +

      With this combo box you can choose the background of the picture you make. +

      +
      • Current use the current view background (as chosen in the preferences)
      • +
      • White creates a plain white background (for e.g. printings)
      • +
      • Black plain black background
      • +
      • Transparent creates a transparent background on image formats which support transparency
      +
      Comment
      +

      Some image formats can transport a comment along the picture. In case you choose one of this formats you can insert a comment or use the comment field for the MIBA information. +

      +

      Scripting

      +

      It's also possible to save the screen by python: +

      +
       Gui.ActiveDocument.ActiveView.saveImage('C:/temp/test.png',1656,783,'Current')
      +

      This script makes a series of pictures of different sizes and from different +points of view. The type of the camera, i.e. orthographic or perspective can also be changed. +

      +
       import Part,PartGui
      + # loading test part
      + Part.open("C:/Documents and Settings/jriegel/My Documents/Projects/FreeCAD/data/Blade.stp")
      + OutDir = 'c:/temp/'
      + 
      + # creating images with different Views, Cameras and sizes
      + for p in ["PerspectiveCamera","OrthographicCamera"]:
      +   Gui.SendMsgToActiveView(p)
      +   for f in ["ViewAxo","ViewFront","ViewTop"]:
      +     Gui.SendMsgToActiveView(f)
      +     for x,y in [[500,500],[1000,3000],[3000,1000],[3000,3000],[8000,8000]]:
      +       Gui.ActiveDocument.ActiveView.saveImage(OutDir + "Blade_" + p +"_" + f + "_" + `x` + "_" + `y` + ".jpg",x,y,"White")
      +       Gui.ActiveDocument.ActiveView.saveImage(OutDir + "Blade_" + p +"_" + f + "_" + `x` + "_" + `y` + ".png",x,y,"Transparent")
      + 
      + # close active document
      + App.closeDocument(App.ActiveDocument.Name)
      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Std_ViewScreenShot.svg b/localwiki/Std_ViewScreenShot.svg new file mode 100644 index 0000000..dc1a006 --- /dev/null +++ b/localwiki/Std_ViewScreenShot.svg @@ -0,0 +1,372 @@ + + + +image/svg+xmlGeneric ImageJakub Steinerimagepicturesnapshotphoto \ No newline at end of file diff --git a/localwiki/Std_ViewXX.html b/localwiki/Std_ViewXX.html new file mode 100644 index 0000000..87eeb33 --- /dev/null +++ b/localwiki/Std_ViewXX.html @@ -0,0 +1,64 @@ +Std ViewXX

      Std ViewXX

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Std ViewXX.png Std_ViewXX

      +
      Menu location +
      {{{MenuLocation}}} +
      Workbenches +
      All +
      Default shortcut +
      None +
      See also +
      ... +

      Contents

      + +
      + +
      +


      +Synopsis +ToDo. +


      +

      +
      +

      This documentation is not finished. Please help and contribute documentation. +

      See Draft ShapeString for good documented Command. Gui Command gives an overview over commands. And see List of Commands for other commands. +

      Go to Help FreeCAD to contribute. +

      +
      + + + +
      + +
      +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Std_ViewZoom.html b/localwiki/Std_ViewZoom.html new file mode 100644 index 0000000..1e88727 --- /dev/null +++ b/localwiki/Std_ViewZoom.html @@ -0,0 +1,67 @@ +Std ViewZoom

      Std ViewZoom

      + +
      +

      This documentation is not finished. Please help and contribute documentation. +

      See Draft ShapeString for good documented Command. Gui Command gives an overview over commands. And see List of Commands for other commands. +

      Go to Help FreeCAD to contribute. +

      +
      +


      +

      + + + + + + + + + + + + + + + + + + + + +
      +

      Std ViewZoom.png Std ViewZoom

      +
      Menu location +
      View → Zoom‏‎ → option +
      Workbenches +
      All +
      Default shortcut +
      +
      See also +
      +

      Contents

      + +
      + +
      +


      +


      +ToDo +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Std_View_Menu.html b/localwiki/Std_View_Menu.html new file mode 100644 index 0000000..5094089 --- /dev/null +++ b/localwiki/Std_View_Menu.html @@ -0,0 +1,136 @@ +Std View Menu

      Std View Menu

      + +

      View +

      Contains all functions related to the display of the model, such as panels show, zoom, etc.. . +

      + + + + +
      • Freeze display +
        • Save views...
        • +
        • Load views...
        • +
        • Freeze view
        • +
        • Clear views
      +
      • Draw Style +
        • DrawStyleAsIs.png As is
        • +
        • DrawStyleFlatLines.png Flat lines
        • +
        • DrawStyleShaded.png Shaded
        • +
        • DrawStyleWireFrame.png Wireframe
        • +
        • DrawStylePoints.png Points
      + +
      + +
      • Toggle axis cross
      + + +
      • Visibility +
        • Toggle visibility (....) (... "space")
        • +
        • Show selection
        • +
        • Hide selection
        • +
        • Toggle all objects
        • +
        • Show all objects
        • +
        • Hide all objects
        • +
        • View-unselectable.png Toggle selectability
        • +
        • Part Measure Toggle All.png Toggle measurement
        • +
        • Part Measure Clear All.png Clear measurement
      +
      • Toggle visibility
      +
      • Toggle navigation/edit mode
      +
      • Appearance... +
        • Viewing mode
        • +
        • Material
        • +
        • Display +
          • Point size
          • +
          • Line width
          • +
          • Transparency
          • +
          • Line transparency
      +
      • Random color
      + + +
      • Toolbars +
        • File
        • +
        • Macro
        • +
        • View
        • +
        • Part Design
        • +
        • Sketcher geometries
        • +
        • Sketcher constraints
        • +
        • Bolts
        • +
        • Info
        • +
        • FreeCAD Part
        • +
        • Screw
        • +
        • Draft Snap
      + +
      • Status bar
      +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Std_WhatsThis.html b/localwiki/Std_WhatsThis.html new file mode 100644 index 0000000..9a8bb77 --- /dev/null +++ b/localwiki/Std_WhatsThis.html @@ -0,0 +1,67 @@ +Std WhatsThis

      Std WhatsThis

      + +
      +

      This documentation is not finished. Please help and contribute documentation. +

      See Draft ShapeString for good documented Command. Gui Command gives an overview over commands. And see List of Commands for other commands. +

      Go to Help FreeCAD to contribute. +

      +
      +


      +

      + + + + + + + + + + + + + + + + + + + + +
      +

      Std WhatsThis.png Std WhatsThis

      +
      Menu location +
      Help → What's This‏‎ +
      Workbenches +
      All +
      Default shortcut +
      Maiusc+F1 +
      See also +
      +

      Contents

      + +
      + +
      +


      +


      +ToDo +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Std_WindowCascade.svg b/localwiki/Std_WindowCascade.svg new file mode 100644 index 0000000..20700fb --- /dev/null +++ b/localwiki/Std_WindowCascade.svg @@ -0,0 +1,442 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Std_WindowNext.svg b/localwiki/Std_WindowNext.svg new file mode 100644 index 0000000..d5aa732 --- /dev/null +++ b/localwiki/Std_WindowNext.svg @@ -0,0 +1,216 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Std_WindowPrev.svg b/localwiki/Std_WindowPrev.svg new file mode 100644 index 0000000..5076a2a --- /dev/null +++ b/localwiki/Std_WindowPrev.svg @@ -0,0 +1,230 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Std_WindowTileVer.svg b/localwiki/Std_WindowTileVer.svg new file mode 100644 index 0000000..91c7381 --- /dev/null +++ b/localwiki/Std_WindowTileVer.svg @@ -0,0 +1,243 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Std_Windows_Menu.html b/localwiki/Std_Windows_Menu.html new file mode 100644 index 0000000..78bb212 --- /dev/null +++ b/localwiki/Std_Windows_Menu.html @@ -0,0 +1,27 @@ +Std Windows Menu

      Std Windows Menu

      + +

      Windows +

      Typical window management menu, which includes these commands: +

      Std WindowNext.png Next +

      Std WindowPrev.png Previous +

      Std WindowTileVer.png Tile +

      Std WindowCascade.png Cascade +

      Arrange icons +

      Windows... +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Std_Workbench.html b/localwiki/Std_Workbench.html new file mode 100644 index 0000000..b923ce4 --- /dev/null +++ b/localwiki/Std_Workbench.html @@ -0,0 +1,67 @@ +Std Workbench

      Std Workbench

      + +
      +

      This documentation is not finished. Please help and contribute documentation. +

      See Draft ShapeString for good documented Command. Gui Command gives an overview over commands. And see List of Commands for other commands. +

      Go to Help FreeCAD to contribute. +

      +
      +


      +

      + + + + + + + + + + + + + + + + + + + + +
      +

      Std Workbench.png Std Workbench

      +
      Menu location +
      View → Workbench +
      Workbenches +
      All +
      Default shortcut +
      ... +
      See also +
      ... +

      Contents

      + +
      + +
      +


      +


      +ToDo. +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Std_Workbench_Menu.html b/localwiki/Std_Workbench_Menu.html new file mode 100644 index 0000000..bb11a6e --- /dev/null +++ b/localwiki/Std_Workbench_Menu.html @@ -0,0 +1,49 @@ +Std Workbench Menu

      Std Workbench Menu

      + +
      +

      This documentation is not finished. Please help and contribute documentation. +

      See Draft ShapeString for good documented Command. Gui Command gives an overview over commands. And see List of Commands for other commands. +

      Go to Help FreeCAD to contribute. +

      +
      +


      +

      Workbench +

      Built-in workbenches +

      + +

      Additional workbenches +

      +
      +


      +

      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Steel.svg b/localwiki/Steel.svg new file mode 100644 index 0000000..4da18b8 --- /dev/null +++ b/localwiki/Steel.svg @@ -0,0 +1,264 @@ + + + + + + + + + + + + image/svg+xml + + + + + Pablo Gil + + + + + SVG + template + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Step10_second_arc.png b/localwiki/Step10_second_arc.png new file mode 100644 index 0000000..4214e53 Binary files /dev/null and b/localwiki/Step10_second_arc.png differ diff --git a/localwiki/Step11_last_arc.png b/localwiki/Step11_last_arc.png new file mode 100644 index 0000000..6b902a3 Binary files /dev/null and b/localwiki/Step11_last_arc.png differ diff --git a/localwiki/Step12_define_ratio.png b/localwiki/Step12_define_ratio.png new file mode 100644 index 0000000..be10b2a Binary files /dev/null and b/localwiki/Step12_define_ratio.png differ diff --git a/localwiki/Step12_define_rectangle.png b/localwiki/Step12_define_rectangle.png new file mode 100644 index 0000000..a53adaa Binary files /dev/null and b/localwiki/Step12_define_rectangle.png differ diff --git a/localwiki/Step14_rectangle_with_golden_ratio.png b/localwiki/Step14_rectangle_with_golden_ratio.png new file mode 100644 index 0000000..22d8d68 Binary files /dev/null and b/localwiki/Step14_rectangle_with_golden_ratio.png differ diff --git a/localwiki/Step1_rectangle_600x400.png b/localwiki/Step1_rectangle_600x400.png new file mode 100644 index 0000000..67ebee0 Binary files /dev/null and b/localwiki/Step1_rectangle_600x400.png differ diff --git a/localwiki/Step2_rectangle_with_symmetry_600x400.png b/localwiki/Step2_rectangle_with_symmetry_600x400.png new file mode 100644 index 0000000..6c741bc Binary files /dev/null and b/localwiki/Step2_rectangle_with_symmetry_600x400.png differ diff --git a/localwiki/Step3_making_SB_600x400.png b/localwiki/Step3_making_SB_600x400.png new file mode 100644 index 0000000..a84babc Binary files /dev/null and b/localwiki/Step3_making_SB_600x400.png differ diff --git a/localwiki/Step4_make_SB_construction_line_600x400.png b/localwiki/Step4_make_SB_construction_line_600x400.png new file mode 100644 index 0000000..d67e0e4 Binary files /dev/null and b/localwiki/Step4_make_SB_construction_line_600x400.png differ diff --git a/localwiki/Step5_helper_vertex.png b/localwiki/Step5_helper_vertex.png new file mode 100644 index 0000000..776be70 Binary files /dev/null and b/localwiki/Step5_helper_vertex.png differ diff --git a/localwiki/Step6_symmetry_setting.png b/localwiki/Step6_symmetry_setting.png new file mode 100644 index 0000000..eb5593e Binary files /dev/null and b/localwiki/Step6_symmetry_setting.png differ diff --git a/localwiki/Step7_arc_defining_BC.png b/localwiki/Step7_arc_defining_BC.png new file mode 100644 index 0000000..bd7f27f Binary files /dev/null and b/localwiki/Step7_arc_defining_BC.png differ diff --git a/localwiki/Step8_arc_BC_finishing.png b/localwiki/Step8_arc_BC_finishing.png new file mode 100644 index 0000000..5558d13 Binary files /dev/null and b/localwiki/Step8_arc_BC_finishing.png differ diff --git a/localwiki/Step9_triangle_ready.png b/localwiki/Step9_triangle_ready.png new file mode 100644 index 0000000..a112077 Binary files /dev/null and b/localwiki/Step9_triangle_ready.png differ diff --git a/localwiki/Stickyfonts.jpg b/localwiki/Stickyfonts.jpg new file mode 100644 index 0000000..36c65c5 Binary files /dev/null and b/localwiki/Stickyfonts.jpg differ diff --git a/localwiki/Straightness.svg b/localwiki/Straightness.svg new file mode 100644 index 0000000..5e7d108 --- /dev/null +++ b/localwiki/Straightness.svg @@ -0,0 +1,112 @@ + + + + + Straightness + + + + + + image/svg+xml + + Straightness + + + bavariaSHAPE + + + + + bavariaSHAPE + + + + + bavariaSHAPE + + + 15.10.2016 + Geometric dimensioning and tolerancing symbols +All symbols in this repository are licensed under CC-BY 3.0 + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Surface.svg b/localwiki/Surface.svg new file mode 100644 index 0000000..159fa87 --- /dev/null +++ b/localwiki/Surface.svg @@ -0,0 +1,281 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + + + + + diff --git a/localwiki/Svg_Namespace.html b/localwiki/Svg_Namespace.html new file mode 100644 index 0000000..6ff0d7b --- /dev/null +++ b/localwiki/Svg_Namespace.html @@ -0,0 +1,178 @@ +Svg Namespace

      Svg Namespace

      + +

      In the SVG documents exported by FreeCAD's Drawing Module and used as page templates, several custom attributes can be used, originally for FreeCAD's own internal use, but could also be used by other FreeCAD-aware applications in the future. These attributes all use the freecad: namespace prefix. The namespace URL defined in those SVG documents refers to this page. +

      + + +

      Usage

      +

      One pixel = one millimeter. +

      You must insert, somewhere inside your svg code, where you want the contents of the drawing to appear (for example at the end of the file, just before the last </svg> tag), the following line: +


      +

      +
      <!-- DrawingContent -->
      +


      +

      +
      <?xml version="1.0" encoding="UTF-8" standalone="no"?>
      +<svg
      +   xmlns:freecad="http://www.freecadweb.org/wiki/index.php?title=Svg_Namespace"
      +

      In order to enable up to scale printing, the real word size has to be given in the width and height attributes of the SVG-Tag. The size of the document in user units, (px), has to be given in the viewBox attribute. +

      The following is to be formatted like the example below where: +

      +
      • xxx = pixel width
      • +
      • yyy = pixel height
      +
      width="xxxmm"
      +height="yyymm"
      +viewBox="0 0 xxx yyy"
      +

      Additional information for Working space and Title block may be added, and is defined on the Drawing templates page. +

      +

      Attributes

      +

      freecad:EditableText

      +

      To use any of the freecad: attributes in your SVG documents, you must first define the freecad namespace as an attribute of the opening <svg> tag: +

      Defines a text in a template that can be edited by FreeCAD. +

      Example: +

      +
       <text freecad:EditableText="MyTitleText">
      +     <tspan>This is a title</tspan>
      + </text>
      +

      freecad:basepoint1

      +

      Defines the first point of a Draft Dimension object (represented as a group in a SVG document). This attribute is used when importing the SVG fragment in FreeCAD, in order to recreate the dimension object. The group contains paths and other graphical items to correctly render the dimension object in other SVG applications. +

      Example: +

      +
       <g freecad:basepoint1="0.5 4.34" freecad:basepoint2="2.4 5.8" dimpoint="3.2 7.76">
      +     <path d="...">
      + </g>
      +

      freecad:basepoint2

      +

      Defines the second point of a Draft Dimension object (represented as a group in a SVG document). This attribute is used when importing the SVG fragment in FreeCAD, in order to recreate the dimension object. The group contains paths and other graphical items to correctly render the dimension object in other SVG applications. +

      Example: see freecad:basepoint1 +

      +

      freecad:dimpoint

      +

      Defines the point of a Draft Dimension object through which the dimension line passes. This attribute is used when importing the SVG fragment in FreeCAD, in order to recreate the dimension object. The group contains paths and other graphical items to correctly render the dimension object in other SVG applications. +

      Example: see freecad:basepoint1 +

      +

      Example of code freecad:EditableText

      +

      This example is taken from a cartridge to a sheet A3_Landscape +

      +

      1 : Title without textedit

      +

      Svg Namespace 01.png +

      +
        <g
      +     id="g3587">
      +    <text
      +       sodipodi:linespacing="119.00001%"
      +       id="text3482"
      +       y="229.10912"
      +       x="220.8476"
      +       style="font-size:1.97555566px;font-style:normal;font-weight:normal;line-height:119.00000572%;letter-spacing:0.01975556px;word-spacing:0.00846667px;writing-mode:lr-tb;fill:#000000;fill-opacity:1;stroke:none;font-family:Sans;-inkscape-font-specification:Sans"
      +       xml:space="preserve"><tspan
      +         y="229.10912"
      +         x="220.8476"
      +         id="tspan3484"
      +         sodipodi:role="line">AUTHOR NAME :</tspan></text>
      +

      2 : Title with textedit

      +

      Svg Namespace 02.png +

      +
        <g
      +     style="fill:none;stroke:#000000;stroke-width:0.13;stroke-linecap:butt;stroke-linejoin:miter"
      +     id="g578-7"
      +     transform="translate(0,4)">
      +    <text
      +       xml:space="preserve"
      +       style="font-size:4px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;line-height:125%;letter-spacing:0px;word-spacing:0px;fill:#000000;fill-opacity:1;stroke:none;font-family:sans;-inkscape-font-specification:sans"
      +       x="220.9935"
      +       y="228.95425"
      +       id="text3331"
      +       sodipodi:linespacing="125%"
      +       freecad:editable="AuthorName"><tspan
      +         sodipodi:role="line"
      +         id="tspan3333"
      +         x="220.9935"
      +         y="228.95425">AUTHOR NAME</tspan></text>
      +    <text
      +    ...
      +    ...
      +    ...
      +    ... </text>
      +  
      +  </g>
      +

      Explanations

      +
        <g
      +

      Beginning of the framework +

      +
           style="fill:none;stroke:#000000;stroke-width:0.13;stroke-linecap:butt;stroke-linejoin:miter"
      +     id="g578-7"
      +     transform="translate(0,4)">
      +

      Data on the framework +

      +
          <text
      +

      Beginning of the text block +

      +
             xml:space="preserve"
      +       style="font-size:4px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;line-height:125%;letter-spacing:0px;word-spacing:0px;fill:#000000;fill-opacity:1;stroke:none;font-family:sans;-inkscape-font-specification:sans"
      +

      All the information about the text that will be displayed +

      +
             x="220.9935"
      +       y="228.95425"
      +       id="text3331"
      +       sodipodi:linespacing="125%"
      +

      Coordinates and identity where the text will appear +

      +
             freecad:editable="AuthorName"><tspan
      +

      Here AuthorName is the var managed by freecad:editable who saves the string to change that will be displayed +

      +
               sodipodi:role="line"
      +         id="tspan3333"
      +         x="220.9935"
      +         y="228.95425">AUTHOR NAME</tspan></text>
      +

      Coordinates and identity of the text that is displayed by default and </text> means the end of the block text +

      +
          <text
      +    ...
      +    ...
      +    ...
      +    ... </text>
      +  </g>
      +

      Other blocks texts and end </g> the framework grouping text blocks +

      It is possible after having worked the Inkscape SVG file as the file no longer works, it is possible that information has gone missing. +

      Then check that the edit text is not modified +

      Example : +

      +
      • editable = "AuthorName"
      • +
      • replace by freecad:editable = "AuthorName"
      +

      Other attributes availlables

      +

      See Drawing_templates +

      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Swept-path_Analysis_GSoC_Project.html b/localwiki/Swept-path_Analysis_GSoC_Project.html new file mode 100644 index 0000000..23502d8 --- /dev/null +++ b/localwiki/Swept-path_Analysis_GSoC_Project.html @@ -0,0 +1,58 @@ +Swept-path Analysis GSoC Project

      Swept-path Analysis GSoC Project

      + +

      This page is describes a potential 2018 Google Summer of Code project regarding configuration management for the FreeCAD CAE application. +

      + + +

      Outline

      +

      In Transportation Engineering, a common need is a "swept-path analysis", which simply analyzes the path a vehicle takes as it turns a corner. Vehicles of differing dimensions and wheel bases, obviously, have different turning capabilities, so it's necessary to ensure public facilities are designed to accommodate the least agile vehicles that are expected to use it. +

      Commercial packages exist which do this. The industry standard in the US is AutoTURN and sells for about $12,000 per license. Despite the price, the technology and theory behind the software has been known and understood for well over 50 years. Yet, apart from one freeware (closed source) option, no freely available tools to perform this analysis exist. +

      +

      Details

      +
      1. Develop a simple database (a CSV file) which contains the key parameters for the design vehicles used in the analysis. This data includes parameters like vehicle height, length, width, axle count, wheel base, and others.
      2. +
      3. Develop several generic vehicle templates as separate sketches into which the database parameters can be fed to create a template which represents a real-world vehicle.
      4. +
      5. Create a Part-based geometry from the sketch object representing the design vehicle and generate a mesh
      6. +
      7. Import a data file (DXF) which contains the roadway gemetry on which to run the analysis.
      8. +
      9. Choose lines from the imported file which act as boundaries for the analysis collision detection.
      +

      Expected Outcome

      +
      1. Accomplishing these items would provide the basis for performing swept path analyses in FreeCAD.
      +

      Future Possibilities

      +

      This work will provide exposure to highway design techniques. +

      +

      Project Properties

      +

      Skills

      +
      • Familiarity with +
      +

      Difficulty

      +

      Medium +

      +

      Additional Information

      +

      FreeCAD Civil Engineering Thread +

      + + +
      + +
      +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Switch_DraftWorkbench.JPG b/localwiki/Switch_DraftWorkbench.JPG new file mode 100644 index 0000000..a3be577 Binary files /dev/null and b/localwiki/Switch_DraftWorkbench.JPG differ diff --git a/localwiki/Switch_PartWorkbench.JPG b/localwiki/Switch_PartWorkbench.JPG new file mode 100644 index 0000000..1a52b0f Binary files /dev/null and b/localwiki/Switch_PartWorkbench.JPG differ diff --git a/localwiki/Symmetrie.svg b/localwiki/Symmetrie.svg new file mode 100644 index 0000000..f699ff2 --- /dev/null +++ b/localwiki/Symmetrie.svg @@ -0,0 +1,130 @@ + + + + + Symmetrie + + + + + + image/svg+xml + + Symmetrie + + + bavariaSHAPE + + + + + bavariaSHAPE + + + + + bavariaSHAPE + + + 15.10.2016 + Geometric dimensioning and tolerancing symbols +All symbols in this repository are licensed under CC-BY 3.0 + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/System-log-out.svg b/localwiki/System-log-out.svg new file mode 100644 index 0000000..0e10988 --- /dev/null +++ b/localwiki/System-log-out.svg @@ -0,0 +1,456 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + Jakub Steiner + + + http://jimmac.musichall.cz + + System Log Out + + + log out + logout + exit + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/TBHS-0.png b/localwiki/TBHS-0.png new file mode 100644 index 0000000..5e1b397 Binary files /dev/null and b/localwiki/TBHS-0.png differ diff --git a/localwiki/TBHS-model.png b/localwiki/TBHS-model.png new file mode 100644 index 0000000..67fd833 Binary files /dev/null and b/localwiki/TBHS-model.png differ diff --git a/localwiki/Tache_Placement_Lacet_fr_Mini.gif b/localwiki/Tache_Placement_Lacet_fr_Mini.gif new file mode 100644 index 0000000..33e080b Binary files /dev/null and b/localwiki/Tache_Placement_Lacet_fr_Mini.gif differ diff --git a/localwiki/Tache_Placement_Roulis_fr_Mini.gif b/localwiki/Tache_Placement_Roulis_fr_Mini.gif new file mode 100644 index 0000000..b4acf82 Binary files /dev/null and b/localwiki/Tache_Placement_Roulis_fr_Mini.gif differ diff --git a/localwiki/Tache_Placement_Tangage_fr_Mini.gif b/localwiki/Tache_Placement_Tangage_fr_Mini.gif new file mode 100644 index 0000000..08b2882 Binary files /dev/null and b/localwiki/Tache_Placement_Tangage_fr_Mini.gif differ diff --git a/localwiki/Tache_Placement_en_02.png b/localwiki/Tache_Placement_en_02.png new file mode 100644 index 0000000..b5b0fd1 Binary files /dev/null and b/localwiki/Tache_Placement_en_02.png differ diff --git a/localwiki/Tache_Placement_en_03.png b/localwiki/Tache_Placement_en_03.png new file mode 100644 index 0000000..1369d05 Binary files /dev/null and b/localwiki/Tache_Placement_en_03.png differ diff --git a/localwiki/Tache_Placement_fr_01.png b/localwiki/Tache_Placement_fr_01.png new file mode 100644 index 0000000..f9203c6 Binary files /dev/null and b/localwiki/Tache_Placement_fr_01.png differ diff --git a/localwiki/Tasks_Placement.html b/localwiki/Tasks_Placement.html new file mode 100644 index 0000000..d773236 --- /dev/null +++ b/localwiki/Tasks_Placement.html @@ -0,0 +1,109 @@ +Tasks Placement

      Tasks Placement

      + +
      + +

      Description

      +

      Command for modifying Placement. +These options relate only to the position and orientation of the object in space, they do not affect other attributes of the shape. The placement is stored internally as a position, and a rotation (rotation axis and angle transformed into a quaternion [1]). While there are several methods to specify a rotation, for instance with a rotation center, this is only used to affect the rotation computation and is not stored for later operations. Similarly, if a rotation axis of (1,1,1) is specified, it may be normalized when stored in the quaternion and appear as (0.58, 0.58, 0.58) when browsing the object later. +

      +

      Usage

      +

      The function Placement can be accessed in several ways: +

      +
      • via script Python in the console and its API.
      +

      Scripting Placement as y/p/r and Matrix +

      +
      • or, in the window Combo View → Properties → Data → Placement → ...,
      +

      Task_Placement +

      +
      • or by the menu Edit → Placement....
      +


      +

      +

      Enable Placement in Combo View

      +
      • Click a shape to select it.
      • +
      • Click Placement (the title, not the little arrow), and a button with three dots appears: Tache_Placement
      • +
      • click on this button, and the Placement Dialog is displayed:
      +


      +

      +
      Tache Placement en 02.png
      +


      +

      +

      Options

      +

      Translation:

      +
      • TASKS X Translation in X direction (Click to enlarge) Moves the coordinate system of the object in the X direction in relation to the axis coordinates of origin 0, 0, 0.
      • +
      • TASKS Y Translation in the Y direction (Click to enlarge) Moves the coordinate system of the object in the Y direction in relation to the axis coordinates of origin 0, 0, 0.
      • +
      • TASKS Z Translation in the Z direction (Click to enlarge) Moves the coordinate system of the object in the Z direction in relation to the axis coordinates of origin 0, 0, 0.
      +

      Center

      +
      • TASKS X: Move the center of rotation in the direction X, from the coordinates of the selected object. (default: 0,0,0).
      • +
      • TASKS Y: Move the center of rotation in the direction Y from the coordinates of the selected object. (default: 0,0,0).
      • +
      • TASKS Z: Move the center of rotation in the direction Z, from the coordinates of the selected object. (default: 0,0,0).
      • +
      • TASKS User Defined ... : Allows you to change the three axes ( X, Y, Z) in a single operation User Defined.
      +

      Rotation

      +

      To adjust our rotation parameters we have two methods available. +

      +
      • First option. Select Rotation axis with angle Tache_Placement Option rotation axis and angle (Default). +
        • TASKS Axis: X: The rotation will be on the X axis.
        • +
        • TASKS Axis: Y: The rotation will be on the Y axis.
        • +
        • TASKS Axis: Z: The rotation will be on the Z axis. (Default axis).
        • +
        • TASKS Angle: Angle of rotation in degrees from -360.00 ° to 360.00 °. (Default: 0.00°).
      +
      • Second option. Select Euler Angles Tache_Placement Option Euler angles.
      +

      This option may be easier to work with, however, even in this mode, there are important things to remember: +Positive rotations are in the clockwise direction, looking out from the origin along a positive axis. Or to put it differently, the rotations are positive in the counterclockwise direction, looking in to the origin along a positive axis. +

      +
      • Yaw : is a horizontal rotation of a body about a vertical axis. (The symbol ψ is often used for yaw.)
      • +
      • Pitch : is defined as an oscillating movement of a vessel fore and aft.
      • +
      • Roll : is a rotary movement of a body about its longitudinal axis (roll axis).
      +

      Yaw, pitch and roll refer to the attitude of an object in 3D space. These terms are commonly used in aviation. +The angles are the Tait-Bryan angles. If you want more information, try Euler angles. +

      +
      Option Euler angles
      +
      +


      +

      Yaw +

      +
      • TASKS yaw axis Yaw is the rotation about the Z axis, that is to say a rotation from left to right. (The yaw angle is the Psi ψ). Value -360.00 ° to 360, 00 ° (Def, 0.00 °).
      +


      +Pitch +

      +
      • TASKS pitch axis Pitch is rotation about the Y axis, that is to say nose-up and nose-down. (The Pitch angle is the Phi φ). Value -360.00 ° to 360, 00 ° (Default, 0.00 °).
      +


      +Roll +

      +
      • TASKS roll axis Roll is rotation about the X axis, that is to say wing up and down. (The Roll angle is the Thêta θ). Value -360.00 ° to 360, 00 ° (Default, 0.00 °).
      +


      +

      +
      • TASKS Apply incremental changes to the placement of the object: Once selected, this option virtually sets all parameters to zero, to allow you to enter your values ​​without having to calculate with the original parameters of the form. Once you have confirmed with OK, the entered values ​​will be added to the values ​​on the form.
      +
      • The Reset returns all values ​​to 0,0,0.
      +

      Links and Example

      +

      A practical example of using this command is in the tutorial Aeroplane. +

      Other explanation on Placement +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/TechDrawGui_API.html b/localwiki/TechDrawGui_API.html new file mode 100644 index 0000000..a76cebe --- /dev/null +++ b/localwiki/TechDrawGui_API.html @@ -0,0 +1,56 @@ +TechDrawGui API

      TechDrawGui API

      + +

      These functions are part of the TechDrawGui module and can be used in scripts and macros or from the python interpreter, once the TechDrawGui module has been imported. +

      See the TechDraw API for more functions. +

      Example: +

      +
      import FreeCAD
      +import TechDrawGui
      +
      +p = FreeCAD.ActiveDocument.Page
      +
      +f = "/home/localuser/myPdfDirectory/savePage.pdf"
      +TechDrawGui.exportPageAsPdf(p,f)
      +
      +f = "/home/localuser/mySvgDirectory/savePage.svg"
      +TechDrawGui.exportPageAsSvg(p,f) 
      +


      +

      +
      +
      Method.png exportPageAsPdf ( pageObject, filePath )
      +
      +

      Description: save a copy of pageObject in Pdf format to location filePath +

      Returns: none +

      +
      +
      +


      +

      +
      +
      Method.png exportPageAsSvg ( pageObject, filePath )
      +
      +

      Description: save a copy of pageObject in Svg format to location filePath +

      Returns: none +

      +
      +
      +


      +


      +Back to TechDraw. +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/TechDraw_API.html b/localwiki/TechDraw_API.html new file mode 100644 index 0000000..c68acd8 --- /dev/null +++ b/localwiki/TechDraw_API.html @@ -0,0 +1,130 @@ +TechDraw API

      TechDraw API

      + +

      These functions are part of the TechDraw module and can be used in scripts and macros or from the python interpreter, once the TechDraw module has been imported. Good examples of basic TechDraw scripting can be found in the unit test scripts. +

      See the TechDrawGui module API for more functions. +

      Example: +

      +
      import FreeCAD
      +import TechDraw
      +page = FreeCAD.ActiveDocument.addObject('TechDraw::DrawPage','Page')
      +FreeCAD.ActiveDocument.addObject('TechDraw::DrawSVGTemplate','Template')
      +FreeCAD.ActiveDocument.Template.Template = templateFileSpec
      +FreeCAD.ActiveDocument.Page.Template = FreeCAD.ActiveDocument.Template
      +page.ViewObject.show()
      +view = FreeCAD.ActiveDocument.addObject('TechDraw::DrawViewPart','View')
      +rc = page.addView(view) 
      +


      +

      +
      +
      Method.png EdgeWalker ( listOfEdges, [bool] )
      +
      +

      Description: Creates wires from edges in input by planar graph traversal. Optionally exclude the OuterWire by setting optional parameter to false. +

      Returns: List of wires sorted by size (descending) +

      +
      +
      +


      +

      +
      +
      Method.png findOuterWire ( listOfEdges )
      +
      +

      Description: Finds the OuterWire (largest) of a list of edges (that form a planar graph). +

      Returns: Outer wire +

      +
      +
      +


      +

      +
      +
      Method.png findShapeOutline ( TopoShape, scale, direction )
      +
      +

      Description: Project shape in direction and find outer wire of result. +

      Returns: Outline wire +

      +
      +
      +


      +

      +
      +
      Method.png viewPartAsDxf ( DrawViewPart )
      +
      +

      Description: Return the edges of a DrawViewPart in Dxf format. +

      Returns: String +

      +
      +
      +


      +

      +Example
      fileSpecDxf = "fcOut.dxf"
      +v = App.ActiveDocument.View
      +s = TechDraw.viewPartAsDxf(v)
      +dxfEnd = "0\nEOF\n"
      +dxfFile = open(fileSpecDxf, "w")
      +dxfFile.write(s)
      +dxfFile.write(dxfEnd)
      +dxfFile.close() 
      +
      +
      Method.png viewPartAsSvg ( DrawViewPart )
      +
      +

      Description: Return the edges of a DrawViewPart in Svg format. +

      Returns: String +

      +
      +
      +


      +

      +Example
      fileSpecSvg = "fcOut.svg"
      +v = App.ActiveDocument.View
      +s = TechDraw.viewPartAsSvg(v)
      +head = '<svg\n' + \
      +       'xmlns="http://www.w3.org/2000/svg" version="1.1" \n' + \
      +       'xmlns:freecad="http://www.freecadweb.org/wiki/index.php?title=Svg_Namespace">\n'
      +tail = '\n</svg>'
      +svgFile = open(fileSpecSvg, "w")
      +svgFile.write(head)
      +svgFile.write(s)
      +svgFile.write(tail)
      +svgFile.close() 
      +
      +
      Method.png writeDXFView ( DrawViewPart, FileName )
      +
      +

      Description: Save the DrawViewPart in Dxf. +

      Returns: File +

      +
      +
      +


      +

      +Example
      import TechDraw
      +TechDraw.writeDXFView(myPart,myFileName) 
      +
      +
      Method.png writeDXFPage ( DrawPage, FileName )
      +
      +

      Description: Save the DrawPage in Dxf. +

      Returns: File +

      +
      +
      +


      +

      +Example
      import TechDraw
      +TechDraw.writeDXFPage(myPage,myFileName) 
      +


      +Back to TechDraw. +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/TechDraw_Arch_example.jpg b/localwiki/TechDraw_Arch_example.jpg new file mode 100644 index 0000000..9246157 Binary files /dev/null and b/localwiki/TechDraw_Arch_example.jpg differ diff --git a/localwiki/TechDraw_Arch_piping.jpg b/localwiki/TechDraw_Arch_piping.jpg new file mode 100644 index 0000000..0ab4d80 Binary files /dev/null and b/localwiki/TechDraw_Arch_piping.jpg differ diff --git a/localwiki/TechDraw_Arch_rendering.jpg b/localwiki/TechDraw_Arch_rendering.jpg new file mode 100644 index 0000000..ebe5aeb Binary files /dev/null and b/localwiki/TechDraw_Arch_rendering.jpg differ diff --git a/localwiki/TechDraw_Clip.html b/localwiki/TechDraw_Clip.html new file mode 100644 index 0000000..d43b7ba --- /dev/null +++ b/localwiki/TechDraw_Clip.html @@ -0,0 +1,71 @@ +TechDraw Clip

      TechDraw Clip

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      TechDraw Clip.png TechDraw Clip

      +
      Menu location +
      TechDraw → Clip +
      Workbenches +
      TechDraw +
      Default shortcut +
      +
      See also +
      TechDraw_ClipPlus TechDraw_ClipMinus +

      + +
      +


      +

      +

      Description

      +

      This tool creates a clipping window which can contain one or more Views. +

      +
      TechDraw Clipview.png
      +

      How to use

      +
      1. Press the TechDraw Clip.png TechDraw Clip button to create a new Clip.
      +

      Properties

      +
      • DATAWidth: The width of the clipping window in units
      • +
      • DATAHeight: The height of the clipping window in units
      • +
      • DATAShowFrame: When true, show a frame around the clipping window
      • +
      • DATAShowLabels: When true, show the Labels of the Views within the clipping window
      • +
      • DATAViews: The Views contained in the clipping window
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/TechDraw_ClipMinus.html b/localwiki/TechDraw_ClipMinus.html new file mode 100644 index 0000000..cae82a7 --- /dev/null +++ b/localwiki/TechDraw_ClipMinus.html @@ -0,0 +1,66 @@ +TechDraw ClipMinus

      TechDraw ClipMinus

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      TechDraw ClipMinus.png TechDraw ClipMinus

      +
      Menu location +
      TechDraw → ClipMinus +
      Workbenches +
      TechDraw +
      Default shortcut +
      +
      See also +
      TechDraw_Clip TechDraw_ClipPlus +

      + +
      +


      +

      +

      Description

      +

      This tool removes a View from an existing Clip and returns it to the Page area. +

      +
      TechDraw Clipview.png
      +

      How to use

      +
      1. Select a View that is part of a Clip and press the TechDraw ClipMinus.png TechDraw ClipMinus button to remove the view.
      +


      +

      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/TechDraw_ClipPlus.html b/localwiki/TechDraw_ClipPlus.html new file mode 100644 index 0000000..1370dfc --- /dev/null +++ b/localwiki/TechDraw_ClipPlus.html @@ -0,0 +1,66 @@ +TechDraw ClipPlus

      TechDraw ClipPlus

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      TechDraw ClipPlus.png TechDraw ClipPlus

      +
      Menu location +
      TechDraw → ClipPlus +
      Workbenches +
      TechDraw +
      Default shortcut +
      +
      See also +
      TechDraw_Clip TechDraw_ClipMinus +

      + +
      +


      +

      +

      Description

      +

      This tool adds a View to an existing Clip. +

      +
      TechDraw Clipview.png
      +

      How to use

      +
      1. Select a Clip and a View and press the TechDraw ClipPlus.png TechDraw ClipPlus button to add the view.
      +


      +

      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/TechDraw_Clipview.png b/localwiki/TechDraw_Clipview.png new file mode 100644 index 0000000..1dc495e Binary files /dev/null and b/localwiki/TechDraw_Clipview.png differ diff --git a/localwiki/TechDraw_Dimension.svg b/localwiki/TechDraw_Dimension.svg new file mode 100644 index 0000000..06ca826 --- /dev/null +++ b/localwiki/TechDraw_Dimension.svg @@ -0,0 +1,335 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [WandererFan] + + + TechDraw_Dimension + 2016-04-27 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/TechDraw/Gui/Resources/icons/TechDraw_Dimension.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + arrow + double arrow + diagonal + + + Double arrow at an angle between two diagonal lines + + + + + + + + + + + + + + + + + diff --git a/localwiki/TechDraw_Dimension_Angle.html b/localwiki/TechDraw_Dimension_Angle.html new file mode 100644 index 0000000..12b00a3 --- /dev/null +++ b/localwiki/TechDraw_Dimension_Angle.html @@ -0,0 +1,94 @@ +TechDraw Dimension Angle

      TechDraw Dimension Angle

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      TechDraw Dimension Angle.png TechDraw Dimension Angle

      +
      Menu location +
      TechDraw → Dimension Angle +
      Workbenches +
      TechDraw +
      Default shortcut +
      +
      See also +
      +

      + +
      +


      +

      +

      Description

      +

      The Dimension Angle tool adds a angular dimension to a View. The dimension may be the interior angle between any two straight line edges. The angle will initially be the projected angle (ie as shown on the drawing), but this may be changed to the actual 3D angle using the Link Dimension LinkDimension.png tool. +

      +
      AngleSample.png
      +

      How to use

      +
      1. Select the points or edge which define your measurement.
      2. +
      3. Press the Dimension Angle.png Dimension Angle button
      4. +
      5. A dimension will be added to the View. The dimension may be dragged to the desired position.
      +

      Options

      +

      None. +

      +

      Properties

      +
      • DATAX: Horizontal position of the dimension text relative to the View.
      • +
      • DATAY: Vertical position of the dimension text relative to the View.
      • +
      • DATAFormatSpec: Allows additional text to be added to the dimension text. Dimension value will replace %.2f (or other valid printf format specifier).
      • +
      • DATAType: Length,radius,diameter, etc. Not normally manipulated by the end user.
      • +
      • DATAMeasureType: "True" - based on 3D geometry or "Projected" - based on the drawing. Not normally manipulated directly by the end user.
      • +
      • DATAArbitrary: "True" - ignore actual value and display FormatSpec as value. "False" - use actual value.
      • +
      • VIEWFont: The name of the font to use for the dimension text.
      • +
      • VIEWFontsize: Dimension text size in mm.
      • +
      • VIEWLineWidth: Dimension line weight.
      • +
      • VIEWColor: Color for lines and text.
      +

      Scripting

      +

      Angle dimensions can be added to Pages using Python. +

      +
      dim1 = FreeCAD.ActiveDocument.addObject('TechDraw::DrawViewDimension','Dimension')
      +dim1.Type = "Angle"
      +dim1.References2D=[(view1, 'Edge1')]
      +rc = page.addView(dim1) 
      +

      Notes

      +
      • None at this time
      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/TechDraw_Dimension_Angle.png b/localwiki/TechDraw_Dimension_Angle.png new file mode 100644 index 0000000..c997ef5 Binary files /dev/null and b/localwiki/TechDraw_Dimension_Angle.png differ diff --git a/localwiki/TechDraw_Dimension_Angle.svg b/localwiki/TechDraw_Dimension_Angle.svg new file mode 100644 index 0000000..c52c386 --- /dev/null +++ b/localwiki/TechDraw_Dimension_Angle.svg @@ -0,0 +1,415 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [WandererFan] + + + TechDraw_Dimension_Angle + 2016-04-27 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/TechDraw/Gui/Resources/icons/TechDraw_Dimension_Angle.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/TechDraw_Dimension_Diameter.html b/localwiki/TechDraw_Dimension_Diameter.html new file mode 100644 index 0000000..8564f89 --- /dev/null +++ b/localwiki/TechDraw_Dimension_Diameter.html @@ -0,0 +1,94 @@ +TechDraw Dimension Diameter

      TechDraw Dimension Diameter

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      TechDraw Dimension Diameter.png TechDraw Dimension Diameter

      +
      Menu location +
      TechDraw → Dimension Diameter +
      Workbenches +
      TechDraw +
      Default shortcut +
      +
      See also +
      +

      + +
      +


      +

      +

      Description

      +

      The Dimension Diameter tool adds a diameter dimension to a View. The dimension may be applied to any circular in the drawing. The distance will initially be the projected distance (ie as shown on the drawing), but this may be changed to the actual 3D distance using the Link Dimension LinkDimension.png tool. +

      +
      DiameterSample.png
      +

      How to use

      +
      1. Select a circular edge in the drawing. (Note some arcs which appear to be circular are actually ellipses or BSplines. You cannot make a diameter dimension in these cases)
      2. +
      3. Press the Dimension Diameter.png Dimension Diameter button
      4. +
      5. A dimension will be added to the View. The dimension may be dragged to the desired position.
      +

      Options

      +

      None. +

      +

      Properties

      +
      • DATAX: Horizontal position of the dimension text relative to the View.
      • +
      • DATAY: Vertical position of the dimension text relative to the View.
      • +
      • DATAFormatSpec: Allows additional text to be added to the dimension text. Dimension value will replace %.2f (or other valid printf format specifier).
      • +
      • DATAType: Length,radius,diameter, etc. Not normally manipulated by the end user.
      • +
      • DATAMeasureType: "True" - based on 3D geometry or "Projected" - based on the drawing. Not normally manipulated directly by the end user.
      • +
      • DATAArbitrary: "True" - ignore actual value and display FormatSpec as value. "False" - use actual value.
      • +
      • VIEWFont: The name of the font to use for the dimension text.
      • +
      • VIEWFontsize: Dimension text size in mm.
      • +
      • VIEWLineWidth: Dimension line weight.
      • +
      • VIEWColor: Color for lines and text.
      +

      Scripting

      +

      Diameter dimensions can be added to Pages using Python. +

      +
      dim1 = FreeCAD.ActiveDocument.addObject('TechDraw::DrawViewDimension','Dimension')
      +dim1.Type = "Diameter"
      +dim1.References2D=[(view1, 'Edge1')]
      +rc = page.addView(dim1) 
      +

      Notes

      +
      • All Dimensions are extremely vulnerable to the infamous "topological naming" issue. It is not possible at this time to keep references to 2D (projected) or 3D (actual) geometrical objects in sync with changes in the model. It is recommended that Dimensions be added towards the end of the drawing creation process.
      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/TechDraw_Dimension_Diameter.svg b/localwiki/TechDraw_Dimension_Diameter.svg new file mode 100644 index 0000000..862e92b --- /dev/null +++ b/localwiki/TechDraw_Dimension_Diameter.svg @@ -0,0 +1,323 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [WandererFan] + + + TechDraw_Dimension_Diameter + 2016-04-27 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/TechDraw/Gui/Resources/icons/TechDraw_Dimension_Diameter.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + double arrow + circle + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/TechDraw_Dimension_Horizontal.html b/localwiki/TechDraw_Dimension_Horizontal.html new file mode 100644 index 0000000..cc18fcc --- /dev/null +++ b/localwiki/TechDraw_Dimension_Horizontal.html @@ -0,0 +1,94 @@ +TechDraw Dimension Horizontal

      TechDraw Dimension Horizontal

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      TechDraw Dimension Horizontal.png TechDraw Dimension Horizontal

      +
      Menu location +
      TechDraw → Dimension Horizontal +
      Workbenches +
      TechDraw +
      Default shortcut +
      +
      See also +
      +

      + +
      +


      +

      +

      Description

      +

      The Dimension Horizontal tool adds a horizontal dimension to a View. The dimension may be between two vertices, the length of one edge or the horizontal distance between 2 edges. The distance will initially be the projected distance (ie as shown on the drawing), but this may be changed to the actual 3D distance using the Link Dimension LinkDimension.png tool. +

      +
      HorizontalSample.png
      +

      How to use

      +
      1. Select the points or edge which define your measurement.
      2. +
      3. Press the Dimension Horizontal.png Dimension Horizontal button
      4. +
      5. A dimension will be added to the View. The dimension may be dragged to the desired position.
      +

      Options

      +

      None. +

      +

      Properties

      +
      • DATAX: Horizontal position of the dimension text relative to the View.
      • +
      • DATAY: Vertical position of the dimension text relative to the View.
      • +
      • DATAFormatSpec: Allows additional text to be added to the dimension text. Dimension value will replace %.2f (or other valid printf format specifier).
      • +
      • DATAType: Length,radius,diameter, etc. Not normally manipulated by the end user.
      • +
      • DATAMeasureType: "True" - based on 3D geometry or "Projected" - based on the drawing. Not normally manipulated directly by the end user.
      • +
      • DATAArbitrary: "True" - ignore actual value and display FormatSpec as value. "False" - use actual value.
      • +
      • VIEWFont: The name of the font to use for the dimension text.
      • +
      • VIEWFontsize: Dimension text size in mm.
      • +
      • VIEWLineWidth: Dimension line weight.
      • +
      • VIEWColor: Color for lines and text.
      +

      Scripting

      +

      Horizonatal dimensions can be added to Pages using Python. +

      +
      dim1 = FreeCAD.ActiveDocument.addObject('TechDraw::DrawViewDimension','Dimension')
      +dim1.Type = "DistanceX"
      +dim1.References2D=[(view1, 'Edge1')]
      +rc = page.addView(dim1) 
      +

      Notes

      +
      • All Dimensions are extremely vulnerable to the infamous "topological naming" issue. It is not possible at this time to keep references to 2D (projected) or 3D (actual) geometrical objects in sync with changes in the model. It is recommended that Dimensions be added towards the end of the drawing creation process.
      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/TechDraw_Dimension_Horizontal.svg b/localwiki/TechDraw_Dimension_Horizontal.svg new file mode 100644 index 0000000..06ce142 --- /dev/null +++ b/localwiki/TechDraw_Dimension_Horizontal.svg @@ -0,0 +1,309 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [WandererFan] + + + TechDraw_Dimension_Horizontal + 2016-04-27 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/TechDraw/Gui/Resources/icons/TechDraw_Dimension_Horizontal.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + Double arrow between two bars + + + double arrow + arrow + horizontal + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/TechDraw_Dimension_Length.html b/localwiki/TechDraw_Dimension_Length.html new file mode 100644 index 0000000..baafb20 --- /dev/null +++ b/localwiki/TechDraw_Dimension_Length.html @@ -0,0 +1,94 @@ +TechDraw Dimension Length

      TechDraw Dimension Length

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      TechDraw Dimension Length.png TechDraw Dimension Length

      +
      Menu location +
      TechDraw → Dimension Length +
      Workbenches +
      TechDraw +
      Default shortcut +
      +
      See also +
      +

      + +
      +


      +

      +

      Description

      +

      The Dimension Length tool adds a linear dimension to a View. The dimension may be between the distance between two vertices, the length of one edge or the distance between 2 edges. The distance will initially be the projected distance (ie as shown on the drawing), but this may be changed to the actual 3D distance using the Link Dimension LinkDimension.png tool. +

      +
      LengthSample.png
      +

      How to use

      +
      1. Select the points or edge which define your measurement.
      2. +
      3. Press the TechDraw Dimension Length.png Dimension Length button
      4. +
      5. A dimension will be added to the View. The dimension may be dragged to the desired position.
      +

      Options

      +

      None. +

      +

      Properties

      +
      • DATAX: Horizontal position of the dimension text relative to the View.
      • +
      • DATAY: Vertical position of the dimension text relative to the View.
      • +
      • DATAFormatSpec: Allows additional text to be added to the dimension text. Dimension value will replace %.2f (or other valid printf format specifier).
      • +
      • DATAType: Length,radius,diameter, etc. Not normally manipulated by the end user.
      • +
      • DATAMeasureType: "True" - based on 3D geometry or "Projected" - based on the drawing. Not normally manipulated directly by the end user.
      • +
      • DATAArbitrary: "True" - ignore actual value and display FormatSpec as value. "False" - use actual value.
      • +
      • VIEWFont: The name of the font to use for the dimension text.
      • +
      • VIEWFontsize: Dimension text size in mm.
      • +
      • VIEWLineWidth: Dimension line weight.
      • +
      • VIEWColor: Color for lines and text.
      +

      Scripting

      +

      Distance dimensions can be added to Pages using Python. +

      +
      dim1 = FreeCAD.ActiveDocument.addObject('TechDraw::DrawViewDimension','Dimension')
      +dim1.Type = "Distance"
      +dim1.References2D=[(view1, 'Edge1')]
      +rc = page.addView(dim1) 
      +

      Notes

      +
      • All Dimensions are extremely vulnerable to the infamous "topological naming" issue. It is not possible at this time to keep references to 2D (projected) or 3D (actual) geometrical objects in sync with changes in the model. It is recommended that Dimensions be added towards the end of the drawing creation process.
      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/TechDraw_Dimension_Length.svg b/localwiki/TechDraw_Dimension_Length.svg new file mode 100644 index 0000000..3fdd9e7 --- /dev/null +++ b/localwiki/TechDraw_Dimension_Length.svg @@ -0,0 +1,334 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [WandererFan] + + + TechDraw_Dimension_Length + 2016-04-27 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/TechDraw/Gui/Resources/icons/TechDraw_Dimension_Length.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + double arrow + diagonal + arrow + + + Double arrow at angle between two diagonal bars + + + + + + + + + + + + + + + + + diff --git a/localwiki/TechDraw_Dimension_Link.html b/localwiki/TechDraw_Dimension_Link.html new file mode 100644 index 0000000..21ea713 --- /dev/null +++ b/localwiki/TechDraw_Dimension_Link.html @@ -0,0 +1,85 @@ +TechDraw Dimension Link

      TechDraw Dimension Link

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      TechDraw Dimension Link.png TechDraw Dimension Link

      +
      Menu location +
      TechDraw → Dimension Link +
      Workbenches +
      TechDraw +
      Default shortcut +
      ? ? +
      See also +
      +

      + +
      +


      +

      +

      Description

      +

      The Dimension Link tool creates a link between 3D geometry and 1 or more Dimensions on a Page. This link allows the Dimension to use actual 3D values instead of 2D projected values. +

      +

      How to use

      +
      1. Create your Dimension on the drawing page as usual.
      2. +
      3. Select geometry (ex an Edge) in the 3D model view that corresponds to one of your Dimensions.
      4. +
      5. Press the TechDraw Dimension Link.png Dimension Link button
      6. +
      7. A dialog will open. Select 1 or more Dimensions to be linked to the selected 3D geometry.
      8. +
      9. Press "OK"
      +

      Options

      +

      None. +

      +

      Properties

      +
      1. The MeasureType property of a linked Dimension will be changed from "Projected" to "True".
      +

      Scripting

      +

      Dimensions can be linked to 3D geometry using Python. +

      +
      tbd 
      +

      Limitations

      +
      1. Dimension links are very sensitive to the "Topological Naming" problem. It is recommended that linking Dimensions be one of the last steps in your process.
      2. +
      3. The Link tool will not stop you from making illogical links.
      4. +
      5. There is currently no way to break a link. You can change the MeasureType back to Projected and the Dimension will use the Projected value instead of the True value.
      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/TechDraw_Dimension_Link.svg b/localwiki/TechDraw_Dimension_Link.svg new file mode 100644 index 0000000..fec78eb --- /dev/null +++ b/localwiki/TechDraw_Dimension_Link.svg @@ -0,0 +1,412 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [WandererFan] + + + TechDraw_Dimension_Link + 2016-04-27 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/TechDraw/Gui/Resources/icons/TechDraw_Dimension_Link.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + chain + link + ellipse + + + Two links of a chain + + + + + + + + + + + + + + + + + diff --git a/localwiki/TechDraw_Dimension_Radius.html b/localwiki/TechDraw_Dimension_Radius.html new file mode 100644 index 0000000..bc8accd --- /dev/null +++ b/localwiki/TechDraw_Dimension_Radius.html @@ -0,0 +1,94 @@ +TechDraw Dimension Radius

      TechDraw Dimension Radius

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      TechDraw Dimension Radius.png TechDraw Dimension Radius

      +
      Menu location +
      TechDraw → Dimension Radius +
      Workbenches +
      TechDraw +
      Default shortcut +
      +
      See also +
      +

      + +
      +


      +

      +

      Description

      +

      The Dimension Radius tool adds a radius dimension to a View. The dimension may be applied to any Edge in the drawing which is a circle or circular arc. +

      +
      RadiusSample.png
      +

      How to use

      +
      1. Select a circle or circular arc in the drawing. (Note some arcs which appear to be circular are actually ellipses or BSplines. You cannot make a radius dimension in these cases)
      2. +
      3. Press the Dimension Radius.png Dimension Radius button
      4. +
      5. A dimension will be added to the View. The dimension may be dragged to the desired position.
      +

      Options

      +

      None. +

      +

      Properties

      +
      • DATAX: Horizontal position of the dimension text relative to the View.
      • +
      • DATAY: Vertical position of the dimension text relative to the View.
      • +
      • DATAFormatSpec: Allows additional text to be added to the dimension text. Dimension value will replace %.2f (or other valid printf format specifier).
      • +
      • DATAType: Length,radius,diameter, etc. Not normally manipulated by the end user.
      • +
      • DATAMeasureType: "True" - based on 3D geometry or "Projected" - based on the drawing. Not normally manipulated directly by the end user.
      • +
      • DATAArbitrary: "True" - ignore actual value and display FormatSpec as value. "False" - use actual value.
      • +
      • VIEWFont: The name of the font to use for the dimension text.
      • +
      • VIEWFontsize: Dimension text size in mm.
      • +
      • VIEWLineWidth: Dimension line weight.
      • +
      • VIEWColor: Color for lines and text.
      +

      Scripting

      +

      Radius dimensions can be added to Pages using Python. +

      +
      dim1 = FreeCAD.ActiveDocument.addObject('TechDraw::DrawViewDimension','Dimension')
      +dim1.Type = "Radius"
      +dim1.References2D=[(view1, 'Edge1')]
      +rc = page.addView(dim1) 
      +

      Notes

      +
      • All Dimensions are extremely vulnerable to the infamous "topological naming" issue. It is not possible at this time to keep references to 2D (projected) or 3D (actual) geometrical objects in sync with changes in the model. It is recommended that Dimensions be added towards the end of the drawing creation process.
      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/TechDraw_Dimension_Radius.svg b/localwiki/TechDraw_Dimension_Radius.svg new file mode 100644 index 0000000..e83c45f --- /dev/null +++ b/localwiki/TechDraw_Dimension_Radius.svg @@ -0,0 +1,410 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [WandererFan] + + + TechDraw_Dimension_Radius + 2016-04-27 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/TechDraw/Gui/Resources/icons/TechDraw_Dimension_Radius.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + arrow + radius + arc + + + Arrow pointing from centre to arc + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/TechDraw_Dimension_Vertical.html b/localwiki/TechDraw_Dimension_Vertical.html new file mode 100644 index 0000000..50e4465 --- /dev/null +++ b/localwiki/TechDraw_Dimension_Vertical.html @@ -0,0 +1,94 @@ +TechDraw Dimension Vertical

      TechDraw Dimension Vertical

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      TechDraw Dimension Vertical.png TechDraw Dimension Vertical

      +
      Menu location +
      TechDraw → Dimension Vertical +
      Workbenches +
      TechDraw +
      Default shortcut +
      +
      See also +
      +

      + +
      +


      +

      +

      Description

      +

      The Dimension Vertical tool adds a vertical dimension to a View. The dimension may be between two vertices, the length of one edge or the vertical distance between 2 edges. The distance will initially be the projected distance (ie as shown on the drawing), but this may be changed to the actual 3D distance using the Link Dimension LinkDimension.png tool. +

      +
      VerticalSample.png
      +

      How to use

      +
      1. Select the points or edge which define your measurement.
      2. +
      3. Press the Dimension Vertical.png Dimension Vertical button
      4. +
      5. A dimension will be added to the View. The dimension may be dragged to the desired position.
      +

      Options

      +

      None. +

      +

      Properties

      +
      • DATAX: Horizontal position of the dimension text relative to the View.
      • +
      • DATAY: Vertical position of the dimension text relative to the View.
      • +
      • DATAFormatSpec: Allows additional text to be added to the dimension text. Dimension value will replace %.2f (or other valid printf format specifier).
      • +
      • DATAType: Length,radius,diameter, etc. Not normally manipulated by the end user.
      • +
      • DATAMeasureType: "True" - based on 3D geometry or "Projected" - based on the drawing. Not normally manipulated directly by the end user.
      • +
      • DATAArbitrary: "True" - ignore actual value and display FormatSpec as value. "False" - use actual value.
      • +
      • VIEWFont: The name of the font to use for the dimension text.
      • +
      • VIEWFontsize: Dimension text size in mm.
      • +
      • VIEWLineWidth: Dimension line weight.
      • +
      • VIEWColor: Color for lines and text.
      +

      Scripting

      +

      Vertical dimensions can be added to Pages using Python. +

      +
      dim1 = FreeCAD.ActiveDocument.addObject('TechDraw::DrawViewDimension','Dimension')
      +dim1.Type = "DistanceX"
      +dim1.References2D=[(view1, 'Edge1')]
      +rc = page.addView(dim1) 
      +

      Notes

      +
      • All Dimensions are extremely vulnerable to the infamous "topological naming" issue. It is not possible at this time to keep references to 2D (projected) or 3D (actual) geometrical objects in sync with changes in the model. It is recommended that Dimensions be added towards the end of the drawing creation process.
      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/TechDraw_Dimension_Vertical.svg b/localwiki/TechDraw_Dimension_Vertical.svg new file mode 100644 index 0000000..9313f9a --- /dev/null +++ b/localwiki/TechDraw_Dimension_Vertical.svg @@ -0,0 +1,303 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [WandererFan] + + + TechDraw_Dimension_Vertical + 2016-04-27 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/TechDraw/Gui/Resources/icons/TechDraw_Dimension_Vertical.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + double arrow + arrow + vertical + + + Vertical double arrow between two bars + + + + + + + + + + + + + + + + + diff --git a/localwiki/TechDraw_Enhancement_Project.html b/localwiki/TechDraw_Enhancement_Project.html new file mode 100644 index 0000000..4bf125c --- /dev/null +++ b/localwiki/TechDraw_Enhancement_Project.html @@ -0,0 +1,62 @@ +TechDraw Enhancement Project

      TechDraw Enhancement Project

      + +

      This page is describes a potential 2018 Google Summer of Code project regarding updates to the FreeCAD Technical Drawing workbench (TechDraw). +

      + + +

      Outline

      +

      FreeCAD is first and foremost a 3D modeling tool. There are times, however, when we must produce 2D drawings for documentation, contracts, permits, etc. The Technical Drawing workbench (TechDraw) is used to produce basic technical drawings based on the 3D model. TechDraw is a recent addition to FreeCAD and requires many enhancements to bring it up to the level of sophistication seen in other workbenches. +

      +

      Details

      +
      1. The FreeCAD user community is very diverse. As such, they use a diverse collection of technical drawing standards. Currently the individual parameters that make up a drawing style must be selected individually. A system of managing groups of drawing parameters by standard is required.
      2. +
      3. Drawing tools to be added include the ability to add leaders and callouts drawings. This is a prerequisite to many enhancements, particularly in the drawing annotation area, such as feature control frames.
      4. +
      5. There is a need for Dimensions that do not rely on specific vertex/edges, but on extrema of the figure - for example, overall width/height. A related request is for an "arbitrary" measurement that can be added when an actual value can not be calculated automatically.
      6. +
      7. A "Broken View" is required to depict very large objects.
      8. +
      9. Conversion to Part Workbench 2D geometry. The Part Workbench was recently enhanced with a full suite of 2D geometry tools. These were not available when TechDraw was first coded. For future ease of maintenance, a single suite of 2D tools would be preferred.
      +

      Expected Outcome

      +
      1. A more robust and capable TechDraw workbench
      +

      Future Possibilities

      +

      This work will provide an introduction to the FreeCAD code base and the use of supporting software such as OpenCascade and Qt. +

      +

      Project Properties

      +

      Skills

      +
      • Programming language mainly C++, unit tests in python
      • +
      • Understand of FreeCAD API is obviously beneficial.
      • +
      • Familiarity with any or all of the following will be helpful +
        • Qt Graphics View Framework
        • +
        • Scalable Vector Graphics (SVG) standard
        • +
        • Regular expressions
      • +
      • Experience in using CAD software is beneficial
      • +
      • Exposure to technical drawing standards
      +

      Difficulty

      +

      Medium +

      +

      Additional Information

      + + + +
      + +
      +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/TechDraw_GeomHatch.html b/localwiki/TechDraw_GeomHatch.html new file mode 100644 index 0000000..d70dd0f --- /dev/null +++ b/localwiki/TechDraw_GeomHatch.html @@ -0,0 +1,91 @@ +TechDraw GeomHatch

      TechDraw GeomHatch

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      TechDraw GeomHatch.png TechDraw GeomHatch

      +
      Menu location +
      TechDraw → GeomHatch +
      Workbenches +
      TechDraw +
      Default shortcut +
      +
      See also +
      TechDraw Hatching +

      + +
      +


      +

      +

      Description

      +

      The Geometric Hatch tool fill a Face with a pattern based on an AutoDesk PAT hatching specification. A small set of sample patterns are available in ".../Mod/TechDraw/PAT/FCPAT.pat". +

      +

      How to use

      +
      1. Select an closed region in a View. The region will turn green.
      2. +
      3. Press the Techdraw-geomhatch.png Hatch button
      4. +
      5. a dialog will open where you may select your pattern, a scale for the pattern and a line weight.
      6. +
      7. You may need to press recompute View-rotate-right.png and/or "wiggle" the parent View to get the pattern to update.
      +

      Options

      +

      None. +

      +

      Properties

      +
      • DATASource: The View and Face to receive the hatch pattern.
      • +
      • DATAFile Pattern: The location of the PAT file to use.
      • +
      • DATAName Pattern: The name of the PAT specification within File Pattern.
      • +
      • DATAScale Pattern: The scale to be applied to the pattern (must be > 0.0).
      • +
      • VIEWWeight Pattern: The thickness of the pattern lines.
      • +
      • VIEWColor Pattern: The color for the pattern lines.
      +

      Scripting

      +

      Hatch can be added to areas in Views using Python. +

      +
      hatch = FreeCAD.ActiveDocument.addObject('TechDraw::DrawGeomHatch','GeomHatch')
      +hatch.Source = (view1,["Face0"])
      +hatch.FilePattern = "path/to/myPATfile.pat"
      +hatch.NamePattern = "Diamond"
      +rc = page.addView(hatch) 
      +

      Notes

      +
      • Note that geometric hatch patterns ARE included when a drawing page is saved as an Svg file.
      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/TechDraw_GeomHatch.png b/localwiki/TechDraw_GeomHatch.png new file mode 100644 index 0000000..cad649a Binary files /dev/null and b/localwiki/TechDraw_GeomHatch.png differ diff --git a/localwiki/TechDraw_Hatch.html b/localwiki/TechDraw_Hatch.html new file mode 100644 index 0000000..a7c4727 --- /dev/null +++ b/localwiki/TechDraw_Hatch.html @@ -0,0 +1,87 @@ +TechDraw Hatch

      TechDraw Hatch

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      TechDraw Hatch.png TechDraw Hatch

      +
      Menu location +
      TechDraw → Hatch +
      Workbenches +
      TechDraw +
      Default shortcut +
      +
      See also +
      TechDraw Hatching +

      + +
      +


      +

      +

      Description

      +

      The Hatch tool fills a closed region in a View with a Hatch pattern. Patterns are created as SVG or bitmap files. Sample SVG patterns are available in ".../Mod/Draft/Resources/patterns". +

      +

      How to use

      +
      1. Select an closed region in a View. The region will turn green.
      2. +
      3. Press the TechDraw Hatch.png Hatch button
      4. +
      5. You may need to press recompute View-rotate-right.png.
      +

      Options

      +

      None. +

      +

      Properties

      +
      • DATASource: The View and Face to receive the hatch pattern.
      • +
      • DATAHatch Pattern: Full path and filename to an SVG pattern file.
      • +
      • VIEWHatch Color: Hatch pattern will be displayed in this color.
      • +
      • VIEWHatch Scale: Hatch pattern size modifier.
      +

      Scripting

      +

      Hatch can be added to areas in Views using Python. +

      +
      hatch = FreeCAD.ActiveDocument.addObject('TechDraw::DrawHatch','Hatch')
      +hatch.Source = (view1,["Face0"])
      +hatch.HatchPattern = hatchFileSpec
      +rc = page.addView(hatch) 
      +

      Notes

      +
      • Note that Svg hatch patterns are not included when a drawing page is saved as an Svg file.
      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/TechDraw_Hatching.html b/localwiki/TechDraw_Hatching.html new file mode 100644 index 0000000..4ddffe9 --- /dev/null +++ b/localwiki/TechDraw_Hatching.html @@ -0,0 +1,75 @@ +TechDraw Hatching

      TechDraw Hatching

      + +
      + +

      Overview

      +

      TechDraw has two hatching tools: Techdraw-hatch.png Hatch Area(tile based) and Techdraw-geomhatch.png Geometric Hatch (line based). +

      For either tool, select a Face, +SelectFace.png +

      then press the appropriate icon. The face will be hatched initially using default values. Edit the hatch properties to get the desired pattern. +

      +

      Hatch Area

      +

      Hatch Area uses Svg or bitmap bases tiles to cover the selected Face. +

      Svg tiles are typically 64x64 pixel images. Some examples are available on GitHub. +

      Any bitmap file can be used (png, jpeg, etc) as a fill. Results are best with many small repeated images rather than fewer larger images. +

      Default Hatch Area fills can be specified in Preferences. +

      +

      Geometric Hatch

      +

      Geometric Hatch forms a pattern of lines based on a specification read from a file. This file is generally compatible with the widely used AutoDesk® PAT format. A small selection of patterns is included in the FCPAT.pat file: +

      +
      ; standard PAT patterns
      +
      +*Diamond, 45 diagonals L & R, Solid, 1.0 mm separation
      +45,0,0,0,1.0
      +-45,0,0,0,1.0
      +*Diamond2, 45 diagonals L & R, Solid, 2.0 mm separation
      +45,0,0,0,2.0
      +-45,0,0,0,2.0
      +*Diamond4, 45 diagonals L & R, Solid, 4.0 mm separation
      +45,0,0,0,4.0
      +-45,0,0,0,4.0
      +*Diagonal4, 45 diagonal R, Solid, 4.0 mm separation
      +45,0,0,0,4.0
      +*Square, square grid, Solid, 5.0 mm separation 
      +90,1,1,0,5.0
      +0,0,0,1,5.0
      +*Horizontal5, horizontal lines, Solid 5.0 separation
      +0,0,0,0,5.0
      +*Vertical5, vertical lines, Solid, 5.0 separation
      +90,0,0,0,5.0 
      +

      You can add your own patterns if you have write permission to FCPAT.pat, or you can create your own *.pat file and point to it in Preferences. +

      +

      PAT File Path

      +

      The FCPAT.pat file can be found in the following location. +

      +
      • Windows: C:\Program Files\FreeCAD\data\Mod\TechDraw\PAT\
      • +
      • Mac: /Applications/FreeCAD.app/Contents/Mod/TechDraw/PAT/
      • +
      • Linux: /usr/share/freecad/Mod/TechDraw/PAT/ +
        • freecad-daily PPA: /usr/share/freecad-daily/Mod/TechDraw/PAT/
      +

      Back to TechDraw. +

      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/TechDraw_Image.html b/localwiki/TechDraw_Image.html new file mode 100644 index 0000000..7dc0733 --- /dev/null +++ b/localwiki/TechDraw_Image.html @@ -0,0 +1,87 @@ +TechDraw Image

      TechDraw Image

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      TechDraw Image.png TechDraw Image

      +
      Menu location +
      TechDraw → Image +
      Workbenches +
      TechDraw +
      Default shortcut +
      +
      See also +
      +

      + +
      +


      +

      +

      Description

      +

      The Image tool inserts an bitmap image (png,jpeg,jpg,bmp,etc) from a file into the page as a view +

      +

      How to use

      +
      1. Press the Techdraw-image.png Image button
      2. +
      3. A file dialog will open. Select a location and file name.
      +

      Options

      +

      None. +

      +

      Properties

      +
      • n/a
      +

      Scripting

      +

      Bitmap Image files can be inserted into a drawing page using Python. +

      +
      dvi = FreeCAD.ActiveDocument.addObject('TechDraw::DrawViewImage','TestImage')
      +rc = page.addView(dvi)
      +dvi.ImageFile = "pathToMy/imageFile.png"
      +dvi.Height = 200
      +dvi.Width  = 200 
      +


      +

      +

      Notes

      +
      • Use the Scale property to adjust the size of the image.
      • +
      • Use the Width and Height properties to clip the image.
      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/TechDraw_Image.png b/localwiki/TechDraw_Image.png new file mode 100644 index 0000000..841734f Binary files /dev/null and b/localwiki/TechDraw_Image.png differ diff --git a/localwiki/TechDraw_LineGroup.html b/localwiki/TechDraw_LineGroup.html new file mode 100644 index 0000000..6c3ed10 --- /dev/null +++ b/localwiki/TechDraw_LineGroup.html @@ -0,0 +1,41 @@ +TechDraw LineGroup

      TechDraw LineGroup

      + +

      Overview

      +

      LineGroups are used to control the appearance of various types of lines. If you have write permission you can edit "../data/Mod/TechDraw/LineGroup/LineGroup.csv" to add your own LineGroups. You can specify your favourite defaults in Preferences. +

      +

      LineGroup File Path

      +
      • Windows: C:\Program Files\FreeCAD\data\Mod\TechDraw\LineGroup\
      • +
      • Mac: /Applications/FreeCAD.app/Contents/Mod/TechDraw/LineGroup/
      • +
      • Linux: /usr/share/freecad/Mod/TechDraw/LineGroup/ +
        • freecad-daily PPA: /usr/share/freecad-daily/Mod/TechDraw/LineGroup/
      +
      ;FreeCAD LineGroup Definitions
      +;Format: *GroupName,thin,graphic,thick,extra
      +;thin: hidden lines
      +;graphic: dimensions, centerlines
      +;thick: visible lines
      +;extra: not implemented 
      +
      *FC 0.25mm,0.13,0.18,0.25,0.50
      +*FC 0.35mm,0.18,0.25,0.35,0.70
      +*FC 0.50mm,0.25,0.35,0.50,1.0
      +*FC 0.70mm,0.35,0.50,0.70,1.4
      +*FC 1.00mm,0.50,0.70,1.00,2.00 
      +

      Notes

      +
      • The LineGroup name (ex FC 0.25mm) must be entered exactly as specified in the CSV file.
      +

      Back to TechDraw. +


      +

      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/TechDraw_Module.html b/localwiki/TechDraw_Module.html new file mode 100644 index 0000000..a5ced0b --- /dev/null +++ b/localwiki/TechDraw_Module.html @@ -0,0 +1,111 @@ +TechDraw Module

      TechDraw Module

      + +

      Preferences-techdraw.svg +

      FreeCAD is primarily a 3D modelling tool. There are times, however, when we must produce 2D drawings for documentation, contracts, permits, etc. The Technical Drawing workbench (TechDraw) is used to produce basic technical drawings based on the 3D model. Each drawing is a Page, and a Page contains many Views of Drawable Objects. The list of Drawable Objects includes Part::Features, PartDesign::Bodies, App::Part groups and Document Object groups. +

      Dimensions and hatched areas can be added to Views. +

      Note if your primary goal is the production of complex 2D drawings, you may wish to consider a dedicated tool such as LibreCad, QCad, TurboCad, etc. +

      available in version 0.17 +


      +TechDraw Workbench Example.png +


      +

      + + +

      Pages

      +

      These are tools for creating Pages. +

      + + +

      Views

      +

      These are tools for creating Views. +

      +
      • Techdraw-view.png New View: Adds a 2D View of a one or more Drawable Objects.
      +
      • Techdraw-projgroup.png New Projection Group: Invokes a dialog for creating Views of one or more Drawable Objects from multiple directions.
      +
      • Techdraw-viewsection.png New Section: Adds a cross-section View of one or more Drawable Objects.
      +
      • Techdraw-viewdetail.png New Detail: Adds a detail View of a portion of an existing View.
      + +
      • Techdraw-draft-view.png New Draft: Adds a View of a Draft module object.
      +
      • Techdraw-arch-view.png New Arch: Adds a View of a Arch module Section Plane object.
      + +

      Clips

      +

      These are tools to create and manage clipped views. +

      +
      • Techdraw-clip.svg Clip: Inserts a clip group into a Page.
      + +
      • Techdraw-clipminus.svg ClipMinus: Removes a View from a clip group.
      +

      Dimensions

      +

      These are tools for working with Dimensions. Linear dimensions can be based on two points, one line or two lines. +

      + + + +
      • Dimension Radius.png New Radius: Adds a Radius dimension to a circle or circular arc.
      +
      • Dimension Diameter.png New Diameter: Adds a Diameter dimension to a circle or a circular arc.
      +
      • Dimension Angle.png New Angle: Adds an Angle dimension between two straight edges.
      +
      • Dimension Link.png New Links: Links 1 or more Dimensions to 3D geometry.
      +

      Import/Export

      +

      These are tools for exporting Pages to other applications. +

      + +

      Decoration

      +

      These are tools for changing the appearance of Pages and Views. +

      +
      • Techdraw-hatch.png Hatch Area: Applies a hatch pattern from a file to a Face.
      + + +
      • Techdraw-image.png New Image: Inserts a png/jpg image into a Page.
      +
      • Techdraw-toggleframe.png Toggle Frames: Turns View frames and labels on or off in a Page.
      + +

      Additional features

      +
      • Hatching: TechDraw supports a number of hatching techniques.
      • +
      • Line Groups: default weights can be assigned to various line types.
      +

      Preference settings

      +

      The TechDraw module has a preferences screen to adjust default values. +

      +

      Scripting

      +

      The TechDraw module features a Python API so you can use its functions in scripts and macros. +

      +

      Limitations

      +
      • TechDraw drawings and Python API are not interchangeable with the Drawing module. It is possible to convert Drawing Pages to TechDraw Pages using Python (moveViews.py). It is possible to have both TechDraw and Drawing Pages in the same FreeCAD document.
      • +
      • There are minor differences in specifying Editable Texts in Templates compared to the Drawing module. See forum discussion here.
      • +
      • TechDraw is available starting with FreeCAD 0.17.
      • +
      • Do not Cut/Copy/Paste TechDraw objects. This does not generally work out well.
      +

      Workarounds

      +
      • None required at the moment.
      +


      +Keep up with TechDraw plans and developments. Visit the TechDraw Roadmap. +


      +

      + +


      +

      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/TechDraw_NewAnnotation.html b/localwiki/TechDraw_NewAnnotation.html new file mode 100644 index 0000000..96e3955 --- /dev/null +++ b/localwiki/TechDraw_NewAnnotation.html @@ -0,0 +1,104 @@ +TechDraw NewAnnotation

      TechDraw NewAnnotation

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      TechDraw NewAnnotation.png TechDraw NewAnnotation

      +
      Menu location +
      TechDraw → Annotation +
      Workbenches +
      TechDraw +
      Default shortcut +
      +
      See also +
      +

      + +
      +


      +

      +

      Description

      +

      The Annotation tool adds a text block to a drawing page. +

      +
      AnnotationSample.png
      +

      How to use

      +
      1. If you have multiple drawing pages in your document, you will need to select the desired page in the tree.
      2. +
      3. Press the TechDraw NewAnnotation.png Annotation button
      4. +
      5. A text block containing "Default Text" will appear on the page. Use the property editor to change the text. Drag the Annotation to the required position.
      6. +
      7. You may need to press recompute View-rotate-right.png to get your text to change.
      +
      UpdateAnnotation.png
      +

      Options

      +

      None. +

      +

      Properties

      +
      ADD_PROPERTY_TYPE(Text ,("Default Text"),vgroup,App::Prop_None,"The text to be displayed");
      +ADD_PROPERTY_TYPE(Font ,(fontName.c_str()),vgroup,App::Prop_None, "The name of the font to use");
      +ADD_PROPERTY_TYPE(TextColor,(0.0f,0.0f,0.0f),vgroup,App::Prop_None,"The color of the text"); 
      +ADD_PROPERTY_TYPE(TextSize,(8),vgroup,App::Prop_None,"The size of the text in mm");
      +ADD_PROPERTY_TYPE(MaxWidth,(-1.0),vgroup,App::Prop_None,"The maximum width of the Annotation block");
      +ADD_PROPERTY_TYPE(LineSpace,(80),vgroup,App::Prop_None,"Line spacing adjustment");
      +TextStyle.setEnums(TextStyleEnums);
      +ADD_PROPERTY(TextStyle, ((long)0));
      +
      +
      • DATAText: The text to be displayed.
      • +
      • DATAFont: The name of the font to use. Annotation will use the best match of installed fonts.
      • +
      • DATATextColor: The color of the text.
      • +
      • DATATextSize: The size of the text in mm.
      • +
      • DATAMaxWidth: The maximum width of the Annotation block. -1 indicates no maximum width.
      • +
      • DATALineSpace: Line spacing adjustment (%).
      • +
      • DATATextStylee: "Normal", "Bold", "Italic", "Bold-Italic"
      +

      Note: Annotation inherits all applicable basic View properties except Scale. Use the TextSize property instead. +

      +

      Scripting

      +

      Annotations can be added to Pages using Python. +

      +
      anno = FreeCAD.ActiveDocument.addObject('TechDraw::DrawViewAnnotation','TestAnno')
      +anno.Text = ['Different Text']
      +anno.TextStyle = 'Bold'
      +rc = page.addView(anno) 
      +

      Notes

      +
      • None at this time
      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/TechDraw_NewArch.html b/localwiki/TechDraw_NewArch.html new file mode 100644 index 0000000..4d0a99b --- /dev/null +++ b/localwiki/TechDraw_NewArch.html @@ -0,0 +1,99 @@ +TechDraw NewArch

      TechDraw NewArch

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      TechDraw NewArch.png TechDraw NewArch

      +
      Menu location +
      TechDraw → ArchView +
      Workbenches +
      TechDraw +
      Default shortcut +
      +
      See also +
      +

      + +
      +


      +

      +

      Description

      +

      The ArchView tool inserts a view of an Arch SectionPlane on a TechDraw page. +

      TechDraw Arch example.jpg +

      +

      How to use

      +
      1. Select an Arch section plane in the 3D view or in the tree
      2. +
      3. If you have multiple drawing pages in your document, you will need to select the desired page in the tree.
      4. +
      5. Press the Techdraw-arch-view.png ArchView button
      6. +
      7. A view of the objects seen by the section plane will appear on the page.
      +

      Options

      +
      • The Arch View is rendered by the Arch Module, the same way as in the Drawing Workbench. See Notes.
      • +
      • Draft Dimensions, Draft Texts and any other 2D (Sketch or Draft) object considered by the section plane is rendered "as is" (no intersection or hidden lines) on top of the solid geometry
      • +
      • The volume of Arch Spaces is not rendered, only the label will be rendered
      • +
      • Cut lines, projected lines (if Show Hidden property is set to True) and 2D lines above can be rendered with different line widths. This can be configured in the Arch preferences.
      • +
      • The ArchView has two rendering modes: Wireframe, which uses the OpenCasCade algorithms of the Drawing Module, is fast and produces only lines (no face fill possible), and Solid, which is based on the Painter's algorithm, and is capable of rendering faces filled with their shape color. However, it is much slower and can fail in many situations. The image below illustrates the difference between the two rendering modes:
      +

      TechDraw Arch rendering.jpg +

      +
      • Only the base line of Arch Pipes is rendered, not the full volume of the tube:
      +

      TechDraw Arch piping.jpg +

      +

      Properties

      +
      • DATASource: The section plane object to be displayed
      • +
      • DATAAll On: If hidden objects must be shown or not. If False, only objects that are visible in the 3D view are rendered
      • +
      • DATARender Mode: The render mode to use, Solid or Wireframe
      • +
      • DATAShow Hidden: If the hidden geometry (the part of the goemetry that lies behind the section plane) is shown or not. It will be rendered in dashed line, which can be configured in the Arch preferences.
      • +
      • DATAShow Fill: If cut areas must be filled with a grey color or not
      • +
      • DATALine Width: The width of the main lines. Cut lines and projected/2D line widths ratios can be configured in the Arch preferences
      • +
      • DATAFont Size: The size of all texts that appear in this view
      +

      Scripting

      +

      ArchViews can be added to Pages using Python. +

      +
      dv = FreeCAD.ActiveDocument.addObject('TechDraw::DrawViewArch','TestArch')
      +dv.Source = mySectionPlane
      +rc = page.addView(dv) 
      +

      Notes

      +
      • Since the ArchView is rendered within the Arch Module, TechDraw has limited control over it's appearance. You may need to make changes within Arch to get the representation you want.
      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/TechDraw_NewDetail.html b/localwiki/TechDraw_NewDetail.html new file mode 100644 index 0000000..44f554c --- /dev/null +++ b/localwiki/TechDraw_NewDetail.html @@ -0,0 +1,89 @@ +TechDraw NewDetail

      TechDraw NewDetail

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      TechDraw New Detail.png TechDraw New Detail

      +
      Menu location +
      TechDraw → Detail +
      Workbenches +
      TechDraw +
      Default shortcut +
      +
      See also +
      +

      + +
      +


      +

      +

      Description

      +

      The Detail tool creates a view of small area of an existing view. +

      +
      ViewDetail.png
      +

      How to use

      +
      1. Select a part view in the 3D window or tree.
      2. +
      3. If you have multiple drawing pages in your document, you will also need to select the desired page in the tree.
      4. +
      5. Press the Techdraw-viewdetail.png Detail button
      +

      Options

      +

      None. +

      +

      Properties

      +
      • DATABaseView: The part view on which this ViewDetail is based.
      • +
      • DATAAnchor: The center of the detail view within the BaseView.
      • +
      • DATARadius: Control the size of the displayed area.
      • +
      • DATAScale: Magnification level.
      • +
      • DATAReference: An identifier to indicate the area of the BaseView being displayed.
      +

      Note: Detail inherits all applicable View properties. +

      +

      Scripting

      +

      Details can be added to Pages using Python. +

      +
      Detail = FreeCAD.ActiveDocument.addObject('TechDraw::DrawViewDetail','Detail')
      +...TBA 
      +

      Notes

      +
      • The detail view can be displayed within a round or square "viewbox". This is controlled by the "Matting" preference setting.
      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/TechDraw_NewDraft.html b/localwiki/TechDraw_NewDraft.html new file mode 100644 index 0000000..ac83baa --- /dev/null +++ b/localwiki/TechDraw_NewDraft.html @@ -0,0 +1,98 @@ +TechDraw NewDraft

      TechDraw NewDraft

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      TechDraw NewDraft.png TechDraw NewDraft

      +
      Menu location +
      TechDraw → DraftView +
      Workbenches +
      TechDraw +
      Default shortcut +
      +
      See also +
      +

      + +
      +


      +

      +

      Description

      +

      The DraftView tool inserts a view of a selected Part-based or Group object into a drawing page. Unlike the standard View tool, views created with this tool are handled by the Draft Workbench, and specially designed for showing 2D objects. See Notes. +

      +
      DraftViewSample.png
      +

      How to use

      +
      1. Select a draft object in the 3D view or in the tree
      2. +
      3. If you have multiple drawing pages in your document, you will need to select the desired page in the tree.
      4. +
      5. Press the TechDraw NewDraft.png DraftView button
      6. +
      7. A view of the draft object will appear on the page.
      +

      Options

      +
      • Creating a Draft View of a group will recursively handle all the objects found into that group and in its subgroups. The View is updated automatically when the contents of the group changes
      • +
      • There is no hidden line removal. Each face found in the handled object(s) will simply be projected along the Direction vector, no specific action is taken when faces overlap
      • +
      • The Draft View also supports all Draft objects that are not Part-based, such as dimensions and texts
      • +
      • Color, line width and line pattern can be specified in the properties. Line patterns can be fine-tuned by directly giving a stroke-dasharray value, such as 3,5
      • +
      • Projected faces are filled with the face color
      +

      Properties

      +
      • DATASource: The draft object to be displayed
      • +
      • DATALineWidth: The width of the lines, independently of the scale
      • +
      • DATAFontSize: The size of all texts appearing in this view (texts and dimensions)
      • +
      • DATADirection: The projection direction to use
      • +
      • DATAColor: The color of lines
      • +
      • DATALineStyle: A line style to use for this view. Can be Solid, Dashed, Dashdot, Dot or a SVG line pattern like 0.20,0.20
      • +
      • DATALineSpacing: The spacing to use between lines of texts for multiline texts
      +

      Note: DraftView inherits all applicable basic View properties. +

      +

      Scripting

      +

      DraftViews can be added to Pages using Python. +

      +
      dv = FreeCAD.ActiveDocument.addObject('TechDraw::DrawViewDraft','TestDraft')
      +dv.Source = myDraftbject
      +rc = page.addView(dv) 
      +

      Notes

      +

      Since the DraftView is rendered within the Draft Module, TechDraw has limited control over it's appearance. You may need to make changes within Draft to get the representation you want. +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/TechDraw_NewProjGroup.html b/localwiki/TechDraw_NewProjGroup.html new file mode 100644 index 0000000..2ff8bb3 --- /dev/null +++ b/localwiki/TechDraw_NewProjGroup.html @@ -0,0 +1,102 @@ +TechDraw NewProjGroup

      TechDraw NewProjGroup

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      TechDraw NewProjGroup.png TechDraw NewProjGroup

      +
      Menu location +
      TechDraw → Insert Projection Group +
      Workbenches +
      TechDraw +
      Default shortcut +
      na +
      See also +
      +

      + +
      +


      +

      +

      Description

      +

      The ProjectionGroup tool creates multiple orthographic projections (https://en.wikipedia.org/wiki/Multiview_orthographic_projection) of one or more 3D objects (Body or Part). Optionally, isometric views of the 4 front corners can be included. +

      +
      ProjGroupSample.png
      +

      Note that if you only want to produce a single View, there is no advantage in using ProjectionGroup to do so, and in fact creating the View in Projection Group may take considerably longer than the equivalent basic View. +

      +

      How to use

      +
      1. Select one or more Body and/or Part objects in the 3D window or tree.
      2. +
      3. If you have multiple drawing pages in your document, you will also need to select the desired page in the tree.
      4. +
      5. Press the Techdraw-projgroup.png Insert Projection Group button
      6. +
      7. A dialog will open in which you can select which views should appear in the group, the group's scale and other parameters.
      8. +
      9. You can move the group as a whole by dragging the central view. You can also move individual views by dragging.
      +
      TaskProjGroup.png
      +

      Options

      +

      None. +

      +

      Properties

      +
      • DATAAnchor: The central view in the group. Normally the Front view.
      • +
      • DATAProjectionType: "First Angle" or Third Angle".
      • +
      • DATAAutoDistribute: If true, space out individual views automatically. Use false to position manually.
      • +
      • DATAspacingX: Horizontal space between views when automatically positioned.
      • +
      • DATAspacingY: Vertical space between views when automatically positioned.
      +

      Note: The ProjectionGroup as a whole inherits X,Y,ScaleType,Scale and Rotation from the basic view. +Note: Individual views within the group inherit all part view properties. +

      +

      Scripting

      +

      ProjGroups can be added to Pages using Python. +

      +
      group = FreeCAD.ActiveDocument.addObject('TechDraw::DrawProjGroup','pGroup')
      +group.Source = [fusion]
      +group.ScaleType = "Document"
      +anchorView = group.addProjection("Front")
      +group.Anchor = anchorView
      +
      +leftView = group.addProjection("Left")
      +topView = group.addProjection("Top")
      +page.addView(group) 
      +

      Notes

      +
      • None at this time.
      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/TechDraw_NewSection.html b/localwiki/TechDraw_NewSection.html new file mode 100644 index 0000000..35a99c1 --- /dev/null +++ b/localwiki/TechDraw_NewSection.html @@ -0,0 +1,105 @@ +TechDraw NewSection

      TechDraw NewSection

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      TechDraw NewSection.png TechDraw NewSection

      +
      Menu location +
      TechDraw → Section +
      Workbenches +
      TechDraw +
      Default shortcut +
      +
      See also +
      +

      + +
      +


      +

      +

      Description

      +

      The Section tool creates a cross section view based on an existing part view. +

      +
      ViewSection.png
      +

      How to use

      +
      1. Select a part view in the 3D window or tree.
      2. +
      3. If you have multiple drawing pages in your document, you will also need to select the desired page in the tree.
      4. +
      5. Press the Techdraw-viewsection.png Section button
      6. +
      7. A dialog will open which will help calculate the various Section properties. The dialog calculates reasonable starting points for SectionNormal and view Direction, but these may be changed after creation for special needs.
      +
      TaskViewSection.png
      +

      Options

      +

      None. +

      +

      Properties

      +
      • DATABaseView: The part view on which this ViewSection is based.
      • +
      • DATASectionNormal: A vector describing the direction normal to the cutting plane.
      • +
      • DATASectionOrigin: A vector describing a point on the cutting plane. Typically the centroid of the original part.
      • +
      • DATAFileHatchPattern: Full path to hatch pattern file.
      • +
      • DATANameGeomPattern: Name of PAT pattern to use (blank for Svg hatch).
      • +
      • VIEWShowCutSurface: Highlight the section surface if true.
      • +
      • VIEWCutSurfaceColor: Solid color for surface highlight.
      • +
      • VIEWHatchColor: Color for surface hatch lines.
      • +
      • VIEWWeightPattern: Line weight for surface hatch lines.
      +

      Note: Section inherits all applicable View properties. +

      +

      Scripting

      +

      Sections can be added to Pages using Python. +

      +
      view = FreeCAD.ActiveDocument.addObject('TechDraw::DrawViewPart','View')
      +rc = page.addView(view)
      +view.Source = box
      +view.Direction = (0.0,0.0,1.0)
      +
      +section = FreeCAD.ActiveDocument.addObject('TechDraw::DrawViewSection','Section')
      +rc = page.addView(section)
      +section.Source = box
      +section.BaseView = view
      +section.Direction = (0.0,1.0,0.0)
      +section.SectionNormal = (0.0,0.0,1.0)
      +section.SectionOrigin = (5.0,5.0,5.0) 
      +

      Notes

      +
      • If you make a mistake, or change your mind while setting up the Section parameters, press the Reset button at the bottom of the Task Dialogue and you can start over.
      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/TechDraw_NewView.html b/localwiki/TechDraw_NewView.html new file mode 100644 index 0000000..6b529a2 --- /dev/null +++ b/localwiki/TechDraw_NewView.html @@ -0,0 +1,118 @@ +TechDraw NewView

      TechDraw NewView

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      TechDraw NewView.png TechDraw NewView

      +
      Menu location +
      TechDraw → View +
      Workbenches +
      TechDraw +
      Default shortcut +
      na +
      See also +
      +

      + +
      +


      +

      +

      Description

      +

      The View tool adds a representation of one or more objects to a Drawing page. This is the basic building block of the TechDraw module. Most other Views are derived in some way from NewView. +

      +
      ViewOfBox2.png
      +

      How to use

      +
      1. Select one or more objects (Body, App::Part, Part::Feature, Draft object, ... See Notes) in the 3D window or tree.
      2. +
      3. If you have multiple drawing pages in your document, you will also need to select the desired page in the tree.
      4. +
      5. Press the Techdraw-view.png View button
      +

      Options

      +

      None. +

      +

      Properties

      +
      • DATAX: The view's horizontal position on the page. (1)
      • +
      • DATAY: The view's vertical position on the page. (1)
      • +
      • DATALockPosition: Prevents Views from being dragged in the Gui when true. The View can still be moved by changing X,Y properties. (1)
      • +
      • DATARotation: Counterclockwise rotation of the View on the page in degrees. (1)
      • +
      • DATAScaleType: "Document": use the Page's scale setting. "Custom": use a scale unique to this view. "Automatic": fit view to page. (1)
      • +
      • DATAScale: A view will be rendered on the page in Scale:1 ratio to the Source. (1)
      • +
      • DATACaption: Optional short text caption.
      • +
      • DATASource: Links to the Drawable Objects to be depicted
      • +
      • DATADirection: A vector representing the viewing direction. Common Directions are Front: (0,-1,0), Top: (0,0,1), Right: (1,0,0), Axo: (1,1,1). (1)
      • +
      • DATAPerspective: True for perspective projection, false for orthogonal projection.
      • +
      • DATAFocus: Distance from camera to projection plane for perspective projections. Needs to be adjusted to fit the object. Too far and the perspective is lost, too close and the object is distorted.
      • +
      • DATACoarseView: If true, TechDraw will use a polygon approximation to calculate drawing geometry. If false, TechDraw will use a precision algorithm. See Notes.
      • +
      • DATASmooth Visible Lines: Visible Smooth lines on/off.
      • +
      • DATASeam Visible Lines: Visible Seam lines on/off.
      • +
      • DATAIso Visible Lines: Visible Isometric(u,v) lines on/off.
      • +
      • DATAHard Hidden Lines: Hidden lines on/off.
      • +
      • DATASmooth Hidden Lines: Hidden Smooth lines on/off.
      • +
      • DATASeam Hidden Lines: Hidden Seam lines on/off.
      • +
      • DATAIso Hidden Lines: Hidden Isometric(u,v) lines on/off.
      • +
      • DATAIso Count: Number of Isometric(u,v) lines to draw on each face.
      +
      • VIEWKeep Label: Always show View Label if true.
      • +
      • VIEWLineWidth: The thickness of visible lines. See Line Groups.
      • +
      • VIEWHiddenWidth: The thickness of hidden lines, if enabled.
      • +
      • VIEWIsoWidth: The thickness of isometric(u,v) surface lines and Dimension lines.
      • +
      • VIEWExtraWidth: not implemented yet.
      • +
      • VIEWShowCenters: Circle/arc center marks on/off.
      • +
      • VIEWCenterScale: Circular arc center mark size adjustment, if enabled.
      • +
      • VIEWHorizCenterLine: Show a horizontal centerline through view.
      • +
      • VIEWVertCenterLine: Show a vertical centerline through view.
      • +
      • VIEWShowSectionLine: Show/hide section line if applicable.
      +

      (1) these properties are common to all View types. +

      +

      Scripting

      +

      Views can be added to Pages using Python. +

      +
      view = FreeCAD.ActiveDocument.addObject('TechDraw::DrawViewPart','View')
      +rc = page.addView(view)
      +FreeCAD.ActiveDocument.View.Source = [App.ActiveDocument.Box]
      +FreeCAD.ActiveDocument.View.Direction = (0.0,0.0,1.0) 
      +

      Notes

      +
      • View will draw anything with a Shape property. You can select Draft objects or Bodies also. View will also extract any shapes from objects within an App::Part container or a DocumentObject Group.
      • +
      • CoarseView can be much faster for complex models. The quality of the drawing is reduced, since every curve is approximated as a series of short line segments. Vertices are not displayed in CoarseView since each short segment would result in two new Vertices and the display becomes cluttered. Linear Dimensions can be added to a CoarseView, but are unlikely to be useful.
      • +
      • Note that CoarseView is affected by an upstream bug in OCCT (#3332) which causes the View's position on the Page to be slightly off from the specified X,Y values.
      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/TechDraw_New_Default.html b/localwiki/TechDraw_New_Default.html new file mode 100644 index 0000000..40406cd --- /dev/null +++ b/localwiki/TechDraw_New_Default.html @@ -0,0 +1,89 @@ +TechDraw New Default

      TechDraw New Default

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      TechDraw New Default.png TechDraw New Default

      +
      Menu location +
      TechDraw → New Default +
      Workbenches +
      TechDraw +
      Default shortcut +
      x x +
      See also +
      TechDraw New Pick +

      + +
      +


      +

      +

      Description

      +

      The New Default tool creates a new Page using the the Template file specified in Preferences. If the default Template is not specified in your configuration file (user.cfg), New Default will look in "my-install-directory/Mod/TechDraw/Templates/A4_LandscapeTD.svg". +

      +

      How to use

      +
      1. Press the TechDraw New Default.png New Default button. An Active Document must exist.
      +

      Options

      +

      None. +

      +

      Properties

      +
      • DATAProjection Type: Default projection type (First or Third Angle) for this Page.
      • +
      • DATAKeepUpdated: If false, Page is not updated with changes to the 3D model. Useful for complicated/slow drawings. See Notes.
      • +
      • DATATemplate: A link to this Page's Template object.
      • +
      • DATAViews: A list of links to the Views on this Page.
      • +
      • DATAScale: Default scale for Views in this Page.
      +

      Scripting

      +

      The New Default tool can by used in macros and from the python console by using the following functions: +

      +
      page = FreeCAD.ActiveDocument.addObject('TechDraw::DrawPage','Page')
      +template = FreeCAD.ActiveDocument.addObject('TechDraw::DrawSVGTemplate','Template')
      +template.Template = templateFileSpec
      +page.Template = FreeCAD.ActiveDocument.Template 
      +
      • Creates a new Page in the current document
      +

      Notes

      +
      • If a Page is marked as "do not keep updated" either through the KeepUpdated Property or by the setting in Preferences, it will ignore changes in the 3D model. You may notice anomalies (missing geometry, missing Dimension values, etc) in the appearance of the Page. These will correct themselves once the Page is updated.
      +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/TechDraw_New_Pick.html b/localwiki/TechDraw_New_Pick.html new file mode 100644 index 0000000..5784941 --- /dev/null +++ b/localwiki/TechDraw_New_Pick.html @@ -0,0 +1,85 @@ +TechDraw New Pick

      TechDraw New Pick

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      TechDraw New Pick.png TechDraw New Pick

      +
      Menu location +
      TechDraw → New Pick +
      Workbenches +
      TechDraw +
      Default shortcut +
      x x +
      See also +
      TechDraw New Default +

      + +
      +


      +

      +

      Description

      +

      The New Pick tool creates a new Page using the a Template file selected from a dialog. The starting directory for the dialog can be specified in Preferences +

      +

      How to use

      +
      1. Press the TechDraw New Pick.png New Pick button
      +

      Options

      +

      None. +

      +

      Properties

      +
      • DATAProjection Type: Default projection type (First or Third Angle) for this Page.
      • +
      • DATAScale: Default scale for Views in this Page.
      +

      Scripting

      +

      The New Pick tool can by used in macros and from the python console by using the following functions: +

      +
      templateFileSpec = QtGui.QFileDialog.getOpenFileName(self.baseWidget,
      +                                                     dialogCaption, 
      +                                                     dialogDir,
      +                                                     dialogFilter)
      +page = FreeCAD.ActiveDocument.addObject('TechDraw::DrawPage','Page')
      +template = FreeCAD.ActiveDocument.addObject('TechDraw::DrawSVGTemplate','Template')
      +template.Template = templateFileSpec
      +page.Template = FreeCAD.ActiveDocument.Template 
      +
      • Creates a new Page in the current document
      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/TechDraw_Pages.svg b/localwiki/TechDraw_Pages.svg new file mode 100644 index 0000000..6346ee3 --- /dev/null +++ b/localwiki/TechDraw_Pages.svg @@ -0,0 +1,207 @@ + + + + + + + + image/svg+xml + + + + + [WandererFan] + + + TechDraw_Pages + 2016-04-27 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/TechDraw/Gui/Resources/icons/TechDraw_Pages.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + pages + page + + + Three pages in a pile + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/TechDraw_Preferences.html b/localwiki/TechDraw_Preferences.html new file mode 100644 index 0000000..9cec9ec --- /dev/null +++ b/localwiki/TechDraw_Preferences.html @@ -0,0 +1,71 @@ +TechDraw Preferences

      TechDraw Preferences

      + +

      The preferences screens of the TechDraw module are found in the Preferences window (Menu Edit → Preferences). +

      Your preference screens may look slightly different depending on platform or formatting scheme. +

      +

      TechDraw 1

      +
      preferences tab 1
      +
      +


      +

      +

      General

      +
      • Projection Angle - TechDraw NewProjGroup.png ProjectionGroups will use either First or Third angle projection. (see multiview projection)
      • +
      • Hidden Line - the style (solid, dashed, etc) to be used for hidden lines.
      • +
      • Detect Faces - if ticked, TechDraw will attempt to build faces using the line segments returned by the hidden line removal algorithm. Faces must be detected in order to use Techdraw-hatch.pnghatching, but there can be a performance penalty in complex models.
      • +
      • ShowSectionEdges - highlight the border of the section cut in TechDraw NewSection.png section views. Usually only for debugging.
      • +
      • KeepPagesUpToDate - keeping the drawing pages in sync with the 3D model in real time can slow response times. In complex models, unticking this box will allow for quicker responses. Use the "KeepUpdated" property of Page to selectively update a single Page.
      • +
      • Template Dot Size - Controls the size of the small green dot used for selecting editable text in a Template.
      +

      Colors

      +

      you can set your preferred colors here. +

      +

      Labels

      +
      • Label Font - the name of the default font for Labels.
      • +
      • Label Size - default size (mm) for label text.
      • +
      • Template dot size - green unit dot size in units
      +

      Files

      +
      • Default Template - use this file chooser to select a default Template file for your drawings.
      • +
      • Template Directory - the starting directory for TechDraw New Pick.png New Page from Template.
      • +
      • Hatch Image - default Svg or Bitmap file for TechDraw Hatch.png hatching.
      • +
      • PAT File - default PAT pattern definition file for TechDraw Hatch.png hatching.
      • +
      • Pattern Name - the name of your favourite PAT pattern.
      +

      TechDraw 2

      +

      preferences tab 2 +

      +
      +

      Dimensions

      +
      • Show Units - append the unit specifier (mm,in,etc) to values.
      • +
      • Use Global Decimals - use the number of decimal positions from Preferences>General>Units.
      • +
      • Alternate Decimals - if Use Global Decimals is unticked, use this number of decimal positions.
      • +
      • Font Size - size for Dimension Text.
      • +
      • Color - default color for Dimension text and lines.
      • +
      • Diameter Symbol - diameter dimensions will be prefixed by this text.
      • +
      • Arrow Style - choose the dimension line end mark you prefer.
      • +
      • Arrow Size - size of end mark in mm.
      +

      Decorations

      +
      • Line Group - the name of default line group specification.
      • +
      • Matting Style - show TechDraw New Detail.png detail views as circles or rectangles.
      • +
      • Center Line Style - default style for View center lines (horizontal and vertical).
      • +
      • Center Line Color - default color for View center lines.
      • +
      • Section Line Style - default style for section line in the Base View of TechDraw NewSection.png a Section View.
      • +
      • Section Line Color - default color for section lines.
      • +
      • Hatch Weight - default line thickness for TechDraw GeomHatch.png geometric hatching. See Techdraw-hatch.png hatching.
      +


      +Back to TechDraw . +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/TechDraw_Preferences1.png b/localwiki/TechDraw_Preferences1.png new file mode 100644 index 0000000..178829b Binary files /dev/null and b/localwiki/TechDraw_Preferences1.png differ diff --git a/localwiki/TechDraw_Preferences2.png b/localwiki/TechDraw_Preferences2.png new file mode 100644 index 0000000..06ebefb Binary files /dev/null and b/localwiki/TechDraw_Preferences2.png differ diff --git a/localwiki/TechDraw_ProjBottom.svg b/localwiki/TechDraw_ProjBottom.svg new file mode 100644 index 0000000..8833b4b --- /dev/null +++ b/localwiki/TechDraw_ProjBottom.svg @@ -0,0 +1,87 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [WandererFan] + + + TechDraw_ProjBottom + 2016-04-27 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/TechDraw/Gui/Resources/icons/TechDraw_ProjBottom.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/TechDraw_ProjFront.svg b/localwiki/TechDraw_ProjFront.svg new file mode 100644 index 0000000..7be92fc --- /dev/null +++ b/localwiki/TechDraw_ProjFront.svg @@ -0,0 +1,92 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [WandererFan] + + + TechDraw_ProjFront + 2016-04-27 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/TechDraw/Gui/Resources/icons/TechDraw_Proj + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/TechDraw_ProjFrontBottomLeft.svg b/localwiki/TechDraw_ProjFrontBottomLeft.svg new file mode 100644 index 0000000..ebbf2bc --- /dev/null +++ b/localwiki/TechDraw_ProjFrontBottomLeft.svg @@ -0,0 +1,88 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [WandererFan] + + + TechDraw_ProjFrontBottomLeft + 2016-04-27 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/TechDraw/Gui/Resources/icons/TechDraw_Proj + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/TechDraw_ProjFrontBottomRight.svg b/localwiki/TechDraw_ProjFrontBottomRight.svg new file mode 100644 index 0000000..2848937 --- /dev/null +++ b/localwiki/TechDraw_ProjFrontBottomRight.svg @@ -0,0 +1,88 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [WandererFan] + + + TechDraw_ProjFrontBottomRight + 2016-04-27 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/TechDraw/Gui/Resources/icons/TechDraw_Proj + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/TechDraw_ProjFrontTopLeft.svg b/localwiki/TechDraw_ProjFrontTopLeft.svg new file mode 100644 index 0000000..97198b6 --- /dev/null +++ b/localwiki/TechDraw_ProjFrontTopLeft.svg @@ -0,0 +1,88 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [WandererFan] + + + TechDraw_ProjFrontTopLeft + 2016-04-27 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/TechDraw/Gui/Resources/icons/TechDraw_Proj + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/TechDraw_ProjFrontTopRight.svg b/localwiki/TechDraw_ProjFrontTopRight.svg new file mode 100644 index 0000000..6b55fb6 --- /dev/null +++ b/localwiki/TechDraw_ProjFrontTopRight.svg @@ -0,0 +1,93 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [WandererFan] + + + TechDraw_ProjFrontTopRight + 2016-04-27 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/TechDraw/Gui/Resources/icons/TechDraw_Proj + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/TechDraw_ProjLeft.svg b/localwiki/TechDraw_ProjLeft.svg new file mode 100644 index 0000000..9a3094d --- /dev/null +++ b/localwiki/TechDraw_ProjLeft.svg @@ -0,0 +1,87 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [WandererFan] + + + TechDraw_ProjLeft + 2016-04-27 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/TechDraw/Gui/Resources/icons/TechDraw_ProjLeft.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/TechDraw_ProjRear.svg b/localwiki/TechDraw_ProjRear.svg new file mode 100644 index 0000000..4d9e038 --- /dev/null +++ b/localwiki/TechDraw_ProjRear.svg @@ -0,0 +1,92 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [WandererFan] + + + TechDraw_ProjRear + 2016-04-27 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/TechDraw/Gui/Resources/icons/TechDraw_ProjRear.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/TechDraw_ProjRight.svg b/localwiki/TechDraw_ProjRight.svg new file mode 100644 index 0000000..6a92b30 --- /dev/null +++ b/localwiki/TechDraw_ProjRight.svg @@ -0,0 +1,92 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [WandererFan] + + + TechDraw_ProjRight + 2016-04-27 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/TechDraw/Gui/Resources/icons/TechDraw_ProjRight.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/TechDraw_ProjTop.svg b/localwiki/TechDraw_ProjTop.svg new file mode 100644 index 0000000..f99c29f --- /dev/null +++ b/localwiki/TechDraw_ProjTop.svg @@ -0,0 +1,92 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [WandererFan] + + + TechDraw_ProjTop + 2016-04-27 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/TechDraw/Gui/Resources/icons/TechDraw_ProjTop.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/TechDraw_Redraw.html b/localwiki/TechDraw_Redraw.html new file mode 100644 index 0000000..df421f5 --- /dev/null +++ b/localwiki/TechDraw_Redraw.html @@ -0,0 +1,79 @@ +TechDraw Redraw

      TechDraw Redraw

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      TechDraw Redraw.png TechDraw Redraw

      +
      Menu location +
      TechDraw → Redraw +
      Workbenches +
      TechDraw +
      Default shortcut +
      +
      See also +
      +

      + +
      +


      +

      +

      Description

      +

      The Redraw tool attempts to redraw a page without recalculating the 3D model. This may or may not result in visible effects. +

      +

      How to use

      +
      1. Press the TechDraw Tree Page Sync.png Redraw button
      +

      Options

      +

      None. +

      +

      Properties

      +
      • n/a
      +

      Scripting

      +

      The Redraw command is not directly available in scripts. +


      +

      +

      Notes

      +
      • None at this time.
      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/TechDraw_Roadmap.html b/localwiki/TechDraw_Roadmap.html new file mode 100644 index 0000000..c80ce37 --- /dev/null +++ b/localwiki/TechDraw_Roadmap.html @@ -0,0 +1,59 @@ +TechDraw Roadmap

      TechDraw Roadmap

      + +

      Preferences-techdraw.svg +


      +The TechDraw workbench is new and hasn't had the years of development that have benefited some other workbenches. Still, TechDraw can now "produce basic technical drawings based on the 3D model". +

      Here is a rough roadmap of areas to be addressed in the future (in no particular order). +

      +

      Current Activity

      +
      • "slanted" dimlines for Dimensions on Axo Views.
      • +
      • bug fixes.
      +

      Recent Changes

      +
      • improved Dxf export compatibility with version R12.
      +

      Draft/Arch coexistence

      +

      There are inconsistencies between the way the Draft/Arch and TechDraw modules represent shapes. This limits the suitability of TechDraw for Draft/Arch users. One notable short-coming is that TechDraw is unable to apply Dimensions to the Svg images it receives from Draft/Arch. +

      +

      Templates

      +

      Making a template with editable text fields requires significant expertise with Svg and an Svg editor like Inkscape. Making the template creation process simpler will be a priority in the v0.18 development cycle. +

      +

      Drawing Tools

      +

      This includes the ability to add leaders, callouts and detail highlights to Views. It is a prerequisite to many enhancements, particularly in the drawing annotation area, such as feature control frames and reference highlights for detail views. +

      +

      2D Geometry

      +

      A number of 2D geometry functions were recently added to the Part module. This needs to be reviewed with an eye towards replacing custom 2D geometry code in TechDraw with standard code from Part. +

      +

      Internal View Consistency

      +

      It is not currently possible to create a Detail from a Section, or a Section from a Detail due to internal differences. Changes here would allow any View type to be a BaseView. +

      +

      "non-Vertex" Dimensions

      +

      There is a need for Dimensions that do not rely on specific vertex/edges, but on extrema of the figure - for example, overall width/height. +

      +

      Support for Newer Dxf Version

      +

      The current Page to Dxf export function uses an older version of the Dxf spec (R12). +An option to support a newer version is required. +

      +

      Bug Fixes/Feature Requests

      +

      See the bug tracker for up to date information. +

      + +


      +Return to TechDraw Module main page. +

      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/TechDraw_SaveDXF.html b/localwiki/TechDraw_SaveDXF.html new file mode 100644 index 0000000..ea5e54d --- /dev/null +++ b/localwiki/TechDraw_SaveDXF.html @@ -0,0 +1,86 @@ +TechDraw SaveDXF

      TechDraw SaveDXF

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      TechDraw SaveDXF.png TechDraw SaveDXF

      +
      Menu location +
      TechDraw → Export page Dxf +
      Workbenches +
      TechDraw +
      Default shortcut +
      +
      See also +
      +

      + +
      +


      +

      +

      Description

      +

      The Export page Dxf tool saves a drawing page as a Dxf file +

      +

      How to use

      +
      1. Select a Page in the tree (if the document contains multiple pages).
      2. +
      3. Press the TechDraw SaveDXF.png Save page as Dxf button
      4. +
      5. A File Save dialog will open. Select a location and file name.
      +

      Options

      +

      None. +

      +

      Properties

      +
      • n/a
      +

      Scripting

      +

      This function is available in Python by using +

      +
      TechDraw.writeDXFPage(page,filename) 
      +

      Notes

      +
      • This function is available in v0.18 and later.
      • +
      • This function exports the R12(AC1009) version of Dxf. This is an older version of the standard, but should be readable by most other software.
      • +
      • If the FreeCAD document contains multiple pages, you will have to select the desired page in the tree before pressing the export button.
      • +
      • Radial and Diametric dimensions will only export properly if they are "inside" the arc.
      • +
      • Scaling is not supported. The Dxf will be drawn in the actual size of the TechDraw Page.
      • +
      • Units are not supported - the Dxf will be drawn in mm. Dimension text will be shown exactly as displayed in TechDraw.
      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/TechDraw_SaveSVG.html b/localwiki/TechDraw_SaveSVG.html new file mode 100644 index 0000000..07a5518 --- /dev/null +++ b/localwiki/TechDraw_SaveSVG.html @@ -0,0 +1,84 @@ +TechDraw SaveSVG

      TechDraw SaveSVG

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      TechDraw ExportPage.png TechDraw ExportPage

      +
      Menu location +
      TechDraw → Export page +
      Workbenches +
      TechDraw +
      Default shortcut +
      +
      See also +
      +

      + +
      +


      +

      +

      Description

      +

      The Export page tool saves the current drawing page as an SVG file +

      +

      How to use

      +
      1. Press the TechDraw SaveSVG.png Export page button
      2. +
      3. A File Save dialog will open. Select a location and file name.
      +

      Options

      +

      None. +

      +

      Properties

      +
      • n/a
      +

      Scripting

      +

      This function is available via Python by using. +

      +
      TechDrawGui.exportPageAsSvg(DrawPageObject,FilePath) 
      +

      Note that the FreeCADGui module must be active to use this function. +

      +

      Notes

      +
      • Hatch patterns are not exported to SVG due to a limitation in Qt4's SVG support.
      • +
      • Text positions and sizes are not correct in the exported file. Using the "system" default font in the drawing improves the size problem considerably.
      • +
      • Creating DXF from saved Svg drawing in Inkscape: To export to DXF with the correct scale in Inkscape v0.48, choose "Desktop Cutting Plotter (AutoCAD DXF R14) (*.dxf)" as export format and choose "Base unit": "px" in the next dialog. The drawing is not on scale yet but has a scale of 10:1. To get the correct scale on LibreCAD, choose "Edit → Current Drawing Preferences → General Factor" of 0.1. Check with a known distance, anyway!
      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/TechDraw_Spreadsheet.html b/localwiki/TechDraw_Spreadsheet.html new file mode 100644 index 0000000..ab9594b --- /dev/null +++ b/localwiki/TechDraw_Spreadsheet.html @@ -0,0 +1,74 @@ +TechDraw Spreadsheet

      TechDraw Spreadsheet

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      TechDraw Spreadsheet.png TechDraw Spreadsheet

      +
      Menu location +
      TechDraw → Spreadsheet +
      Workbenches +
      TechDraw +
      Default shortcut +
      +
      See also +
      +

      + +
      +


      +

      +

      Description

      +

      This tool allows you to place a view of a selected spreadsheet on a Page. +

      +
      TechDraw Spreadsheetview.png
      +

      How to use

      +
      1. In the tree, select a spreadsheet you wish to put on a drawing sheet
      2. +
      3. Press the TechDraw-spreadsheet.png TechDraw Spreadsheet button
      +

      Properties

      +
      • DATASource: The spreadsheet to be added to the page
      • +
      • DATACell Start: The top left cell of the cells range to be included in this view
      • +
      • DATACell End: The bottom right cell of the cells range to be included in this view
      • +
      • DATAFont: The name of the font used for texts
      • +
      • DATAColor: The color of lines and texts that have no color specified in the spreadsheet
      • +
      • DATAFont Size: The font size of texts
      • +
      • DATALine Width: The width of the cell borders
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/TechDraw_Symbol.html b/localwiki/TechDraw_Symbol.html new file mode 100644 index 0000000..bbde06a --- /dev/null +++ b/localwiki/TechDraw_Symbol.html @@ -0,0 +1,88 @@ +TechDraw Symbol

      TechDraw Symbol

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      TechDraw Symbol.png TechDraw Symbol

      +
      Menu location +
      TechDraw → Symbol +
      Workbenches +
      TechDraw +
      Default shortcut +
      +
      See also +
      +

      + +
      +


      +

      +

      Description

      +

      The Symbol tool inserts an SVG file into the page as a view +

      +

      How to use

      +
      1. Press the Symbol.png Symbol button
      2. +
      3. A File Save dialog will open. Select a location and file name.
      +

      Options

      +

      None. +

      +

      Properties

      +
      • n/a
      +

      Scripting

      +

      SVG files can be inserted into a drawing page using Python. +

      +
      sym = FreeCAD.ActiveDocument.addObject('TechDraw::DrawViewSymbol','TestSymbol')
      +rc = page.addView(anno)
      +f = open(unicode(symbolFileSpec,'utf-8'),'r')
      +svg = f.read()
      +f.close()
      +sym.Symbol = svg
      +rc = page.addView(sym) 
      +


      +

      +

      Notes

      +
      • Symbol appear larger than expected. Use the Scale property to adjust the size.
      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/TechDraw_TemplateHowTo.html b/localwiki/TechDraw_TemplateHowTo.html new file mode 100644 index 0000000..1c38618 --- /dev/null +++ b/localwiki/TechDraw_TemplateHowTo.html @@ -0,0 +1,80 @@ +TechDraw TemplateHowTo

      TechDraw TemplateHowTo

      + +


      +

      +

      How to Make a TechDraw Template

      +

      This HowTo assumes you are familiar with FreeCAD, Inkscape and Svg. +

      We're going to make a simple template for US Letter size paper in landscape orientation. A copy of the result of this HowTo is available in your FreeCAD Template directory (HowToExample.svg). +

      +
      • open a new document in Inkscape
      • +
      • in Document Properties +
        • select a page size (US Letter) & orientation (landscape)
        • +
        • set default units and page size units to mm (279.4 x 215.9)
      +
      InkDocProp.png
      +


      +

      + +
      InkXMLNameSpace.png
      +


      +

      +
      • draw outlines, zone numbers, centerlines, etc
      • +
      • draw the boxes and lines for the title block.
      • +
      • add and position your static text
      • +
      • add and position your editable text
      • +
      • you now have your finished artwork - something like this:
      +
      InkFinishedArt.png
      +


      +

      +
      • use the XML Editor to add "freecad:editable" tag to each editable <text> item +
        • assign a meaningful field name to each editable text
      +
      InkXMLeditableTag.png
      +


      +

      +
      • use XML editor to adjust viewbox to match your page size in mm
      +
      InkXMLviewBox.png
      +


      +

      +
      • your template will now appear much too big.
      +
      InkMuchTooBig.png
      +


      +

      +
      • We need to shrink it. +
        • Edit>Select All in All Layers (or box select. make sure you select everything)
        • +
        • adjust the W: and H: spinboxes to match your artwork's size in mm +
          • page-size less any applicable margins
        • +
        • use "Align and Distribute" or X/Y spinboxes to position artwork on page if required.
        • +
        • your template should now look right, just like it did in the finished artwork picture above.
      +


      +

      +
      • ensure that all your editable texts are "ungrouped" (shift-ctl-g)
      • +
      • select everything on your page (box select or Edit>SelectAll) and Edit>Copy
      • +
      • Layer>Delete Current Layer
      • +
      • Edit>Paste in Place
      +


      +

      +
      • Your template should now look right and shouldn't have any unwanted transforms
      • +
      • Save your template
      • +
      • try it in FreeCAD.
      +
      FCTemplateHow.png
      +


      +

      +

      Notes

      +

      - Don't use Layers until you've mastered template creation without them. Layers (and Groups) can automatically insert unwanted transforms into your SVG. +

      Back to Templates. +

      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/TechDraw_Templates.html b/localwiki/TechDraw_Templates.html new file mode 100644 index 0000000..0e9089e --- /dev/null +++ b/localwiki/TechDraw_Templates.html @@ -0,0 +1,35 @@ +TechDraw Templates

      TechDraw Templates

      + +

      Overview

      +

      Every TechDraw Page is based on a Template. The Template controls paper size and contains all the "pre-printed" text and graphics of the page. The Template can also contain editable text fields for attributes like "Title", "Author", "Scale". +

      Templates are Svg files and are created and modified outside of FreeCAD. +

      +

      Properties

      +
      • DATAOrientation: Portrait or Landscape.
      • +
      • DATAWidth: Paper width in mm.
      • +
      • DATAHeight: Paper height in mm.
      • +
      • DATAPage Result: A copy of the original Template file including all changes to editable texts. This allows users who may not have a copy of the Template file to see the Page as intended. Not typically useful for end users.
      • +
      • DATATemplate: a) A pointer to the copy of the original Template file which is incorporated into this *.FCSTD file, or b) a filepath to a template accessible on the current machine. Use the file selection ellipsis (...) to change to a different template.
      +

      Custom Templates

      +

      A limited number of pre-formatted Templates in various page sizes are included with FreeCAD. Custom Templates can also be created and specified as a default in Preferences. +

      How to make a custom TechDraw template +


      +Back to TechDraw. +

      +

      Notes

      +
      • TechDraw Templates are not entirely interchangeable with Drawing Templates. In general, Drawing templates will work in TechDraw, but there may be problems with editable text.
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/TechDraw_Toggle.html b/localwiki/TechDraw_Toggle.html new file mode 100644 index 0000000..c37936d --- /dev/null +++ b/localwiki/TechDraw_Toggle.html @@ -0,0 +1,84 @@ +TechDraw Toggle

      TechDraw Toggle

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      TechDraw Toggle.png TechDraw Toggle

      +
      Menu location +
      TechDraw → Toggle +
      Workbenches +
      TechDraw +
      Default shortcut +
      +
      See also +
      +

      + +
      +


      +

      +

      Description

      +

      The Toggle tool turns the display of View frames, labels and vertices on or off. +

      +
      FramesOn.png
      FramesOff.png
      +



      +

      +

      How to use

      +
      1. If you have multiple drawing pages in your document, you will need to select the desired page in the tree.
      2. +
      3. Press the Techdraw-toggleframe.png Toggle button
      4. +
      5. If View frames are currently visible, they will disappear. If View frames are not visible, they will appear.
      6. +
      7. It is possible for different Views to be in different states of frame display. If this happens, press the Techdraw-toggleframe.png Toggle button once or twice to resynchronize the Views.
      +

      Options

      +

      None. +

      +

      Properties

      +
      • n/a
      +

      Scripting

      +

      This function is not currently available via Python scripting. +

      +

      Notes

      +
      • None at this time
      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/TechDraw_Tree_Annotation.svg b/localwiki/TechDraw_Tree_Annotation.svg new file mode 100644 index 0000000..4968681 --- /dev/null +++ b/localwiki/TechDraw_Tree_Annotation.svg @@ -0,0 +1,164 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [WandererFan] + + + TechDraw_Tree_Annotation + 2016-04-27 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/TechDraw/Gui/Resources/icons/TechDraw_Tree_Annotation.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/TechDraw_Tree_Hatch.svg b/localwiki/TechDraw_Tree_Hatch.svg new file mode 100644 index 0000000..f276fbf --- /dev/null +++ b/localwiki/TechDraw_Tree_Hatch.svg @@ -0,0 +1,69 @@ + + + + + + image/svg+xml + + + + + [WandererFan] + + + TechDraw_Tree_Hatch + 2016-04-27 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/TechDraw/Gui/Resources/icons/TechDraw_Tree_Hatch.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/TechDraw_Tree_Multi.svg b/localwiki/TechDraw_Tree_Multi.svg new file mode 100644 index 0000000..3f5b3ec --- /dev/null +++ b/localwiki/TechDraw_Tree_Multi.svg @@ -0,0 +1,60 @@ + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [WandererFan] + + + TechDraw_Tree_Multi + 2016-10-29 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/TechDraw/Gui/Resources/icons/TechDraw_Tree_Multi.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + diff --git a/localwiki/TechDraw_Tree_Page.svg b/localwiki/TechDraw_Tree_Page.svg new file mode 100644 index 0000000..a14f12f --- /dev/null +++ b/localwiki/TechDraw_Tree_Page.svg @@ -0,0 +1,49 @@ + + + + + + + image/svg+xml + + + + [WandererFan] + + + TechDraw_Tree_Page + 2016-04-27 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/TechDraw/Gui/Resources/icons/TechDraw_Tree_Page.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + diff --git a/localwiki/TechDraw_Tree_PageTemplate.svg b/localwiki/TechDraw_Tree_PageTemplate.svg new file mode 100644 index 0000000..274401e --- /dev/null +++ b/localwiki/TechDraw_Tree_PageTemplate.svg @@ -0,0 +1,318 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [WandererFan] + + + TechDraw_Tree_PageTemplate + 2016-04-27 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/TechDraw/Gui/Resources/icons/TechDraw_Tree_PageTemplate.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + diff --git a/localwiki/TechDraw_Tree_Page_Sync.svg b/localwiki/TechDraw_Tree_Page_Sync.svg new file mode 100644 index 0000000..137b24e --- /dev/null +++ b/localwiki/TechDraw_Tree_Page_Sync.svg @@ -0,0 +1,642 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + Jakub Steiner + + + http://jimmac.musichall.cz + + + + + reload + refresh + view + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/TechDraw_Tree_Page_Unsync.svg b/localwiki/TechDraw_Tree_Page_Unsync.svg new file mode 100644 index 0000000..5be6297 --- /dev/null +++ b/localwiki/TechDraw_Tree_Page_Unsync.svg @@ -0,0 +1,664 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + Jakub Steiner + + + http://jimmac.musichall.cz + + + + + reload + refresh + view + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/TechDraw_Tree_ProjGroup.svg b/localwiki/TechDraw_Tree_ProjGroup.svg new file mode 100644 index 0000000..d0922d7 --- /dev/null +++ b/localwiki/TechDraw_Tree_ProjGroup.svg @@ -0,0 +1,94 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [WandererFan] + + + TechDraw_Tree_ProjGroup + 2016-04-27 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/TechDraw/Gui/Resources/icons/TechDraw_Tree_ProjGroup.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/TechDraw_Tree_Section.svg b/localwiki/TechDraw_Tree_Section.svg new file mode 100644 index 0000000..8ec3e24 --- /dev/null +++ b/localwiki/TechDraw_Tree_Section.svg @@ -0,0 +1,61 @@ + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [WandererFan] + + + TechDraw_Tree_Section + 2016-04-27 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/TechDraw/Gui/Resources/icons/TechDraw_Tree_Section.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + diff --git a/localwiki/TechDraw_Tree_Spreadsheet.svg b/localwiki/TechDraw_Tree_Spreadsheet.svg new file mode 100644 index 0000000..fa9ff1d --- /dev/null +++ b/localwiki/TechDraw_Tree_Spreadsheet.svg @@ -0,0 +1,178 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [WandererFan] + + + TechDraw_Tree_Spreadsheet + 2016-05-04 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/TechDraw/Gui/Resources/icons/TechDraw_Tree_Spreadsheet.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/TechDraw_Tree_Symbol.svg b/localwiki/TechDraw_Tree_Symbol.svg new file mode 100644 index 0000000..34c7cf1 --- /dev/null +++ b/localwiki/TechDraw_Tree_Symbol.svg @@ -0,0 +1,775 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [agryson] Alexander Gryson + + + http://agryson.net + + TechDraw_Tree_Symbol + 2016-04-27 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/TechDraw/Gui/Resources/icons/TechDraw_Tree_Symbol.svg + + + FreeCAD LGPL2+ + + + + + [agryson] Alexander Gryson + + + + + technical drawing + circles + page + + + 3 cirlces drawn on a page with a text box in bottom left + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/TechDraw_Tree_View.svg b/localwiki/TechDraw_Tree_View.svg new file mode 100644 index 0000000..8a3b092 --- /dev/null +++ b/localwiki/TechDraw_Tree_View.svg @@ -0,0 +1,178 @@ + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + [WandererFan] + + + TechDraw_Tree_View + 2016-04-27 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/TechDraw/Gui/Resources/icons/TechDraw_Tree_View.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + dashed line + monotone + + + Irregular shape in the center framed by a dashed outline + + + + + + + + + + + + diff --git a/localwiki/TechDraw_Workbench.html b/localwiki/TechDraw_Workbench.html new file mode 100644 index 0000000..3579f9b --- /dev/null +++ b/localwiki/TechDraw_Workbench.html @@ -0,0 +1,111 @@ +TechDraw Workbench

      TechDraw Workbench

      (Redirected from TechDraw Workbench)
      + +

      Preferences-techdraw.svg +

      FreeCAD is primarily a 3D modelling tool. There are times, however, when we must produce 2D drawings for documentation, contracts, permits, etc. The Technical Drawing workbench (TechDraw) is used to produce basic technical drawings based on the 3D model. Each drawing is a Page, and a Page contains many Views of Drawable Objects. The list of Drawable Objects includes Part::Features, PartDesign::Bodies, App::Part groups and Document Object groups. +

      Dimensions and hatched areas can be added to Views. +

      Note if your primary goal is the production of complex 2D drawings, you may wish to consider a dedicated tool such as LibreCad, QCad, TurboCad, etc. +

      available in version 0.17 +


      +TechDraw Workbench Example.png +


      +

      + + +

      Pages

      +

      These are tools for creating Pages. +

      + + +

      Views

      +

      These are tools for creating Views. +

      +
      • Techdraw-view.png New View: Adds a 2D View of a one or more Drawable Objects.
      +
      • Techdraw-projgroup.png New Projection Group: Invokes a dialog for creating Views of one or more Drawable Objects from multiple directions.
      +
      • Techdraw-viewsection.png New Section: Adds a cross-section View of one or more Drawable Objects.
      +
      • Techdraw-viewdetail.png New Detail: Adds a detail View of a portion of an existing View.
      + +
      • Techdraw-draft-view.png New Draft: Adds a View of a Draft module object.
      +
      • Techdraw-arch-view.png New Arch: Adds a View of a Arch module Section Plane object.
      + +

      Clips

      +

      These are tools to create and manage clipped views. +

      +
      • Techdraw-clip.svg Clip: Inserts a clip group into a Page.
      + +
      • Techdraw-clipminus.svg ClipMinus: Removes a View from a clip group.
      +

      Dimensions

      +

      These are tools for working with Dimensions. Linear dimensions can be based on two points, one line or two lines. +

      + + + +
      • Dimension Radius.png New Radius: Adds a Radius dimension to a circle or circular arc.
      +
      • Dimension Diameter.png New Diameter: Adds a Diameter dimension to a circle or a circular arc.
      +
      • Dimension Angle.png New Angle: Adds an Angle dimension between two straight edges.
      +
      • Dimension Link.png New Links: Links 1 or more Dimensions to 3D geometry.
      +

      Import/Export

      +

      These are tools for exporting Pages to other applications. +

      + +

      Decoration

      +

      These are tools for changing the appearance of Pages and Views. +

      +
      • Techdraw-hatch.png Hatch Area: Applies a hatch pattern from a file to a Face.
      + + +
      • Techdraw-image.png New Image: Inserts a png/jpg image into a Page.
      +
      • Techdraw-toggleframe.png Toggle Frames: Turns View frames and labels on or off in a Page.
      + +

      Additional features

      +
      • Hatching: TechDraw supports a number of hatching techniques.
      • +
      • Line Groups: default weights can be assigned to various line types.
      +

      Preference settings

      +

      The TechDraw module has a preferences screen to adjust default values. +

      +

      Scripting

      +

      The TechDraw module features a Python API so you can use its functions in scripts and macros. +

      +

      Limitations

      +
      • TechDraw drawings and Python API are not interchangeable with the Drawing module. It is possible to convert Drawing Pages to TechDraw Pages using Python (moveViews.py). It is possible to have both TechDraw and Drawing Pages in the same FreeCAD document.
      • +
      • There are minor differences in specifying Editable Texts in Templates compared to the Drawing module. See forum discussion here.
      • +
      • TechDraw is available starting with FreeCAD 0.17.
      • +
      • Do not Cut/Copy/Paste TechDraw objects. This does not generally work out well.
      +

      Workarounds

      +
      • None required at the moment.
      +


      +Keep up with TechDraw plans and developments. Visit the TechDraw Roadmap. +


      +

      + +


      +

      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Techdraw-annotation.svg b/localwiki/Techdraw-annotation.svg new file mode 100644 index 0000000..28443ce --- /dev/null +++ b/localwiki/Techdraw-annotation.svg @@ -0,0 +1,164 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [WandererFan] + + + techdraw-annotation + 2016-01-14 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/TechDraw/Gui/Resources/icons/actions/techdraw-annotation.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Techdraw-arch-view.svg b/localwiki/Techdraw-arch-view.svg new file mode 100644 index 0000000..96fbdc9 --- /dev/null +++ b/localwiki/Techdraw-arch-view.svg @@ -0,0 +1,1105 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + Jakub Steiner + + + http://jimmac.musichall.cz + + techdraw-arch-view + 2016-10-28 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/TechDraw/Gui/Resources/icons/actions/techdraw-arch-view.svg + + + FreeCAD LGPL2+ + + + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Techdraw-clip.svg b/localwiki/Techdraw-clip.svg new file mode 100644 index 0000000..1421c83 --- /dev/null +++ b/localwiki/Techdraw-clip.svg @@ -0,0 +1,169 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [WandererFan] + + + techdraw-clip + 2016-01-14 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/TechDraw/Gui/Resources/icons/actions/techdraw-clip.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Techdraw-clipminus.svg b/localwiki/Techdraw-clipminus.svg new file mode 100644 index 0000000..d85e50b --- /dev/null +++ b/localwiki/Techdraw-clipminus.svg @@ -0,0 +1,173 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [WandererFan] + + + techdraw-clipminus + 2016-01-14 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/TechDraw/Gui/Resources/icons/actions/techdraw-clipminus.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Techdraw-clipplus.svg b/localwiki/Techdraw-clipplus.svg new file mode 100644 index 0000000..1b74788 --- /dev/null +++ b/localwiki/Techdraw-clipplus.svg @@ -0,0 +1,183 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [WandererFan] + + + techdraw-clipplus + 2016-01-14 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/TechDraw/Gui/Resources/icons/actions/techdraw-clipplus.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Techdraw-draft-view.svg b/localwiki/Techdraw-draft-view.svg new file mode 100644 index 0000000..3be67a2 --- /dev/null +++ b/localwiki/Techdraw-draft-view.svg @@ -0,0 +1,611 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + Jakub Steiner + + + http://jimmac.musichall.cz + + techdraw-draft-view + 2016-01-14 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/TechDraw/Gui/Resources/icons/actions/techdraw-draft-view.svg + + + FreeCAD LGPL2+ + + + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Techdraw-geomhatch.svg b/localwiki/Techdraw-geomhatch.svg new file mode 100644 index 0000000..4f60e31 --- /dev/null +++ b/localwiki/Techdraw-geomhatch.svg @@ -0,0 +1,223 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Techdraw-hatch.svg b/localwiki/Techdraw-hatch.svg new file mode 100644 index 0000000..903aed0 --- /dev/null +++ b/localwiki/Techdraw-hatch.svg @@ -0,0 +1,69 @@ + + + + + + image/svg+xml + + + + + [WandererFan] + + + techdraw-hatch + 2016-01-14 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/TechDraw/Gui/Resources/icons/actions/techdraw-hatch.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Techdraw-image.svg b/localwiki/Techdraw-image.svg new file mode 100644 index 0000000..8b4e9ad --- /dev/null +++ b/localwiki/Techdraw-image.svg @@ -0,0 +1,998 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + Jakub Steiner + + + http://jimmac.musichall.cz + + techdraw-image + 2016-11-06 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/TechDraw/Gui/Resources/icons/actions/techdraw-image.svg + + + FreeCAD LGPL2+ + + + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Techdraw-multiview.svg b/localwiki/Techdraw-multiview.svg new file mode 100644 index 0000000..9a0d4a5 --- /dev/null +++ b/localwiki/Techdraw-multiview.svg @@ -0,0 +1,184 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [agryson] Alexander Gryson + + + http://agryson.net + + techdraw-multiview + 2016-10-29 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/TechDraw/Gui/Resources/icons/actions/techdraw-multiview.svg + + + FreeCAD LGPL2+ + + + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Techdraw-new-default.svg b/localwiki/Techdraw-new-default.svg new file mode 100644 index 0000000..cc93b39 --- /dev/null +++ b/localwiki/Techdraw-new-default.svg @@ -0,0 +1,1066 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [agryson] Alexander Gryson + + + http://agryson.net + + techdraw-new-default + 2016-01-14 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/TechDraw/Gui/Resources/icons/actions/techdraw-new-default.svg + + + FreeCAD LGPL2+ + + + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Techdraw-new-pick.svg b/localwiki/Techdraw-new-pick.svg new file mode 100644 index 0000000..44c0122 --- /dev/null +++ b/localwiki/Techdraw-new-pick.svg @@ -0,0 +1,113 @@ + + + + + + + + + + image/svg+xml + + + + + [WandererFan] + + + techdraw-new-pick + 2016-01-14 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/TechDraw/Gui/Resources/icons/actions/techdraw-new-pick.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Techdraw-projgroup.svg b/localwiki/Techdraw-projgroup.svg new file mode 100644 index 0000000..8e5c474 --- /dev/null +++ b/localwiki/Techdraw-projgroup.svg @@ -0,0 +1,758 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + Jakub Steiner + + + http://jimmac.musichall.cz + + techdraw-projgroup + 2016-01-14 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/TechDraw/Gui/Resources/icons/actions/techdraw-projgroup.svg + + + FreeCAD LGPL2+ + + + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Techdraw-saveSVG.svg b/localwiki/Techdraw-saveSVG.svg new file mode 100644 index 0000000..763e2e7 --- /dev/null +++ b/localwiki/Techdraw-saveSVG.svg @@ -0,0 +1,458 @@ + + + + + + + + image/svg+xml + + + + + [WandererFan] + + + techdraw-symbol + 2016-01-14 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/TechDraw/Gui/Resources/icons/actions/techdraw-symbol.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Techdraw-spreadsheet.svg b/localwiki/Techdraw-spreadsheet.svg new file mode 100644 index 0000000..998bf2d --- /dev/null +++ b/localwiki/Techdraw-spreadsheet.svg @@ -0,0 +1,178 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [WandererFan] + + + techdraw-spreadsheet + 2016-05-04 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/TechDraw/Gui/Resources/icons/actions/techdraw-spreadsheet.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Techdraw-symbol.svg b/localwiki/Techdraw-symbol.svg new file mode 100644 index 0000000..211de46 --- /dev/null +++ b/localwiki/Techdraw-symbol.svg @@ -0,0 +1,427 @@ + + + + + + + + image/svg+xml + + + + + [WandererFan] + + + techdraw-symbol + 2016-01-14 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/TechDraw/Gui/Resources/icons/actions/techdraw-symbol.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Techdraw-toggleframe.svg b/localwiki/Techdraw-toggleframe.svg new file mode 100644 index 0000000..b34da82 --- /dev/null +++ b/localwiki/Techdraw-toggleframe.svg @@ -0,0 +1,906 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + Jakub Steiner + + + http://jimmac.musichall.cz + + techdraw-toggleframe + 2016-01-30 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/TechDraw/Gui/Resources/icons/actions/techdraw-toggleframe.svg + + + FreeCAD LGPL2+ + + + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Techdraw-view.svg b/localwiki/Techdraw-view.svg new file mode 100644 index 0000000..318bdf0 --- /dev/null +++ b/localwiki/Techdraw-view.svg @@ -0,0 +1,184 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [agryson] Alexander Gryson + + + http://agryson.net + + techdraw-view + 2016-01-14 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/TechDraw/Gui/Resources/icons/actions/techdraw-view.svg + + + FreeCAD LGPL2+ + + + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Techdraw-viewdetail.svg b/localwiki/Techdraw-viewdetail.svg new file mode 100644 index 0000000..895ed41 --- /dev/null +++ b/localwiki/Techdraw-viewdetail.svg @@ -0,0 +1,174 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [agryson] Alexander Gryson + + + http://agryson.net + + techdraw-viewdetail + 2016-11-20 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/TechDraw/Gui/Resources/icons/actions/techdraw-viewdetail.svg + + + FreeCAD LGPL2+ + + + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Techdraw-viewsection.svg b/localwiki/Techdraw-viewsection.svg new file mode 100644 index 0000000..c3c0acc --- /dev/null +++ b/localwiki/Techdraw-viewsection.svg @@ -0,0 +1,216 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [agryson] Alexander Gryson + + + http://agryson.net + + techdraw-viewsection + 2016-01-14 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/TechDraw/Gui/Resources/icons/actions/techdraw-viewsection.svg + + + FreeCAD LGPL2+ + + + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/TemplateExample.svg b/localwiki/TemplateExample.svg new file mode 100644 index 0000000..d3b667b --- /dev/null +++ b/localwiki/TemplateExample.svg @@ -0,0 +1,261 @@ + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + + + + + + + + + + + Project Name + Date + Scale + Author + + + AUTHOR + DATE + NAME + X:X + + + + + + + + + + diff --git a/localwiki/TestWorkbench.svg b/localwiki/TestWorkbench.svg new file mode 100644 index 0000000..9e27880 --- /dev/null +++ b/localwiki/TestWorkbench.svg @@ -0,0 +1,211 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + diff --git a/localwiki/Testing.html b/localwiki/Testing.html new file mode 100644 index 0000000..b3bcea0 --- /dev/null +++ b/localwiki/Testing.html @@ -0,0 +1,85 @@ +Testing

      Testing

      + +

      FreeCAD comes with an extensive testing framework. The testing bases on a set of Python scripts which are located in the test module. +

      + + +

      Introduction

      +

      This is the list of test apps as of 0.15 Git 4207: +

      +

      TestAPP.All

      +

      Add test function +

      +

      BaseTests

      +

      Add test function +

      +

      UnitTests

      +

      Add test function +

      +

      Document

      +

      Add test function +

      +

      UnicodeTests

      +

      Add test function +

      +

      MeshTestsApp

      +

      Add test function +

      +

      TestSketcherApp

      +

      Add test function +

      +

      TestPartApp

      +

      Add test function +

      +

      TestPartDesignApp

      +

      Add test function +

      +

      Workbench

      +

      Add test function +

      +

      Menu

      +

      Add test function +

      +

      Menu.MenuDeleteCases

      +

      Add test function +

      +

      Menu.MenuCreateCases

      +

      Add test function +

      + +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Tetraedres.gif b/localwiki/Tetraedres.gif new file mode 100644 index 0000000..3a5c061 Binary files /dev/null and b/localwiki/Tetraedres.gif differ diff --git a/localwiki/TextDocument.svg b/localwiki/TextDocument.svg new file mode 100644 index 0000000..5735b43 --- /dev/null +++ b/localwiki/TextDocument.svg @@ -0,0 +1,230 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + 2005-10-15 + + + Andreas Nilsson + + + + + edit + copy + + + + + + Jakub Steiner + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/ThicknessEsempio1.png b/localwiki/ThicknessEsempio1.png new file mode 100644 index 0000000..7d51442 Binary files /dev/null and b/localwiki/ThicknessEsempio1.png differ diff --git a/localwiki/ThicknessEsempio2.png b/localwiki/ThicknessEsempio2.png new file mode 100644 index 0000000..f7938a2 Binary files /dev/null and b/localwiki/ThicknessEsempio2.png differ diff --git a/localwiki/ThicknessEsempio3.png b/localwiki/ThicknessEsempio3.png new file mode 100644 index 0000000..610efc4 Binary files /dev/null and b/localwiki/ThicknessEsempio3.png differ diff --git a/localwiki/ThicknessEsempio4.png b/localwiki/ThicknessEsempio4.png new file mode 100644 index 0000000..cc92bea Binary files /dev/null and b/localwiki/ThicknessEsempio4.png differ diff --git a/localwiki/Third_Party_Libraries.html b/localwiki/Third_Party_Libraries.html new file mode 100644 index 0000000..efe6eca --- /dev/null +++ b/localwiki/Third_Party_Libraries.html @@ -0,0 +1,220 @@ +Third Party Libraries

      Third Party Libraries

      + +
      + +

      Overview

      +

      These are libraries which are not changed in the FreeCAD project. They are basically used unchanged as a dynamic link library (*.so or *.dll). If there is a change necessary or a wrapper class is needed, then the code of the wrapper or the changed library code has to be moved to the FreeCAD base package. +The used libraries are: +

      If you are using Windows, consider using LibPack instead of downloading and installing all the stuff on your own. +

      +

      Links

      + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
      Link table +
      Lib name Version needed Link to get it +
      Python >= 2.5.x http://www.python.org/ +
      OpenCasCade >= 5.2 http://www.opencascade.org +
      Qt >= 4.1.x https://www.qt.io/ +
      Coin3D >= 2.x http://www.coin3d.org +
      SoQt >= 1.2 http://www.coin3d.org +
      Xerces-C++ >= 2.7.x < 3.0 http://xml.apache.org/xerces-c/ +
      Zlib >= 1.x.x http://www.zlib.net/ +
      Boost >= 1.33.x http://www.boost.org/ +
      Eigen3 >= 3.0.1 http://eigen.tuxfamily.org/index.php?title=Main_Page +
      Shiboken >= 1.1.2 http://shiboken.readthedocs.org/en/latest/ +
      libarea N/A https://github.com/danielfalck/libarea +
      +

      Details

      +

      Python

      +

      Version: 2.5 or higher +

      License: Python 2.5 license +

      You can use the source or binary from http://www.python.org/ or use alternetivly ActiveState Python from http://www.activestate.com/ though it is a little bit hard to get the debug libs from ActiveState. +

      +
      Description
      +

      Python is the primary scripting language and is used throughout the application. +For example: +

      +
      • Implement test scripts for testing on: +
        • memory leaks
        • +
        • ensure presents of functionality after changes
        • +
        • post build checks
        • +
        • test coverage tests
      • +
      • Macros and macro recording
      • +
      • Implement application logic for standard packages
      • +
      • Implementation of whole workbenches
      • +
      • Dynamic loading of packages
      • +
      • Implementing rules for design (Knowledge engineering)
      • +
      • Doing some fancy Internet stuff like work groups and PDM
      • +
      • And so on ...
      +

      Especially the dynamic package loading of Python is used to load at run time additional functionality and workbenches needed for the actual tasks. For a closer look to Python see: www.python.org Why Python you may ask. There are some reasons: So far I used different scripting languages in my professional life: +

      +
      • Perl
      • +
      • Tcl/Tk
      • +
      • VB
      • +
      • Java
      +

      Python is more OO then Perl and Tcl, the code is not a mess like in Perl and VB. Java isn't a script language in the first place and hard (or impossible) to embed. Python is well documented and easy to embed and extend. It is also well tested and has a strong back hold in the open source community. +

      +
      Credits
      +

      Goes to Guido van Rossum and a lot of people made Python such a success! +

      +

      OpenCasCade

      +

      Version: 5.2 or higher +

      License: v6.7.0 and later are governed by GNU Lesser General Public License (LGPL) version 2.1 with additional exception. https://www.opencascade.com/content/licensing Earlier versions use a slightly different license: https://www.opencascade.com/content/occt-public-license +

      OCC is a full-featured CAD Kernel. Originally, it's developed by Matra Datavision in France for the Strim (Styler) and Euclid Quantum applications and later on made Open Source. It's a really huge library and makes a free CAD application possible in the first place, by providing some packages which would be hard or impossible to implement in an Open Source project: +

      +
      • A complete STEP compliant geometry kernel
      • +
      • A topological data model and all needed functions to work on (cut, fuse, extrude, and so on. . . )
      • +
      • Standard Import- / Export processors like STEP, IGES, VRML
      • +
      • 3D and 2D viewer with selection support
      • +
      • A document and project data structure with support for save and restore, external linking of documents, recalculation of design history (parametric modeling) and a facility to load new data types as an extension package dynamically
      +

      To learn more about OpenCasCade take a look at the OpenCasCade page or http://www.opencascade.org. +

      +

      Qt

      +

      Version: 4.1.x or higher +

      License: GPL v2.0/v3.0 or Commercial (from version 4.5 on also LPGL v2.1) +

      I don't think I need to tell a lot about Qt. It's one of the most often used GUI toolkits in Open Source projects. For me the most important point to use Qt is the Qt Designer and the possibility to load whole dialog boxes as a (XML) resource and incorporate specialized widgets. In a CAX application the user interaction and dialog boxes are by far the biggest part of the code and a good dialog designer is very important to easily extend FreeCAD with new functionality. Further information and a very good online documentation you'll find on http://www.qtsoftware.com. +

      +

      Coin3D

      +

      Version: 2.0 or higher +

      License: GPL v2.0 or Commercial +

      Coin is a high-level 3D graphics library with a C++ Application Programming Interface. Coin uses scenegraph data structures to render real-time graphics suitable for mostly all kinds of scientific and engineering visualization applications. +

      Coin is portable over a wide range of platforms: any UNIX / Linux / *BSD platform, all Microsoft Windows operating system, and Mac OS X. +

      Coin is built on the industry-standard OpenGL immediate mode rendering library, and adds abstractions for higher-level primitives, provides 3D interactivity, immensely increases programmer convenience and productivity, and contains many complex optimization features for fast rendering that are transparent for the application programmer. +

      Coin is based on the SGI Open Inventor API. Open Inventor, for those who are not familiar with it, has long since become the de facto standard graphics library for 3D visualization and visual simulation software in the scientific and engineering community. It has proved it's worth over a period of more than 10 years, its maturity contributing to its success as a major building block in thousands of large-scale engineering applications around the world. +

      We will use OpenInventor as 3D viewer in FreeCAD because the OpenCasCade viewer (AIS and Graphics3D) has serios limitations and performace bottlenecks, especially when it goes in large-scale engineering rendering. Other things like textures or volumetric rendering are not really supported, and so on .... +

      Since Version 2.0 Coin uses a different licence model. It's not longer LGPL. They use GPL for open source and a commercial licence for closed source. That means if you want to sell your work based on FreeCAD (extension modules) you need to purchase a Coin licence! +

      +

      SoQt

      +

      Version: 1.2.0 or higher +

      License: GPL v2.0 or Commercial +

      SoQt is the Inventor binding to the Qt Gui Toolkit. Unfortunately, it's not longer LGPL so we have to remove it from the code base of FreeCAD and link it as a library. It has the same licence model like Coin. And you have to compile it with your version of Qt. +

      +

      Xerces-C++

      +

      Version: 2.7.0 or higher +

      License: Apache Software License Version 2.0 +

      Xerces-C++ is a validating XML parser written in a portable subset of C++. Xerces-C++ makes it easy to give your application the ability to read and write XML data. A shared library is provided for parsing, generating, manipulating, and validating XML documents. +

      Xerces-C++ is faithful to the XML 1.0 recommendation and many associated standards (see Features below). +

      The parser provides high performance, modularity, and scalability. Source code, samples and API documentation are provided with the parser. For portability, care has been taken to make minimal use of templates, no RTTI, and minimal use of #ifdefs. +

      The parser is used for saving and restoring parameters in FreeCAD. +

      +

      Zlib

      +

      Version: 1.x.x +

      License: zlib License +

      zlib is designed to be a free, general-purpose, legally unencumbered -- that is, not covered by any patents -- lossless data-compression library for use on virtually any computer hardware and operating system. The zlib data format is itself portable across platforms. Unlike the LZW compression method used in Unix compress(1) and in the GIF image format, the compression method currently used in zlib essentially never expands the data. (LZW can double or triple the file size in extreme cases.) zlib's memory footprint is also independent of the input data and can be reduced, if necessary, at some cost in compression. +

      +

      Boost

      +

      Version: 1.33.x +

      License: Boost Software License - Version 1.0 +

      The Boost C++ libraries are a collection of peer-reviewed, open source libraries that extend the functionality of C++. The libraries are licensed under the Boost Software License, designed to allow Boost to be used with both open and closed source projects. Many of Boost's founders are on the C++ standard committee and several Boost libraries have been accepted for incorporation into the Technical Report 1 of C++0x. +

      The libraries are aimed at a wide range of C++ users and application domains. They range from general-purpose libraries like SmartPtr, to OS Abstractions like FileSystem, to libraries primarily aimed at other library developers and advanced C++ users, like MPL. +

      In order to ensure efficiency and flexibility, Boost makes extensive use of templates. Boost has been a source of extensive work and research into generic programming and meta-programming in C++. +

      See: http://www.boost.org/ for details. +

      +

      libarea

      +

      Version: N/A +

      License: New BSD (BSD 3-Clause) +

      Area is a piece of software created by Dan Heeks for HeeksCNC. It is employed as a library for generation of CAM related operations in the Path Workbench. +

      +

      LibPack

      +

      LibPack is a convenient package with all the above libraries packed together. It is currently available for the +Windows platform on the Download page! If you're working under Linux you don't need a LibPack, instead of you should make use of the package repositories of your Linux distribution. +

      +

      FreeCADLibs7.x Changelog

      +
      • Using QT 4.5.x and Coin 3.1.x
      • +
      • Eigen template lib for Robot added
      • +
      • SMESH experimental
      +


      +

      + +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Third_Party_Tools.html b/localwiki/Third_Party_Tools.html new file mode 100644 index 0000000..05e11f9 --- /dev/null +++ b/localwiki/Third_Party_Tools.html @@ -0,0 +1,84 @@ +Third Party Tools

      Third Party Tools

      + +
      + +

      Tool Page

      +

      For every serious software development you need tools. Here is a list of tools we use to develop FreeCAD: +

      +

      Platform independend tools

      +

      Qt-Toolkit

      +

      The Qt-toolkit is a state of the art, plattform independend user interface design tool. It is contained in the LibPack of FreeCAD, but can also be downloaded at Qt project. +

      +

      InkScape

      +

      Great vector drawing programm. Adhers to the SVG standard and is used to draw Icons and Pictures. Get it at www.inkscape.org. +

      +

      Doxygen

      +

      A very good and stable tool to generate source documentation from the .h and .cpp files. +

      +

      The Gimp

      +

      Not much to say about the Gnu Image Manipulation Program. Besides it can handle .xpm files which is a very convenient way to handle Icons in QT Programms. XPM is basicly C-Code which can be compiled into a programme. +

      Get the GIMP here: www.gimp.org +

      +

      Tools on Windows

      +

      Visual Studio 8 Express

      +

      Although VC8 is for C++ development not really a step forward since VisualStudio 6 (IMO a big step back), its a free development system on Windows. For native Win32 applications you need to download the PlatformSDK from M$. +

      So the Express edition is hard to find. But you might try this link +

      +

      CamStudio

      +

      Is a Open Source tool to record Screencasts (Webcasts). Its a very good tool to create tutorials by recording them. Its far not so boring as writing documentation. +

      See camstudio.org for details. +


      +

      +

      Tortoise SVN

      +

      This is a very great tool. It makes using Subversion (our version control system on sf.net) a real pleasure. You can throught out the explorer integration, easily manage Revisions, check on Diffs, resolve Confilcts, make branches, and so on.... The commit dialog itself is a piece of art. It gives you an overview over your changed files and allows you to put them in the commit or not. That makes it easy to bundle the changes to logical units and give them an clear commit message. +

      You find ToroiseSVN on tortoisesvn.tigris.org. +

      +

      StarUML

      +

      A full featured Open Source UML programm. It has a lot of features of the big ones, including reverse engeniering C++ source code.... +

      Download here: staruml.sourceforge.net +


      +

      +

      Tools on Linux

      +

      TODO +

      + +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Thread-by-vertical-profile-rule2.png b/localwiki/Thread-by-vertical-profile-rule2.png new file mode 100644 index 0000000..cad869d Binary files /dev/null and b/localwiki/Thread-by-vertical-profile-rule2.png differ diff --git a/localwiki/Thread_for_Screw_Tutorial.html b/localwiki/Thread_for_Screw_Tutorial.html new file mode 100644 index 0000000..6f0cb54 --- /dev/null +++ b/localwiki/Thread_for_Screw_Tutorial.html @@ -0,0 +1,197 @@ +Thread for Screw Tutorial

      Thread for Screw Tutorial

      + +
      + + + + + + + + + + + + + + + + + + + + + + + + + + + +
      +

      Base ExampleCommandModel.png Tutorial

      +
      Topic +
      Modeling +
      Level +
      Advanced +
      Time to complete +
      +
      Author +
      DeepSOIC, Murdic +
      FreeCAD version +
      0.14 or above (depends on method) +
      Example File(s) +
      +

      + +
      +


      +

      +

      Introduction

      +

      This tutorial is a collection of techniques to model screw threads in FreeCAD. +

      Modeling threads is discouraged, because it puts big load on modeling kernel, as well as on rendering side. Thread shapes take a lot of memory, and having just one thread in a FreeCAD project can easily blow the file size into megabyte range. However, there are some situations, where it is essential to model the thread to its full details, and this is what the tutorial is for. +

      +

      Method 0. Obtain one from library of parts

      +

      Using models that other people have made is easy and saves time. Check out Macro BOLTS, which is an interface for inserting standard parts from BOLTS library. +

      +

      Method 1. Using macros.

      +

      There is a famous Screw Maker macro, made by ulrich1a, and a whole Fasteners Workbench made by shaise (link to GitHub). These have an option to generate a thread. +These are aimed at standard thread profiles (triangular-ish). +

      +

      Method 2. Cheating by stacking disks.

      +

      This is a very good way for visualizing threads, yet keeping the geometry simple. +

      The idea is to create a non-helical thread (which is just a revolution of a sawtooth profile, or a stack of disks with tapered edges). Such a fake thread is hard to tell apart from the real helical one by just looking at it. This may work for FEM, too. However, if you want to 3d-print it, this isn't going to work. +

      Thread-stack-vs-proper.png +

      +

      Method 3. Sweeping a vertical profile.

      +

      Idea

      +

      The idea is pretty simple: draw the profile of the thread, and then sweep it along a helix. When sweeping, make sure to tick Solid and Frenet checkboxes. Solid is the key to be able to perform union or cut operations on it. Frenet will keep the profile from twisting (more info on that is available in Part Sweep documentation). +

      This generates a coil of the thread, without the rod or the hole. To make a thread on a rod or a hole, one has to union or cut this coil with a cylinder. Additional Boolean operations are needed to shape up the ugly abrupt ends of the coil. +

      +
      Creating a thread coil by sweeping a vertical profile. 1 - the profile (a sketch). 2 - sweep path (Part Helix). 3 - the result of sweeping (Part Sweep)
      +

      Tricks to success

      +

      Thread-by-vertical-profile-rule1.png +

      Rule 1. The sweep must not self-intersect. A self-intersecting sweep is an invalid solid. Attempts to fuse it or cut it are very likely to fail. Nevertheless, this may be OK for 3d-printing and visualization purposes to leave the coil and the cylinder unfused (intersecting). +

      1000 +

      Rule 2. Remember that helix in FreeCAD is an imprecise thing. As a consequence, a cylinder made to mate with the thread precisely is very likely to fail to fuse to the thread. In general, avoid geometry coincident to elements of the sweep, such as tangent faces, edges tangent to faces they are not connected to, coincident and tangent edges, etc. +

      Tip 1. The radius of the helix does not matter (unless the helix is tapered). All that matters is the pitch and the height of the helix. This means that you can use a generic helix to generate a number of threads with equal pitch. +

      Tip 2. Keep it short (low number of turns). Long threads tend to fail in Boolean operations. Consider stacking the thread from short pieces using Draft Array, if a long thread proves problematic. +

      +

      Pros and cons

      +

      + Very natural way of defining thread profile +

      + easy to understand +

      + no problems with mesh generation, unlike method 4 +

      - due to invalidity of self-intersecting sweeps, it is next to impossible to generate a gapless thread (that is, with no cylindrical faces at the outer or inner sides of the thread) +

      - Boolean operations are required to obtain meaningful results. These take long time and fail often. +

      - Threads with high number of turns are problematic. +

      +

      Method 4. Sweeping a horizontal profile

      +

      Idea

      +

      The idea is to sweep a horizontal cross-section of the thread along the helix. The main problem here is figuring out, what profile to use to obtain a certain thread. +

      Thread-by-horz-profile.png +

      If one uses a circle as a horizontal profile (the circle has to be placed off the origin, that offset defines the depth of the thread), thread profile will be sinusoidal. +

      To obtain a standard sawtooth profile, a pair of mirrored archimedean spirals need to be fused into a wire. The resulting figure is a heart shape, which becomes barely distinguishable from a circle when the depth of the thread is small compared to its diameter (this is why such a "thick" thread is shown on the picture above). +

      +

      Generating the profile

      +

      Figuring out, what the horizontal profile needs to be made for obtaining a certain vertical profile is not easy. For simple cases like triangular or trapezoidal, it can be constructed manually. Alternatively, it can be constructed by creating a short thread with method 3, and getting a slice of it by doing a common between a horizontal plane face and the thread. +

      +
      Profile for triangular thread
      +
      1. Create a spiral (archimedian) in XY plane. +
        1. Set number of turns to 0.5,
        2. +
        3. the radius to the inner radius of the thread (outer radius will be this + depth of cut)
        4. +
        5. and growth to double the depth of cut of the thread.
      2. +
      3. Part Mirror the spiral against XY plane
      4. +
      5. Part Union the spiral and the mirror to obtain a closed wire, shaped like a heart. Done!
      +
      Profile for arbitrary cross-section
      +

      Thread-by-horz-profile-profileMake.png +

      +
      1. make a (vertical) cut profile. Make sure that the height of the sketch matches the pitch of the thread you need.
      2. +
      3. make a helix1 with height identical to the pitch and the pitch identical to the thread pitch and a helix radius of 0.42*nominal diameter of the thread.
      4. +
      5. Sweep the cut profile along the helix1. Set make solid and frenet to true.
      6. +
      7. Make a circle with nominal radius of the thread in the x-y-plane.
      8. +
      9. Make a face from the circle. (Part-workbench: advanced utility to create shapes, or Draft Upgrade then MakeFace = true)
      10. +
      11. cut the face with the sweep profile
      12. +
      13. make a clone from the cut (Draft workbench)
      14. +
      15. Downgrade the clone in order to get a wire. (Draft workbench) This wire is the horizontal profile needed for this method.
      16. +
      17. Make a helix with radius of nominal radius of the thread and a pitch of the thread and the height of the needed thread.
      18. +
      19. Sweep the wire along the helix. Set solid and frenet to true.
      +

      You are done. +

      Credit: step-by-step guide from a forum post by Ulrich1a, slightly modified. +

      The steps are also shown in action on this video by Gaurav Prabhudesai: http://www.youtube.com/watch?v=fxKxSOGbDYs +

      +

      Pros and cons

      +

      + A ready-to-use thread-on-a-rod solid shape is created by the sweep directly. +

      + Less or even no Boolean operations required, generation speed is very high compared to Method 3. +

      + Thread ends are nicely cut straight away +

      + Long threads are not a problem, unless a Boolean operation is needed. Otherwise, it is not going to be much better than Method 3. +

      + Gapless threads are not a problem. +

      - Defining thread profile is complicated. +

      - Standard mesher generates ugly meshes, which can lead to problems. Other meshers are better, Mefisto seems to give the best results. +

      - large memory footprint [1] +


      +

      +

      Method 5. Lofting between helical extruded faces

      +

      Idea

      +

      Helical splines will extrude coaxial faces that are able to be lofted, while FreeCAD's parametric helix won't. It takes two helical splines to define a thread. Those two can be scaled from a library spline, then located and extruded appropriately to get the form right. +


      +FreeCAD's parametric helixes aren't truly helical, but helical b-splines aren't difficult to lay out. One manual method is to array dodecagons (12-sided polygons) with 5mm radius/10mm diameter at 1/12mm (0.08333.mm) z intervals and trace splines from vertex to vertex in ascending and rotating order, and to consider doing it once with, say, 10 turns, so that that spline can be re-used as a library file for import and reuse. It's convenient to use 10mm diameter/1mm pitch for ease of scaling. If you are doing it manually, drawing a Dwire and then converting it to a b-spline is easier than drawing a spline. Dwires don't have curvature computed while being drawn, so they follow the cursor and snap more obediently. +

      Once the splines are scaled to the right size and located so that the loft will have the right included angle between the thread flanks, they're extruded along their axis, a pitch length's worth for the inner spline, the outer pitch/8. +


      +Splineextrudeloft.png +


      +ISO and other threads have relieved, ie flat, inner and outer edges rather than sharp, which suits FreeCAD users with this method, because we can loft to the helical face at the nominal fastener size, while an inner face can't be lofted to an outer edge spline because a face is a closed profile, a spline is open. ISO standard says the nominal size of external threads have a face width pitch/8. The picture shows how the geometry is arranged, and the helical faces that result. Then, loft between the faces, and then a cylinder that gives the inner helical face, which ISO puts at pitch/4 width, is added to the threads. +


      +761PX +


      +This method produces reliable solids that boolean properly. While it doesn't produce "parametric" screw threads in standard sizes in the sense of having simple access to form by fastener size, it's an easy way of producing an accurate library for reuse, and models of specialised forms like ACME, or Archimedian screws, are also uncomplicated as one-offs. +


      +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Threadform.PNG b/localwiki/Threadform.PNG new file mode 100644 index 0000000..905b7e4 Binary files /dev/null and b/localwiki/Threadform.PNG differ diff --git a/localwiki/Tolerance_editable.svg b/localwiki/Tolerance_editable.svg new file mode 100644 index 0000000..f890bbe --- /dev/null +++ b/localwiki/Tolerance_editable.svg @@ -0,0 +1,111 @@ + + + + + Frame 4 Symbol + + + + + + image/svg+xml + + Frame 4 Symbol + + + bavariaSHAPE + + + + + bavariaSHAPE + + + + + bavariaSHAPE + + + 15.10.2016 + Geometric dimensioning and tolerancing + + + + + + + 0.01 + + + + diff --git a/localwiki/Toothbrush_Head_Stand.html b/localwiki/Toothbrush_Head_Stand.html new file mode 100644 index 0000000..57c9248 --- /dev/null +++ b/localwiki/Toothbrush_Head_Stand.html @@ -0,0 +1,456 @@ +Toothbrush Head Stand

      Toothbrush Head Stand

      + +
      + + + + + + + + + + + + + + + + + + + + + + + + + + + +
      +

      Base ExampleCommandModel.png Tutorial

      +
      Topic +
      Modeling +
      Level +
      Beginner +
      Time to complete +
      1 hour +
      Author +
      EmmanuelG +
      FreeCAD version +
      0.16 or greater +
      Example File(s) +
      Thingiverse 2403310 +

      + +
      +


      +

      +

      A daily-life problem

      +

      Electric toothbrushes rarely come with a head stand, while in a family you will often see multiple heads used with one body. Many people facing a common problem lead us to a variety of solutions, as you can see on Thingiverse (200-800 projects are related to that). Here is the first answer and how to design it. +

      This tutorial will take you through the steps needed to model the part shown in the image below using basic tools from the Part Design Workbench (many of the tools and capabilities are not covered). +

      +
      TBHS-model.png
      +

      First idea : a plate

      +
      • From the start-page, select Workbench PartDesign.png Part Design, or create a new document and select the Part Design workbench.
      +
      TBHS-0.png
      +

      Create a sketch

      +
      • Click on Sketcher NewSketch.png New sketch. Either from the contextual task menu at the left, or the toolbar above or from the Part Design menu at the top.
      +
      TBHS-1.JPG
      +


      +A dialog prompts you to choose the sketch orientation and provide an offset. +

      +
      • We will pick the XY Plane as shown in the image above (that orientation correspond to the common build plate of most 3D printers), then click OK.
      +
      TBHS-2.JPG
      +


      +You now are facing the XY plane from above, and have access to the drawing tools. +

      +
      • Click on Sketcher CreateRectangle.png Rectangle.
      • +
      • Click to place a first point.
      • +
      • Click to place the opposite corner.
      • +
      • Press ESC or click the right mouse button to stop using the tool.
      +
      TBHS-3.JPG
      +


      +You now have a floating rectangle of unspecified dimensions. +

      +
      • Click on a line of the rectangle, you now have access to the constraint tools at the right of the toolbar (depending of the size of your screen you may need to drag them to the left in order to see them all)
      • +
      • Click on Constraint Length.png Length
      • +
      • A dialog prompts you to set a dimension. Enter 80mm, click OK.
      • +
      • Repeat with the other side of the rectangle, also 80mm.
      +
      TBHS-4.JPG
      +


      +You now have a floating square. +

      +
      • Click on the lower left point of the square.
      • +
      • Click on the origin of the XY plane (at the intersection of the two thick lines).
      • +
      • Click on Constraint PointOnPoint.png Coincident.
      +
      TBHS-5.JPG
      +


      +You now have a totally constrained sketch, as you are told by the solver on the left and the change of color. +It is a good practice to always have a totally constrained sketch. +

      An under-constrained sketch can leave room for unwanted change, if you modify something later on. +On the opposite, an over-constrained sketch is also not good. In that case the solver warn you of redundant constraints and you should remove some of them. +

      +
      • To leave the sketch, click either on the "Close" button on the left, or the Sketcher LeaveSketch.png icon in the toolbar, or press ESC.
      +
      TBHS-6.JPG
      +


      +You now only see the square, and the contextual task menu on the left show you more options than before. +

      +

      Create a pad

      +
      • Click on View-axometric.png Axonometric among the standard views, to better see what will happen.
      • +
      • Click on PartDesign Pad.png Pad.
      • +
      • Enter 4mm and click OK.
      +
      TBHS-7.JPG
      +


      +Your sketch is now in volume ! +

      +

      Create a sketch on it

      +
      • Select the upper face
      +
      TBHS-8.JPG
      +


      +The color of the face change and you have more options in the contextual task menu. +

      +
      • Click on Sketcher NewSketch.png New sketch. As a face was selected it will not ask you to choose a plane.
      +
      TBHS-9.JPG
      +


      +

      +
      • Click on Sketcher Circle.png Circle, click to place the center, move the pointer and click to define the radius.
      • +
      • Draw 4 circles on the pad (of any size)
      • +
      • Press ESC or click the right mouse button to stop using the tool.
      +
      TBHS-10.JPG
      +


      +

      + +
      TBHS-11.JPG
      +


      +Now the circles share the same radius. +

      +
      • Click on Sketcher External.png External geometry.
      • +
      • Click on the four sides of the square, it add lines, color magenta.
      +
      TBHS-12.JPG
      +


      +Theses lines will serve as reference to position the circles. +

      +
      • Use Constraint Length.png Length to position them at 20mm from the edges.
      +
      TBHS-13.JPG
      +


      +

      +
      • Click on a circle
      • +
      • Click on Constraint Radius.png Radius and set it at 1,5mm.
      +
      TBHS-14.JPG
      +


      +

      +
      • To leave the sketch, click either on the "Close" button on the left, or the Sketcher LeaveSketch.png icon in the toolbar, or press ESC.
      +
      TBHS-15.JPG
      +

      Create a pad

      +
      • Click on View-axometric.png Axonometric among the standard views, to better see what will happen.
      • +
      • Click on PartDesign Pad.png Pad.
      • +
      • Enter 25mm and click OK.
      +
      TBHS-16.JPG
      +


      +You have the basic shape, it just need final touches. +

      +

      Rounding the corners

      +
      • Holding CTRL click on the vertical edge at each corner to select the four of them.
      +

      Don't hesitate to help you by switching the display mode (just at the left of the Axonometric View) between DrawStyleWireFrame.svg Wireframe and DrawStyleFlatLines.svg Wireframe and shadow. +

      +
      TBHS-17.JPG
      +


      +

      +
      • Click on PartDesign Fillet.png Fillet.
      • +
      • Set the radius at 20mm.
      +
      TBHS-18.JPG
      +


      +Much better. +

      +

      Making it more robust

      +

      We need to add material at the base of the cylinders to make them less prone to snap. Because of the printing orientation these small surfaces will be fragile at the junction with the base. +

      +
      • Select the circles at the base of the cylinders
      +
      TBHS-19.JPG
      +


      +

      +
      • Click on PartDesign Chamfer.png Chamfer.
      • +
      • Set it to 2mm.
      +
      TBHS-20.JPG
      +

      Chamfer the edges

      +
      • Select the face under the base, add a PartDesign Chamfer.png Chamfer of 0,5mm.
      +

      The first layer of plastic is often being squashed a little too much, this will compensate that and save you time in cleaning the model. If the first layer is ok that will make it only nicer +

      +
      TBHS-21.JPG
      +


      +

      +
      • Select the edges at the border of the upper face (holding CTRL ).
      +
      TBHS-23.JPG
      +


      +

      +
      • Add a PartDesign Chamfer.png Chamfer of 1mm. This one is only aesthetic.
      +
      TBHS-22.JPG
      +


      +Tadaa ! +

      +

      Export as a .STL

      +
      • In the Combo View on the left, select the tree view instead of the contextual task menu, click on the last feature (the chamfer).
      +
      TBHS-24.JPG
      +


      +

      +
      • Now you can select "Export..." from the File menu at the top left, and select the file format .STL.
      • +
      • Just print it :-)
      +

      Inspiration

      +

      The above model make a good starting point to use FreeCAD, but as a toothbrush head stand it have its flaws : due to the print orientation and small surface the sticks are prone to break. +

      Inspired by the variety of solutions other people came up with, we will make this second version which will be much better. +

      +
      TBHS-v2.jpg
      +


      +Don't worry it is often needed to go through several revision for an idea (e.g. : once the prototype on the picture was used, we added more space between the heads so that they should not touch). +

      In this second part you will also learn to use more tools, like the powerful Linear repetition. +

      +

      Second idea : a band

      +
      • Create a new document and select the Workbench PartDesign.png Part Design workbench.
      +

      Create a sketch

      +
      • Create a Sketcher NewSketch.png New sketch, on the XY plan.
      +
      TBHS-1.JPG
      +


      +

      +
      • Draw a Sketcher CreateSlot.png Slot +
        • Click to place the first center
        • +
        • Move to define the length and radius
        • +
        • Click to set the second center.
      +
      TBHS2-1.JPG
      +


      +You now have a floating slot of unspecified dimensions. +

      +
      • Click on one of the horizontal line of the slot
      • +
      • Click on Constraint Length.png Length
      • +
      • A dialog prompts you to set a dimension. Enter 75mm, click OK. +
        • that's for a 3 head stand, count 25mm for each, if you want more
      +
      TBHS2-2.JPG
      +


      +

      +
      • Click on one point of the horizontal line
      • +
      • Click on one point of the other horizontal line
      • +
      • Click on Constraint Length.png Length
      • +
      • A dialog prompts you to set a dimension. Enter 29mm, click OK.
      +
      TBHS2-3.JPG
      +


      +

      +
      • Draw a Sketcher CreateSlot.png Slot around the first slot.
      +
      TBHS2-4.JPG
      +


      +

      +
      • Make the centers of the second slot coincident with the centers of the first slot with Constraint PointOnPoint.png Coincident.
      +
      TBHS2-5.JPG
      +


      +

      +
      • Click on one point of the horizontal line of the first slot
      • +
      • Click on one point of the nearest horizontal line of the second slot
      • +
      • Click on Constraint Length.png Length
      • +
      • A dialog prompts you to set a dimension. Enter 3mm, click OK.
      +
      TBHS2-6.JPG
      +


      +

      +
      • To make the sketch fully constrained +
        • Click on the lower left point of the second slot
        • +
        • Click on the origin of the XY plan
        • +
        • Click on Constraint PointOnPoint.png Coincident
      +
      TBHS2-7.JPG
      +


      +

      +
      • To leave the sketch, click either on the "Close" button on the left, or the Sketcher LeaveSketch.png icon in the toolbar, or press ESC.
      +
      TBHS2-8.JPG
      +

      Create a pad

      +
      • Click on View-axometric.png Axonometric among the standard views, to better see what will happen.
      • +
      • Click on PartDesign Pad.png Pad.
      • +
      • Enter 30mm and click OK.
      +
      TBHS2-9.JPG
      +


      +

      +

      Create a sketch on it

      +
      • Select the upper face
      +
      TBHS2-10.JPG
      +


      +

      +
      • Create a Sketcher NewSketch.png New sketch. As a face was selected it will not ask you to choose a plane.
      +
      TBHS2-11.JPG
      +


      +

      +
      • Draw an Sketcher CreateHexagon.png Hexagon +
        • Click to place the center
        • +
        • Move to define the radius
        • +
        • Click to set
      +
      TBHS2-12.JPG
      +


      +

      +
      • Click on an edge of the hexagon
      • +
      • Click on Constraint Horizontal.png Horizontal
      +
      TBHS2-13.JPG
      +


      +

      +
      • Click on the center of the hexagon
      • +
      • Click on the horizontal line of the XY plane
      • +
      • Click on Constraint Length.png Length
      • +
      • A dialog prompts you to set a dimension. Enter 15mm, click OK.
      +
      TBHS2-14.JPG
      +


      +

      +
      • Click on the center of the hexagon
      • +
      • Click on the vertical of the XY plane
      • +
      • Click on Constraint Length.png Length
      • +
      • A dialog prompts you to set a dimension. Enter 10mm, click OK.
      +
      TBHS2-15.JPG
      +


      +

      +
      • Click on the blue circle of the hexagon
      • +
      • Click on Constraint Radius.png Radius
      • +
      • A dialog prompts you to set a dimension. Enter 8mm, click OK.
      +
      TBHS2-16.JPG
      +


      +

      +
      • To leave the sketch, click either on the "Close" button on the left, or the Sketcher LeaveSketch.png icon in the toolbar, or press ESC.
      +
      TBHS2-17.JPG
      +

      Create a hole

      +
      • Click on View-axometric.png Axonometric among the standard views, to better see what will happen.
      • +
      • Click on PartDesign Pocket.png Pocket.
      • +
      • Select to the first in the dropdown menu and click OK.
      +
      TBHS2-18.JPG
      +


      +

      +

      Linear repetition

      +
      • In the Combo View on the left, select the tree view instead of the contextual task menu, click on the pocket feature.
      • +
      • Click on PartDesign LinearPattern.png LinearPattern.
      • +
      • Set the length at 55mm and occurencies at 3, then click OK.
      +
      TBHS2-19.JPG
      +

      Create a sketch on it

      +
      • Select the inner face
      +
      TBHS2-20.JPG
      +


      +

      +
      • Create a Sketcher NewSketch.png New sketch. As a face was selected it will not ask you to choose a plane.
      +
      TBHS2-21.JPG
      +


      +

      +
      • Click on Sketcher Circle.png Circle, click to place the center, move the pointer and click to define the radius.
      +
      TBHS2-22.JPG
      +


      +

      +
      • Click on the center of the circle
      • +
      • Click on the horizontal line of the XY plane
      • +
      • Click on Constraint Length.png Length
      • +
      • A dialog prompts you to set a dimension. Enter 15mm, click OK.
      +
      TBHS2-23.JPG
      +


      +

      +
      • Click on the center of the circle
      • +
      • Click on the vertical of the XY plane
      • +
      • Click on Constraint Length.png Length
      • +
      • A dialog prompts you to set a dimension. Enter 10mm, click OK.
      +
      TBHS2-24.JPG
      +


      +

      +
      • Click on the circle
      • +
      • Click on Constraint Radius.png Radius
      • +
      • A dialog prompts you to set a dimension. Enter 3.5mm, click OK.
      +
      TBHS2-25.JPG
      +


      +

      +
      • To leave the sketch, click either on the "Close" button on the left, or the Sketcher LeaveSketch.png icon in the toolbar, or press ESC.
      +
      TBHS2-26.JPG
      +


      +

      +

      Create a pad

      +
      • Click on View-axometric.png Axonometric among the standard views, to better see what will happen.
      • +
      • Click on PartDesign Pad.png Pad.
      • +
      • Enter 4mm and click OK.
      +
      TBHS2-27.JPG
      +

      Linear repetition

      +
      • In the Combo View on the left, select the tree view instead of the contextual task menu, click on the pad feature.
      • +
      • Click on PartDesign LinearPattern.png LinearPattern.
      • +
      • Set the length at 55mm and occurencies at 3, then click OK.
      +
      TBHS2-28.JPG
      +


      +

      +

      Draft

      +
      • Select the side of each round pads
      +
      TBHS2-29.JPG
      +


      +

      +
      • Click on PartDesign Draft.png Draft.
      • +
      • Set the draft angle at 40°.
      • +
      • Click on "Neutral plane" and select the face on which the sketch is drawn.
      • +
      • Tick "Invert the draft direction".
      +
      TBHS2-30.JPG
      +


      +We could have used a chamfer to do something similar, but the draft is more appropriate in this case. +

      Chamfer = left / Draft = right +

      TBHS2-30-chamfer.JPGTBHS2-30-draft.JPG +


      +

      +

      Finitions

      +
      • Holding CTRL select the bottom and top faces.
      +

      TBHS2-31-bottom.JPGTBHS2-31-top.JPG +

      +
        • Add a PartDesign Chamfer.png Chamfer of 0,5mm.
      +
      TBHS2-31.JPG
      +


      +Perfect ! +

      +

      Export as a .STL

      +
      • In the Combo View on the left, select the tree view instead of the contextual task menu, click on the last feature (the chamfer).
      +
      TBHS2-32.JPG
      +


      +

      +
      • Now you can select "Export..." from the File menu at the top left, and select the file format .STL.
      • +
      • Print it instead of the first version or to replace it if it eventually broke ;-)
      +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/TopoShape_API.html b/localwiki/TopoShape_API.html new file mode 100644 index 0000000..36c1aaf --- /dev/null +++ b/localwiki/TopoShape_API.html @@ -0,0 +1,719 @@ +TopoShape API

      TopoShape API

      + +

      The TopoShape is the mother object of the Part Module. All shape types (wire, face, solid, etc...) of the Part module are TopoShapes, and share the following attributes and methods. Example: +

      +
      import Part
      +sh = Part.makeBox(10,10,10)
      +print sh.Faces
      +for f in sh.Faces:
      +   print f.Edges 
      +


      +

      +
      +
      Property.png Area
      +
      +

      Returns: The total area of the faces of the shape. +

      +
      +
      +


      +

      +
      +
      Property.png BoundBox
      +
      +

      Returns: The BoundBox of the object +

      +
      +
      +


      +

      +
      +
      Property.png CenterOfMass
      +
      +

      Returns: The center of mass of the current system. If the gravitational field is uniform, it is the center of gravity. The coordinates returned for the center of mass are expressed in the absolute Cartesian coordinate system. +

      +
      +
      +


      +

      +
      +
      Property.png CompSolids
      +
      +

      Returns: Lists the subsequent shapes in this shape. +

      +
      +
      +


      +

      +
      +
      Property.png Compounds
      +
      +

      Returns: Lists the coumpounds in this shape. +

      +
      +
      +


      +

      +
      +
      Property.png Edges
      +
      +

      Returns: Lists the Edges in this shape. +

      +
      +
      +


      +

      +
      +
      Property.png Faces
      +
      +

      Returns: Lists the faces in this shape. +

      +
      +
      +


      +

      +
      +
      Property.png Length
      +
      +

      Returns: Total length of the edges of the shape. +

      +
      +
      +


      +

      +
      +
      Property.png Matrix
      +
      +

      Returns: The current transformation of the object as matrix +

      +
      +
      +


      +

      +
      +
      Property.png Orientation
      +
      +

      Returns: the orientation of the shape. +

      +
      +
      +


      +

      +
      +
      Property.png Placement
      +
      +

      Returns: The current transformation of the object as placement +

      +
      +
      +


      +

      +
      +
      Property.png ShapeType
      +
      +

      Returns: The type of the shape. +

      +
      +
      +


      +

      +
      +
      Property.png Shells
      +
      +

      Returns: Lists the subsequent shapes in this shape. +

      +
      +
      +


      +

      +
      +
      Property.png Solids
      +
      +

      Returns: List of subsequent shapes in this shape. +

      +
      +
      +


      +

      +
      +
      Property.png Vertexes
      +
      +

      Returns: List of vertexes in this shape. +

      +
      +
      +


      +

      +
      +
      Property.png Volume
      +
      +

      Returns: Total volume of the solids of the shape. +

      +
      +
      +


      +

      +
      +
      Property.png Wires
      +
      +

      Returns: List of wires in this shape. +

      +
      +
      +


      +

      +
      +
      Method.png approximate ( )
      +
      +

      Description: Approximates a B-Spline-curve from this wire +

      Returns: a BSplineCurve object +

      +
      +
      +


      +

      +
      +
      Method.png check ( )
      +
      +

      Description: Checks the shape and report errors in the shape structure. This is a more detailed check as done in isValid(). +

      Returns: +

      +
      +
      +


      +

      +
      +
      Method.png common ( TopoShape )
      +
      +

      Description: Intersection of this and a given topo shape. +

      Returns: a TopoShape +

      +
      +
      +


      +

      +
      +
      Method.png complement ( )
      +
      +

      Description: Computes the complement of the orientation of this shape, i.e. reverses the interior/exterior status of boundaries of this shape. +

      Returns: a TopoShape +

      +
      +
      +


      +

      +
      +
      Method.png copy ( )
      +
      +

      Description: Creates a copy of this shape +

      Returns: a TopoShape +

      +
      +
      +


      +

      +
      +
      Method.png cut ( TopoShape )
      +
      +

      Description: Difference of this and a given topo shape. +

      Returns: a TopoShape +

      +
      +
      +


      +

      +
      +
      Method.png distToShape ( TopoShape )
      +
      +

      Description: Calculates the minimum distance between this and a given TopoShape. +

      Returns: float<minimum distance>,list<nearest points>,list<nearest subshapes & parameters> +

      +
      +
      +


      +

      +
      +
      Method.png exportBrep ( string )
      +
      +

      Description: Exports the content of this shape to an BREP file. BREP is a CasCade native format. +

      Returns: +

      +
      +
      +


      +

      +
      +
      Method.png exportIges ( string )
      +
      +

      Description: Exports the content of this shape to an IGES file. +

      Returns: +

      +
      +
      +


      +

      +
      +
      Method.png exportStep ( string )
      +
      +

      Description: Exports the content of this shape to an STEP file. +

      Returns: +

      +
      +
      +


      +

      +
      +
      Method.png exportStl ( string )
      +
      +

      Description: Exports the content of this shape to an STL mesh file. +

      Returns: +

      +
      +
      +


      +

      +
      +
      Method.png extrude ( Vector )
      +
      +

      Description: Extrudes the shape along a direction. +

      Returns: a TopoShape +

      +
      +
      +


      +

      +
      +
      Method.png fuse ( TopoShape )
      +
      +

      Description: Union of this and a given topo shape. +

      Returns: a TopoShape +

      +
      +
      +


      +

      +
      +
      Method.png getAllDerivedFrom ( )
      +
      +

      Description: Returns all descentences of this object type +

      Returns: a list +

      +
      +
      +


      +

      +
      +
      Method.png hashCode ( )
      +
      +

      Description: This value is computed from the value of the underlying shape reference and the location. Orientation is not taken into account. +

      Returns: a string +

      +
      +
      +


      +

      +
      +
      Method.png isClosed ( )
      +
      +

      Description: Checks if the shape is closed. +

      Returns: a boolean +

      +
      +
      +


      +

      +
      +
      Method.png isDerivedFrom ( string )
      +
      +

      Description: Returns true if given type is a father +

      Returns: boolean +

      +
      +
      +


      +

      +
      +
      Method.png isEqual ( TopoShape )
      +
      +

      Description: Returns true if both shapes share the same TShape, have the same Location and have the same Orientation. +

      Returns: a boolean +

      +
      +
      +


      +

      +
      +
      Method.png isInside ( Vector,float,Boolean )
      +
      +

      Description: Checks if a point is inside a solid with a certain tolerance. If the 3rd parameter is True a point on a face is considered as inside +

      Returns: a boolean +

      +
      +
      +


      +

      +
      +
      Method.png isNull ( )
      +
      +

      Description: Checks if the shape is null. +

      Returns: a boolean +

      +
      +
      +


      +

      +
      +
      Method.png isPartner ( TopoShape )
      +
      +

      Description: Returns true if both shapes share the same TShape, but may have a different Location and may have a different Orientation. +

      Returns: a boolean +

      +
      +
      +


      +

      +
      +
      Method.png isSame ( TopoShape )
      +
      +

      Description: Checks if both shapes share the same geometry, true if both shapes share the same TShape, have the same Location but may have a different Orientation. +

      Returns: a boolean +

      +
      +
      +


      +

      +
      +
      Method.png isValid ( )
      +
      +

      Description: Checks if the shape is valid, i.e. neither null, nor empty nor corrupted. +

      Returns: a boolean +

      +
      +
      +


      +

      +
      +
      Method.png makeFillet ( float,TopoShape )
      +
      +

      Description: Returns a new object based on TopoShape, but with a fillet of radius 'float' applied to each edge. +

      Returns: a TopoShape +

      +
      +
      +


      +

      +
      +
      Method.png makeHomogenousWires ( wire )
      +
      +

      Description: Makes this and the given wire homogenous to have the same number of edges +

      Returns: a wire +

      +
      +
      +


      +

      +
      +
      Method.png makeOffset ( float )
      +
      +

      Description: Offsets the shape by a given ammount +

      Returns: a TopoShape +

      +
      +
      +


      +

      +
      +
      Method.png makePipe ( wire )
      +
      +

      Description: Makes a pipe by sweeping along a wire. +

      Returns: a TopoShape +

      +
      +
      +


      +

      +
      +
      Method.png makePipeShell ( wire )
      +
      +

      Description: Makes a loft defined by profiles along a wire. +

      Returns: a TopoShape +

      +
      +
      +


      +

      +
      +
      Method.png makeShapeFromMesh ( mesh )
      +
      +

      Description: Makes a compound shape out of mesh data. Note: This should be used for rather small meshes only. +

      Returns: a TopoShape +

      +
      +
      +


      +

      +
      +
      Method.png makeThickness ( list,float,float )
      +
      +

      Description: A hollowed solid is built from an initial solid and a set of faces on this solid, which are to be removed. The remaining faces of the solid become the walls of the hollowed solid, their thickness defined at the time of construction. The arguments to be passed are a list of faces to be skipped, the thickness of the walls and a tolerance value. +

      Returns: a TopoShape +

      +
      +
      +


      +

      +
      +
      Method.png nullify ( )
      +
      +

      Description: Destroys the reference to the underlying shape stored in this shape. As a result, this shape becomes null. +

      Returns: +

      +
      +
      +


      +

      +
      +
      Method.png project ( TopoShape )
      +
      +

      Description: Project a shape on this shape +

      Returns: a TopoShape +

      +
      +
      +


      +

      +
      +
      Method.png read ( string )
      +
      +

      Description: Reads in an IGES, STEP or BREP file. +

      Returns: a TopoShape +

      +
      +
      +


      +

      +
      +
      Method.png reverse ( )
      +
      +

      Description: Reverses the orientation of this shape. +

      Returns: +

      +
      +
      +


      +

      +
      +
      Method.png revolve ( Vector, Vector, float )
      +
      +

      Description: Revolves the shape around a Axis to a given degree. ex: Part.revolve(Vector(0,0,0),Vector(0,0,1),360) revolves the shape around the Z Axis 360 degree. +

      Returns: a TopoShape +

      +
      +
      +


      +

      +
      +
      Method.png rotate ( Vector<position>, Vector<direction>, float<angle> )
      +
      +

      Description: Rotates this shape by angle degrees around an axis specified by position and direction. ex: Shp.rotate(Vector(0,0,0),Vector(0,0,1),180) rotate the shape around the Z Axis 180 degrees. +

      Returns: +

      +
      +
      +


      +

      +
      +
      Method.png scale ( float<factor>, [Vector<centre>] )
      +
      +

      Description: Uniformly scales this shape by factor. Optionally specify centre of scaling transformation. +

      Returns: +

      +
      +
      +


      +

      +
      +
      Method.png section ( TopoShape )
      +
      +

      Description: Section of this with a given topo shape. +

      Returns: a TopoShape +

      +
      +
      +


      +

      +
      +
      Method.png sewShape ( )
      +
      +

      Description: Sews the shape if there is a gap. +

      Returns: +

      +
      +
      +


      +

      +
      +
      Method.png tessellate ( float )
      +
      +

      Description: Tessellate the the shape and return a list of vertices and face indices. The given float is the tolerance. +

      Returns: a list +

      +
      +
      +


      +

      +
      +
      Method.png toNurbs ( )
      +
      +

      Description: Conversion of the complete geometry of a shape into NURBS geometry. For example, all curves supporting edges of the basis shape are converted into BSpline curves, and all surfaces supporting its faces are converted into BSpline surfaces. +

      Returns: a NURBS curve +

      +
      +
      +


      +

      +
      +
      Method.png transformGeometry ( matrix )
      +
      +

      Description: Applies geometric transformation on a copy of the shape. The transformation to be applied is defined as a 4x4 matrix. The underlying geometry of the following shapes may change to a curve which supports an edge of the shape, or a surface which supports a face of the shape. For example, a circle may be transformed into an ellipse when applying an affinity transformation. It may also happen that the circle then is represented as a b-spline curve. The transformation is applied to all the curves which support edges of the shape, and all the surfaces which support faces of the shape. Note: If you want to transform a shape without changing the underlying geometry then use the methods translate or rotate. +

      Returns: a TopoShape +

      +
      +
      +


      +

      +
      +
      Method.png transformShape ( matrix )
      +
      +

      Description: Applies transformation on a shape without changing the underlying geometry. +

      Returns: +

      +
      +
      +


      +

      +
      +
      Method.png translate ( Vector )
      +
      +

      Description: Applies the translation to the current location of this shape. +

      Returns: +

      +
      +
      +


      +

      +
      +
      Method.png writeInventor ( )
      +
      +

      Description: Writes the mesh in OpenInventor format to a string. +

      Returns: a string +

      +
      +
      +


      +


      +Some attributes and methods apply only to certain TopoShapes. These items apply to Edges (TopoShapeEdge). +


      +

      +
      +
      Property.png FirstParameter
      +
      +

      Returns: The parameter value at one end of the Edge. Not necessarily at Vertex[0]. See Parametric Equations +

      +
      +
      +


      +

      +
      +
      Property.png LastParameter
      +
      +

      Returns: The parameter value at the other end of the Edge. Not necessarily at Vertex[1]. +

      +
      +
      +


      +

      +
      +
      Method.png getParameterByLength ( Float )
      +
      +

      Description: Maps the interval [0,Length] to the interval [FirstParameter,LastParameter] +

      Returns: Float +

      +
      +
      +


      +

      +
      +
      Method.png valueAt ( Float )
      +
      +

      Description: Returns the 3D vector corresponding to a parameter value. +

      Returns: Vector +

      +
      +
      +


      +

      +
      +
      Method.png parameterAt ( Vertex,[Face] )
      +
      +

      Description: Returns the parameter value corresponding to a Vertex (3D point). +

      Returns: Float +

      +
      +
      +


      +

      +
      +
      Method.png tangentAt ( Float )
      +
      +

      Description: Returns the direction vector of the tangent to the edge at a parameter value (if it exists). +

      Returns: Vector +

      +
      +
      +


      +

      +
      +
      Method.png normalAt ( Float )
      +
      +

      Description: Returns the direction vector of the normal to the edge at a parameter value (if it exists uniquely). +

      Returns: Vector +

      +
      +
      +


      +

      +
      +
      Method.png curvatureAt ( Float )
      +
      +

      Description: Returns the curvature of the edge at a parameter value. +

      Returns: Float +

      +
      +
      +


      +

      +
      +
      Method.png centerOfCurvatureAt ( Float )
      +
      +

      Description: Returns the center (3D point) of the osculating circle at a parameter value. +

      Returns: Vector +

      +
      +
      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Topological_data_scripting.html b/localwiki/Topological_data_scripting.html new file mode 100644 index 0000000..d900718 --- /dev/null +++ b/localwiki/Topological_data_scripting.html @@ -0,0 +1,877 @@ +Topological data scripting

      Topological data scripting

      + +
      + + + + + + + + + + + + + + + + + + + + + + + + + + + +
      +

      Base ExampleCommandModel.png Tutorial

      +
      Topic +
      Programming +
      Level +
      Intermediate +
      Time to complete +
      +
      Author +
      +
      FreeCAD version +
      +
      Example File(s) +
      +

      + +
      +


      +


      +This page describes several methods for creating and modifying Part shapes from python. Before reading this page, if you are new to python, it is a good idea to read about python scripting and how python scripting works in FreeCAD. +

      +

      Introduction

      +

      Here we will explain to you how to control the Part Module directly from the FreeCAD Python interpreter, or from any external script. The basics about Topological data scripting are described in Part Module Explaining the concepts. Be sure to browse the Scripting section and the FreeCAD Scripting Basics pages if you need more information about how python scripting works in FreeCAD. +

      +

      Class Diagram

      +

      This is a Unified Modeling Language (UML) overview of the most important classes of the Part module: +

      +
      Python classes of the Part module
      +

      Geometry

      +

      The geometric objects are the building block of all topological objects: +

      +
      • Geom Base class of the geometric objects
      • +
      • Line A straight line in 3D, defined by starting point and end point
      • +
      • Circle Circle or circle segment defined by a center point and start and end point
      • +
      • ...... And soon some more
      +

      Topology

      +

      The following topological data types are available: +

      +
      • Compound A group of any type of topological object.
      • +
      • Compsolid A composite solid is a set of solids connected by their faces. It expands the notions of WIRE and SHELL to solids.
      • +
      • Solid A part of space limited by shells. It is three dimensional.
      • +
      • Shell A set of faces connected by their edges. A shell can be open or closed.
      • +
      • Face In 2D it is part of a plane; in 3D it is part of a surface. Its geometry is constrained (trimmed) by contours. It is two dimensional.
      • +
      • Wire A set of edges connected by their vertices. It can be an open or closed contour depending on whether the edges are linked or not.
      • +
      • Edge A topological element corresponding to a restrained curve. An edge is generally limited by vertices. It has one dimension.
      • +
      • Vertex A topological element corresponding to a point. It has zero dimension.
      • +
      • Shape A generic term covering all of the above.
      +

      Quick example : Creating simple topology

      +

      Wire +


      +We will now create a topology by constructing it out of simpler geometry. +As a case study we use a part as seen in the picture which consists of +four vertexes, two circles and two lines. +

      +

      Creating Geometry

      +

      First we have to create the distinct geometric parts of this wire. +And we have to take care that the vertexes of the geometric parts +are at the same position. Otherwise later on we might not be +able to connect the geometric parts to a topology! +

      So we create first the points: +

      +
      from FreeCAD import Base
      +V1 = Base.Vector(0,10,0)
      +V2 = Base.Vector(30,10,0)
      +V3 = Base.Vector(30,-10,0)
      +V4 = Base.Vector(0,-10,0) 
      +

      Arc

      +

      Circle +


      +To create an arc of circle we make a helper point and create the arc of +circle through three points: +

      +
      VC1 = Base.Vector(-10,0,0)
      +C1 = Part.Arc(V1,VC1,V4)
      +# and the second one
      +VC2 = Base.Vector(40,0,0)
      +C2 = Part.Arc(V2,VC2,V3) 
      +

      Line

      +

      Line +


      +The line can be created very simple out of the points: +

      +
      L1 = Part.Line(V1,V2)
      +# and the second one
      +L2 = Part.Line(V4,V3) 
      +

      Putting all together

      +

      The last step is to put the geometric base elements together +and bake a topological shape: +

      +
      S1 = Part.Shape([C1,C2,L1,L2]) 
      +

      Make a prism

      +

      Now extrude the wire in a direction and make an actual 3D shape: +

      +
      W = Part.Wire(S1.Edges)
      +P = W.extrude(Base.Vector(0,0,10)) 
      +

      Show it all

      +
      Part.show(P) 
      +

      Creating basic shapes

      +

      You can easily create basic topological objects with the "make...()" +methods from the Part Module: +

      +
      b = Part.makeBox(100,100,100)
      +Part.show(b) 
      +

      A couple of other make...() methods available: +

      +
      • makeBox(l,w,h): Makes a box located in p and pointing into the direction d with the dimensions (l,w,h)
      • +
      • makeCircle(radius): Makes a circle with a given radius
      • +
      • makeCone(radius1,radius2,height): Makes a cone with a given radii and height
      • +
      • makeCylinder(radius,height): Makes a cylinder with a given radius and height.
      • +
      • makeLine((x1,y1,z1),(x2,y2,z2)): Makes a line of two points
      • +
      • makePlane(length,width): Makes a plane with length and width
      • +
      • makePolygon(list): Makes a polygon of a list of points
      • +
      • makeSphere(radius): Make a sphere with a given radius
      • +
      • makeTorus(radius1,radius2): Makes a torus with a given radii
      +

      See the Part API page for a complete list of available methods of the Part module. +

      +

      Importing the needed modules

      +

      First we need to import the Part module so we can use its contents in python. +We'll also import the Base module from inside the FreeCAD module: +

      +
      import Part
      +from FreeCAD import Base 
      +

      Creating a Vector

      +

      Vectors are one of the most +important pieces of information when building shapes. They contain a 3 numbers +usually (but not necessarily always) the x, y and z cartesian coordinates. You +create a vector like this: +

      +
      myVector = Base.Vector(3,2,0) 
      +

      We just created a vector at coordinates x=3, y=2, z=0. In the Part module, +vectors are used everywhere. Part shapes also use another kind of point +representation, called Vertex, which is acually nothing else than a container +for a vector. You access the vector of a vertex like this: +

      +
      myVertex = myShape.Vertexes[0]
      +print myVertex.Point
      +> Vector (3, 2, 0) 
      +

      Creating an Edge

      +

      An edge is nothing but a line with two vertexes: +

      +
      edge = Part.makeLine((0,0,0), (10,0,0))
      +edge.Vertexes
      +> [<Vertex object at 01877430>, <Vertex object at 014888E0>] 
      +

      Note: You can also create an edge by passing two vectors: +

      +
      vec1 = Base.Vector(0,0,0)
      +vec2 = Base.Vector(10,0,0)
      +line = Part.Line(vec1,vec2)
      +edge = line.toShape() 
      +

      You can find the length and center of an edge like this: +

      +
      edge.Length
      +> 10.0
      +edge.CenterOfMass
      +> Vector (5, 0, 0) 
      +

      Putting the shape on screen

      +

      So far we created an edge object, but it doesn't appear anywhere on screen. +This is because we just manipulated python objects here. The FreeCAD 3D scene +only displays what you tell it to display. To do that, we use this simple +method: +

      +
      Part.show(edge) 
      +

      An object will be created in our FreeCAD document, and our "edge" shape +will be attributed to it. Use this whenever it's time to display your +creation on screen. +

      +

      Creating a Wire

      +

      A wire is a multi-edge line and can be created from a list of edges +or even a list of wires: +

      +
      edge1 = Part.makeLine((0,0,0), (10,0,0))
      +edge2 = Part.makeLine((10,0,0), (10,10,0))
      +wire1 = Part.Wire([edge1,edge2]) 
      +edge3 = Part.makeLine((10,10,0), (0,10,0))
      +edge4 = Part.makeLine((0,10,0), (0,0,0))
      +wire2 = Part.Wire([edge3,edge4])
      +wire3 = Part.Wire([wire1,wire2])
      +wire3.Edges
      +> [<Edge object at 016695F8>, <Edge object at 0197AED8>, <Edge object at 01828B20>, <Edge object at 0190A788>]
      +Part.show(wire3) 
      +

      Part.show(wire3) will display the 4 edges that compose our wire. Other +useful information can be easily retrieved: +

      +
      wire3.Length
      +> 40.0
      +wire3.CenterOfMass
      +> Vector (5, 5, 0)
      +wire3.isClosed()
      +> True
      +wire2.isClosed()
      +> False 
      +

      Creating a Face

      +

      Only faces created from closed wires will be valid. In this example, wire3 +is a closed wire but wire2 is not a closed wire (see above) +

      +
      face = Part.Face(wire3)
      +face.Area
      +> 99.999999999999972
      +face.CenterOfMass
      +> Vector (5, 5, 0)
      +face.Length
      +> 40.0
      +face.isValid()
      +> True
      +sface = Part.Face(wire2)
      +face.isValid()
      +> False 
      +

      Only faces will have an area, not wires nor edges. +

      +

      Creating a Circle

      +

      A circle can be created as simply as this: +

      +
      circle = Part.makeCircle(10)
      +circle.Curve
      +> Circle (Radius : 10, Position : (0, 0, 0), Direction : (0, 0, 1)) 
      +

      If you want to create it at certain position and with certain direction: +

      +
      ccircle = Part.makeCircle(10, Base.Vector(10,0,0), Base.Vector(1,0,0))
      +ccircle.Curve
      +> Circle (Radius : 10, Position : (10, 0, 0), Direction : (1, 0, 0)) 
      +

      ccircle will be created at distance 10 from origin on x and will be facing +towards x axis. Note: makeCircle only accepts Base.Vector() for position +and normal but not tuples. You can also create part of the circle by giving +start angle and end angle as: +

      +
      from math import pi
      +arc1 = Part.makeCircle(10, Base.Vector(0,0,0), Base.Vector(0,0,1), 0, 180)
      +arc2 = Part.makeCircle(10, Base.Vector(0,0,0), Base.Vector(0,0,1), 180, 360) 
      +

      Both arc1 and arc2 jointly will make a circle. Angles should be provided in +degrees, if you have radians simply convert them using formula: +degrees = radians * 180/PI or using python's math module (after doing import +math, of course): +

      +
      degrees = math.degrees(radians) 
      +

      Creating an Arc along points

      +

      Unfortunately there is no makeArc function but we have Part.Arc function to +create an arc along three points. Basically it can be supposed as an arc +joining start point and end point along the middle point. Part.Arc creates +an arc object on which .toShape() has to be called to get the edge object, +the same way as when using Part.Line instead of Part.makeLine. +

      +
      arc = Part.Arc(Base.Vector(0,0,0),Base.Vector(0,5,0),Base.Vector(5,5,0))
      +arc
      +> <Arc object>
      +arc_edge = arc.toShape() 
      +

      Arc only accepts Base.Vector() for points but not tuples. arc_edge is what +we want which we can display using Part.show(arc_edge). You can also obtain +an arc by using a portion of a circle: +

      +
      from math import pi
      +circle = Part.Circle(Base.Vector(0,0,0),Base.Vector(0,0,1),10)
      +arc = Part.Arc(c,0,pi) 
      +

      Arcs are valid edges, like lines. So they can be used in wires too. +

      +

      Creating a polygon

      +

      A polygon is simply a wire with multiple straight edges. The makePolygon +function takes a list of points and creates a wire along those points: +

      +
      lshape_wire = Part.makePolygon([Base.Vector(0,5,0),Base.Vector(0,0,0),Base.Vector(5,0,0)]) 
      +

      Creating a Bezier curve

      +

      Bézier curves are used to model smooth curves using a series of poles (points) and optional weights. The function below makes a Part.BezierCurve from a series of FreeCAD.Vector points. (Note: when "getting" and "setting" a single pole or weight indices start at 1, not 0.) +

      +
      def makeBCurveEdge(Points):
      +   geomCurve = Part.BezierCurve()
      +   geomCurve.setPoles(Points)
      +   edge = Part.Edge(geomCurve)
      +   return(edge) 
      +

      Creating a Plane

      +

      A Plane is simply a flat rectangular surface. The method used to create one is +this: makePlane(length,width,[start_pnt,dir_normal]). By default +start_pnt = Vector(0,0,0) and dir_normal = Vector(0,0,1). Using dir_normal = Vector(0,0,1) +will create the plane facing z axis, while dir_normal = Vector(1,0,0) will create the +plane facing x axis: +

      +
      plane = Part.makePlane(2,2)
      +plane
      +><Face object at 028AF990>
      +plane = Part.makePlane(2,2, Base.Vector(3,0,0), Base.Vector(0,1,0))
      +plane.BoundBox
      +> BoundBox (3, 0, 0, 5, 0, 2) 
      +

      BoundBox is a cuboid enclosing the plane with a diagonal starting at +(3,0,0) and ending at (5,0,2). Here the BoundBox thickness in y axis is zero, +since our shape is totally flat. +

      Note: makePlane only accepts Base.Vector() for start_pnt and dir_normal but not tuples +

      +

      Creating an ellipse

      +

      To create an ellipse there are several ways: +

      +
      Part.Ellipse() 
      +

      Creates an ellipse with major radius 2 and minor radius 1 with the center in (0,0,0) +

      +
      Part.Ellipse(Ellipse) 
      +

      Create a copy of the given ellipse +

      +
      Part.Ellipse(S1,S2,Center) 
      +

      Creates an ellipse centered on the point Center, where the plane of the +ellipse is defined by Center, S1 and S2, its major axis is defined by +Center and S1, its major radius is the distance between Center and S1, +and its minor radius is the distance between S2 and the major axis. +

      +
      Part.Ellipse(Center,MajorRadius,MinorRadius) 
      +

      Creates an ellipse with major and minor radii MajorRadius and MinorRadius, +and located in the plane defined by Center and the normal (0,0,1) +

      +
      eli = Part.Ellipse(Base.Vector(10,0,0),Base.Vector(0,5,0),Base.Vector(0,0,0))
      +Part.show(eli.toShape()) 
      +

      In the above code we have passed S1, S2 and center. Similarly to Arc, +Ellipse also creates an ellipse object but not edge, so we need to +convert it into edge using toShape() to display. +

      Note: Arc only accepts Base.Vector() for points but not tuples +

      +
      eli = Part.Ellipse(Base.Vector(0,0,0),10,5)
      +Part.show(eli.toShape()) 
      +

      for the above Ellipse constructor we have passed center, MajorRadius and MinorRadius +

      +

      Creating a Torus

      +

      Using the method makeTorus(radius1,radius2,[pnt,dir,angle1,angle2,angle]). By +default pnt=Vector(0,0,0),dir=Vector(0,0,1),angle1=0,angle2=360 and angle=360. +Consider a torus as small circle sweeping along a big circle. Radius1 is the +radius of big cirlce, radius2 is the radius of small circle, pnt is the center +of torus and dir is the normal direction. angle1 and angle2 are angles in +radians for the small circle, the last parameter angle is to make a section of +the torus: +

      +
      torus = Part.makeTorus(10, 2) 
      +

      The above code will create a torus with diameter 20(radius 10) and thickness 4 +(small cirlce radius 2) +

      +
      tor=Part.makeTorus(10,5,Base.Vector(0,0,0),Base.Vector(0,0,1),0,180) 
      +

      The above code will create a slice of the torus +

      +
      tor=Part.makeTorus(10,5,Base.Vector(0,0,0),Base.Vector(0,0,1),0,360,180) 
      +

      The above code will create a semi torus, only the last parameter is changed +i.e the angle and remaining angles are defaults. Giving the angle 180 will +create the torus from 0 to 180, that is, a half torus. +

      +

      Creating a box or cuboid

      +

      Using makeBox(length,width,height,[pnt,dir]). +By default pnt=Vector(0,0,0) and dir=Vector(0,0,1) +

      +
      box = Part.makeBox(10,10,10)
      +len(box.Vertexes)
      +> 8 
      +

      Creating a Sphere

      +

      Using makeSphere(radius,[pnt, dir, angle1,angle2,angle3]). By default +pnt=Vector(0,0,0), dir=Vector(0,0,1), angle1=-90, angle2=90 and angle3=360. +angle1 and angle2 are the vertical minimum and maximum of the sphere, angle3 +is the sphere diameter itself. +

      +
      sphere = Part.makeSphere(10)
      +hemisphere = Part.makeSphere(10,Base.Vector(0,0,0),Base.Vector(0,0,1),-90,90,180) 
      +

      Creating a Cylinder

      +

      Using makeCylinder(radius,height,[pnt,dir,angle]). By default +pnt=Vector(0,0,0),dir=Vector(0,0,1) and angle=360 +

      +
      cylinder = Part.makeCylinder(5,20)
      +partCylinder = Part.makeCylinder(5,20,Base.Vector(20,0,0),Base.Vector(0,0,1),180)
      +

      Creating a Cone

      +

      Using makeCone(radius1,radius2,height,[pnt,dir,angle]). By default +pnt=Vector(0,0,0), dir=Vector(0,0,1) and angle=360 +

      +
      cone = Part.makeCone(10,0,20)
      +semicone = Part.makeCone(10,0,20,Base.Vector(20,0,0),Base.Vector(0,0,1),180)
      +

      Modifying shapes

      +

      There are several ways to modify shapes. Some are simple transformation operations +such as moving or rotating shapes, other are more complex, such as unioning and +subtracting one shape from another. Be aware that +

      +

      Transform operations

      +

      Translating a shape

      +

      Translating is the act of moving a shape from one place to another. +Any shape (edge, face, cube, etc...) can be translated the same way: +

      +
      myShape = Part.makeBox(2,2,2)
      +myShape.translate(Base.Vector(2,0,0))
      +

      This will move our shape "myShape" 2 units in the x direction. +

      +

      Rotating a shape

      +

      To rotate a shape, you need to specify the rotation center, the axis, +and the rotation angle: +

      +
      myShape.rotate(Vector(0,0,0),Vector(0,0,1),180)
      +

      The above code will rotate the shape 180 degrees around the Z Axis. +

      +

      Generic transformations with matrixes

      +

      A matrix is a very convenient way to store transformations in the 3D +world. In a single matrix, you can set translation, rotation and scaling +values to be applied to an object. For example: +

      +
      myMat = Base.Matrix()
      +myMat.move(Base.Vector(2,0,0))
      +myMat.rotateZ(math.pi/2)
      +

      Note: FreeCAD matrixes work in radians. Also, almost all matrix operations +that take a vector can also take 3 numbers, so those 2 lines do the same thing: +

      +
      myMat.move(2,0,0)
      +myMat.move(Base.Vector(2,0,0))
      +

      When our matrix is set, we can apply it to our shape. FreeCAD provides 2 +methods to do that: transformShape() and transformGeometry(). The difference +is that with the first one, you are sure that no deformations will occur (see +"scaling a shape" below). So we can apply our transformation like this: +

      +
       myShape.trasformShape(myMat)
      +

      or +

      +
      myShape.transformGeometry(myMat)
      +

      Scaling a shape

      +

      Scaling a shape is a more dangerous operation because, unlike translation +or rotation, scaling non-uniformly (with different values for x, y and z) +can modify the structure of the shape. For example, scaling a circle with +a higher value horizontally than vertically will transform it into an +ellipse, which behaves mathematically very differently. For scaling, we +can't use the transformShape, we must use transformGeometry(): +

      +
      myMat = Base.Matrix()
      +myMat.scale(2,1,1)
      +myShape=myShape.transformGeometry(myMat)
      +

      Boolean Operations

      +

      Subtraction

      +

      Subtracting a shape from another one is called "cut" in OCC/FreeCAD jargon +and is done like this: +

      +
      cylinder = Part.makeCylinder(3,10,Base.Vector(0,0,0),Base.Vector(1,0,0))
      +sphere = Part.makeSphere(5,Base.Vector(5,0,0))
      +diff = cylinder.cut(sphere)
      +

      Intersection

      +

      The same way, the intersection between 2 shapes is called "common" and is done +this way: +

      +
      cylinder1 = Part.makeCylinder(3,10,Base.Vector(0,0,0),Base.Vector(1,0,0))
      +cylinder2 = Part.makeCylinder(3,10,Base.Vector(5,0,-5),Base.Vector(0,0,1))
      +common = cylinder1.common(cylinder2)
      +

      Union

      +

      Union is called "fuse" and works the same way: +

      +
      cylinder1 = Part.makeCylinder(3,10,Base.Vector(0,0,0),Base.Vector(1,0,0))
      +cylinder2 = Part.makeCylinder(3,10,Base.Vector(5,0,-5),Base.Vector(0,0,1))
      +fuse = cylinder1.fuse(cylinder2)
      +

      Section

      +

      A Section is the intersection between a solid shape and a plane shape. +It will return an intersection curve, a compound with edges +

      +
      cylinder1 = Part.makeCylinder(3,10,Base.Vector(0,0,0),Base.Vector(1,0,0))
      +cylinder2 = Part.makeCylinder(3,10,Base.Vector(5,0,-5),Base.Vector(0,0,1))
      +section = cylinder1.section(cylinder2)
      +section.Wires
      +> []
      +section.Edges
      +> [<Edge object at 0D87CFE8>, <Edge object at 019564F8>, <Edge object at 0D998458>, 
      + <Edge  object at 0D86DE18>, <Edge object at 0D9B8E80>, <Edge object at 012A3640>, 
      + <Edge object at 0D8F4BB0>]
      +

      Extrusion

      +

      Extrusion is the act of "pushing" a flat shape in a certain direction resulting in +a solid body. Think of a circle becoming a tube by "pushing it out": +

      +
      circle = Part.makeCircle(10)
      +tube = circle.extrude(Base.Vector(0,0,2))
      +

      If your circle is hollow, you will obtain a hollow tube. If your circle is actually +a disc, with a filled face, you will obtain a solid cylinder: +

      +
      wire = Part.Wire(circle)
      +disc = Part.Face(wire)
      +cylinder = disc.extrude(Base.Vector(0,0,2))
      +

      Exploring shapes

      +

      You can easily explore the topological data structure: +

      +
      import Part
      +b = Part.makeBox(100,100,100)
      +b.Wires
      +w = b.Wires[0]
      +w
      +w.Wires
      +w.Vertexes
      +Part.show(w)
      +w.Edges
      +e = w.Edges[0]
      +e.Vertexes
      +v = e.Vertexes[0]
      +v.Point
      +

      By typing the lines above in the python interpreter, you will gain a good +understanding of the structure of Part objects. Here, our makeBox() command +created a solid shape. This solid, like all Part solids, contains faces. +Faces always contain wires, which are lists of edges that border the face. +Each face has at least one closed wire (it can have more if the face has a hole). +In the wire, we can look at each edge separately, and inside each edge, we can +see the vertexes. Straight edges have only two vertexes, obviously. +

      +

      Edge analysis

      +

      In case of an edge, which is an arbitrary curve, it's most likely you want to +do a discretization. In FreeCAD the edges are parametrized by their lengths. +That means you can walk an edge/curve by its length: +

      +
      import Part
      +box = Part.makeBox(100,100,100)
      +anEdge = box.Edges[0]
      +print anEdge.Length
      +

      Now you can access a lot of properties of the edge by using the length as a +position. That means if the edge is 100mm long the start position is 0 and +the end position 100. +

      +
      anEdge.tangentAt(0.0)      # tangent direction at the beginning
      +anEdge.valueAt(0.0)        # Point at the beginning
      +anEdge.valueAt(100.0)      # Point at the end of the edge
      +anEdge.derivative1At(50.0) # first derivative of the curve in the middle
      +anEdge.derivative2At(50.0) # second derivative of the curve in the middle
      +anEdge.derivative3At(50.0) # third derivative of the curve in the middle
      +anEdge.centerOfCurvatureAt(50) # center of the curvature for that position
      +anEdge.curvatureAt(50.0)   # the curvature
      +anEdge.normalAt(50)        # normal vector at that position (if defined)
      +

      Using the selection

      +

      Here we see now how we can use the selection the user did in the viewer. +First of all we create a box and shows it in the viewer +

      +
      import Part
      +Part.show(Part.makeBox(100,100,100))
      +Gui.SendMsgToActiveView("ViewFit")
      +

      Select now some faces or edges. With this script you can +iterate all selected objects and their sub elements: +

      +
      for o in Gui.Selection.getSelectionEx():
      +print o.ObjectName
      +for s in o.SubElementNames:
      +print "name: ",s
      +for s in o.SubObjects:
      +print "object: ",s
      +

      Select some edges and this script will calculate the length: +

      +
      length = 0.0
      +for o in Gui.Selection.getSelectionEx():
      +for s in o.SubObjects:
      +length += s.Length
      +print "Length of the selected edges:" ,length
      +

      Complete example: The OCC bottle

      +

      A typical example found in the +OpenCasCade Technology Tutorial +is how to build a bottle. This is a good exercise for FreeCAD too. In fact, +you can follow our example below and the OCC page simultaneously, you will +understand well how OCC structures are implemented in FreeCAD. The complete script +below is also included in FreeCAD installation (inside the Mod/Part folder) and +can be called from the python interpreter by typing: +

      +
      import Part
      +import MakeBottle
      +bottle = MakeBottle.makeBottle()
      +Part.show(bottle)
      +

      The complete script

      +

      Here is the complete MakeBottle script: +

      +
      import Part, FreeCAD, math
      +from FreeCAD import Base
      +
      +def makeBottle(myWidth=50.0, myHeight=70.0, myThickness=30.0):
      +   aPnt1=Base.Vector(-myWidth/2.,0,0)
      +   aPnt2=Base.Vector(-myWidth/2.,-myThickness/4.,0)
      +   aPnt3=Base.Vector(0,-myThickness/2.,0)
      +   aPnt4=Base.Vector(myWidth/2.,-myThickness/4.,0)
      +   aPnt5=Base.Vector(myWidth/2.,0,0)
      +   
      +   aArcOfCircle = Part.Arc(aPnt2,aPnt3,aPnt4)
      +   aSegment1=Part.LineSegment(aPnt1,aPnt2)
      +   aSegment2=Part.LineSegment(aPnt4,aPnt5)
      +   aEdge1=aSegment1.toShape()
      +   aEdge2=aArcOfCircle.toShape()
      +   aEdge3=aSegment2.toShape()
      +   aWire=Part.Wire([aEdge1,aEdge2,aEdge3])
      +   
      +   aTrsf=Base.Matrix()
      +   aTrsf.rotateZ(math.pi) # rotate around the z-axis
      +   
      +   aMirroredWire=aWire.transformGeometry(aTrsf)
      +   myWireProfile=Part.Wire([aWire,aMirroredWire])
      +   myFaceProfile=Part.Face(myWireProfile)
      +   aPrismVec=Base.Vector(0,0,myHeight)
      +   myBody=myFaceProfile.extrude(aPrismVec)
      +   myBody=myBody.makeFillet(myThickness/12.0,myBody.Edges)
      +   neckLocation=Base.Vector(0,0,myHeight)
      +   neckNormal=Base.Vector(0,0,1)
      +   myNeckRadius = myThickness / 4.
      +   myNeckHeight = myHeight / 10
      +   myNeck = Part.makeCylinder(myNeckRadius,myNeckHeight,neckLocation,neckNormal)
      +   myBody = myBody.fuse(myNeck)
      +   
      +   faceToRemove = 0
      +   zMax = -1.0
      +   
      +   for xp in myBody.Faces:
      +       try:
      +           surf = xp.Surface
      +           if type(surf) == Part.Plane:
      +               z = surf.Position.z
      +               if z > zMax:
      +                   zMax = z
      +                   faceToRemove = xp
      +       except:
      +           continue
      +   
      +   myBody = myBody.makeFillet(myThickness/12.0,myBody.Edges)
      +   
      +   return myBody
      +
      +el = makeBottle()
      +Part.show(el)
      +

      Detailed explanation

      +
      import Part, FreeCAD, math
      +from FreeCAD import Base
      +

      We will need,of course, the Part module, but also the FreeCAD.Base module, +which contains basic FreeCAD structures like vectors and matrixes. +

      +
      def makeBottle(myWidth=50.0, myHeight=70.0, myThickness=30.0):
      +   aPnt1=Base.Vector(-myWidth/2.,0,0)
      +   aPnt2=Base.Vector(-myWidth/2.,-myThickness/4.,0)
      +   aPnt3=Base.Vector(0,-myThickness/2.,0)
      +   aPnt4=Base.Vector(myWidth/2.,-myThickness/4.,0)
      +   aPnt5=Base.Vector(myWidth/2.,0,0)
      +

      Here we define our makeBottle function. This function can be called without +arguments, like we did above, in which case default values for width, height, +and thickness will be used. Then, we define a couple of points that will be used +for building our base profile. +

      +
         aArcOfCircle = Part.Arc(aPnt2,aPnt3,aPnt4)
      +   aSegment1=Part.Line(aPnt1,aPnt2)
      +   aSegment2=Part.Line(aPnt4,aPnt5)
      +

      Here we actually define the geometry: an arc, made of 3 points, and two +line segments, made of 2 points. +

      +
         aEdge1=aSegment1.toShape()
      +   aEdge2=aArcOfCircle.toShape()
      +   aEdge3=aSegment2.toShape()
      +   aWire=Part.Wire([aEdge1,aEdge2,aEdge3])
      +

      Remember the difference between geometry and shapes? Here we build +shapes out of our construction geometry. 3 edges (edges can be straight +or curved), then a wire made of those three edges. +

      +
         aTrsf=Base.Matrix()
      +   aTrsf.rotateZ(math.pi) # rotate around the z-axis
      +   aMirroredWire=aWire.transformGeometry(aTrsf)
      +   myWireProfile=Part.Wire([aWire,aMirroredWire])
      +

      Until now we built only a half profile. Easier than building the whole profile +the same way, we can just mirror what we did, and glue both halfs together. +So we first create a matrix. A matrix is a very common way to apply transformations +to objects in the 3D world, since it can contain in one structure all basic +transformations that 3D objects can suffer (move, rotate and scale). Here, +after we create the matrix, we mirror it, and we create a copy of our wire +with that transformation matrix applied to it. We now have two wires, and +we can make a third wire out of them, since wires are actually lists of edges. +

      +
         myFaceProfile=Part.Face(myWireProfile)
      +   aPrismVec=Base.Vector(0,0,myHeight)
      +   myBody=myFaceProfile.extrude(aPrismVec)
      +   myBody=myBody.makeFillet(myThickness/12.0,myBody.Edges)
      +

      Now that we have a closed wire, it can be turned into a face. Once we have a face, +we can extrude it. Doing so, we actually made a solid. Then we apply a nice little +fillet to our object because we care about good design, don't we? +

      +
         neckLocation=Base.Vector(0,0,myHeight)
      +   neckNormal=Base.Vector(0,0,1)
      +   myNeckRadius = myThickness / 4.
      +   myNeckHeight = myHeight / 10
      +   myNeck = Part.makeCylinder(myNeckRadius,myNeckHeight,neckLocation,neckNormal)
      +

      Then, the body of our bottle is made, we still need to create a neck. So we +make a new solid, with a cylinder. +

      +
         myBody = myBody.fuse(myNeck)
      +

      The fuse operation, which in other apps is sometimes called union, is very +powerful. It will take care of gluing what needs to be glued and remove parts that +need to be removed. +

      +
         return myBody
      +

      Then, we return our Part solid as the result of our function. +

      +
      el = makeBottle()
      +Part.show(el)
      +

      At the end we call the definite function and make the part visible. +

      +

      Box pierced

      +

      Here a complete example of building a box pierced. +

      The construction is done side by side and when the cube is finished, it is hollowed out of a cylinder through. +

      +
      import Draft, Part, FreeCAD, math, PartGui, FreeCADGui, PyQt4
      +from math import sqrt, pi, sin, cos, asin
      +from FreeCAD import Base
      +
      +size = 10
      +poly = Part.makePolygon( [ (0,0,0), (size, 0, 0), (size, 0, size), (0, 0, size), (0, 0, 0)])
      +
      +face1 = Part.Face(poly)
      +face2 = Part.Face(poly)
      +face3 = Part.Face(poly)
      +face4 = Part.Face(poly)
      +face5 = Part.Face(poly)
      +face6 = Part.Face(poly)
      +     
      +myMat = FreeCAD.Matrix()
      +myMat.rotateZ(math.pi/2)
      +face2.transformShape(myMat)
      +face2.translate(FreeCAD.Vector(size, 0, 0))
      +
      +myMat.rotateZ(math.pi/2)
      +face3.transformShape(myMat)
      +face3.translate(FreeCAD.Vector(size, size, 0))
      +
      +myMat.rotateZ(math.pi/2)
      +face4.transformShape(myMat)
      +face4.translate(FreeCAD.Vector(0, size, 0))
      +
      +myMat = FreeCAD.Matrix()
      +myMat.rotateX(-math.pi/2)
      +face5.transformShape(myMat)
      +
      +face6.transformShape(myMat)               
      +face6.translate(FreeCAD.Vector(0,0,size))
      +
      +myShell = Part.makeShell([face1,face2,face3,face4,face5,face6])   
      +
      +mySolid = Part.makeSolid(myShell)
      +mySolidRev = mySolid.copy()
      +mySolidRev.reverse()
      +
      +myCyl = Part.makeCylinder(2,20)
      +myCyl.translate(FreeCAD.Vector(size/2, size/2, 0))
      +
      +cut_part = mySolidRev.cut(myCyl)
      +
      +Part.show(cut_part)
      +

      Loading and Saving

      +

      There are several ways to save your work in the Part module. You can +of course save your FreeCAD document, but you can also save Part +objects directly to common CAD formats, such as BREP, IGS, STEP and STL. +

      Saving a shape to a file is easy. There are exportBrep(), exportIges(), +exportStl() and exportStep() methods availables for all shape objects. +So, doing: +

      +
      import Part
      +s = Part.makeBox(0,0,0,10,10,10)
      +s.exportStep("test.stp")
      +

      this will save our box into a STEP file. To load a BREP, +IGES or STEP file, simply do the contrary: +

      +
      import Part
      +s = Part.Shape()
      +s.read("test.stp")
      +

      To convert an .stp in .igs file simply : +

      +
       import Part
      + s = Part.Shape()
      + s.read("file.stp")       # incoming file igs, stp, stl, brep
      + s.exportIges("file.igs") # outbound file igs
      +

      Note that importing or opening BREP, IGES or STEP files can also be done +directly from the File -> Open or File -> Import menu, while exporting +is with File -> Export +

      + +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/TorusExampleAngle1.jpg b/localwiki/TorusExampleAngle1.jpg new file mode 100644 index 0000000..7439ded Binary files /dev/null and b/localwiki/TorusExampleAngle1.jpg differ diff --git a/localwiki/TorusExampleAngle2.jpg b/localwiki/TorusExampleAngle2.jpg new file mode 100644 index 0000000..4b6f18c Binary files /dev/null and b/localwiki/TorusExampleAngle2.jpg differ diff --git a/localwiki/TorusExampleAngle3.jpg b/localwiki/TorusExampleAngle3.jpg new file mode 100644 index 0000000..28a32ff Binary files /dev/null and b/localwiki/TorusExampleAngle3.jpg differ diff --git a/localwiki/TorusExampleOverviewParameters.jpg b/localwiki/TorusExampleOverviewParameters.jpg new file mode 100644 index 0000000..c52d882 Binary files /dev/null and b/localwiki/TorusExampleOverviewParameters.jpg differ diff --git a/localwiki/TorusExampleRadius1.jpg b/localwiki/TorusExampleRadius1.jpg new file mode 100644 index 0000000..fdea27c Binary files /dev/null and b/localwiki/TorusExampleRadius1.jpg differ diff --git a/localwiki/TorusExampleRadius2.jpg b/localwiki/TorusExampleRadius2.jpg new file mode 100644 index 0000000..096d8ad Binary files /dev/null and b/localwiki/TorusExampleRadius2.jpg differ diff --git a/localwiki/Total_run-out.svg b/localwiki/Total_run-out.svg new file mode 100644 index 0000000..796ba17 --- /dev/null +++ b/localwiki/Total_run-out.svg @@ -0,0 +1,146 @@ + + + + + Total run-out + + + + + + image/svg+xml + + Total run-out + + + bavariaSHAPE + + + + + bavariaSHAPE + + + + + bavariaSHAPE + + + 15.10.2016 + Geometric dimensioning and tolerancing symbols +All symbols in this repository are licensed under CC-BY 3.0 + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Touch_One-Finger-Drag.svg b/localwiki/Touch_One-Finger-Drag.svg new file mode 100644 index 0000000..92fc8af --- /dev/null +++ b/localwiki/Touch_One-Finger-Drag.svg @@ -0,0 +1,207 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + + + + + + + + + diff --git a/localwiki/Touch_Pinch.svg b/localwiki/Touch_Pinch.svg new file mode 100644 index 0000000..d836627 --- /dev/null +++ b/localwiki/Touch_Pinch.svg @@ -0,0 +1,218 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Touch_Rotate.svg b/localwiki/Touch_Rotate.svg new file mode 100644 index 0000000..397e269 --- /dev/null +++ b/localwiki/Touch_Rotate.svg @@ -0,0 +1,232 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + + + + + + + + + + diff --git a/localwiki/Touch_Tap-Hold-Drag.svg b/localwiki/Touch_Tap-Hold-Drag.svg new file mode 100644 index 0000000..48f550b --- /dev/null +++ b/localwiki/Touch_Tap-Hold-Drag.svg @@ -0,0 +1,238 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Touch_Tap.svg b/localwiki/Touch_Tap.svg new file mode 100644 index 0000000..f0709c7 --- /dev/null +++ b/localwiki/Touch_Tap.svg @@ -0,0 +1,194 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + + + + + + + diff --git a/localwiki/Touch_Two-Finger-Drag.svg b/localwiki/Touch_Two-Finger-Drag.svg new file mode 100644 index 0000000..5bb84f0 --- /dev/null +++ b/localwiki/Touch_Two-Finger-Drag.svg @@ -0,0 +1,245 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + + + + + + + + + + diff --git a/localwiki/Tracker.html b/localwiki/Tracker.html new file mode 100644 index 0000000..3f424ab --- /dev/null +++ b/localwiki/Tracker.html @@ -0,0 +1,188 @@ +Tracker

      Tracker

      + +
      link=https://freecadweb.org/tracker/MantisBT is the bugtracker framework FreeCAD uses
      +

      The address of our bug tracker is: +

      https://www.freecadweb.org/tracker +

      The Tracker is the place toː report bugs, submit feature requests, patches, or request to merge your branch if you developed something using Git. The tracker is divided into 'Workbenches', so please be specific and file your request in the appropriate subsection. In case of doubt, leave it in the "FreeCAD" section. +


      +

      + + +

      Recommended Workflow

      +
      Bugreport-workflow.png
      +

      As shown in the above flowchart, before creating tickets, please always first search the forums and bugtracker to discover if your issue is a known issue. This saves a lot of time/work for developers and volunteers that could be spending said time making FreeCAD even more awesome. +

      +

      Reporting bugs

      +

      If you think you might have found a bug, you are welcome to report it as long as you have followed our step-by-step guidelinesː +

      +
      • Make sure you're using the most up to date version of FreeCAD. NOTEː your bug may be fixed in the Development (unstable) version. The average user runs the stable version of FC.
      • +
      • Make sure your bug is really a bug, that is, something that should be working but isn't. Make sure the same bug hasn't been reported before by first searching the bugtracker and forum. +
        • Rememberː if you aren't sure, please don't hesitate to explain your problem/bug in the Help forum and ask what to do.
        • +
        • Noteː before posting to the forum please read the Forum Guidelines.
      • +
      • Describe as clearly as possible the problem, and how it can be reproduced. If we can not verify the bug, we might not be able to fix it. +
        • This means reporting in a clear, well-formatted, step-by-step fashion so even an amateur user could reproduce.
        • +
        • Recommendedː Screenshots of the bug are also very helpful to include. Windows users: please do not attach screen captures in Word or PDF format. Use the Windows Snipping tool to save your capture as a PNG image.
        • +
        • Recommendedː Even better, an Animated gif or Screencast would also increase the likelihood of reproducing the issue.
      • +
      • Add an example FreeCAD file (.FCStd file) so devs/testers can quickly reproduce the bug. +
        • Please don't zip your *.FCStd file, it is already zipped.
        • +
        • File attachments are limited in size. If your *.FCStd file is too big to attach, you can use an online storage service (many are free like Google Drive, Microsoft OneDrive, Dropbox).
      • +
      • Include all the information from the "Copy to Clipboard" button in the Help (menu) -> About FreeCAD dialogue. Make sure your data includes your OCC or OCE version.
      • +
      • Please file one separate report for each bug.
      • +
      • If your bug causes a crash in FreeCAD and you're on a system that supports it you can try running a debug backtrace and attach said trace to the ticket. This can save devs a lot of time pinpointing the source of the crash. See Debugging for more details.
      +

      Requesting features

      +

      If you want something to appear in FreeCAD that is not implemented yet, it is not a bug but a feature request. +

      +
      1. IMPORTANTː Before requesting a potential Feature Request please be certain that you are the first one doing so by searching the forums and the bugtracker. If you have concluded that there are no pre-existing tickets/discussions the next step is toː
      2. +
      3. Start a forum thread to discuss your feature request with the community via the Open Discussion forum.
      4. +
      5. Once the community agrees that this is a valid Feature, you then can open a ticket on the tracker (file it under feature request instead of bug).
      +
      • NOTE #1 To keep things organized please remember to link the forum thread URL into the ticket and the ticket number (as a link) in to the forum thread.
      • +
      • NOTE #2 Keep in mind there are no guarantees that your wish will be fulfilled.
      +
      FreeCAD Bugtracker report page - use the dropdown to correctly designate what the ticket is
      +

      Submitting patches

      +

      In case you have programmed a bug fix, an extension or something else that can be of public use in FreeCAD, create a patch using the Git diff tool and submit it on the same tracker (file it as patch). +

      Addendumː FreeCAD development has switched to the GitHub development model so the workflow for submitting patches has been greatly enhanced/streamlined by submitting Pull Requests. +

      +
      • Open a forum thread in the Developer subforum to announce and discuss your patch.
      • +
      • Submit your PR to the FreeCAD GitHub repo. Be sure to link the forum thread in to the git commit summary.
      • +
      • Paste the PR link in to the forum thread for the devs/testers to test.
      • +
      • Be present for the discussion so that your code can potentially be merged more effectively.
      +

      NOTEː the FreeCAD community recommends to first discuss any large revision to the source code in advance to save everyone time. +

      +

      Requesting merge

      +

      (Same guidelines as Submiting patches) +

      If you have created a git branch containing changes that you would like to see merged into the FreeCAD code, you can ask there to have your branch reviewed and merged if the FreeCAD developers are OK with it. You must first publish your branch to a public git repository (github, gitlab, bitbucket, sourceforge etc...) and then give the URL of your branch in your merge request. +

      +

      MantisBT Tips and Tricks

      +

      MantisBT Markup

      +

      MantisBT (Mantis Bug Tracker) has it's own unique markup. +

      +
      • @mention - works just like on GitHub where if you prepend '@' to someone's username they will receive an email that they have been 'mentioned' in a ticket thread
      +
      Mantisbt-mention-example.jpg
      +
      • #1234 - By adding a hash tag in front of a number a shortcut to link to another ticket within MantisBT will present. +
        Note: if you hover over a ticket it will show you the summary + if the ticket is closed, it will be struck-through like #1234.
      +
      Mantisbt-ticket-shortcut-example.jpg
      +
      • ~5678 - a shortcut that links to a bug note within a ticket. This can be used to reference someone's response within the thread. Each person that posts will show a unique ~#### number next to their username. If you look at the image in the example, you see that the shortcut is referencing the ticket number:comment number of said ticket
      +
      Mantisbt-comment-shortcut-example.jpg
      +
      • <del></del> - Using these tags will strikeout text.
      +
      Mantisbt-strikeout-text-example.jpg
      +
      • <code></code> - To present a line or block of code, use this tag and it will colorize and differentiate it elegantly.
      +
      Mantisbt-colorized-code-example.jpg
      +

      MantisBT BBCode

      +

      In addition to the above Tracker/MantisBT ̠Markup one also has the possibility to use BBCode format. For a comprehensive list see the BBCode plus plugin page. Here is a list of supported BBCode tagsː +
      +[img][/img] - Images
      +[url][/url] - Links
      +[email][/email] - Email addresses
      +[color=red][/color] - Colored text
      +[highlight=yellow][/highlight] - Highlighted text
      +[size][/size] - Font size
      +[list][/list] - Lists
      +[list=1][/list] - Numbered lists (number is starting number)
      +[*] - List items
      +[b][/b] - Bold
      +[u][/u] - underline
      +[i][/i] - Italic
      +[s][/s] - Strikethrough
      +[left][/left] - Left align
      +[center][/center] - Center
      +[right][/right] - Right align
      +[justify][/justify] - Justify
      +[hr] - Horizontal rule
      +[sub][/sub] - Subscript
      +[sup][/sup] - Superscript
      +[table][/table] - Table
      +[table=1][/table] - Table with border of specified width
      +[tr][/tr] - Table row
      +[td][/td] - Table column
      +[code][/code] - Code block
      +[code=sql][/code] - Code block with language definition
      +[code start=3][/code] - Code block with line numbers starting at number
      +[quote][/quote] - Quote by *someone* (no name)
      +[quote=name][/quote] - Quote by *name*
      +
      +
      +

      +

      MantisBT <=> GitHub Markup

      +

      Below are special MantisBT Source-Integration plugin keywords which will link to the FreeCAD GitHub repo. See Tracker#GitHub_and_MantisBT. +

      +
      • c:FreeCAD:git commit hash: - c stands for 'commit'. FreeCAD stands for the FreeCAD GitHub repo. 'git commit hash' is the specific git commit hash to reference. Note: the trailing colon is necessary. Exampleː cːFreeCADː709d2f325db0490016807b8fa6f49d1c867b6bd8ː
      • +
      • d:FreeCAD:git commit hash: - similar to the above, d stands for 'diff' which will provide a Diff view of the commit. Exampleː dːFreeCADː709d2f325db0490016807b8fa6f49d1c867b6bd8ː
      • +
      • p:FreeCAD:pullrequest: - similar to the above, p stands for Pull Request. Exampleː pːFreeCADː498ː
      +
      Mantisbt-source-integration-markup.jpg
      +
      +


      +

      +

      GitHub and MantisBT

      +

      The FreeCAD bugtracker has a plug-in called Source Integration which essentially ties both the FreeCAD GitHub repo to our MantisBT tracker. It makes it easier to track and associate git commits with their respective MantisBT tickets. The Source Integration plugin scans the git commit messages for specific keywords in order to execute the following actions: +

      Note The below keywords need to be added in the git commit message and not the PR subject +

      +

      Attaching a git commit to a ticket

      +

      The format MantisBT will recognize: +

      +
      • bug #1234
      • +
      • bugs #1234, #5678
      • +
      • issue #1234
      • +
      • issues #1234, #5678
      • +
      • report #1234
      • +
      • reports #1234, #5678
      +

      For the inquisitive here is the regex MantisBT uses for this operation:
      +/(?:bugs?|issues?|reports?)+\s*:?\s+(?:#(?:\d+)[,\.\s]*)+/i
      +

      +

      Remotely resolving a ticket

      +

      The format MantisBT will recognize: +

      +
      • fix #1234
      • +
      • fixed #1234
      • +
      • fixes #1234
      • +
      • fixed #1234, #5678
      • +
      • fixes #1234, #5678
      • +
      • resolve #1234
      • +
      • resolved #1234
      • +
      • resolves #1234
      • +
      • resolved #1234, #5678
      • +
      • resolves #1234, #5678
      +

      For the inquisitive here is the regex MantisBT uses for this operation:
      +/(?:fixe?d?s?|resolved?s?)+\s*:?\s+(?:#(?:\d+)[,\.\s]*)+/i
      +

      +

      Related

      + + +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Traditional_triangle.png b/localwiki/Traditional_triangle.png new file mode 100644 index 0000000..c2d1177 Binary files /dev/null and b/localwiki/Traditional_triangle.png differ diff --git a/localwiki/Transportation_Workbench.html b/localwiki/Transportation_Workbench.html new file mode 100644 index 0000000..8252ed5 --- /dev/null +++ b/localwiki/Transportation_Workbench.html @@ -0,0 +1,33 @@ +Transportation Workbench

      Transportation Workbench

      + +


      +

      +

      Description

      +

      A subset of the Civil Engineering Workbench +

      +

      Related Forum Threads

      +
      • Civil engineering feature implementation (Transportation Engineering) thread
      • +
      • Civil Engineering Design functions thread
      • +
      • Thread tracking FreeCAD & QGIS integration thread
      +

      Related Links

      + +


      +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/TreeView_SpeadSheet.gif b/localwiki/TreeView_SpeadSheet.gif new file mode 100644 index 0000000..988f6c8 Binary files /dev/null and b/localwiki/TreeView_SpeadSheet.gif differ diff --git a/localwiki/Tree_Annotation.svg b/localwiki/Tree_Annotation.svg new file mode 100644 index 0000000..0af4c4c --- /dev/null +++ b/localwiki/Tree_Annotation.svg @@ -0,0 +1,143 @@ + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + + + + + + + + + + + diff --git a/localwiki/Tree_Dimension.svg b/localwiki/Tree_Dimension.svg new file mode 100644 index 0000000..f76636d --- /dev/null +++ b/localwiki/Tree_Dimension.svg @@ -0,0 +1,109 @@ + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + + + + + diff --git a/localwiki/Tree_Mesh.svg b/localwiki/Tree_Mesh.svg new file mode 100644 index 0000000..0ac809f --- /dev/null +++ b/localwiki/Tree_Mesh.svg @@ -0,0 +1,275 @@ + + + + + Tree_Mesh + + + + + + + + + + + + + + + + image/svg+xml + + Tree_Mesh + + + [agryson] Alexander Gryson + + + + Mon Oct 10 13:44:52 2011 +0000 + + + [wmayer] + + + + + FreeCAD LGPL2+ + + + + + FreeCAD + + + FreeCAD/src/Mod/Mesh/Gui/Resources/icons/Tree_Mesh.svg + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + mesh + plane + tesselated + + + Tesselated folded plane, lit from top + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Tree_Part.svg b/localwiki/Tree_Part.svg new file mode 100644 index 0000000..362c01b --- /dev/null +++ b/localwiki/Tree_Part.svg @@ -0,0 +1,70 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [wmayer] + + + Tree_Part + 2011-10-10 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Part/Gui/Resources/icons/Tree_Part.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + diff --git a/localwiki/Tree_PartDesign_Pad.svg b/localwiki/Tree_PartDesign_Pad.svg new file mode 100644 index 0000000..5949127 --- /dev/null +++ b/localwiki/Tree_PartDesign_Pad.svg @@ -0,0 +1,143 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [jmaustpc] + + + Tree_PartDesign_Pad + 2013-03-17 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/PartDesign/Gui/Resources/icons/Tree_PartDesign_Pad.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + diff --git a/localwiki/Tree_PartDesign_Revolution.svg b/localwiki/Tree_PartDesign_Revolution.svg new file mode 100644 index 0000000..5fff74b --- /dev/null +++ b/localwiki/Tree_PartDesign_Revolution.svg @@ -0,0 +1,125 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [jmaustpc] + + + Tree_PartDesign_Revolution + 2013-03-17 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/PartDesign/Gui/Resources/icons/Tree_PartDesign_Revolution.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + diff --git a/localwiki/Tree_Part_Box_Parametric.svg b/localwiki/Tree_Part_Box_Parametric.svg new file mode 100644 index 0000000..6260798 --- /dev/null +++ b/localwiki/Tree_Part_Box_Parametric.svg @@ -0,0 +1,134 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [jmaustpc] + + + Tree_Part_Box_Parametric + 2013-03-13 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Part/Gui/Resources/icons/Tree_Part_Box_Parametric.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Tree_Part_Cone_Parametric.svg b/localwiki/Tree_Part_Cone_Parametric.svg new file mode 100644 index 0000000..a4fab60 --- /dev/null +++ b/localwiki/Tree_Part_Cone_Parametric.svg @@ -0,0 +1,107 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [jmaustpc] + + + Tree_Part_Cone_Parametric + 2013-03-13 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Part/Gui/Resources/icons/Tree_Part_Cone_Parametric.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Tree_Part_Cylinder_Parametric.svg b/localwiki/Tree_Part_Cylinder_Parametric.svg new file mode 100644 index 0000000..8abf971 --- /dev/null +++ b/localwiki/Tree_Part_Cylinder_Parametric.svg @@ -0,0 +1,118 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [jmaustpc] + + + Tree_Part_Cylinder_Parametric + 2013-03-13 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Part/Gui/Resources/icons/Tree_Part_Cylinder_Parametric.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Tree_Part_Ellipsoid_Parametric.svg b/localwiki/Tree_Part_Ellipsoid_Parametric.svg new file mode 100644 index 0000000..df98598 --- /dev/null +++ b/localwiki/Tree_Part_Ellipsoid_Parametric.svg @@ -0,0 +1,119 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [jmaustpc] + + + Tree_Part_Ellipsoid_Parametric + 2013-03-13 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Part/Gui/Resources/icons/Tree_Part_Ellipsoid_Parametric.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Tree_Part_Plane_Parametric.svg b/localwiki/Tree_Part_Plane_Parametric.svg new file mode 100644 index 0000000..929da1f --- /dev/null +++ b/localwiki/Tree_Part_Plane_Parametric.svg @@ -0,0 +1,129 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [jmaustpc] + + + Tree_Part_Plane_Parametric + 2013-03-13 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Part/Gui/Resources/icons/Tree_Part_Plane_Parametric.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Tree_Part_Prism.svg b/localwiki/Tree_Part_Prism.svg new file mode 100644 index 0000000..fb4de8b --- /dev/null +++ b/localwiki/Tree_Part_Prism.svg @@ -0,0 +1,146 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [wmayer] + + + Tree_Part_Prism + 2013-11-08 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Part/Gui/Resources/icons/Tree_Part_Prism.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Tree_Part_Sphere_Parametric.svg b/localwiki/Tree_Part_Sphere_Parametric.svg new file mode 100644 index 0000000..a9f3e2e --- /dev/null +++ b/localwiki/Tree_Part_Sphere_Parametric.svg @@ -0,0 +1,87 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [jmaustpc] + + + Tree_Part_Sphere_Parametric + 2013-03-13 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Part/Gui/Resources/icons/Tree_Part_Sphere_Parametric.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Tree_Part_Torus_Parametric.svg b/localwiki/Tree_Part_Torus_Parametric.svg new file mode 100644 index 0000000..962ae71 --- /dev/null +++ b/localwiki/Tree_Part_Torus_Parametric.svg @@ -0,0 +1,146 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [jmaustpc] + + + Tree_Part_Torus_Parametric + 2013-03-13 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Part/Gui/Resources/icons/Tree_Part_Torus_Parametric.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Tree_Part_Wedge.svg b/localwiki/Tree_Part_Wedge.svg new file mode 100644 index 0000000..2f3695e --- /dev/null +++ b/localwiki/Tree_Part_Wedge.svg @@ -0,0 +1,130 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [wmayer] + + + Tree_Part_Wedge + 2013-11-08 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Part/Gui/Resources/icons/Tree_Part_Wedge.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Tree_Python.svg b/localwiki/Tree_Python.svg new file mode 100644 index 0000000..6cfa641 --- /dev/null +++ b/localwiki/Tree_Python.svg @@ -0,0 +1,145 @@ + + + + + + + + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Triangel_angle_small.png b/localwiki/Triangel_angle_small.png new file mode 100644 index 0000000..567e563 Binary files /dev/null and b/localwiki/Triangel_angle_small.png differ diff --git a/localwiki/Triangle_equilateral_small.png b/localwiki/Triangle_equilateral_small.png new file mode 100644 index 0000000..f36e19b Binary files /dev/null and b/localwiki/Triangle_equilateral_small.png differ diff --git a/localwiki/Triangle_isosceles_small.png b/localwiki/Triangle_isosceles_small.png new file mode 100644 index 0000000..a25440c Binary files /dev/null and b/localwiki/Triangle_isosceles_small.png differ diff --git a/localwiki/Triangles.gif b/localwiki/Triangles.gif new file mode 100644 index 0000000..e422942 Binary files /dev/null and b/localwiki/Triangles.gif differ diff --git a/localwiki/Truggy_differential_full.jpg b/localwiki/Truggy_differential_full.jpg new file mode 100644 index 0000000..6d30842 Binary files /dev/null and b/localwiki/Truggy_differential_full.jpg differ diff --git a/localwiki/Tut17_final.png b/localwiki/Tut17_final.png new file mode 100644 index 0000000..7c59801 Binary files /dev/null and b/localwiki/Tut17_final.png differ diff --git a/localwiki/Tut17_final_refined.png b/localwiki/Tut17_final_refined.png new file mode 100644 index 0000000..efe765f Binary files /dev/null and b/localwiki/Tut17_final_refined.png differ diff --git a/localwiki/Tut17_innerplane.png b/localwiki/Tut17_innerplane.png new file mode 100644 index 0000000..67f1d98 Binary files /dev/null and b/localwiki/Tut17_innerplane.png differ diff --git a/localwiki/Tut17_profile.png b/localwiki/Tut17_profile.png new file mode 100644 index 0000000..0311490 Binary files /dev/null and b/localwiki/Tut17_profile.png differ diff --git a/localwiki/Tut17_profilewithsideblocks.png b/localwiki/Tut17_profilewithsideblocks.png new file mode 100644 index 0000000..f0d0aa9 Binary files /dev/null and b/localwiki/Tut17_profilewithsideblocks.png differ diff --git a/localwiki/Tut17_profilewithsideblocksrearplane.png b/localwiki/Tut17_profilewithsideblocksrearplane.png new file mode 100644 index 0000000..23c8501 Binary files /dev/null and b/localwiki/Tut17_profilewithsideblocksrearplane.png differ diff --git a/localwiki/Tut17_profilewithslots.png b/localwiki/Tut17_profilewithslots.png new file mode 100644 index 0000000..6bee48a Binary files /dev/null and b/localwiki/Tut17_profilewithslots.png differ diff --git a/localwiki/Tut17_profilewithslotsrearplane.png b/localwiki/Tut17_profilewithslotsrearplane.png new file mode 100644 index 0000000..b1aabf2 Binary files /dev/null and b/localwiki/Tut17_profilewithslotsrearplane.png differ diff --git a/localwiki/Tut17_rechtangleholeunconstrained.png b/localwiki/Tut17_rechtangleholeunconstrained.png new file mode 100644 index 0000000..2c0e5d9 Binary files /dev/null and b/localwiki/Tut17_rechtangleholeunconstrained.png differ diff --git a/localwiki/Tut17_rectangleconstrained.png b/localwiki/Tut17_rectangleconstrained.png new file mode 100644 index 0000000..42c29cc Binary files /dev/null and b/localwiki/Tut17_rectangleconstrained.png differ diff --git a/localwiki/Tut17_rectangleholeconstrained.png b/localwiki/Tut17_rectangleholeconstrained.png new file mode 100644 index 0000000..4ad281f Binary files /dev/null and b/localwiki/Tut17_rectangleholeconstrained.png differ diff --git a/localwiki/Tut17_rectangleunconstrained.png b/localwiki/Tut17_rectangleunconstrained.png new file mode 100644 index 0000000..aebe9ca Binary files /dev/null and b/localwiki/Tut17_rectangleunconstrained.png differ diff --git a/localwiki/Tut17_refine.png b/localwiki/Tut17_refine.png new file mode 100644 index 0000000..fa6f1ec Binary files /dev/null and b/localwiki/Tut17_refine.png differ diff --git a/localwiki/Tut17_sidblockunconstrained.png b/localwiki/Tut17_sidblockunconstrained.png new file mode 100644 index 0000000..8ee6dba Binary files /dev/null and b/localwiki/Tut17_sidblockunconstrained.png differ diff --git a/localwiki/Tut17_sideblock.png b/localwiki/Tut17_sideblock.png new file mode 100644 index 0000000..ef87e07 Binary files /dev/null and b/localwiki/Tut17_sideblock.png differ diff --git a/localwiki/Tut17_sideblockconstraind.png b/localwiki/Tut17_sideblockconstraind.png new file mode 100644 index 0000000..c538cff Binary files /dev/null and b/localwiki/Tut17_sideblockconstraind.png differ diff --git a/localwiki/Tut17_sketcherempty.png b/localwiki/Tut17_sketcherempty.png new file mode 100644 index 0000000..cd70b88 Binary files /dev/null and b/localwiki/Tut17_sketcherempty.png differ diff --git a/localwiki/Tut17_slot_unconstrained.png b/localwiki/Tut17_slot_unconstrained.png new file mode 100644 index 0000000..2442f8e Binary files /dev/null and b/localwiki/Tut17_slot_unconstrained.png differ diff --git a/localwiki/Tut17_slote_constrained.png b/localwiki/Tut17_slote_constrained.png new file mode 100644 index 0000000..68d84e7 Binary files /dev/null and b/localwiki/Tut17_slote_constrained.png differ diff --git a/localwiki/Tut17_wrongplaneforpocket.png b/localwiki/Tut17_wrongplaneforpocket.png new file mode 100644 index 0000000..b6346b4 Binary files /dev/null and b/localwiki/Tut17_wrongplaneforpocket.png differ diff --git a/localwiki/Tutorial-normand01.jpg b/localwiki/Tutorial-normand01.jpg new file mode 100644 index 0000000..4afd469 Binary files /dev/null and b/localwiki/Tutorial-normand01.jpg differ diff --git a/localwiki/Tutorial-normand02.jpg b/localwiki/Tutorial-normand02.jpg new file mode 100644 index 0000000..1f60224 Binary files /dev/null and b/localwiki/Tutorial-normand02.jpg differ diff --git a/localwiki/Tutorial-normand03.jpg b/localwiki/Tutorial-normand03.jpg new file mode 100644 index 0000000..4c0c119 Binary files /dev/null and b/localwiki/Tutorial-normand03.jpg differ diff --git a/localwiki/Tutorial-normand04.jpg b/localwiki/Tutorial-normand04.jpg new file mode 100644 index 0000000..2521411 Binary files /dev/null and b/localwiki/Tutorial-normand04.jpg differ diff --git a/localwiki/Tutorial-normand05.jpg b/localwiki/Tutorial-normand05.jpg new file mode 100644 index 0000000..38e044a Binary files /dev/null and b/localwiki/Tutorial-normand05.jpg differ diff --git a/localwiki/Tutorial-normand06.jpg b/localwiki/Tutorial-normand06.jpg new file mode 100644 index 0000000..5c306b1 Binary files /dev/null and b/localwiki/Tutorial-normand06.jpg differ diff --git a/localwiki/Tutorial-normand07.jpg b/localwiki/Tutorial-normand07.jpg new file mode 100644 index 0000000..b600b54 Binary files /dev/null and b/localwiki/Tutorial-normand07.jpg differ diff --git a/localwiki/Tutorial-normand08.jpg b/localwiki/Tutorial-normand08.jpg new file mode 100644 index 0000000..2c86d82 Binary files /dev/null and b/localwiki/Tutorial-normand08.jpg differ diff --git a/localwiki/Tutorial_Drawing_Sheet.png b/localwiki/Tutorial_Drawing_Sheet.png new file mode 100644 index 0000000..6b16202 Binary files /dev/null and b/localwiki/Tutorial_Drawing_Sheet.png differ diff --git a/localwiki/Tutorial_WhiffleBall.jpg b/localwiki/Tutorial_WhiffleBall.jpg new file mode 100644 index 0000000..f46e45c Binary files /dev/null and b/localwiki/Tutorial_WhiffleBall.jpg differ diff --git a/localwiki/Tutorial_WhiffleBall_BasicShape.jpg b/localwiki/Tutorial_WhiffleBall_BasicShape.jpg new file mode 100644 index 0000000..79aedf5 Binary files /dev/null and b/localwiki/Tutorial_WhiffleBall_BasicShape.jpg differ diff --git a/localwiki/Tutorial_WhiffleBall_UnfinishedShape.jpg b/localwiki/Tutorial_WhiffleBall_UnfinishedShape.jpg new file mode 100644 index 0000000..741f9a4 Binary files /dev/null and b/localwiki/Tutorial_WhiffleBall_UnfinishedShape.jpg differ diff --git a/localwiki/Tutorials.html b/localwiki/Tutorials.html new file mode 100644 index 0000000..7018d1d --- /dev/null +++ b/localwiki/Tutorials.html @@ -0,0 +1,251 @@ +Tutorials

      Tutorials

      + +

      This page presents a selection of written tutorials, it is in no way complete! A complete, unsorted list of tutorials can be found here: Category:Tutorials. +

      You can also check out Offsite tutorials and Video tutorials which list links to tutorials hosted on external sites. A useful source of video tutorials is of course also a FreeCAD keyword search on YouTube. +

      + + +

      Architecture and BIM

      + +

      Modeling Parts

      +

      FreeCAD provides two main workflows to modeling parts: combining objects (a method called constructive solid geometry (CSG)) using the Part workbench, or using a feature editing methodology with the PartDesign workbench. Please note that PartDesign work flow was considerably changed from v0.17 onward: some of the tutorials are yet to be updated. +

      + +

      Drafting and Sketching

      + +

      Technical Drawings

      + +

      FEM

      + +

      CNC & 3D Printing

      + +

      Import and Export

      + +

      Rendering

      + +

      Robot workbench

      + +
      +


      +

      + +


      +

      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Type_class.svg b/localwiki/Type_class.svg new file mode 100644 index 0000000..5aa4d27 --- /dev/null +++ b/localwiki/Type_class.svg @@ -0,0 +1,364 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Type_enum.svg b/localwiki/Type_enum.svg new file mode 100644 index 0000000..2142251 --- /dev/null +++ b/localwiki/Type_enum.svg @@ -0,0 +1,231 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Type_module.svg b/localwiki/Type_module.svg new file mode 100644 index 0000000..9777daf --- /dev/null +++ b/localwiki/Type_module.svg @@ -0,0 +1,336 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/US_Ledger_ds_Landscape.svg b/localwiki/US_Ledger_ds_Landscape.svg new file mode 100644 index 0000000..695e564 --- /dev/null +++ b/localwiki/US_Ledger_ds_Landscape.svg @@ -0,0 +1,518 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + + + + + + + + + 1 + 2 + 3 + 4 + A + B + C + + + + + + + + + + + + + + + + + + + + TITLE + DESCRIPTION + Scale : + SCALE + Title 0 : + TITLE 0 + Date : + DATE + Made With : + FreeCAD + www.freecadweb.org + TEXT 1 + TEXT 2 + + + + + + diff --git a/localwiki/US_Legal_ds_Landscape.svg b/localwiki/US_Legal_ds_Landscape.svg new file mode 100644 index 0000000..ae995a6 --- /dev/null +++ b/localwiki/US_Legal_ds_Landscape.svg @@ -0,0 +1,523 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + + + + + + + + + 1 + 2 + 3 + 4 + A + B + C + + + + + + + + + + + + + + + + + + + + TITLE + DESCRIPTION + Scale : + SCALE + Title 0 : + TITLE 0 + Date : + DATE + Made With : + FreeCAD + www.freecadweb.org + TEXT 1 + TEXT 2 + + + + + + diff --git a/localwiki/US_Letter_ds_Landscape.svg b/localwiki/US_Letter_ds_Landscape.svg new file mode 100644 index 0000000..d89b7ba --- /dev/null +++ b/localwiki/US_Letter_ds_Landscape.svg @@ -0,0 +1,638 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + + + + + + + + + 1 + 2 + 3 + 4 + A + B + C + + + + + + + + + + + + + + + + + + + + TITLE + DESCRIPTION + Scale : + SCALE + Title 0 : + TITLE 0 + Date : + DATE + Made With : + FreeCAD + www.freecadweb.org + TEXT 1 + TEXT 2 + + + + + + diff --git a/localwiki/US_Letter_landscape.svg b/localwiki/US_Letter_landscape.svg new file mode 100644 index 0000000..8e19960 --- /dev/null +++ b/localwiki/US_Letter_landscape.svg @@ -0,0 +1,1664 @@ + + + + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/US_Letter_portrait.svg b/localwiki/US_Letter_portrait.svg new file mode 100644 index 0000000..dd1b2c1 --- /dev/null +++ b/localwiki/US_Letter_portrait.svg @@ -0,0 +1,1667 @@ + + + + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/UTF_Project.html b/localwiki/UTF_Project.html new file mode 100644 index 0000000..36f4c1a --- /dev/null +++ b/localwiki/UTF_Project.html @@ -0,0 +1,35 @@ +UTF Project

      UTF Project

      + +

      This is the project plan for the FreeCAD part of the Development roadmap. +

      +

      Purpose and principles

      +

      To improve multi-language capabilities in FreeCAD by implementing support for UTF characters within the Coin3D interface. +

      Despite Coin3D now moving to a more open development platform, it's still very difficult to contribute back into the project. +

      (mrlukeparry) I have yet to receive a response on contributing back and for now it seems more appropriate to keep this within the FreeCAD project and would mean we can let users test without requiring development versions of Coin3D. I would aim to achieve this by 0.14 considering it's a big priority for increasing accessibility of FreeCAD to non-english users. +

      +

      Organizing

      +
      • Provide a basic UTF string handling functionality that is independent of major libraries except STL.
      • +
      • Implement the Coin3D fields and 3D text nodes for handling the new UTF data storage.
      • +
      • Migrate modules over to use the new textual nodes.
      • +
      • Rigorous testing
      +

      Next actions

      +
      • Implement the UTF String Handling Class (WIP)
      • +
      • Handling of fonts and glyphs.
      • +
      • Implement Coin3D text fields and nodes for use in project
      • +
      • Migrate modules using SoText2 and SoText3 to utilise new nodes
      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/UnbiasedRendering.png b/localwiki/UnbiasedRendering.png new file mode 100644 index 0000000..90e4d8a Binary files /dev/null and b/localwiki/UnbiasedRendering.png differ diff --git a/localwiki/Unfolding_test2.png b/localwiki/Unfolding_test2.png new file mode 100644 index 0000000..0e9c483 Binary files /dev/null and b/localwiki/Unfolding_test2.png differ diff --git a/localwiki/Units.html b/localwiki/Units.html new file mode 100644 index 0000000..31f7379 --- /dev/null +++ b/localwiki/Units.html @@ -0,0 +1,368 @@ +Units

      Units

      + +

      Here some reading about units: +

      + + + +

      Examples

      +
      # -- some examples of the FreeCAD unit translation system --
      +# make a shortcut for the examples
      +tu = FreeCAD.Units.parseQuantity
      +
      +# 10 meters in internal numbers
      +tu('10 m')
      +# doing math
      +tu('3/8 in')
      +# combined stuff
      +tu('100 km/h')
      +# transfer to other units
      +tu('100 km/h')/tu('m/s')
      +# derived units (Ohm)
      +tu('m^2*kg*s^-3*A^-2')
      +# or
      +tu('(m^2*kg)/(A^2*s^3)')
      +# angles 
      +tu('2*pi rad') # full circle
      +# as gon
      +tu('2*pi rad') / tu('gon')
      +# more imperial
      +tu('1ft (3+7/16)in')
      +# or 
      +tu('1\' (3+7/16)"') # the ' we have to escape because of python
      +# trigonometry
      +tu('sin(pi)')
      +# Using translated units as parameters, this command will create a 50.8mm x 20mm x 10mm box
      +b = Part.makeBox(tu('2in'),tu('2m')/100,10)
      +
      +

      Supported units

      +

      Here the defined units in FreeCAD so far. It's easy to add a new user defined unit. The definition is here[1]. +

      Metric length +

      +
      "mm"    1.0;        // millimeter       (internal standard length)
      +"m"     1000.0;     // meter
      +"cm"    10.0;       // centimeter
      +"dm"    100.0;      // decimeter
      +"km"    1000000.0;  // kilometer
      +
      +

      Imperial lenth +

      +
      "in" "\""  25.4;       // inch
      +"ft" "'"   304.8;      // foot
      +"th"       0.0254;     // thou
      +"yr"       914.4;      // yard
      +
      +

      Metric mass +

      +
      "kg"    1.0;        // kilogram       (internal standard mass)
      +"g"     0.001;      // gram
      +"mg"    0.000001;   // milligram
      +"t"     1000.0;     // ton 
      +
      +

      Imperial mass +

      +
      "lb"    0.45359237; // pound
      +"oz"    0.45359237; // ounce
      +"st"    6.35029318; // Stone
      +"cwt"   50.80234544;// hundredweights
      +
      +

      Angle +

      +
      "deg"   1.0;        // degree         (internal standard angle)
      +"rad"   180/M_PI;   // radian         
      +"gon"   360.0/400.0;// gon   
      +     
      +
      +

      Time +

      +
      "s"     1.0;        // second         (internal standard time)
      +"min"   60.0;       // minute
      +"h"     3600.0;     // hour  
      +
      +

      Rest of SI +

      +
      "A"     1.0;        // Ampere         (internal standard electric current)
      +"K"     1.0;        // Kelvin         (internal standard thermodynamic temperature)
      +"cd"    1.0;        // Candela        (internal standard luminous intensity)        
      +"mol"   1.0;        // Mole           (internal standard amount of substance)
      +       
      +
      +

      Metric Volume +

      +
      "µl"    1.0;        // microliter mm^3(derived  standard volume)
      +"ml"    1000.0;     // milliliter cm^3    
      +"l"     1000000.0;  // Liter      dm^3
      +
      +

      Purpose and principles: proposal of an extension of the unit management system

      +

      An extension unit management system is proposed in the following sections, developping the concept of unit system, activated during a running FreeCAD instance. +The interest in defining such a new concept is to work more easily with as many type of physical units as one wants (even user-created ones), without increasing the complexity of unit management for the user, nor for FreeCAD developpers. +

      In short, event of unit scaling are localized precisely, and carried out in a generic fashion. +

      Achieving such a flexibility is most notably required when one starts to deal with material properties that can have very different units, difficult to manage one by one manually. +

      The reasoning proposed allows handling the units such as described in the Guide for the Use of the International System of Units (SI) and The International System of Units (SI) both from NIST. +

      In this proposal, one first recall in Brainstorming section what are the possible contexts for which unit management is required. +

      In Organizing section, we present the data model retained to achieve unit management, based on 3 objects, the unit, the unit dictionary, and the unit system. +Finally, a short API of a 4th object called the unit manager is presented as well. +

      +

      Outcome

      +

      Thanks to this extension, one aims to ease unit scaling that can occurs between different business tasks. For instance, technical drawings can be done in standard unit system, while FE modelling can be managed in an unit system more suited for it. +

      The exchange of data between these two kind of activities become easier with this extension. +

      +

      Brainstorming

      +

      In this section are highlighted the contexts of use of such an unit management system. +From these contexts, we are then able to defined its technical specifications. +

      Essentially 2 contexts are given as example. +

      +

      Context 1: opening a data file

      +

      This case is probably the most frequent case. +You receive a file containing for instance a geometrical model, or describing a material with quite a lot of properties. The geometrical model is expressed in meters, or the material properties according the international unit system. +

      Too bad... +

      You are an expert FE modelling, and you usually work with millimeter for length, MegaPascal for stress, tonne for mass... +

      In this context, unit management is required to scale data from an initial unit system defined in the input file to a user-defined target unit system. +

      +

      Context 2: switching the unit system at runtime

      +

      In this case, you can be at the same time the guy that carries out a drawing, and the guy that will manage the FE modelling. Similarly to the previous case, the unit systems for these 2 tasks are not the same, and you need to switch the initial unit system at runtime to your favorite one. +

      +

      Organizing

      +

      Logic of unit scaling

      +

      In the Brainstorming section have been presented 2 contexts when using unit scaling. +Some items should be highlighted from these two contexts. +

      +

      Unit coherence throughout the FreeCAD running instance

      +

      The system proposed is based on a primary assumption: the user is working in a coherent unit system. +For instance, this means that if the user expresses length in millimeters, necessarily areras will be expressed in terms of squared millimeters, not squared meters. +This is hypothesis one. +

      +

      Unit system

      +

      Because of hypothesis one, it is possible and relevant to define an unit system. +An unit system applies to: +

      +
      • a running FreeCAD instance into which you are working
      • +
      • or it may also apply globally to the content of an input file
      +

      According Guide for the Use of the International System of Units (SI) from NIST, they are 7 physical base units. +We chose to express a unit system in terms of these 7 base units. +

      When working within an instance of FreeCAD, the user has thus to define first the unit system according to which she/he is working before she/he decides to switch to another unit system, or before importing data from an input file. +

      This unit system will apply till the user decides to change it. If she/he does, all data with dimensions will be scaled. +

      Considering hypothesis one, all data that the user will input manually in FreeCAD are assumed to be coherent with the chosen unit system. +

      The benefit to work with a unit system defined at a FreeCAD running instance level, or at data file level (instead of unit which are defined at the data level) is then that unit management is considerably simplified. +

      Here are some examples of unit systems. +

      +
      • meter, kilogram, second, ampere, Kelvin, mole, candela
      • +
      • millimeter, tonne, millisecond, ampere, Kelvin, mole, candela
      • +
      • millimeter, kilogramme, millisecond, ampere, Kelvin, mole, candela
      • +
      • ...
      +

      Base and derived units

      +

      Derived units are created by combination of base units. For instance, an acceleration (m/s) combines at the same time length and time. An interesting picture presenting the relationships between base and derived units can be seen here also from NIST. +

      Thanks to the definition of unit system, it is possible for the user to work with any kind of derived units, without the need for FreeCAD developpers to foresee them in advance. +

      +

      Base and derived unit symbols

      +

      According to The International System of Units (SI), the symbols to specify a units are officially approved. Two consequences can be highlighted from this. +

      +
      • it is not easy for a computer program to work with unit symbols because some are greek letters for instance. Hence they can be a bit difficult to process by a program
      • +
      • while some units and their symbols can be used widely, they may be not approved officially, like for instance tonne unit (see p32 of The International System of Units (SI))
      +

      To overcome these limitations and remain flexible, the proposed system favors the use of unit magnitudes instead of unit symbols, which remain nonetheless available for an ergonomy reason. +

      +

      Data model

      +

      The three core objects of the unit management system are presented, namely the unit, the unit dictionary and the unit system. +

      +

      Unit

      +

      As a foreword, it is important to highlight that a unit object in itself only indicates a dimension like length, mass, time... It doesn't specify a magnitude like meter, millimeter, kilometer... This last information is specified through the unit system. +

      +
      Dimension
      +

      Compulsory string indicating the dimension of the unit. The dimension of the 7 base units are indicated below (from Guide for the Use of the International System of Units (SI)). +

      +
      • LENGTH
      • +
      • MASS
      • +
      • TIME
      • +
      • ELECTRIC CURRENT
      • +
      • THERMODYNAMIC TEMPERATURE
      • +
      • AMOUNT OF SUBSTANCE
      • +
      • LUMINOUS INTENSITY
      +

      Dimension attribute allows identifying the unit. +Two units cannot share the same dimension. +

      +
      Signature
      +

      Compulsory integer array of size 7 (number of base units) that defines what the unit is. +The signature of the 7 base units are: +

      +
      • LENGTH: [1,0,0,0,0,0,0]
      • +
      • MASS: [0,1,0,0,0,0,0]
      • +
      • TIME: [0,0,1,0,0,0,0]
      • +
      • ELECTRIC CURRENT: [0,0,0,1,0,0,0]
      • +
      • THERMODYNAMIC TEMPERATURE: [0,0,0,0,1,0,0]
      • +
      • AMOUNT OF SUBSTANCE: [0,0,0,0,0,1,0]
      • +
      • LUMINOUS INTENSITY: [0,0,0,0,0,0,1]
      +

      From these 7 units, we are then able to express all derived units defined in Guide for the Use of the International System of Units (SI) and create new ones as needed such as for instance: +

      +
      • MASS DENSITY: [-3,1,0,0,0,0,0]
      • +
      • AREA: [0,2,0,0,0,0,0]
      +

      Signature is the attribute thanks to which unit scaling can be achieved in a generic way. +

      +
      Symbols
      +

      Array of [real, string] (meaning [magnitude, symbol]) that lists all symbols known by FreeCAD. +Thanks to this array, the unit scaling API becomes more ergonomic because symbols and related magnitudes are linked. +

      This array can be extended as required. +

      For instance, the list of symbols of the LENGTH unit, and their related magnitudes is: +

      +
      [1e+12,"Tm"],[1e+09,"Gm"],[1e+06,"Mm"],
      +[1e+03,"km"],[1e+02,"hm"],[1e+01,"dam"],
      +[1e+00,"m"],[1e-01,"dm"],[1e-02,"cm"],
      +[1e-03,"mm"],[1e-06,"µm"],[1e-09,"nm"],
      +[1e-12,"pm"],[1e-15,"fm"]
      +
      +

      Standard symbols can be found on NIST website and p23 to 26 and p32 (metric ton or tonne) of The International System of Units (SI). +

      +

      Unit dictionary

      +

      All the units available in FreeCAD, and new ones created by the user, should be stored in unit dictionary, which is an XML file (FreeCAD configuration file), so as to be retrieved when needed, i.e. when achieving unit scaling. +

      +
      Units
      +

      Array of units, contained in the unit dictionary. +

      +

      Unit system

      +

      A unit system is the object that allows the user defining the current unit magnitude of each base units with which she/he is working. +For instance, knowing that the user is working with millimeter, tonne, and second, thanks to the use of a unit system, FreeCAD can know that energy is expressed in terms of milliJoule, force in terms of Newton, and stress in terms of MegaPascal. +Hence a unit system is only defined by a name (for instance Standard unit system) and a magnitude table specifying for each of the 7 base units, what is its corresponding magnitude. +

      +
      Name
      +

      String allowing to the user identifying what is the unit system. +

      +
      Magnitudes
      +

      By specifying the magnitude of the 7 base units, a unit system is defined. +

      For instance [1e-03, 1e+03, 1, 1, 1, 1, 1], meaning millimeter, tonne, second, ampere, Kelvin, mole, candela +

      +

      Unit management API

      +

      Only the logic of some methods is presented, in order to highlight some features. +These methods could belong to an object called Unit manager. +

      +
      Checking the unit dictionary
      +
      isValid
      +

      The unit dictionary can be an XML file (FreeCAD configuration file). It contains a list of defined units. +Such a dictionary is required for the proposed unit management system to work. +

      It must fulfills some conditions that should be checked before activating the unit management system. +These conditions are: +

      +
      • check that all base units are defined
      • +
      • check that a dimension is not defined twice through the units
      • +
      • check that a symbol is not defined twice in all the existing symbols
      • +
      • check that the signatures of all units have all the same size
      • +
      • chacke that a standard symbol (for which magnitude is 1) is defined for all units
      +
      isCompatibleWithThisSignature
      +

      A unit dictionary defines a set of units and their known magnitudes. +When managing a unit, it is relevant to check that its signature is compatible with the set of units registered in the unit dictionary, so as to process it. +This check includes: +

      +
      • check that the input signature length is of the same size than the unit dictionary unit signatures
      +
      Scaling units
      +
      scaleUnitFromSymbolToSymbol
      +

      Knowing a value, an initial unit by its symbol, the target unit by its symbol, scale the value. +

      +
      scaleUnitFromSymbolToUnitSystem
      +

      Knowing a value, an initial unit by its symbol, the target unit system, scale the value. +

      +
      scaleUnitFromUnitSystemToSymbol
      +

      Knowing a value, an initial unit system, the target unit by its symbol, scale the value. +

      +

      Motivations for such a management: example of application

      +

      Let's assume that we are going to setup a finite element model. +To build our model, we need the mesh, material properties, and to define numerical parameters. +Considering that they can be tens of material properties to manage, expressed with different units, sometimes not always very common, it is interesting for the user to only have to specify a global unit system, without caring much. +

      FreeCAD would then just do the job. +

      As FreeCAD developpers and FreeCAD users do not necessarily know all units that can be defined in the material property files, it is interesting to rely on a generic system. +

      Let's assume that in such a file we have a fair number of exotic material properties expressed with exotic units, and that we want to work in a specific unit system. +

      It is easy with the proposed extension to scale any of these properties by knowing their signatures, magnitudes, and the target unit system. +

      For each of the properties, the scaling is obtained by multiplying the initial property value with the factor <math>\frac{initialMagnitude}{targetMagnitude}</math>. +

      The targetMagnitude is then simply obtained with the operation <math>\prod_{bu} targetMagnitude_{bu}^{signature_{bu}}</math>, bu standing for base unit. +

      It becomes thus very easy to manage any number of properties with any kind of units with very few lines of Python. +

      +

      Next actions

      +
      • Implementing Quantity and Unit classes (mostly done)
      • +
      • Implementing InputField as User front end (in progress)
      • +
      • UnitsCalculator as test bed (in progress)
      • +
      • Quantity documentation (in progress)
      • +
      • UnitsCalculator documentation
      • +
      • Update Material framework to work only with Quantities
      • +
      • Test Cases
      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Units_Calculator_it.png b/localwiki/Units_Calculator_it.png new file mode 100644 index 0000000..99e857f Binary files /dev/null and b/localwiki/Units_Calculator_it.png differ diff --git a/localwiki/Units_project.html b/localwiki/Units_project.html new file mode 100644 index 0000000..286cafd --- /dev/null +++ b/localwiki/Units_project.html @@ -0,0 +1,62 @@ +Units project

      Units project

      + +

      This project is toward the implementation of a decent Units system in FreeCAD. It follows the rules of the Getting things done process. The projects are collected in the Development roadmap. +

      + + +

      Purpose and principles

      +

      This is a software development project aimed to implement a Unit-system framework into FreeCAD. +

      The development steps are planed here (Next actions) and tracked in the Issue tracking system to get a well formed change log: Issue tracker +

      +

      Outcome

      +

      It will enable FreeCAD to handle wired measurement systems, like the imperial system, and complex compound SI units. +Also handle the import/export formats which are able to transport Units (like STEP). And allow scaling based on assumptions of Units (mm->m, m->in). +

      +

      Brainstorming

      +

      Lots of discussion was done here: +http://forum.freecadweb.org/viewtopic.php?f=10&t=1616 +

      And lot of information you'll find in the Units article. +

      +

      Organizing

      +

      Upgrading units parser

      +

      Upgrading the parser to handle and generate signatures as discussed in the Units article. +

      +

      Properties

      +

      Changing the properties form e.g. PropertyLength to PropertyUntit with a unit signature. +

      Eventually a property editor for the PropertyUntit. +

      +

      Workbenches

      +
      • Upgrading workbenches to use the Units framework. I would start with Sketcher and PartDesign and go subsequently further...
      • +
      • Documenting that upgrade process so other people can do the same with other workbenches --Yorikvanhavre 13:13, 28 November 2011 (UTC)
      +

      Next actions

      +
      • Upgrading units parser (jriegel)
      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/UnsavedDocument.png b/localwiki/UnsavedDocument.png new file mode 100644 index 0000000..5c96de4 Binary files /dev/null and b/localwiki/UnsavedDocument.png differ diff --git a/localwiki/User.svg b/localwiki/User.svg new file mode 100644 index 0000000..5308502 --- /dev/null +++ b/localwiki/User.svg @@ -0,0 +1,698 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + + + + + + + + diff --git a/localwiki/Utilities-terminal.svg b/localwiki/Utilities-terminal.svg new file mode 100644 index 0000000..658afa3 --- /dev/null +++ b/localwiki/Utilities-terminal.svg @@ -0,0 +1,613 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + Terminal + 2005-10-15 + + + Andreas Nilsson + + + + + terminal + emulator + term + command line + + + + + + Jakub Steiner + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Utube-alignment-STEP-models.png b/localwiki/Utube-alignment-STEP-models.png new file mode 100644 index 0000000..9a8070d Binary files /dev/null and b/localwiki/Utube-alignment-STEP-models.png differ diff --git a/localwiki/Utube-alignment-tool-tutorial.png b/localwiki/Utube-alignment-tool-tutorial.png new file mode 100644 index 0000000..ac847db Binary files /dev/null and b/localwiki/Utube-alignment-tool-tutorial.png differ diff --git a/localwiki/V2_scale.png b/localwiki/V2_scale.png new file mode 100644 index 0000000..0fad32c Binary files /dev/null and b/localwiki/V2_scale.png differ diff --git a/localwiki/VRML_Preparation_for_Robot_Simulation.html b/localwiki/VRML_Preparation_for_Robot_Simulation.html new file mode 100644 index 0000000..34039b8 --- /dev/null +++ b/localwiki/VRML_Preparation_for_Robot_Simulation.html @@ -0,0 +1,585 @@ +VRML Preparation for Robot Simulation

      VRML Preparation for Robot Simulation

      + +
      + + + + + + + + + + + + + + + + + + + + + + + + + + + +
      +

      Base ExampleCommandModel.png Tutorial

      +
      Topic +
      Robot Workbench +
      Level +
      Intermediate +
      Time to complete +
      +
      Author +
      +
      FreeCAD version +
      +
      Example File(s) +
      +

      + +
      +


      +


      +This tutorial explains how to use FreeCAD and the Robot Simulation Workbench to simulate the motions of 6-axis serial robot. The tutorial focuses on the creation of the vrml file used as visualization. The base of the vrml file is a FreeCAD model. The version of FreeCAD used is 0.11.4252ppa1 on Ubuntu 32bit. +

      +

      Open a file or create one with FreeCAD

      +

      The tutorial is based on a STEP-file of a Stäubli TX40 (TX40-HB.stp). You can download the file from Stäubli. However, though I still didn't have time to check this, the method should also apply to a model completely made in FreeCAD. +After opening the file, you should obtain this: +

      Staeubli step import.png +

      Notice, that on import, the robot is made of 8 shapes, directly on the root of the document tree. The structure of the exported vrml file may change if groups are used. The shapes are ordered from the base to the tool. The last shape contains the axes of rotations of all robot axes. The correlation shape name – part name is given by (as for now (March 2011) FreeCAD doesn't import the names included in STEP files): +

      + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
      FreeCAD name + STEP name +
      TX40_HB +HORIZONTAL BASE CABLE OUTLET +
      TX40_HB001 + SHOULDER +
      TX40_HB002 + ARM +
      TX40_HB003 + ELBOW +
      TX40_HB004 + FOREARM +
      TX40_HB005 + WRIST +
      TX40_HB006 + TOOL FLANGE +
      TX40_HB007 + ? +
      +

      For this import, change the “Display Mode” of each shape, TX40_HB007 excepted, from “Flat Lines” to “Shaded” for the vrml export to look good. I also changed the colors to [245, 196, 0] and [204, 204, 204] to better correspond to Stäubli's yellow. Hide TX40_HB007 because it contains the axes of all joints and cannot be taken apart. +

      +

      Measure geometric characteristics

      +

      In order to build the Denavit-Hartenberg table (see Robot 6-Axis) and prepare the vrml file, you need to get characteristics of the robot. For now, the measurement tool of FreeCAD is not ready, you can use the axes included in TX40_HB007 (the co-ordinates are indicated on the bottom left when you point an object with the mouse) or you have to use the Python console to get some information about the geometry. Note that the DH-table is only required if you need to use the inverse kinematics, i.e. get the Cartesian coordinates or drive the robot with Cartesian coordinates. +The DH-table for this robot is the following (mm, deg and deg/s): +

      + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
      i + d + θ + r + α + θmin + θmax + Axis velocity +
      1 + 320 + q1 + 0 + -90 + -180 + 180 + 555 +
      2 + 35 + q2 - 90 + 225 + 0 + -125 + 125 + 475 +
      3 + 0 + q3 + 90 + 0 + 90 + -138 + 138 + 585 +
      4 + 225 + q4 + 0 + -90 + -270 + 270 + 1035 +
      5 + 0 + q5 + 0 + 90 + -120 + 133.5 + 1135 +
      6 + 65 + q6 + 0 + 0 + -270 + 270 + 1575 +
      +

      The csv file is then: +

      +
      a  , alpha, d  , theta, rotDir, maxAngle, minAngle, AxisVelocity
      +0  ,   -90, 320,     0,      1,      180,     -180, 555
      +225,     0,  35,   -90,      1,      125,     -125, 475
      +0  ,    90,   0,    90,      1,      138,     -138, 585
      +0  ,   -90, 225,     0,      1,      270,     -270, 1035
      +0  ,    90,   0,     0,      1,    133.5,     -120, 1135
      +0  ,     0,  65,     0,      1,      270,     -270, 1575
      +
      +

      Export to vrml

      +

      Export the document to a vrml file. The structure of the vrml file is the following: +

      +
       #VRML V2.0 utf8
      + 
      + 
      + Group {
      +   children 
      +     Group {
      +       children [ 
      +         Group {
      +         …
      + 
      +         },
      +           
      +         Group {
      +         …
      + 
      +         },
      +           
      +         Group {
      +         …
      + 
      +         },
      +           
      +         Group {
      +         …
      + 
      +         },
      +           
      +         Group {
      +         …
      + 
      +         },
      +           
      +         Group {
      +         …
      + 
      +         },
      +           
      +         Group {
      +         …
      + 
      +         },
      +           
      +         Group {
      +         …
      + 
      +         } ]
      + 
      +     }
      + 
      + }
      +

      You can notice that we have 8 independent groups corresponding to the 8 shapes. +

      +

      Preparation of the vrml file

      +

      All shapes in the vrml file are expressed in the base frame, independently from each other. For the Robot Simulation Workbench, we need to create a structure where a movement of a shape induces a movement of all shapes situated afterwards in the structure. The placement of the shapes will be relative to the preceding shape, so we need to include some translations from the absolute reference system to the relative one. The translations are described in the following picture: +

      Staeubli important points.png +

      With +

      +
      A=(0, 0, 168)
      +
      B=(0, 107.8, 320)
      +
      C=(0, 104.15, 545)
      +
      D=(0, 35, 601)
      +
      E=(0, 35, 770)
      +
      F=(0, 35, 835).
      +

      Let's take the example of axis 4 between ELBOW and FOREARM, situated at D=(xd, yd, zd). The anchor for the FreeCAD axis is +

      +
       "DEF FREECAD_AXIS4 Transform { rotation 0 1 0 0 children ["
      +

      This corresponds to a rotation about the y-axis. In the CAD model, the rotation is about the z-axis. Thus, we need to a rotation about the x-axis of <math>\pi</math> before the FreeCAD axis definition and of <math>-\pi</math> after it. Also, a translation of (-xd, -yd, -zd) is needed just before the Group corresponding to the definition of FOREARM to express it in the relative reference frame centered at D. This means that a translation of (xd, yd, zd) must be inserted before the first rotation. +At the end, the vrml-file from the definition of ELBOW to the definition of FOREARM looks like this: +

      +
             # ELBOW
      +       Group {
      +         … here comes the unmodified definition of ELBOW
      +   
      +       },
      +         
      +       Transform {
      +         translation 0 35 601
      +         rotation 1 0 0 1.5707963
      +         children
      +           DEF FREECAD_AXIS4 Transform { rotation 0 1 0 0 children
      +             Transform {
      +               rotation 1 0 0 -1.5707963
      +               children
      +                 Transform {
      +                   translation 0 -35 -601
      +                   children [
      +       # FOREARM  
      +       Group {
      +         ... here comes the unmodified definition of FOREARM
      +   
      +       },
      +At the end of the document, the appropriate closing brackets must be inserted:
        ]}}}},
      +

      for each of the 6 axes. Eventually, the document looks like this (I don't know if I can link the file here because of copyrights): +

      +
       #VRML V2.0 utf8
      +   
      +   
      + Group {
      +   children
      +   Group {
      +     children [ 
      +       # HORIZONTAL BASE CABLE OUTLET 
      +       Group {
      +           ... here comes the unmodified definition of HORIZONTAL BASE CABLE OUTLET
      +    
      +       },
      +         
      +       Transform {
      +         translation 0 0 168
      +         rotation 1 0 0 1.5707963
      +         children
      +           DEF FREECAD_AXIS1 Transform { rotation 0 1 0 0 children
      +             Transform {
      +               rotation 1 0 0 -1.5707963
      +               children
      +                 Transform {
      +                   translation 0 0 -168
      +                   children [
      +       # SHOULDER
      +       Group {
      +           ... here comes the unmodified definition of SHOULDER 
      +   
      +       },
      +         
      +       Transform {
      +         translation 0 107.8 320
      +         #rotation 0 0 1 0
      +         children
      +           DEF FREECAD_AXIS2 Transform { rotation 0 1 0 0 children
      +             Transform {
      +               #rotation 0 0 1 0
      +               children
      +                 Transform {
      +                   translation 0 -107.8 -320
      +                   children [
      +       # ARM  
      +       Group {
      +           ... here comes the unmodified definition of ARM 
      +   
      +       },
      +         
      +       Transform {
      +         translation 0 104.15 545
      +         #rotation 0 0 1 0
      +         children
      +           DEF FREECAD_AXIS3 Transform { rotation 0 1 0 0 children
      +             Transform {
      +               #rotation 0 0 1 0
      +               children
      +                 Transform {
      +                   translation 0 -104.15 -545
      +                   children [
      +       # ELBOW
      +       Group {
      +           ... here comes the unmodified definition of ELBOW
      +   
      +       },
      +         
      +       Transform {
      +         translation 0 35 601
      +         rotation 1 0 0 1.5707963
      +         children
      +           DEF FREECAD_AXIS4 Transform { rotation 0 1 0 0 children
      +             Transform {
      +               rotation 1 0 0 -1.5707963
      +               children
      +                 Transform {
      +                   translation 0 -35 -601
      +                   children [
      +       # FOREARM  
      +       Group {
      +           ... here comes the unmodified definition of FOREARM
      +   
      +       },
      +         
      +       Transform {
      +         translation 0 35 770
      +         #rotation 0 0 1 0
      +         children
      +           DEF FREECAD_AXIS5 Transform { rotation 0 1 0 0 children
      +             Transform {
      +               #rotation 0 0 1 0
      +               children
      +                 Transform {
      +                   translation 0 -35 -770
      +                   children [
      +       # WRIST
      +       Group {
      +           ... here comes the unmodified definition of WRIST
      +   
      +       },
      +         
      +       Transform {
      +         translation 0 35 835
      +         rotation 1 0 0 1.5707963
      +         children
      +           DEF FREECAD_AXIS6 Transform { rotation 0 1 0 0 children
      +             Transform {
      +               rotation 1 0 0 -1.5707963
      +               children
      +                 Transform {
      +                   translation 0 -35 -835
      +                   children [
      +       # TOOL FLANGE
      +       Group {
      +           ... here comes the unmodified definition of TOOL FRAME
      +   
      +       },
      +         
      +       Group {
      +           ... here comes the unmodified definition of TX40_HB007
      +   
      +       } # "]" was deleted from this line
      +     ]}}}},
      +     ]}}}},
      +     ]}}}},
      +     ]}}}},
      +     ]}}}},
      +     ]}}}},
      +     ] # this is the "]" deleted from the line above
      +   }
      + }
      +

      Here is a patch to obtain the vrml file suitable for robot simulation: +

      +
       7a8
      + >         # HORIZONTAL BASE CABLE OUTLET 
      + 95968a95970,95981
      + >         Transform {
      + >           translation 0 0 168
      + >           rotation 1 0 0 1.5707963
      + >           children
      + >             DEF FREECAD_AXIS1 Transform { rotation 0 1 0 0 children
      + >               Transform {
      + >                 rotation 1 0 0 -1.5707963
      + >                 children
      + >                   Transform {
      + >                     translation 0 0 -168
      + >                     children [
      + >         # SHOULDER
      + 128428a128442,128453
      + >         Transform {
      + >           translation 0 107.8 320
      + >           #rotation 0 0 1 0
      + >           children
      + >             DEF FREECAD_AXIS2 Transform { rotation 0 1 0 0 children
      + >               Transform {
      + >                 #rotation 0 0 1 0
      + >                 children
      + >                   Transform {
      + >                     translation 0 -107.8 -320
      + >                     children [
      + >         # ARM  
      + 206503a206529,206540
      + >         Transform {
      + >           translation 0 104.15 545
      + >           #rotation 0 0 1 0
      + >           children
      + >             DEF FREECAD_AXIS3 Transform { rotation 0 1 0 0 children
      + >               Transform {
      + >                 #rotation 0 0 1 0
      + >                 children
      + >                   Transform {
      + >                     translation 0 -104.15 -545
      + >                     children [
      + >         # ELBOW
      + 267111a267149,267160
      + >         Transform {
      + >           translation 0 35 601
      + >           rotation 1 0 0 1.5707963
      + >           children
      + >             DEF FREECAD_AXIS4 Transform { rotation 0 1 0 0 children
      + >               Transform {
      + >                 rotation 1 0 0 -1.5707963
      + >                 children
      + >                   Transform {
      + >                     translation 0 -35 -601
      + >                     children [
      + >         # FOREARM  
      + 417854a417904,417915
      + >         Transform {
      + >           translation 0 35 770
      + >           #rotation 0 0 1 0
      + >           children
      + >             DEF FREECAD_AXIS5 Transform { rotation 0 1 0 0 children
      + >               Transform {
      + >                 #rotation 0 0 1 0
      + >                 children
      + >                   Transform {
      + >                     translation 0 -35 -770
      + >                     children [
      + >         # WRIST
      + 422053a422115,422126
      + >         Transform {
      + >           translation 0 35 835
      + >           rotation 1 0 0 1.5707963
      + >           children
      + >             DEF FREECAD_AXIS6 Transform { rotation 0 1 0 0 children
      + >               Transform {
      + >                 rotation 1 0 0 -1.5707963
      + >                 children
      + >                   Transform {
      + >                     translation 0 -35 -835
      + >                     children [
      + >         # TOOL FLANGE
      + 435627c435700,435707
      + <         } ]
      + ---
      + >         } 
      + >       ]}}}},
      + >       ]}}}},
      + >       ]}}}},
      + >       ]}}}},
      + >       ]}}}},
      + >       ]}}}},
      + >       ]
      +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Vector_API.html b/localwiki/Vector_API.html new file mode 100644 index 0000000..25eb349 --- /dev/null +++ b/localwiki/Vector_API.html @@ -0,0 +1,193 @@ +Vector API

      Vector API

      + +

      Vectors are used everywhere in FreeCAD. +

      Example: +

      +
      v=FreeCAD.Vector()
      +v=FreeCAD.Vector(1,0,0)
      +v=FreeCAD.Base.Vector()
      +v2 = FreeCAD.Vector(3,2,-5)
      +v3 = v.add(v2)
      +print v3.Length 
      +


      +

      +
      +
      Property.png Length
      +
      +

      Returns: returns the length of the vector. +

      +
      +
      +


      +

      +
      +
      Method.png add ( Vector )
      +
      +

      Description: adds another vector to this one. +

      Returns: vector +

      +
      +
      +


      +

      +
      +
      Method.png cross ( Vector )
      +
      +

      Description: the crossproduct between this vector and another. +

      Returns: vector +

      +
      +
      +


      +

      +
      +
      Method.png distanceToLine ( Vector1,Vector2 )
      +
      +

      Description: the distance between the vector and a line through Vector1 in direction Vector2. +

      Returns: float +

      +
      +
      +


      +

      +
      +
      Method.png distanceToLineSegment ( Vector1,Vector2 )
      +
      +

      Description: a vector to the closest point on a line segment from Vector1 to Vector2. +

      Returns: vector +

      +
      +
      +


      +

      +
      +
      Method.png distanceToPlane ( Vector1,Vector2 )
      +
      +

      Description: the distance between the vector and a plane defined by a point and a normal. +

      Returns: float +

      +
      +
      +


      +

      +
      +
      Method.png dot ( Vector )
      +
      +

      Description: the dot product between 2 vectors. +

      Returns: float +

      +
      +
      +


      +

      +
      +
      Method.png getAngle ( Vector )
      +
      +

      Description: the angle in radians between this vector and another. +

      Returns: float +

      +
      +
      +


      +

      +
      +
      Method.png multiply ( Float )
      +
      +

      Description: multiplies (uniform scale) a vector by the given factor. +

      Returns: nothing +

      +
      +
      +


      +

      +
      +
      Method.png normalize ( )
      +
      +

      Description: normalizes a vector (sets its length to 1.0). +

      Returns: nothing +

      +
      +
      +


      +

      +
      +
      Method.png projectToLine ( Vector1,Vector2 )
      +
      +

      Description: projects the vector on a line through Vector1 in direction Vector2. +

      Returns: nothing +

      +
      +
      +


      +

      +
      +
      Method.png projectToPlane ( Vector1,Vector2 )
      +
      +

      Description: projects the vector on a plane defined by a point (Vector1) and a normal (Vector2). +

      Returns: nothing +

      +
      +
      +


      +

      +
      +
      Method.png scale ( Float,Float,Float )
      +
      +

      Description: Same as multiply but lets specify different values for x, y and z directions. (non-uniform scale) +

      Returns: nothing +

      +
      +
      +


      +

      +
      +
      Method.png sub ( Vector )
      +
      +

      Description: subtracts another vector from this one. +

      Returns: vector +

      +
      +
      +


      +

      +
      +
      Property.png x
      +
      +

      Returns: the x coordinate of a vector. +

      +
      +
      +


      +

      +
      +
      Property.png y
      +
      +

      Returns: the y coordinate of a vector. +

      +
      +
      +


      +

      +
      +
      Property.png z
      +
      +

      Returns: the z coordinate of a vector. +

      +
      +
      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/VerticalSample.png b/localwiki/VerticalSample.png new file mode 100644 index 0000000..679dd25 Binary files /dev/null and b/localwiki/VerticalSample.png differ diff --git a/localwiki/Video_tutorials.html b/localwiki/Video_tutorials.html new file mode 100644 index 0000000..a37ea75 --- /dev/null +++ b/localwiki/Video_tutorials.html @@ -0,0 +1,64 @@ +Video tutorials

      Video tutorials

      + +

      Below is a collection of video tutorials made by FreeCAD users and developers. Check out the Tutorials and videos forum for more links. +

      +
      This documentation page is in need of updating. The video list needs to be reviewed, new videos added, dead links removed. Please help us update this page!
      +


      +

      + + +

      Part design

      +

      Videos that go through modeling of various parts using workbenches such as Part, PartDesign and Sketcher. Some of them were recorded a long time ago, but are still relevant. +

      + + +
      • Cad1919 Tutorials: several playlists starting with downloading and installing 0.15.4671 on Windows 8, FreeCAD Part Design / Sketcher basics, and moving on to more advanced models. The GUI is in Chinese or Japanese but the videos have graphics added so they can still be followed by someone unfamiliar with cad1919's language.
      + + + + + + +

      Architectural design

      + + + + + +

      Computer-Aided Manufacturing (CAM)

      + +

      Other

      + + +

      Outdated Videos

      +

      These videos were made many years ago, and may not be relevant anymore. +

      + + + + +


      +

      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/View-C3P.png b/localwiki/View-C3P.png new file mode 100644 index 0000000..50c1449 Binary files /dev/null and b/localwiki/View-C3P.png differ diff --git a/localwiki/View-Front.png b/localwiki/View-Front.png new file mode 100644 index 0000000..e4787f3 Binary files /dev/null and b/localwiki/View-Front.png differ diff --git a/localwiki/View-Left.png b/localwiki/View-Left.png new file mode 100644 index 0000000..64a17ce Binary files /dev/null and b/localwiki/View-Left.png differ diff --git a/localwiki/View-Top.png b/localwiki/View-Top.png new file mode 100644 index 0000000..c98f3bd Binary files /dev/null and b/localwiki/View-Top.png differ diff --git a/localwiki/View-axonometric.svg b/localwiki/View-axonometric.svg new file mode 100644 index 0000000..5f849c3 --- /dev/null +++ b/localwiki/View-axonometric.svg @@ -0,0 +1,212 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/View-bottom.svg b/localwiki/View-bottom.svg new file mode 100644 index 0000000..73a0903 --- /dev/null +++ b/localwiki/View-bottom.svg @@ -0,0 +1,210 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/View-front.svg b/localwiki/View-front.svg new file mode 100644 index 0000000..243bfa6 --- /dev/null +++ b/localwiki/View-front.svg @@ -0,0 +1,247 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + diff --git a/localwiki/View-fullscreen.svg b/localwiki/View-fullscreen.svg new file mode 100644 index 0000000..34589cc --- /dev/null +++ b/localwiki/View-fullscreen.svg @@ -0,0 +1,681 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + Jakub Steiner + + + http://jimmac.musichall.cz + + View Fullscreen + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/View-isometric.svg b/localwiki/View-isometric.svg new file mode 100644 index 0000000..0409e1e --- /dev/null +++ b/localwiki/View-isometric.svg @@ -0,0 +1,208 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/View-left.svg b/localwiki/View-left.svg new file mode 100644 index 0000000..8c309dc --- /dev/null +++ b/localwiki/View-left.svg @@ -0,0 +1,231 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/View-measurement.svg b/localwiki/View-measurement.svg new file mode 100644 index 0000000..69b18f6 --- /dev/null +++ b/localwiki/View-measurement.svg @@ -0,0 +1,538 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/View-perspective.svg b/localwiki/View-perspective.svg new file mode 100644 index 0000000..0a4ac8b --- /dev/null +++ b/localwiki/View-perspective.svg @@ -0,0 +1,192 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + diff --git a/localwiki/View-rear.svg b/localwiki/View-rear.svg new file mode 100644 index 0000000..d6f32d0 --- /dev/null +++ b/localwiki/View-rear.svg @@ -0,0 +1,231 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/View-refresh.svg b/localwiki/View-refresh.svg new file mode 100644 index 0000000..de17450 --- /dev/null +++ b/localwiki/View-refresh.svg @@ -0,0 +1,659 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + Jakub Steiner + + + http://jimmac.musichall.cz + + + + + reload + refresh + view + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/View-right.svg b/localwiki/View-right.svg new file mode 100644 index 0000000..217123b --- /dev/null +++ b/localwiki/View-right.svg @@ -0,0 +1,247 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + diff --git a/localwiki/View-rotate-left.svg b/localwiki/View-rotate-left.svg new file mode 100644 index 0000000..5743012 --- /dev/null +++ b/localwiki/View-rotate-left.svg @@ -0,0 +1,172 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + Mon Oct 10 13:44:52 2011 +0000 + + + [wmayer] + + + + + FreeCAD LGPL2+ + + + + + FreeCAD + + + FreeCAD/src/Mod/Draft/Resources/icons/Draft_Rotate.svg + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + [agryson] Alexander Gryson, [agryson] Alexander Gryson, [agryson] Alexander Gryson + + + An arrow in a circular shape with the head curving towards the tail + + + arrow + curved + refresh + rotate + + + arrow-ccw + https://www.gnu.org/copyleft/lesser.html + + + + diff --git a/localwiki/View-rotate-right.svg b/localwiki/View-rotate-right.svg new file mode 100644 index 0000000..9f30cb4 --- /dev/null +++ b/localwiki/View-rotate-right.svg @@ -0,0 +1,172 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + Mon Oct 10 13:44:52 2011 +0000 + + + [wmayer] + + + + + FreeCAD LGPL2+ + + + + + FreeCAD + + + FreeCAD/src/Mod/Draft/Resources/icons/Draft_Rotate.svg + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + [agryson] Alexander Gryson + + + An arrow in a circular shape with the head curving towards the tail + + + arrow + curved + refresh + rotate + + + arrow-cw + https://www.gnu.org/copyleft/lesser.html + + + + diff --git a/localwiki/View-select.svg b/localwiki/View-select.svg new file mode 100644 index 0000000..44535e7 --- /dev/null +++ b/localwiki/View-select.svg @@ -0,0 +1,140 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + + + + + + diff --git a/localwiki/View-top.svg b/localwiki/View-top.svg new file mode 100644 index 0000000..f941238 --- /dev/null +++ b/localwiki/View-top.svg @@ -0,0 +1,204 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + diff --git a/localwiki/View-unselectable.svg b/localwiki/View-unselectable.svg new file mode 100644 index 0000000..d8cd2e7 --- /dev/null +++ b/localwiki/View-unselectable.svg @@ -0,0 +1,140 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + + + + + + diff --git a/localwiki/View-zoom-all.svg b/localwiki/View-zoom-all.svg new file mode 100644 index 0000000..7ab0296 --- /dev/null +++ b/localwiki/View-zoom-all.svg @@ -0,0 +1,738 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + Martin Ruskov + + + http://commons.wikimedia.org/wiki/Tango_icon + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/View-zoom-border.svg b/localwiki/View-zoom-border.svg new file mode 100644 index 0000000..5e53dc9 --- /dev/null +++ b/localwiki/View-zoom-border.svg @@ -0,0 +1,636 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + Martin Ruskov + + + http://commons.wikimedia.org/wiki/Tango_icon + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/View-zoom-in.svg b/localwiki/View-zoom-in.svg new file mode 100644 index 0000000..c5ab32d --- /dev/null +++ b/localwiki/View-zoom-in.svg @@ -0,0 +1,875 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + Martin Ruskov + + + http://commons.wikimedia.org/wiki/Tango_icon + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/View-zoom-out.svg b/localwiki/View-zoom-out.svg new file mode 100644 index 0000000..fcbe93b --- /dev/null +++ b/localwiki/View-zoom-out.svg @@ -0,0 +1,855 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + Martin Ruskov + + + http://commons.wikimedia.org/wiki/Tango_icon + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/View-zoom-selection.svg b/localwiki/View-zoom-selection.svg new file mode 100644 index 0000000..0620854 --- /dev/null +++ b/localwiki/View-zoom-selection.svg @@ -0,0 +1,753 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + Martin Ruskov + + + http://commons.wikimedia.org/wiki/Tango_icon + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/View.svg b/localwiki/View.svg new file mode 100644 index 0000000..bf549e8 --- /dev/null +++ b/localwiki/View.svg @@ -0,0 +1,178 @@ + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + [WandererFan] + + + TechDraw_Tree_View + 2016-04-27 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/TechDraw/Gui/Resources/icons/TechDraw_Tree_View.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + dashed line + monotone + + + + + + + + + + + + + + + diff --git a/localwiki/ViewObject_API.html b/localwiki/ViewObject_API.html new file mode 100644 index 0000000..12a94c3 --- /dev/null +++ b/localwiki/ViewObject_API.html @@ -0,0 +1,252 @@ +ViewObject API

      ViewObject API

      + +

      When the GUI is up, each object in the FreeCAD document has an associated ViewObject, that resides in the FreeCADGui document counterpart. A view object can be retrieved by two ways. Example: +

      +
      myViewObj = FreeCAD.ActiveDocument.myObjectName.ViewObject
      +myViewObj = FreeCADGui.ActiveDocument.myObjectName
      +print myViewObj.IV 
      +


      +

      +
      +
      Property.png Annotation
      +
      +

      Returns: the annotation node of a ViewObject +

      +
      +
      +


      +

      +
      +
      Property.png BoundingBox
      +
      +

      Returns: the bounding box +

      +
      +
      +


      +

      +
      +
      Property.png Content
      +
      +

      Returns: an XML representation of a ViewObject's properties +

      +
      +
      +


      +

      +
      +
      Property.png DisplayMode
      +
      +

      Returns: the current display mode +

      +
      +
      +


      +

      +
      +
      Property.png IV
      +
      +

      Returns: an Inventor representation of the ViewObject +

      +
      +
      +


      +

      +
      +
      Property.png Object
      +
      +

      Returns: the associated FreeCAD Document Object of this ViewObject +

      +
      +
      +


      +

      +
      +
      Property.png PropertiesList
      +
      +

      Returns: a list of properties of this ViewObject +

      +
      +
      +


      +

      +
      +
      Property.png RootNode
      +
      +

      Returns: the Inventor node of this ViewObject (pivy.coin object) +

      +
      +
      +


      +

      +
      +
      Property.png Selectable
      +
      +

      Returns: True if the object is selectable +

      +
      +
      +


      +

      +
      +
      Property.png Type
      +
      +

      Returns: the type of this ViewObject +

      +
      +
      +


      +

      +
      +
      Property.png Visibility
      +
      +

      Returns: True if the viewObject is visible +

      +
      +
      +


      +

      +
      +
      Method.png getAllDerivedFrom ( )
      +
      +

      Description: +

      Returns: all descentences of this object +

      +
      +
      +


      +

      +
      +
      Method.png getDocumentationOfProperty ( )
      +
      +

      Description: +

      Returns: the documentation string of the property of this class. +

      +
      +
      +


      +

      +
      +
      Method.png getGroupOfProperty ( )
      +
      +

      Description: +

      Returns: the name of the group which the property belongs to in this class. The properties sorted in differnt named groups for convenience. +

      +
      +
      +


      +

      +
      +
      Method.png getPropertyByName ( )
      +
      +

      Description: +

      Returns: the value of a named property. +

      +
      +
      +


      +

      +
      +
      Method.png getTypeOfProperty ( )
      +
      +

      Description: +

      Returns: the type of a named property. This can be (Hidden,ReadOnly,Output) or any combination. +

      +
      +
      +


      +

      +
      +
      Method.png hide ( )
      +
      +

      Description: Hides the object. +

      Returns: +

      +
      +
      +


      +

      +
      +
      Method.png isDerivedFrom ( string )
      +
      +

      Description: Checks if this object is derived from the given object type +

      Returns: True if given type is a father +

      +
      +
      +


      +

      +
      +
      Method.png isVisible ( )
      +
      +

      Description: Checks if the object is visible +

      Returns: a boolean +

      +
      +
      +


      +

      +
      +
      Method.png listDisplayModes ( )
      +
      +

      Description: Shows a list of all display modes +

      Returns: a list +

      +
      +
      +


      +

      +
      +
      Method.png setTransformation ( coin.SoTransform )
      +
      +

      Description: Sets a transformation on the Inventor node +

      Returns: nothing +

      +
      +
      +


      +

      +
      +
      Method.png show ( )
      +
      +

      Description: Shows the object if hidden +

      Returns: nothing +

      +
      +
      +


      +

      +
      +
      Method.png toString ( )
      +
      +

      Description: +

      Returns: a string representation of the Inventor node +

      +
      +
      +


      +

      +
      +
      Method.png update ( )
      +
      +

      Description: Updates the view representation of the object +

      Returns: +

      +
      +
      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/ViewOfBox2.png b/localwiki/ViewOfBox2.png new file mode 100644 index 0000000..8b7d86f Binary files /dev/null and b/localwiki/ViewOfBox2.png differ diff --git a/localwiki/ViewSection.png b/localwiki/ViewSection.png new file mode 100644 index 0000000..43b44aa Binary files /dev/null and b/localwiki/ViewSection.png differ diff --git a/localwiki/WF_centerObjectsPlanes.png b/localwiki/WF_centerObjectsPlanes.png new file mode 100644 index 0000000..16288ee Binary files /dev/null and b/localwiki/WF_centerObjectsPlanes.png differ diff --git a/localwiki/WF_wf.png b/localwiki/WF_wf.png new file mode 100644 index 0000000..2f63dd8 Binary files /dev/null and b/localwiki/WF_wf.png differ diff --git a/localwiki/Web-browser.svg b/localwiki/Web-browser.svg new file mode 100644 index 0000000..cb1cb28 --- /dev/null +++ b/localwiki/Web-browser.svg @@ -0,0 +1,1462 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + Globe + + + Jakub Steiner + + + + + Tuomas Kuosmanen + + + + http://jimmac.musichall.cz + + + globe + international + web + www + internet + network + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Web-home.svg b/localwiki/Web-home.svg new file mode 100644 index 0000000..4d8df54 --- /dev/null +++ b/localwiki/Web-home.svg @@ -0,0 +1,482 @@ + +image/svg+xmlGo HomeJakub Steinerhttp://jimmac.musichall.czhomereturngodefaultuserdirectoryTuomas Kuosmanen + + + + + + + + + + + + + + + + + \ No newline at end of file diff --git a/localwiki/Web-next.svg b/localwiki/Web-next.svg new file mode 100644 index 0000000..c213be6 --- /dev/null +++ b/localwiki/Web-next.svg @@ -0,0 +1,867 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + Jakub Steiner + + + http://jimmac.musichall.cz + + + + + go + previous + left + arrow + pointer + < + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Web-previous.svg b/localwiki/Web-previous.svg new file mode 100644 index 0000000..eb83b1a --- /dev/null +++ b/localwiki/Web-previous.svg @@ -0,0 +1,867 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + Jakub Steiner + + + http://jimmac.musichall.cz + + Go Previous + + + go + previous + left + arrow + pointer + < + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Web-refresh.svg b/localwiki/Web-refresh.svg new file mode 100644 index 0000000..f00daa6 --- /dev/null +++ b/localwiki/Web-refresh.svg @@ -0,0 +1,659 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + Jakub Steiner + + + http://jimmac.musichall.cz + + View Refresh + + + reload + refresh + view + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Web-sketchfab.svg b/localwiki/Web-sketchfab.svg new file mode 100644 index 0000000..8049efa --- /dev/null +++ b/localwiki/Web-sketchfab.svg @@ -0,0 +1,77 @@ + + + + + + + + + + image/svg+xml + + + + + + + + + + + + + + diff --git a/localwiki/Web-stop.svg b/localwiki/Web-stop.svg new file mode 100644 index 0000000..f378b03 --- /dev/null +++ b/localwiki/Web-stop.svg @@ -0,0 +1,343 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + Stop + 2005-10-16 + + + Andreas Nilsson + + + + + stop + halt + error + + + + + + Jakub Steiner + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Web-zoom-in.svg b/localwiki/Web-zoom-in.svg new file mode 100644 index 0000000..a866c6a --- /dev/null +++ b/localwiki/Web-zoom-in.svg @@ -0,0 +1,452 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + Add + 2006-01-04 + + + Andreas Nilsson + + + http://tango-project.org + + + add + plus + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Web-zoom-out.svg b/localwiki/Web-zoom-out.svg new file mode 100644 index 0000000..162e090 --- /dev/null +++ b/localwiki/Web-zoom-out.svg @@ -0,0 +1,452 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + 2006-01-04 + + + Andreas Nilsson + + + http://tango-project.org + + + add + plus + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Web.png b/localwiki/Web.png new file mode 100644 index 0000000..c74603e Binary files /dev/null and b/localwiki/Web.png differ diff --git a/localwiki/WebTools_Workbench.html b/localwiki/WebTools_Workbench.html new file mode 100644 index 0000000..edd4479 --- /dev/null +++ b/localwiki/WebTools_Workbench.html @@ -0,0 +1,24 @@ +WebTools Workbench

      WebTools Workbench

      + +

      An external workbench containing a series of tools to communicate with web services from within FreeCAD. +This is an external workbench hosted at https://github.com/yorikvanhavre/WebTools +

      + +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/WebWorkbench.svg b/localwiki/WebWorkbench.svg new file mode 100644 index 0000000..cb1cb28 --- /dev/null +++ b/localwiki/WebWorkbench.svg @@ -0,0 +1,1462 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + Globe + + + Jakub Steiner + + + + + Tuomas Kuosmanen + + + + http://jimmac.musichall.cz + + + globe + international + web + www + internet + network + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Web_Sketchfab.html b/localwiki/Web_Sketchfab.html new file mode 100644 index 0000000..7a4284b --- /dev/null +++ b/localwiki/Web_Sketchfab.html @@ -0,0 +1,78 @@ +Web Sketchfab

      Web Sketchfab

      + +
      + + + + + + + + + + + + + + + + + + + +
      +

      Web Sketchfab.png Web Sketchfab

      +
      Menu location +
      Web → Sketchfab +
      Workbenches +
      Web +
      Default shortcut +
      +
      See also +
      +

      + +
      +


      +

      +

      Description

      +

      This tool allows you to export and upload objects to your SketchFab account available in version 0.17 +


      +Sketchfab exporter.jpg +

      +

      How to use

      +
      1. Make yourself an account on SketchFab if you don't have one yet. Free accounts are just fine, paid accounts add more features like the possibility to have private models and bigger maximum upload sizes
      2. +
      3. Prepare a model you wish to upload
      4. +
      5. Click on Web Sketchfab.png from the main toolbar in the Web Workbench
      6. +
      7. Fill in the fields. Name and API key are mandatory
      8. +
      9. Click the "Upload" button
      +

      Options

      +
      • You need a Sketchfab API key for this exporter to be able to connect to your sketchfab account. By pressing the "Obtain" button, you will be directed to your Sketchfab settings page, where that API key (which is unique to your account), is given. Copy the key and paste it in the "API key" field in the exporter. This value will be stored by FreeCAD so you only need to do it once
      • +
      • The name field is mandatory, the others can be left blank.
      • +
      • The exporter proposes several different export formats. The best on for you depends on the kind of model and result you wish to obtain, it is recommended to test what works best for you. Generally, OBJ + MTL will give you a better control over materials, while IV (OpenInventor) will give a result that is more similar to what you see in the FreeCAD 3D view.
      • +
      • Once your model is uploaded, Sketchfab offers a pretty advanced interface where you can further configure materials, lighting and environment.
      • +
      • When you press the "Upload button", after the upload finished, if everything went well, the button will turn into a "View your model online" button, which, when clicked, will take you directly to the model page on Sketchfab.
      • +
      • Some formats, like OBJ, are interpreted differently by Sketchfab and FreeCAD. FreeCAD considers the Z axis to point upwards, while Sketchfab considers it points towards the person behind the screen. To remedy this, after the upload is finished, the exporter will use the Sketchfab API to rotate the model to its correct position. If this operation fails, you will be warned, but your model will still be correctly uploaded. You can rotate it manually in the Sketchfab interface, by pressing the right arrow besides the"X" axis in the model orientation tab.
      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Web_Workbench.html b/localwiki/Web_Workbench.html new file mode 100644 index 0000000..d249609 --- /dev/null +++ b/localwiki/Web_Workbench.html @@ -0,0 +1,20 @@ +Web Workbench

      Web Workbench

      + +

      The Web Workbench provides a web browser window within FreeCAD,based on WebKit. From this browser you are able to navigate the web, log into websites (cookies are supported). The web workbench is also a base for developing web-related tools in FreeCAD. The web browser provides a couple of standard navigation buttons such as stop, reload, previous and next page. +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Wedge_examples.png b/localwiki/Wedge_examples.png new file mode 100644 index 0000000..eeadbc5 Binary files /dev/null and b/localwiki/Wedge_examples.png differ diff --git a/localwiki/WhatsThis.svg b/localwiki/WhatsThis.svg new file mode 100644 index 0000000..2c0cf9f --- /dev/null +++ b/localwiki/WhatsThis.svg @@ -0,0 +1,204 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + diff --git a/localwiki/Whiffle_Ball_tutorial.html b/localwiki/Whiffle_Ball_tutorial.html new file mode 100644 index 0000000..c60dcce --- /dev/null +++ b/localwiki/Whiffle_Ball_tutorial.html @@ -0,0 +1,201 @@ +Whiffle Ball tutorial

      Whiffle Ball tutorial

      + +
      + + + + + + + + + + + + + + + + + + + + + + + + + + + +
      +

      Base ExampleCommandModel.png Tutorial

      +
      Topic +
      Whiffle Ball (Part Module) +
      Level +
      Beginner +
      Time to complete +
      +
      Author +
      r-frank +
      FreeCAD version +
      0.16.6703 +
      Example File(s) +
      [1] Whiffle Ball +

      + +
      +


      +

      +

      Introduction

      +

      This tutorial is here to teach you how to use the Part Module. +You will practice: +

      +
      • inserting primitives
      • +
      • changing values of primitives
      • +
      • using placement
      • +
      • doing boolean operations
      +


      +Tip: If you selected something wrong or just want to quickly de-select everything,
      +just click (Navigation-Style OpenInventor: CTRL-Click) in empty space in the 3D-view. +

      +

      Final model

      +

      Tutorial WhiffleBall.jpg +

      +

      Setting up the basic shape

      +
      1. Switch to the Part Module
      2. +
      3. Create a new document by clicking on File New
      4. +
      5. Insert box by clicking on Part Box.png
      6. +
      7. Make sure the box ("cube") is selected in tree view
      8. +
      9. Change the dimensions of the box (see data-tab) to +
        1. Length= 90 mm
        2. +
        3. Width= 90 mm
        4. +
        5. Heigth= 90 mm
      10. +
      11. Click into the value field of placement-row in data-tab so that ... appears on right side
      12. +
      13. Click on ... to change the placement of the box +
        1. X: -45 mm
        2. +
        3. Y: -45 mm
        4. +
        5. Z: -45 mm
      14. +
      15. Click on OK to close dialog
      16. +
      17. Insert box ("cube001") by clicking on Part Box.png
      18. +
      19. Make sure the box ("cube001") is selected in tree view
      20. +
      21. Change the dimensions of the box ("cube001") (see data-tab) to +
        1. Length= 80 mm
        2. +
        3. Width= 80 mm
        4. +
        5. Heigth= 80 mm
      22. +
      23. Change the placement of the box ("cube001") to +
        1. X: -40 mm
        2. +
        3. Y: -40 mm
        4. +
        5. Z: -40 mm
      24. +
      25. Click Part Cylinder.png to insert a cylinder ("cylinder")
      26. +
      27. Make sure the cylinder ("cylinder") is selected in tree view
      28. +
      29. Change radius of cylinder to be 27,5 mm, change height to be 120 mm
      30. +
      31. Change placement values of "cylinder" to be +
        1. X: 0 mm
        2. +
        3. Y: 0 mm
        4. +
        5. Z: -60 mm
      32. +
      33. Click Part Cylinder.png to insert a cylinder ("cylinder001")
      34. +
      35. Change radius of "cylinder001" to be 27,5 mm, change height to be 120 mm
      36. +
      37. Choose Edit > Duplicate selection from the top menu to get another cylinder ("cylinder002")
      38. +
      39. Make sure "cylinder001" is selected in tree view
      40. +
      41. Change placement values of "cylinder001" to be +
        1. Y: 60 mm
        2. +
        3. Rotation axis with angle
        4. +
        5. Axis: X
        6. +
        7. Angle: 90°
      42. +
      43. Click on OK to apply values and close dialog
      44. +
      45. Make sure "cylinder002" is selected in tree view
      46. +
      47. Change placement values of "cylinder001" to be +
        1. X: -60 mm
        2. +
        3. Rotation axis with angle
        4. +
        5. Axis: Y
        6. +
        7. Angle: 90°
      48. +
      49. Click on OK to apply values and close dialog
      50. +
      51. Click on View-axometric.png to change to axometric view
      52. +
      53. Click on View-zoom-all.png to zoom to fit all
      54. +
      55. Select "cube001", "cylinder", "cylinder001" and "cylinder002" and fuse them by clicking Part Fuse.png
      56. +
      57. Select "cube" and "fusion", but make sure, that "cube" is selected FIRST
      58. +
      59. Apply a boolean cut by clicking Part Cut.png
      60. +
      61. The finished basic shape should look like this:
      +

      Tutorial WhiffleBall BasicShape.jpg +

      +

      Cutting the corners part 1

      +
      1. Insert box ("cube002") by clicking on Part Box.png
      2. +
      3. Change the dimensions of the box ("cube002") (see data-tab) to +
        1. Length= 140 mm
        2. +
        3. Width= 112 mm
        4. +
        5. Heigth= 112 mm
      4. +
      5. Change the placement of the box ("cube002") to +
        1. X: -70 mm
        2. +
        3. Y: -56 mm
        4. +
        5. Z: -56 mm
      6. +
      7. Insert box ("cube003") by clicking on Part Box.png
      8. +
      9. Change the dimensions of the box ("cube003") (see data-tab) to +
        1. Length= 180 mm
        2. +
        3. Width= 180 mm
        4. +
        5. Heigth= 180 mm
      10. +
      11. Change the placement of the box ("cube003") to +
        1. X: -90 mm
        2. +
        3. Y: -90 mm
        4. +
        5. Z: -90 mm
      12. +
      13. Make sure "cube002" is selected in tree view, otherwise select it
      14. +
      15. Choose Edit > Duplicate selection from the top menu to get another box ("cube004")
      16. +
      17. Make sure "cube003" is selected in tree view, otherwise select it
      18. +
      19. Choose Edit > Duplicate selection from the top menu to get another box ("cube005")
      20. +
      21. Select "cube003" and "cube002", but make sure, that "cube003" is selected FIRST
      22. +
      23. Activate menu to change placement
      24. +
      25. Tick option "Apply incremental changes to object placement", notice that all values are reset ...
      26. +
      27. Choose "Rotation: X-Axis" and "Angle: 45°" and click on Apply
      28. +
      29. Choose "Rotation: Z-Axis" and "Angle: 45°" and click on Apply
      30. +
      31. Click on OK to close the dialog
      32. +
      33. Apply a boolean cut by clicking Part Cut.png, the resulting object will be named "cut001"
      +

      Cutting the corners part 2

      +
      1. Select "cube005" and "cube004", but make sure, that "cube005" is selected FIRST
      2. +
      3. Activate menu to change placement
      4. +
      5. Tick option "Apply incremental changes to object placement", notice that all values are resetted ...
      6. +
      7. Choose "Rotation: X-Axis" and "Angle: 45°" and click on Apply
      8. +
      9. Choose "Rotation: Z-Axis" and "Angle: -45°" and click on Apply
      10. +
      11. Click on OK to close the dialog
      12. +
      13. Apply a boolean cut by clicking Part Cut.png, the resulting object will be named "cut002"
      14. +
      15. Click on View-axometric.png to change to axometric view
      16. +
      17. Click on View-zoom-all.png to zoom to fit all
      +

      If everything went well your model should look like this: +

      Tutorial WhiffleBall UnfinishedShape.jpg +

      +

      Finishing the model

      +
      1. Select "cut" and "cut001", but make sure, that "cut" is selected FIRST
      2. +
      3. Apply a boolean cut by clicking Part Cut.png, the resulting object will be named "cut003"
      4. +
      5. Select "cut003" and "cut002", but make sure, that "cut003" is selected FIRST
      6. +
      7. Apply a boolean cut by clicking Part Cut.png, the resulting object will be named "cut004"
      8. +
      9. Click on View-axometric.png to change to axometric view
      10. +
      11. Click on View-zoom-all.png to zoom to fit all
      12. +
      13. Don't forget to save your file ...
      +

      Congratulations! You just finished this tutorial succesfully! +


      +

      +
      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Wikihouse_porting_tutorial.html b/localwiki/Wikihouse_porting_tutorial.html new file mode 100644 index 0000000..aa187b5 --- /dev/null +++ b/localwiki/Wikihouse_porting_tutorial.html @@ -0,0 +1,161 @@ +Wikihouse porting tutorial

      Wikihouse porting tutorial

      + +
      + + + + + + + + + + + + + + + + + + + + + + + + + + + +
      +

      Base ExampleCommandModel.png Tutorial

      +
      Topic +
      Wikihouse porting tutorial +
      Level +
      Intermediate/Advanced +
      Time to complete +
      60 minutes +
      Author +
      +
      FreeCAD version +
      +
      Example File(s) +
      +

      + +
      +


      +

      +

      Introduction

      +

      This tutorial will show you how to convert SketchUp files used by the WikiHouse project to FreeCAD, making use of the Arch Panel tools in FreeCAD. The result is a full copy of the original SketchUp file, except that it has become fully parametric. The level of parametricism of the final file depends on the work you spend on it, as explained below. But it is totally possible to do things step by step, and rebuild the Wikihouse file rather quickly, and leave the more lengthy conversion of base profiles to sketches for later. +

      This tutorial will require intermediate knowledge of FreeCAD, that is, you are able to find your way between the different workbenches and tools, are already able to model simple objects, and, above all, are comfortable with Draft Move and Draft Rotate. It will use mostly Draft and Arch tools, but knowledge of the Sketcher will become necessary when converting the base profiles to sketches. +

      Since the Wikihouse project is open by nature, files are easy to find on the project website, but also on the SketchUp 3D Warehouse or in the project's github repositories. The preferred format used by the project is Sketchup, so most of the files you'll find are in that format. +

      In the following tutorial we used the Chassis file from Wikihouse's Microhouse subproject. +

      +

      Preparing the Sketchup file

      +

      The first thing you will need to do is to open the file in SketchUp and delete everything you don't want to export. We will only export one section of the Microhouse, so everything else must be deleted. +

      Arch Wikihouse 05.jpg +

      The Wikihouse elements, in SketchUp, are made in a specific way: By adding small "pieces" together in order to create the different components: +

      Arch Wikihouse 06.jpg +

      This is not how we will proceed in FreeCAD. Since one of the most powerful features of FreeCAD is Constrained Sketches, we'd better take advantage of this, and base all our Wikihouse elements on Sketches. That way, modifying any part can be done in the Sketcher, which is much more comfortable. +

      In order to turn our SketchUp objects into FreeCAD sketches, which can then be used to create Arch Panel objects, we need to extract one, flat face from each wikihouse piece. The thickness will be re-added later, in FreeCAD, directly in the Arch Panel properties. This way, we will keep it parametric as well. To turn each wikihouse component into a single, flat face, enter each component by double-clicking it, then select each sub-component, and right-click → Explode, until all sub-components are exploded, and your component is composed only of faces and edges: +

      Arch Wikihouse 08.jpg +

      Once this is done, select everything in your component, and unselect, by Shift + double-clicking them, each frontal face of your component. Be sure to double-click instead of single-click, because otherwise you will only unselect the face and not its border edges (which we will need to keep as well). After that, we will have unselected everything we want to keep, so we only need to press the delete key. Now our component is only one big flat face. +

      Arch Wikihouse 07.jpg +

      Repeat this for each component. Since many are duplicated, this is not as huge a task as it looks. Besides, if you are not familiar with the Wikihouse system, this step will give you a pretty good understanding of how it works. +

      When our piece of house is fully made of flat elements, we can select everything and export it to a .dae file, and then import this file into FreeCAD. Be sure to mark the "triangulate all +

      +

      Solving the double faces bug

      +

      There is a nasty problem for which I haven't found a better solution: Meshes exported from SketchUp to the .dae format have their faces duplicated. Each face becomes actually two faces. The easiest way I have found so far is to open the exported file in Blender for repair: +

      +
      1. Open the dae file in Blender (File → Import → Collada)
      2. +
      3. Select a component, and hit TAB to enter edit mode
      4. +
      5. Press A to deselect everything, then A again to select everything
      6. +
      7. Press W → Remove doubles
      8. +
      9. Press TAB to exit edit mode
      10. +
      11. Repeat for all the components
      12. +
      13. Save a new dae file (File → Export → Collada)
      +

      Normally the above operation shouldn't change the scale, but it is always wise to verify, using the measuring tools, that the imported geometry is at correct scale before going further. You might need to tweak Blender's Collada export settings if needed. +

      +

      Importing and converting to wires

      +

      Note that it might be easier to go by parts and treat + export objects group by group, as we did below, we exported only the first layer, made of yellow elements in SketchUp. These elements will come into FreeCAD as Mesh objects: +

      Arch Wikihouse 09.jpg +

      The next step is to create wires from each of our meshes. There is a convenient Macro named Macro Extract Wires from Mesh that does just that. Install it (Refer to the Macros page for instructions), then one by one (you can do them all at once, but this macro takes some time), convert all our meshes to wire objects: +

      Arch Wikihouse 10.jpg +

      We could now already make Arch Panel objects from each of these wire-like objects, simply by selecting them and pressing the Arch Panel button. However, their base shape wouldn't be parametric. We now have several options: We could turn each component into a sketch, using the Draft Draft2Sketch tool, but these will be rather heavy sketches, and might not be very manageable on a slow machine, or we could turn each individual wire (the outline and each hole) of the sketch into a separate sketch. This would allow us, for example, to reuse a typical hole, make it only once, then duplicate it with Draft Clone to make the other holes. This way, you would only need to edit one to edit them all. +

      The Extract Wires from Mesh macro also sometimes fails in finding closed wires inside a mesh, which will not produce correct Panels. An easy procedure to recompose the wires of a component is this: +

      +
      1. Select the component, optionally hide everything else to see better
      2. +
      3. Draft Downgrade it. It will be exploded into a series of individual edges
      4. +
      5. Start selecting the holes with Ctrl or by using Shift + B to box-select
      6. +
      7. Press Draft Upgrade to turn back each hole into an individual wire
      8. +
      9. Finally select all the remaining individual edges in the tree, which form the outline, and Draft Upgrade them
      10. +
      11. Select Part → make Compound to join back all these wires into one object
      12. +
      13. Select the compound and press the Arch Panel button
      +

      Arch Wikihouse 11.jpg +

      There are many possible strategies here, depending on how editable and precise you need the result. The Arch Panel object needs a base object made of wires. It doesn't matter how this object is made, if it is a single sketch, or, like in the example above, a compound of different sketches or draft object. +

      +

      Converting to Sketches

      +

      It is also possible to do that part later, you could already create Panels from each of the component, but let's see already how to to convert a wire-like object to a sketch: +

      +
      1. Create a copy of your wire-like object with Ctrl+C, Ctrl+V. This si so we can modify it but still keep one in its correct location
      2. +
      3. Move and rotate it so it lies in the XY plane, using Draft Move and Draft Rotate. This is not indispensable, but the next point sometimes fails otherwise
      4. +
      5. Use Draft Draft2Sketch to turn the wire into a sketch. Be warned, this can fail or take a very long time for huge wires. It is best to decompose your object into individual wires as shown above.
      6. +
      7. If the command above fails, using Draft Upgrade twice on a wire-like object, to convert it to a Face then to a Draft Wire, before using Draft Draft2Sketch, usually works better, because the Draft Wire keeps a better track of the order of vertices inside a wire.
      8. +
      9. Curves are made of several small segments. They can be left as is, but they introduce a lot of endpoint constraints. It is better to replace them by arcs. It is fairly easy to do, just delete the small segments and replace them by an arc. The arc can then be made tangential to the neighbouring segments, but make sure the position of those segments is locked before doing this, as this operation will make them move.
      10. +
      11. If you worked with several sketches, make a Part Compound of them
      12. +
      13. Create an Arch Panel from it
      14. +
      15. Rotate/move it back into position with Draft Move and Draft Rotate
      +

      Arch Wikihouse 12.jpg +

      +

      Rebuilding the wikihouse and exporting cut sheets

      +

      Also, make sure you don't redo any duplicated part. Instead, select the Draft Clone tool to duplicate parts based on the same profile, so they will all share one same profile object. Then, since we have the outline at the correct place to use as a guide, it is fairly easy to rotate and move the clone into its correct position with Draft Rotate and Draft Move. +

      After a while, all our Microhouse section is done. +

      Arch Wikihouse 01.jpg +

      We can now easily create the cut sheets, which are DXF files that will be sent to the shop that will cut the actual panels. The easiest way to do this is to select everything in your document with Ctrl+A, and then use the Arch Panel Cut tool. This will produce one Panel Cut object for each Panel object found in the selection. By moving them apart, we get a clear view of all our pieces: +

      Arch Wikihouse 02.jpg +

      We must then "nest" our pieces, that is, move and rotate them so they occupy as much as possible to space of a given panel, to generate as little material loss as possible. This operation unfortunately needs to be done by hand, but if you are using a Wikihouse project that already has produced cut sheets, copying them goes pretty fast: +

      +
      1. To make sure everything will stay in the XY plane, it is advised to set the Workign Plane to XY (top)
      2. +
      3. Create an Arch Panel Sheet
      4. +
      5. Give it the desired width and height values (Wikihouses are typically printed on 122x244cm plywood sheets)
      6. +
      7. Move it to a convenient place with Draft Move
      8. +
      9. Optionally, set its margin values to help you position the cut pieces
      10. +
      11. Move and rotate the individual Arch Panel Cut objects so they fit inside the Panel Sheet
      12. +
      13. When you are more or less ready, select the Panel Sheet, and double click it in the tree view to enter Edit mode
      14. +
      15. Select all the Panel Cuts you wish to insert in it (you may want to switch the tree view to the "project" tab to select in the tree)
      16. +
      17. Select the "group" section in the Panel Sheet's Task view
      18. +
      19. Press the "Add" button
      20. +
      21. Press the "OK" button
      +

      In the Panel Sheet's Task view, there is also a button that allows you to move the individual Panel Cuts after they've been inserted inside the sheet. After a while, we have our sheets ready: +

      Arch Wikihouse 03.jpg +

      The last step is simply to select all the sheets, then export them to DXF from menu File → Export. The sheets contents will be exported separated in different layers, with the same color coding commonly used by the Wikihouse project: +

      Arch Wikihouse 04.jpg +

      These files are ready to send to the shops that will do the actual cut. It would be possible to generate the G-Code to be sent to the CNC machine directly from FreeCAD too, but that is matter for another tutorial. +

      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Window-new.svg b/localwiki/Window-new.svg new file mode 100644 index 0000000..e338f10 --- /dev/null +++ b/localwiki/Window-new.svg @@ -0,0 +1,304 @@ + + + + + + + + image/svg+xml + + New Window + + + Corey Woodworth + + + + http://jimmac.musichall.cz + + + Jakub Steiner + + + + + new + insert + window + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Windows.png b/localwiki/Windows.png new file mode 100644 index 0000000..3b811e7 Binary files /dev/null and b/localwiki/Windows.png differ diff --git a/localwiki/Wire.png b/localwiki/Wire.png new file mode 100644 index 0000000..fc5946c Binary files /dev/null and b/localwiki/Wire.png differ diff --git a/localwiki/WizardShaft.svg b/localwiki/WizardShaft.svg new file mode 100644 index 0000000..26b81e1 --- /dev/null +++ b/localwiki/WizardShaft.svg @@ -0,0 +1,635 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + diff --git a/localwiki/Wood.svg b/localwiki/Wood.svg new file mode 100644 index 0000000..85e3b09 --- /dev/null +++ b/localwiki/Wood.svg @@ -0,0 +1,926 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Woodgrain.svg b/localwiki/Woodgrain.svg new file mode 100644 index 0000000..6228d83 --- /dev/null +++ b/localwiki/Woodgrain.svg @@ -0,0 +1,154 @@ + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + diff --git a/localwiki/Workbench_Arch.svg b/localwiki/Workbench_Arch.svg new file mode 100644 index 0000000..c55eaba --- /dev/null +++ b/localwiki/Workbench_Arch.svg @@ -0,0 +1,666 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [triplus] + + + ArchWorkbench + 2016-02-26 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Arch/Resources/icons/ArchWorkbench.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Workbench_Complete.svg b/localwiki/Workbench_Complete.svg new file mode 100644 index 0000000..7865be2 --- /dev/null +++ b/localwiki/Workbench_Complete.svg @@ -0,0 +1,125 @@ + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + + + + + + diff --git a/localwiki/Workbench_Concept.html b/localwiki/Workbench_Concept.html new file mode 100644 index 0000000..9aeef2b --- /dev/null +++ b/localwiki/Workbench_Concept.html @@ -0,0 +1,57 @@ +Workbench Concept

      Workbench Concept

      (Redirected from Workbench Concept)
      + +

      FreeCAD, like many modern design applications such as Revit or CATIA, is based on the concept of Workbench. A workbench can be considered as a set of tools specially grouped for a certain task. In a traditional furniture workshop, you would have a work table for the person who works with wood, another one for the one who works with metal pieces, and maybe a third one for the guy who mounts all the pieces together. +

      In FreeCAD, the same concept applies. Tools are grouped into workbenches according to the tasks they are related to. +

      When you switch from one workbench to another, the tools available on the interface change. Toolbars, command bars and possibly other parts of the interface switch to the new workbench, but the contents of your scene doesn't change. You could, for example, start drawing 2D shapes with the Draft Workbench, then work further on them with the Part Workbench. +

      Note that sometimes a Workbench is referred to as a Module. However, Workbenches and Modules are different entities. A Module is any extension of FreeCAD, while a Workbench is a special GUI configuration that groups some toolbars and menus. Usually every Module contains its own Workbench, hence the cross-use of the name. +

      +

      Built-in workbenches

      +

      The following workbenches are available on every FreeCAD installation: +

      +

      Workbenches

      +

      These are the base workbenches bundled with every installation of FreeCAD: +

      +
      • Workbench Arch.svg The Arch Workbench for working with architectural elements.
      • +
      • Workbench Complete.svg The Complete Workbench hold all commands and features from all the modules and workbenches which met certain quality criteria.
      • +
      • Workbench Draft.svg The Draft Workbench contains 2D tools and basic 2D and 3D CAD operations.
      • +
      • Workbench Drawing.svg The Drawing Workbench for displaying your 3D work on a 2D sheet.
      • +
      • Workbench FEM.svg The FEM Workbench provides Finite Element Analysis (FEA) workflow.
      + + +
      • Workbench Reverse Engineering.svg The Reverse Engineering Workbench is intended to give you specific tools to convert shapes/solids/meshes into parametric FreeCAD-compatible features. It is still in development.
      • +
      • Workbench Robot.svg The Robot Workbench for studying robot movements.
      • +
      • Workbench Ship.svg The Ship Workbench FreeCAD-Ship works over Ship entities, that must be created on top of provided geometry.
      • +
      • Workbench Sketcher.svg The Sketcher Workbench for working with geometry-constrained sketches.
      • +
      • Workbench Spreadsheet.svg The Spreadsheet Workbench for creating and manipulating spreadsheet data.
      + +

      External workbenches

      +

      FreeCAD workbenches are easy to program in Python, there are therefore many people developing additional workbenches outside of the FreeCAD codebase. The External workbenches page has some information and tutorials about some of them, and the FreeCAD Addons project aims at gathering them and making them easily installable from within FreeCAD. +

      New workbenches are in development, stay tuned! +

      + +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Workbench_Draft.svg b/localwiki/Workbench_Draft.svg new file mode 100644 index 0000000..8ec2468 --- /dev/null +++ b/localwiki/Workbench_Draft.svg @@ -0,0 +1,364 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + DraftWorkbench + + Fri Feb 26 23:17:43 2016 +0100 + + + [triplus] + + + + + FreeCAD LGPL2+ + + + + + FreeCAD + + + FreeCAD/src/Mod/Draft/Resources/icons/DraftWorkbench.svg + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + [agryson] Alexander Gryson + + + + + ruler + drafting board + right angle ruler + + + A right angle ruler resting on a ruler on a drafting board + + + + diff --git a/localwiki/Workbench_Drawing.svg b/localwiki/Workbench_Drawing.svg new file mode 100644 index 0000000..495ed18 --- /dev/null +++ b/localwiki/Workbench_Drawing.svg @@ -0,0 +1,129 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + New Document + + + Jakub Steiner + + + http://jimmac.musichall.cz + + 2016-02-26 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Drawing/Gui/Resources/icons/DrawingWorkbench.svg + + + FreeCAD LGPL2+ + + + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Workbench_FEM.svg b/localwiki/Workbench_FEM.svg new file mode 100644 index 0000000..ad797d7 --- /dev/null +++ b/localwiki/Workbench_FEM.svg @@ -0,0 +1,259 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [triplus] + + + FemWorkbench + 2016-02-26 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/ + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Workbench_Image.svg b/localwiki/Workbench_Image.svg new file mode 100644 index 0000000..e7a0a50 --- /dev/null +++ b/localwiki/Workbench_Image.svg @@ -0,0 +1,243 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + + + + + + + + + diff --git a/localwiki/Workbench_Inspection.svg b/localwiki/Workbench_Inspection.svg new file mode 100644 index 0000000..d83fa47 --- /dev/null +++ b/localwiki/Workbench_Inspection.svg @@ -0,0 +1,253 @@ + + + + + mesh_pipette + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + mesh_pipette + + + + FreeCAD LGPL2+ + + + + + FreeCAD + + + FreeCAD/src/Mod/Mesh/Gui/Resources/icons/mesh_pipette.svg + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + pipette + eyedropper + sample + + + Pipette or eyedropper lit from above + + + [agryson] Alexander Gryson + + + Sat Feb 8 16:10:16 2014 +0100 + + + [wmayer] + + + + + + + + + + + + + + + + + diff --git a/localwiki/Workbench_Mesh.svg b/localwiki/Workbench_Mesh.svg new file mode 100644 index 0000000..6dd12f8 --- /dev/null +++ b/localwiki/Workbench_Mesh.svg @@ -0,0 +1,367 @@ + + + + + MeshWorkbench + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + MeshWorkbench + + + FreeCAD LGPL2+ + + + + + mesh + sphere + workbench + tesselated + + + + Tesselated sphere mesh, lit from top + + + [agryson] Alexander Gryson + + + + + + FreeCAD + + + + + [triplus] + + + Fri Feb 26 23:17:43 2016 +0100 + FreeCAD/src/Mod/Mesh/Gui/Resources/icons/MeshWorkbench.svg + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Workbench_OpenSCAD.svg b/localwiki/Workbench_OpenSCAD.svg new file mode 100644 index 0000000..800057f --- /dev/null +++ b/localwiki/Workbench_OpenSCAD.svg @@ -0,0 +1,159 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [triplus] + + + OpenSCADWorkbench + 2016-02-26 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/OpenSCAD/Resources/icons/OpenSCADWorkbench.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Workbench_Part.svg b/localwiki/Workbench_Part.svg new file mode 100644 index 0000000..f94d8ae --- /dev/null +++ b/localwiki/Workbench_Part.svg @@ -0,0 +1,70 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + [triplus] + + + PartWorkbench + 2016-02-26 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Part/Gui/Resources/icons/PartWorkbench.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + diff --git a/localwiki/Workbench_PartDesign.png b/localwiki/Workbench_PartDesign.png new file mode 100644 index 0000000..cb09226 Binary files /dev/null and b/localwiki/Workbench_PartDesign.png differ diff --git a/localwiki/Workbench_PartDesign.svg b/localwiki/Workbench_PartDesign.svg new file mode 100644 index 0000000..b988862 --- /dev/null +++ b/localwiki/Workbench_PartDesign.svg @@ -0,0 +1,114 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [triplus] + + + PartDesignWorkbench + 2016-02-26 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/PartDesign/Gui/Resources/icons/PartDesignWorkbench.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Workbench_Path.svg b/localwiki/Workbench_Path.svg new file mode 100644 index 0000000..75589dd --- /dev/null +++ b/localwiki/Workbench_Path.svg @@ -0,0 +1,161 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + PathWorkbench + 2016-02-26 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Path/Gui/Resources/icons/PathWorkbench.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Workbench_Plot.svg b/localwiki/Workbench_Plot.svg new file mode 100644 index 0000000..f6bf871 --- /dev/null +++ b/localwiki/Workbench_Plot.svg @@ -0,0 +1,148 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [triplus] + + + PlotWorkbench + 2016-02-26 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Plot/resources/icons/PlotWorkbench.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Workbench_Points.svg b/localwiki/Workbench_Points.svg new file mode 100644 index 0000000..24d5dd3 --- /dev/null +++ b/localwiki/Workbench_Points.svg @@ -0,0 +1,151 @@ + + + + + + image/svg+xml + + + + $committer + + + + 2016-02-26 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Points/Gui/Resources/icons/PointsWorkbench.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Workbench_Raytracing.svg b/localwiki/Workbench_Raytracing.svg new file mode 100644 index 0000000..cad3ec7 --- /dev/null +++ b/localwiki/Workbench_Raytracing.svg @@ -0,0 +1,85 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + $committer + + + RaytracingWorkbench + 2016-02-26 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Raytracing/Gui/Resources/icons/RaytracingWorkbench.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + diff --git a/localwiki/Workbench_Reverse_Engineering.svg b/localwiki/Workbench_Reverse_Engineering.svg new file mode 100644 index 0000000..875408b --- /dev/null +++ b/localwiki/Workbench_Reverse_Engineering.svg @@ -0,0 +1,612 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + + + + + + + + + diff --git a/localwiki/Workbench_Robot.svg b/localwiki/Workbench_Robot.svg new file mode 100644 index 0000000..0869197 --- /dev/null +++ b/localwiki/Workbench_Robot.svg @@ -0,0 +1,90 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [triplus] + + + RobotWorkbench + 2016-02-26 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Robot/Gui/Resources/icons/RobotWorkbench.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Workbench_Ship.svg b/localwiki/Workbench_Ship.svg new file mode 100644 index 0000000..412d96d --- /dev/null +++ b/localwiki/Workbench_Ship.svg @@ -0,0 +1,157 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [triplus] + + + ShipWorkbench + 2016-02-26 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Ship/resources/icons/ShipWorkbench.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Workbench_Sketcher.svg b/localwiki/Workbench_Sketcher.svg new file mode 100644 index 0000000..b84b018 --- /dev/null +++ b/localwiki/Workbench_Sketcher.svg @@ -0,0 +1,190 @@ + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [triplus] + + + SketcherWorkbench + 2016-02-26 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Sketcher/Gui/Resources/icons/SketcherWorkbench.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + diff --git a/localwiki/Workbench_Spreadsheet.svg b/localwiki/Workbench_Spreadsheet.svg new file mode 100644 index 0000000..85c337b --- /dev/null +++ b/localwiki/Workbench_Spreadsheet.svg @@ -0,0 +1,64 @@ + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [triplus] + + + SpreadsheetWorkbench + 2016-02-26 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Spreadsheet/Gui/Resources/icons/SpreadsheetWorkbench.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + + + + + + + + + + diff --git a/localwiki/Workbench_Start.svg b/localwiki/Workbench_Start.svg new file mode 100644 index 0000000..c5583b6 --- /dev/null +++ b/localwiki/Workbench_Start.svg @@ -0,0 +1,182 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [triplus] + + + StartWorkbench + 2016-02-26 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/Start/Gui/Resources/icons/StartWorkbench.svg + + + FreeCAD LGPL2+ + + + https://www.gnu.org/copyleft/lesser.html + + + [agryson] Alexander Gryson + + + + + arrow + right + + + Arrow pointing towards the right + + + + + + + + diff --git a/localwiki/Workbench_TechDraw.svg b/localwiki/Workbench_TechDraw.svg new file mode 100644 index 0000000..34c7cf1 --- /dev/null +++ b/localwiki/Workbench_TechDraw.svg @@ -0,0 +1,775 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + [agryson] Alexander Gryson + + + http://agryson.net + + TechDraw_Tree_Symbol + 2016-04-27 + http://www.freecadweb.org/wiki/index.php?title=Artwork + + + FreeCAD + + + FreeCAD/src/Mod/TechDraw/Gui/Resources/icons/TechDraw_Tree_Symbol.svg + + + FreeCAD LGPL2+ + + + + + [agryson] Alexander Gryson + + + + + technical drawing + circles + page + + + 3 cirlces drawn on a page with a text box in bottom left + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Workbench_Test.png b/localwiki/Workbench_Test.png new file mode 100644 index 0000000..4cadcbd Binary files /dev/null and b/localwiki/Workbench_Test.png differ diff --git a/localwiki/Workbench_Test.svg b/localwiki/Workbench_Test.svg new file mode 100644 index 0000000..9e27880 --- /dev/null +++ b/localwiki/Workbench_Test.svg @@ -0,0 +1,211 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + diff --git a/localwiki/Workbench_Web.svg b/localwiki/Workbench_Web.svg new file mode 100644 index 0000000..cb1cb28 --- /dev/null +++ b/localwiki/Workbench_Web.svg @@ -0,0 +1,1462 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + Globe + + + Jakub Steiner + + + + + Tuomas Kuosmanen + + + + http://jimmac.musichall.cz + + + globe + international + web + www + internet + network + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Workbench_creation.html b/localwiki/Workbench_creation.html new file mode 100644 index 0000000..ffdfb6b --- /dev/null +++ b/localwiki/Workbench_creation.html @@ -0,0 +1,250 @@ +Workbench creation

      Workbench creation

      + +

      This page will show you how to add a new workbench to the FreeCAD interface. Workbenches are containers for FreeCAD commands. They can be coded in python, in C++, or in a mix of both, which has the advantage to ally the speed of C++ to the flexibility of python. In all cases, though, your workbench will be launched by a set of two python files. +

      + + +

      The workbench structure

      +

      Basically it is simple: You need a folder, with any name you like, placed in the Mod directory, with an Init.py file, and, optionally an InitGui.py file. The Init file is executed when FreeCAD starts, always, and the InitGui.py file is executed immediately after, but only when FreeCAD starts in GUI mode, not in console mode. That's all it needs for FreeCAD to find your workbench at startup and add it to its interface. +

      Inside those files you can do whatever you want. Usually they are used like this: +

      +
      • In the Init.py file you just add a couple of things used even when FreeCAD works in console mode, for example the file importers and exporters
      +
      • In the InitGui.py file you usually define a workbench, which contains a name, an icon, and a series of FreeCAD commands (see below). That workbench also defines functions that are executed when FreeCAD loads (you try to do as little as possible there, so you don't slow down the startup), another that gets executed when the workbench is activated (that's where you'll do most of the work), and a third one when the workbench is deactivated (so you can remove things if needed).
      +

      C++ workbench structure

      +

      If you are going to code your workbench in python, you don't need to take special care, and can simply place your other python files together with your Init.py and InitGui.py files. When working with C++, however, you should take greater care, and start with respecting one fundamental rule of FreeCAD: The separation of your workbench between an App part (that can run in console mode, without any GUI element), and a Gui part, which will only be loaded when FreeCAD runs with its full GUI environment. So when doing a C++ workbench, you will actually most likely be doing two modules, an App and a Gui. These two modules must of course be callable from python. Any FreeCAD module (App or Gui) consists, at the very least, of a module init file. This is a typical AppMyModuleGui.cpp file: +

      +
      extern "C" {
      +    void MyModuleGuiExport initMyModuleGui()  
      +    {
      +         if (!Gui::Application::Instance) {
      +            PyErr_SetString(PyExc_ImportError, "Cannot load Gui module in console application.");
      +            return;
      +        }
      +        try {
      +            // import other modules this one depends on
      +            Base::Interpreter().runString("import PartGui");
      +            // run some python code in the console
      +            Base::Interpreter().runString("print('welcome to my module!')");
      +        }
      +        catch(const Base::Exception& e) {
      +            PyErr_SetString(PyExc_ImportError, e.what());
      +            return;
      +        }
      +        (void) Py_InitModule("MyModuleGui", MyModuleGui_Import_methods);   /* mod name, table ptr */
      +        Base::Console().Log("Loading GUI of MyModule... done\n");
      +    
      +        // initializes the FreeCAD commands (in another cpp file)
      +        CreateMyModuleCommands();
      +    
      +        // initializes workbench and object definitions
      +        MyModuleGui::Workbench::init();
      +        MyModuleGui::ViewProviderSomeCustomObject::init();
      +    
      +         // add resources and reloads the translators
      +        loadMyModuleResource();
      +    }
      +} 
      +

      The Init.py file

      +
      # FreeCAD init script of XXX module  
      +
      +#***************************************************************************
      +#*   (c) John Doe john@doe.com 2015                                        *   
      +#*                                                                         *
      +#*   This file is part of the FreeCAD CAx development system.              *
      +#*                                                                         *
      +#*   This program is free software; you can redistribute it and/or modify  *
      +#*   it under the terms of the GNU Lesser General Public License (LGPL)    *
      +#*   as published by the Free Software Foundation; either version 2 of     *
      +#*   the License, or (at your option) any later version.                   *
      +#*   for detail see the LICENCE text file.                                 *
      +#*                                                                         *
      +#*   FreeCAD is distributed in the hope that it will be useful,            *
      +#*   but WITHOUT ANY WARRANTY; without even the implied warranty of        *
      +#*   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the         *
      +#*   GNU Lesser General Public License for more details.                   *
      +#*                                                                         *
      +#*   You should have received a copy of the GNU Library General Public     *
      +#*   License along with FreeCAD; if not, write to the Free Software        *
      +#*   Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  *
      +#*   USA                                                                   *
      +#*                                                                         *
      +#***************************************************************************/
      +
      +FreeCAD.addImportType("My own format (*.own)","importOwn")
      +FreeCAD.addExportType("My own format (*.own)","importOwn")
      +print "I am executing some stuff here when FreeCAD starts!" 
      +

      You can choose any license you like for your workbench, but be aware that if you wish +to see your workbench integrated into and distributed with the FreeCAD source code at +some point, it needs to be LGPL2+ like the example above. +The FreeCAD.addImportType() and addEXportType() functions allow you to give the name +and extension of a file type, and a python module responsible for its import. In the +example above, an "importOwn.py" module will handle .own files. See Code snippets +for more examples. +

      +

      Python workbenches

      +
      class MyWorkbench (Workbench):
      +
      +    MenuText = "My Workbench"
      +    ToolTip = "A description of my workbench"
      +    Icon = """paste here the contents of a 16x16 xpm icon"""
      +
      +    def Initialize(self):
      +        "This function is executed when FreeCAD starts"
      +        import MyModuleA, MyModuleB # import here all the needed files that create your FreeCAD commands
      +        self.list = ["MyCommand1, MyCommand2"] # A list of command names created in the line above
      +        self.appendToolbar("My Commands",self.list) # creates a new toolbar with your commands
      +        self.appendMenu("My New Menu",self.list) # creates a new menu
      +        self.appendMenu(["An existing Menu","My submenu"],self.list) # appends a submenu to an existing menu
      +
      +    def Activated(self):
      +        "This function is executed when the workbench is activated"
      +        return
      +
      +    def Deactivated(self):
      +        "This function is executed when the workbench is deactivated"
      +        return
      +
      +    def ContextMenu(self, recipient):
      +        "This is executed whenever the user right-clicks on screen"
      +        # "recipient" will be either "view" or "tree"
      +        self.appendContextMenu("My commands",self.list) # add commands to the context menu
      +
      +    def GetClassName(self): 
      +        # this function is mandatory if this is a full python workbench
      +        return "Gui::PythonWorkbench"
      +       
      +Gui.addWorkbench(MyWorkbench())
      +

      Other than that, you can do anything you want: You could put your whole workbench code +inside the InitGui.py if you want, but it is usually more convenient to place the different +functions of your workbench in separate files. So those files are smaller and easier to +read. Then you import those files into your InitGui.py file. You can organize those files +the way you want, a good example is one for each FreeCAD command you add. +

      +

      C++ workbenches

      +

      If you are going to code your workbench in C++, you will probably want to code the +workbench definition itself in C++ too (although it is not necessary: You could also +code only the tools in C++, and leave the workbench definition in python). In that case, +the InitGui.py file becomes very simple: It might contain just one line: +

      +
      import MyModuleGui 
      +

      where MyModule is your complete C++ workbench, including the commands and workbench +definition. +

      Coding C++ workbenches works in a pretty similar way. This is a typical Workbench.cpp +file to include in the Gui part of your module: +

      +
      namespace MyModuleGui {
      +    class MyModuleGuiExport Workbench : public Gui::StdWorkbench
      +    {
      +        TYPESYSTEM_HEADER();
      +
      +    public:
      +        Workbench();
      +        virtual ~Workbench();
      +
      +        virtual void activated();
      +        virtual void deactivated();
      +
      +    protected:
      +        Gui::ToolBarItem* setupToolBars() const;
      +        Gui::MenuItem*    setupMenuBar() const;
      +    };
      +} 
      +

      FreeCAD commands

      +

      FreeCAD commands are the basic building block of the FreeCAD interface. They can appear +as a button on toolbars, and as a menu entry in menus. But it is the same command. A +command is a simple python class, that must contain a couple of predefined attributes +and functions, that define the name of the command, its icon, and what to do when the +command is activated. +

      +

      Python command definition

      +
      class My_Command_Class():
      +    """My new command"""
      +
      +    def GetResources(self):
      +        return {'Pixmap'  : 'My_Command_Icon', # the name of a svg file available in the resources
      +                'Accel' : "Shift+S", # a default shortcut (optional)
      +                'MenuText': "My New Command"
      +                'ToolTip' : "What my new command does"}
      +
      +    def Activated(self):
      +        "Do something here"
      +        return
      +
      +    def IsActive(self):
      +        """Here you can define if the command must be active or not (greyed) if certain conditions
      +        are met or not. This function is optional."""
      +        return True
      +
      +FreeCADGui.addCommand('My_Command',My_Command_Class()) 
      +

      C++ command definition

      +

      Similarly, you can code your commands in C++, typically have a Commands.cpp file in your Gui module. This is a typical Commands.cpp file: +

      +
      DEF_STD_CMD_A(CmdMyCommand);
      +
      +CmdMyCommand::CmdMyCommand()
      +  :Command("My_Command")
      +{
      +  sAppModule    = "MyModule";
      +  sGroup        = QT_TR_NOOP("MyModule");
      +  sMenuText     = QT_TR_NOOP("Runs my command...");
      +  sToolTipText  = QT_TR_NOOP("Describes what my command does");
      +  sWhatsThis    = QT_TR_NOOP("Describes what my command does");
      +  sStatusTip    = QT_TR_NOOP("Describes what my command does");
      +  sPixmap       = "some_svg_icon_from_my_resource";
      +}
      +
      +void CmdMyCommand::activated(int iMsg)
      +{
      +    openCommand("My Command");
      +    doCommand(Doc,"print('Hello, world!')");
      +    commitCommand();
      +    updateActive();
      +}
      +
      +bool CmdMyCommand::isActive(void)
      +{
      +  if( getActiveGuiDocument() )
      +    return true;
      +  else
      +    return false;
      +}
      +
      +void CreateMyModuleCommands(void)
      +{
      +    Gui::CommandManager &rcCmdMgr = Gui::Application::Instance->commandManager();
      +    rcCmdMgr.addCommand(new CmdMyCommand());
      +} 
      +


      +

      +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Workbench_select_sketcher.png b/localwiki/Workbench_select_sketcher.png new file mode 100644 index 0000000..f6e0860 Binary files /dev/null and b/localwiki/Workbench_select_sketcher.png differ diff --git a/localwiki/Workbenches.html b/localwiki/Workbenches.html new file mode 100644 index 0000000..b35618d --- /dev/null +++ b/localwiki/Workbenches.html @@ -0,0 +1,57 @@ +Workbenches

      Workbenches

      + +

      FreeCAD, like many modern design applications such as Revit or CATIA, is based on the concept of Workbench. A workbench can be considered as a set of tools specially grouped for a certain task. In a traditional furniture workshop, you would have a work table for the person who works with wood, another one for the one who works with metal pieces, and maybe a third one for the guy who mounts all the pieces together. +

      In FreeCAD, the same concept applies. Tools are grouped into workbenches according to the tasks they are related to. +

      When you switch from one workbench to another, the tools available on the interface change. Toolbars, command bars and possibly other parts of the interface switch to the new workbench, but the contents of your scene doesn't change. You could, for example, start drawing 2D shapes with the Draft Workbench, then work further on them with the Part Workbench. +

      Note that sometimes a Workbench is referred to as a Module. However, Workbenches and Modules are different entities. A Module is any extension of FreeCAD, while a Workbench is a special GUI configuration that groups some toolbars and menus. Usually every Module contains its own Workbench, hence the cross-use of the name. +

      +

      Built-in workbenches

      +

      The following workbenches are available on every FreeCAD installation: +

      +

      Workbenches

      +

      These are the base workbenches bundled with every installation of FreeCAD: +

      +
      • Workbench Arch.svg The Arch Workbench for working with architectural elements.
      • +
      • Workbench Complete.svg The Complete Workbench hold all commands and features from all the modules and workbenches which met certain quality criteria.
      • +
      • Workbench Draft.svg The Draft Workbench contains 2D tools and basic 2D and 3D CAD operations.
      • +
      • Workbench Drawing.svg The Drawing Workbench for displaying your 3D work on a 2D sheet.
      • +
      • Workbench FEM.svg The FEM Workbench provides Finite Element Analysis (FEA) workflow.
      + + +
      • Workbench Reverse Engineering.svg The Reverse Engineering Workbench is intended to give you specific tools to convert shapes/solids/meshes into parametric FreeCAD-compatible features. It is still in development.
      • +
      • Workbench Robot.svg The Robot Workbench for studying robot movements.
      • +
      • Workbench Ship.svg The Ship Workbench FreeCAD-Ship works over Ship entities, that must be created on top of provided geometry.
      • +
      • Workbench Sketcher.svg The Sketcher Workbench for working with geometry-constrained sketches.
      • +
      • Workbench Spreadsheet.svg The Spreadsheet Workbench for creating and manipulating spreadsheet data.
      + +

      External workbenches

      +

      FreeCAD workbenches are easy to program in Python, there are therefore many people developing additional workbenches outside of the FreeCAD codebase. The External workbenches page has some information and tutorials about some of them, and the FreeCAD Addons project aims at gathering them and making them easily installable from within FreeCAD. +

      New workbenches are in development, stay tuned! +

      + +
      + + + +
      + + +
      + + +
      +

      Navigation menu

      + + \ No newline at end of file diff --git a/localwiki/Workingplane_example.jpg b/localwiki/Workingplane_example.jpg new file mode 100644 index 0000000..7dc03d3 Binary files /dev/null and b/localwiki/Workingplane_example.jpg differ diff --git a/localwiki/XY_Title_v2.svg b/localwiki/XY_Title_v2.svg new file mode 100644 index 0000000..3e0809b --- /dev/null +++ b/localwiki/XY_Title_v2.svg @@ -0,0 +1,214 @@ + + + + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + + + + X1a + X2a + Y2a + Y1a + + + + + + + + diff --git a/localwiki/XY_Working_v2.svg b/localwiki/XY_Working_v2.svg new file mode 100644 index 0000000..d481645 --- /dev/null +++ b/localwiki/XY_Working_v2.svg @@ -0,0 +1,195 @@ + + + + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + + + + + + + X1 + X2 + Y1 + Y2 + + diff --git a/localwiki/Zoom-all.svg b/localwiki/Zoom-all.svg new file mode 100644 index 0000000..7ab0296 --- /dev/null +++ b/localwiki/Zoom-all.svg @@ -0,0 +1,738 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + Martin Ruskov + + + http://commons.wikimedia.org/wiki/Tango_icon + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Zoom-border.svg b/localwiki/Zoom-border.svg new file mode 100644 index 0000000..5e53dc9 --- /dev/null +++ b/localwiki/Zoom-border.svg @@ -0,0 +1,636 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + Martin Ruskov + + + http://commons.wikimedia.org/wiki/Tango_icon + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Zoom-fit-best.svg b/localwiki/Zoom-fit-best.svg new file mode 100644 index 0000000..7e2da76 --- /dev/null +++ b/localwiki/Zoom-fit-best.svg @@ -0,0 +1,1010 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + Martin Ruskov + + + http://commons.wikimedia.org/wiki/Tango_icon + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Zoom-in.svg b/localwiki/Zoom-in.svg new file mode 100644 index 0000000..c5ab32d --- /dev/null +++ b/localwiki/Zoom-in.svg @@ -0,0 +1,875 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + Martin Ruskov + + + http://commons.wikimedia.org/wiki/Tango_icon + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Zoom-mouse-CTRL-SHIFT.svg b/localwiki/Zoom-mouse-CTRL-SHIFT.svg new file mode 100644 index 0000000..7989091 --- /dev/null +++ b/localwiki/Zoom-mouse-CTRL-SHIFT.svg @@ -0,0 +1,196 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + + + + + + + CTRL + + + + SHIFT + + diff --git a/localwiki/Zoom-mouse.svg b/localwiki/Zoom-mouse.svg new file mode 100644 index 0000000..7f88822 --- /dev/null +++ b/localwiki/Zoom-mouse.svg @@ -0,0 +1,161 @@ + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Zoom-out.svg b/localwiki/Zoom-out.svg new file mode 100644 index 0000000..fcbe93b --- /dev/null +++ b/localwiki/Zoom-out.svg @@ -0,0 +1,855 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + Martin Ruskov + + + http://commons.wikimedia.org/wiki/Tango_icon + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Zoom-selection.svg b/localwiki/Zoom-selection.svg new file mode 100644 index 0000000..0620854 --- /dev/null +++ b/localwiki/Zoom-selection.svg @@ -0,0 +1,753 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + Martin Ruskov + + + http://commons.wikimedia.org/wiki/Tango_icon + + + + + + + + + + + + + + + + + + + + + diff --git a/localwiki/Zoom_cursor.png b/localwiki/Zoom_cursor.png new file mode 100644 index 0000000..6d6039d Binary files /dev/null and b/localwiki/Zoom_cursor.png differ diff --git a/localwiki/about.txt b/localwiki/about.txt new file mode 100644 index 0000000..e965e93 --- /dev/null +++ b/localwiki/about.txt @@ -0,0 +1,4 @@ + +
      FreeCAD 0.17 help files
      +http://www.freecadweb.org
      + \ No newline at end of file diff --git a/localwiki/cc-by.png b/localwiki/cc-by.png new file mode 100644 index 0000000..9cca2f9 Binary files /dev/null and b/localwiki/cc-by.png differ diff --git a/localwiki/default.html b/localwiki/default.html new file mode 100644 index 0000000..a5ed849 --- /dev/null +++ b/localwiki/default.html @@ -0,0 +1 @@ +  \ No newline at end of file diff --git a/localwiki/freecad-icon-64.png b/localwiki/freecad-icon-64.png new file mode 100644 index 0000000..25576e3 Binary files /dev/null and b/localwiki/freecad-icon-64.png differ diff --git a/localwiki/freecad.qhcp b/localwiki/freecad.qhcp new file mode 100644 index 0000000..3552189 --- /dev/null +++ b/localwiki/freecad.qhcp @@ -0,0 +1,33 @@ + + + + FreeCAD User Manual + freecad-icon-64.png + freecad/freecad + qthelp://org.freecad.usermanual/doc/Online_Help_Startpage.html + + About FreeCAD + + + about.txt + + freecad-icon-64.png + + true + true + true + + + + + freecad.qhp + freecad.qch + + + + freecad.qch + + + diff --git a/localwiki/freecad.qhp b/localwiki/freecad.qhp new file mode 100644 index 0000000..f83629c --- /dev/null +++ b/localwiki/freecad.qhp @@ -0,0 +1,5736 @@ + + + org.freecad.usermanual + doc + + + + +
      +
      +
      +
      +
      +
      +
      +
      +
      +
      +
      +
      +
      +
      +
      +
      +
      +
      +
      +
      +
      +
      +
      +
      +
      +
      +
      +
      +
      +
      +
      +
      +
      +
      +
      +
      +
      +
      +
      +
      +
      +
      +
      +
      +
      +
      +
      +
      +
      +
      +
      +
      +
      +
      +
      +
      +
      +
      +
      +
      +
      +
      +
      +
      +
      +
      +
      +
      +
      +
      +
      +
      +
      +
      +
      +
      +
      +
      +
      +
      +
      +
      +
      +
      +
      +
      +
      +
      +
      +
      +
      +
      +
      +
      +
      +
      +
      +
      +
      +
      + +
      + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +OpenSCAD_Minkowski.html +David.html +AssemblyWorkbench.svg +Arch_Axis.svg +Elbow_equality_horizontal_vertical.png +Macro_Extract_Wires_from_Mesh.html +FCCamera_06.png +16px-Draft_Polygon.png +32px-Mesh_Ellipsoid.png +PartDesign_SubtractiveWedge_example.svg +CompileOnWindows_-_Reducing_Disk_Footprint.html +16px-Arch_Panel_Cut.png +1024px-Raytracing_example.jpg +Arch_Rebar.svg +Constraint_Parallel.svg +PartDesign_Mirrored_example.svg +DagViewPass.svg +Draft_Drawing.svg +Screenshot_installer.jpg +Std_Edit.svg +275px-FCCircularText_02.png +16px-TechDraw_Hatch.png +32px-Sketcher_Clone.png +Tolerance_editable.svg +480px-Macro_FCInfoToMouse_00.png +32px-Arch_Wall.png +Macro_ReproWire.html +400px-TaskPanel.jpg +Macro_FCTreeView_23.png +32px-PartDesign_Pad.png +32px-FEM_ConstraintDisplacement.png +24px-Workbench_Web.png +KukaBase.jpg +Property.html +FCGear_00.png +PartHelixPrimitivesOptions_en.png +FCCamera_08.png +24px-FEM_Solver.png +200px-TBHS2-30-chamfer.JPG +Fem-fluid-section.svg +SketcherCreateFilletExample.png +16px-Path-Job.png +Draft_Dimension.html +Spreadsheet_CSV.html +668px-JoinFeatures_demo.png +LockConstraint5.png +FreeCAD05_Tango_Anaglyph.svg +600px-RotationOffsetAfter.png +OpenSCAD_RemoveSubtree.svg +32px-Snap_Grid.png +600px-Part_Slice_Demo.png +Python_3.html +PartDesign_MultiTransform.html +32px-Robot_SetDefaultOrientation.png +300px-PartDesign_Chamfer-02.png +24px-View-zoom-out.png +578px-Arch_tutorial_00.jpg +700px-Pic6.png +640px-Draft_Label_Preview.png +32px-Draft_Draft2Sketch.png +Snap_Intersection.svg +Macro_Geneva_Wheel_GUI.html +32px-Std_OnlineHelpPython.png +Raytracing_tutorial.html +Part_Helix.html +Macro_Rotate_View_with_Z_pointing_upwards_.png +Path-JobOutput.png +Sketcher_CreatePentagon_Constr.svg +CompileOnMinGW.html +Captura_de_pantalla_de_2015-09-10_11-17-30.png +32px-Path_GcodeFromShape.png +256px-LengthConstraint6.png +Mesh_Mesher_Mefisto.jpg +16px-Drawing_SpreadsheetView.png +FreeCAD-Ship-S60ShipCreationFront.png +32px-Points_ExportPoints.png +Part_Thickness.svg +Hbone.svg +FCCamera_04.png +Utilities-terminal.svg +Sketcher_CreatePolyline_Constr.svg +PartDesign_AdditivePipe_example.svg +Arch_site_example_03.jpg +Macro_Make_Cube.html +Mouse_pointer.svg +Preference_OpenSCAD_Tab_01.png +24px-Std_Close.png +Installing_Helpfile.html +FEM_MeshClear.html +Macro_Half-Hull_ModelOption5.jpg +Constraint_Ellipse_Major_Radius.svg +Sketcher_Circle.html +Path-Toolpath.svg +Part_RefineShape.html +250px-Tetra4--ccx.png +Import_from_STL_or_OBJ.html +32px-Arch_Site.png +Fem-add-fem-mesh.svg +PySide.html +Tut17_final.png +32px-Macro_SelectVisible.png +Std_DuplicateSelection.html +800px-TBHS-9.JPG +32px-Std_MeasureToggleDelta.png +Tasks_Placement.html +Manipulator-WB-Mover-with-External-Reference.gif +Arch_RemoveShape.html +32px-TechDraw_New_Pick.png +Pref_Draft_Snapping.png +Code_snippets.html +Draft-tutorial-walls.jpg +Arch_Wikihouse_07.jpg +Path-Machine-test1.svg +32px-Snap_Dimensions.png +Macro_HighlightDifference.html +Macro_FCPropertyMemo_00.png +24px-PartDesign_Body.png +Std_DlgMacroRecord.html +Part_SectionCross.html +Development_roadmap.html +GGTuto1_8.PNG +Macro_triangleAH.html +TechDraw_Dimension_Angle.svg +Dxf_Importer_Install_06.png +Mesh_Mesher_Netgen.jpg +Draft_ToggleGrid.html +PartDesign_Pad.html +Line.png +PartSection1_it.png +32px-Constraint_Horizontal.png +FEM_ElementGeometry2D.html +267px-FCCircularText_53.png +Path_Pocket_Shape.png +Sketcher_NewSketch.svg +600px-RotationAboutYXAfter.png +FC017_Navigation_Indicator_02.png +16px-Part_Sweep.png +Draft_Apply.html +View-zoom-in.svg +Assemblage_Imprimante_3D.gif +Feature4.jpg +400px-Macro_FCTexture_008b.png +800px-TBHS2-3.JPG +Part_Create_Primitives1.jpeg +400px-Draft_Move_example.jpg +RPH_before.png +NavigationOpenCascade.svg +16px-Draft_Rectangle.png +PartDesign_Body.svg +Macro_Texture.html +Pivy.html +Drawing_Landscape_A3.html +Install_on_Unix.html +32px-Sketcher_Element_Ellipse_All.png +Applications-python.svg +Units_project.html +Plot_Module.html +Preference_Import_Export_Tab_08.png +Draft_Construction.svg +480px-FEM_tutorial_result.png +Step10_second_arc.png +Draft_Cursor.svg +FreeCAD05_Tango_Face-sad.svg +Linux.png +Std_Refresh.png +Tache_Placement_Lacet_fr_Mini.gif +Draft_2DShapeView.svg +Draft_tutorial.html +Countersunk_and_counterbored_holes_cross-section1.png +Techdraw-hatch.svg +View-zoom-out.svg +32px-Sketcher_ViewSketch.png +24px-View-left.png +TechDraw_New_Pick.html +Earth.svg +Sketcher_ExternalEsempio4.png +32px-Arch_PipeConnector.png +Hand_cursor.png +32px-Std_WhatsThis.png +FEMMaterialProperties.PNG +Document-open.svg +Sketcher_Rectangle.html +32px-Snap_Ortho.png +Meshes_RegularSolid_Torus.jpg +Draft_CloseLine.html +Part_Measure_Linear.svg +Preference_Path_Tab_01_2.png +FCCircularText_12.png +32px-Std_ViewBoxZoom.png +Robot_InsertWaypointPre.svg +Flatness_editable.svg +Macro_FCCircularText.html +32px-TechDraw_NewDraft.png +Ship_TankNew.png +120px-Bottle.jpg +300px-Spring_02.png +Tutorial_Drawing_Sheet.png +Mesh_BuildRegularSolid.html +Std_DlgPreferences.html +32px-TechDraw_NewProjGroup.png +Tache_Placement_Roulis_fr_Mini.gif +Path-ToolController.svg +Constraint_EqualLength.svg +Std_CloseAll.png +Tutorial-normand08.jpg +24px-Techdraw-toggleframe.png +Path-PocketOperation.gif +FreeCAD05_Tango_Face-smile.svg +267px-FCCircularText_41.png +32px-Web_Sketchfab.png +Path_FAQ.html +268px-Texture_005_larme.png +32px-Draft_Ellipse.png +Macro_FCTreeView_001.png +24px-View-zoom-border.png +Mesh_Mesher_Standard.jpg +32px-PartDesign_AdditiveTorus.png +OpenSCAD_MeshBooleans.svg +300px-FC017_Sketcher_B-spline_01.png +600px-Sketcher_ConsraintAngle_mode4.png +US_Letter_portrait.svg +Ship_Loading.html +32px-Path-Profile-Edges.png +Workbench_Start.svg +16px-Arch_Roof.png +32px-Sketcher_CreateArcOfEllipse.png +Arch_tutorial_43.jpg +Macro_FCSpreadSheet_Extract.html +32px-Draft_Special.png +Robot_TrajectoryDressUp.html +Debug_marker.svg +NavigationBlender_Pan.svg +32px-Part_Ellipsoid.png +Std_TipOfTheDay.html +32px-Raytracing_Export.png +Web-zoom-in.svg +Draft_Mirror.svg +Arch_D_Portrait.svg +Sketcher_MapSketch.svg +Techdraw-toggleframe.svg +Web_Workbench.html +PartDesign_AdditiveBox.html +Draft_Move.png +600px-Patharray_alignment-YZ.png +Draft_Rotate.svg +32px-Part_Helix.png +600px-RotationEulerBefore.png +Arch_panel_tutorial_09.jpg +NavigationOpenInventor_ZoomAlt.svg +Macro_TruncateSpring_01.png +250px-Seg3--fc.png +Release_notes_0.14.html +32px-Draft_Offset.png +Dxf_Importer_Install_18.png +32px-Sketcher_Elliptical_Arc.png +Arch_Building_Tree.svg +FEM_Element_Types.html +FreeCAD05_Tango_Face-blush.svg +Std_View_Menu.html +24px-Macro_Easy_Cutouts_for_Enclosures.png +Macro_merge_duplicate_materials.html +24px-Text-x-python.png +GGTuto1_Vue.PNG +Macro_FCTreeView_002.png +Draft_Wipe.svg +32px-Replace_Part.png +24px-Part_Prism_Apothem.png +Techdraw-clip.svg +EllipseCenter2Point.png +256px-LengthConstraint4.png +Macro_FCSpreadsheet_Extract.png +TechDraw_Dimension_Length.html +FCCircularText_21.png +Draft_Clone.html +600px-RotationEulerAfter.png +Mesh_FlipNormals.html +Cartouche_03_US.svg +Macro_FCSpring_Helix_Variable.gif +Macro_Circle.html +SpreadsheetStyleUnderline.svg +Part_Offset.svg +640px-Arch_Space_example.jpg +NavigationMayaGesture_ZoomAlt.svg +32px-PartDesign_MultiTransform.png +24px-Macro_FCConvertLines.png +32px-Arch_Structure.png +Linearpattern_parameters.png +Misc_templates_Full.html +16px-FEM_ShowResult.png +Preference_Draft_Tab_02.png +SpreadsheetAlignTop.svg +406px-Exercise_arch_01.jpg +24px-TechDraw_NewAnnotation.png +Installing_more_workbenches.html +Macro_FCTreeView_30.png +Constraint_Parallel.html +CustomizeToolBar_17.png +32px-Arch_Survey.png +Custom_Spacing.html +Polarpattern_example2.jpg +Cylindricity.svg +SpNav-Roll.svg +NavigationTouchpad_Select.svg +Arch_JSON.html +Part_Cut.svg +16px-Arch_RemoveShape.png +Path-Stock.svg +Macro_FaceToSketch.html +Easy-cutouts.gif +DraftViewSample.png +700px-Pic1.png +Part_Loft_Liste_Auswahl_3d.png +Caliper-ico.png +Shapebinder_tree.png +Application-exit.svg +PartDesign_Subtractive_Loft.svg +FEM_ElementFluid1D.html +Bugtracker.html +Draft_Style_Couleur_Ligne.png +Section-up.svg +Sketcher_CreateFillet.svg +SketcherCreateSquareExample.png +A0_Portrait_plain.svg +FemWorkbench.jpg +Tache_Placement_fr_01.png +Preferences-draft.svg +Preference_Path_Tab_01_1.png +View-right.svg +Elbow_equality_90%C2%B0to_vertical.png +Macro_Compound_Plus.png +PythonDevelopmentEnvironment.jpg +FreeCAD-Ship-LoadIco.png +640px-CustomizeToolBar_18.png +32px-Mesh_ExportMesh.png +Draft_Circle.svg +Path-Axis.svg +400px-Macro_Connect_And_Sweep_06.png +24px-PartDesign_AdditivePrism.png +800px-TBHS2-32.JPG +256px-LengthConstraint1.png +Part_Section.html +Land_Survey_Workbench_Blueprint.html +Fem-analysis.svg +32px-Macro_DeepCopy.png +32px-PartDesign_Body.png +Module_Creation.html +500px-Sketcher_EllipseExample1.png +PartDesignConstraintPointOnPointScriptingFigure4.jpg +250px-Setup_Bottle.JPG +Macro_Make_Arc_3_Points.html +Workbench_Arch.svg +32px-PartDesign_Hole.png +800px-TBHS2-22.JPG +Path-ToolChange.svg +600px-Arch_Section_example2.jpg +Bound-expression.svg +Arch_tutorial_15.jpg +32px-Robot_Edge2Trac.png +Arch_panel_tutorial_03.jpg +Arch_E2_Portrait.svg +Button_valid.svg +16px-Arch_PipeConnector.png +Part_Point.html +24px-PropertyMemo.png +Arch_B_Landscape.svg +24px-PartDesign_SubtractiveWedge.png +Path_Job.html +800px-InkFinishedArt.png +Part_Offset_Tasks.png +600px-Plot_Trigonometric_Example.png +16px-UShapeRebar.png +Techdraw-new-pick.svg +800px-TBHS2-28.JPG +SketcherTrimExample2.png +Macro_FCTreeView_14.png +Part_BooleanFragments.html +32px-Spreadsheet_Create.png +Constraint_Lock.html +32px-Part_Offset.png +PythonOCC.html +800px-TBHS-1.JPG +700px-Figure12_Deformed_Mesh_Clipped_View_%282%29.png +1024px-Drill-FreeCAD.png +New_GW_GUI.png +32px-Part_Union.png +32px-Arch_Remove.png +Drawing_Dimensioning_example.jpg +PD_WB_Tutorial005.png +Part_Chamfer-Properties.png +Macro_Perpendicular_To_Wire_04.png +16px-Sketcher_CreateHexagon.png +Arch_Check.svg +Macro_Install_HowTo_11.png +32px-Points_ImportPoints.png +Constraint_TangentToEnd.svg +Macro_installer_01.jpg +200px-Macro_FCInfo_06.png +Mouse_Model.html +700px-Pic7.png +Mac.png +640px-WF.png +24px-Workbench_Robot.png +Web-sketchfab.svg +Drawing-landscape.svg +Step9_triangle_ready.png +TechDraw_Dimension_Horizontal.html +32px-Draft_Heal.png +32px-Std_MeasureToggleAll.png +Drone_Design_Full.jpg +Robot_CreateTrajectory.html +24px-FCSpring_Helix_Variable.png +800px-TBHS2-8.JPG +Draft_Slope.svg +32px-Path_Profile.png +200px-FCCircularText_30.png +Part_Line_Parametric.svg +12px-Draft_Edit.png +Robot_RestoreHomePos.html +32px-Constraint_EqualLength.png +16px-Arch_Space.png +Draft_ToggleSnap.html +Tut17_rectangleholeconstrained.png +32px-Arch_Add.png +Arch_panel_tutorial_18.jpg +Path_Area_Workplane.html +Localisation.html +Arch_E3_Landscape.svg +Preference_Import_Export_Tab_05.png +24px-Dimension_Diameter.png +Path_Post.html +32px-Snap_Intersection.png +133px-Macro_Draft_Circle_3_Points04.png +32px-TechDraw_NewSection.png +Path-PostOutput.gif +16px-Path_Inspect.png +FreeCAD05_Tango_Face-plain.svg +FCCamera_01.png +Path-BPause.svg +32px-OpenSCAD_ExplodeGroup.png +300px-PartDesign_Chamfer-01.png +PD_WB_Tutorial014.png +534px-Arch_panel_tutorial_01.jpg +Macro_FCConvertLines_07.png +Sketcher_Create3PointArc_Constr.svg +267px-FCCircularText_59.png +Constraint_Symmetric.svg +Path-BStop.svg +250px-Tria6--fc.png +FreeCAD05_Tango_Dialog-warning.svg +LocalZBefore2.png +Edit-cut.svg +Center-align-faces.png +32px-Draft_FlipDimension.png +Vector_API.html +Fem-constraint-flow-velocity.svg +Draft_Mirror.html +Macro_Half-Hull_Model.html +PartLineProperty_it.png +Macro_Half-Hull_ModelImage4.jpg +32px-Robot_CreateTrajectory.png +300px-Loft_crescent_pentagon.png +Tree_Annotation.svg +256px-ConstrainParallel3.png +PD_WB_Tutorial011.png +Assembly_Demo.svg +Std_Tool11.svg +16px-Draft_Wire.png +Organization_chart.html +256px-ConstrainRadius4.png +Macro_CloneConvert.html +Arch_tutorial_18.jpg +Arch_tutorial_34.jpg +18px-Macro_FCTreeView_18.png +Fem-femmesh-boundary-layer.svg +32px-Constraint_InternalAlignment.png +Arch_tutorial_33.jpg +Macro_Repro_Wire.html +600px-Plot_MultiAxes_Example.png +32px-Part_Box.png +18px-Macro_FCTreeView_22.png +Plot_Axes.png +Drawing-spreadsheet.svg +Tut17_slote_constrained.png +Arch_Wall.svg +OpenSCADexamaple1.png +Macro_Manage_Navigational_Style.html +Macro_Install_HowTo_13.png +400px-HolderTop2-16.jpg +PartDesign_Pocket.html +400px-FCCircularText_01.png +Arch_presets_example.jpg +Arch_IFC.html +Part_Attachment.svg +16px-Draft_BSpline.png +400px-HolderTop1-14.jpg +30px-Robot_TrajectoryCompound.png +TechDraw_Enhancement_Project.html +Path-Datums.svg +32px-Macro_Build_Utility.png +NavigationMayaGesture_PanTouch.svg +600px-Mantisbt-colorized-code-example.jpg +1024px-Satnogs_Rotator_FreeCAD.jpg +Icone02.png +16px-Draft_Move.png +Sketcher_Element_Elliptical_Arc_Edge.svg +Ship_GZ.svg +Group.svg +400px-Draft_Rectangle_example.jpg +Macro_FCTreeView_01.png +800px-TBHS-15.JPG +Arch_Space_Tree.svg +PartDesign_SubtractiveSphere.html +24px-View-top.png +Release-0.13-Origin.png +32px-PartDesign_AdditiveCylinder.png +Macro_SelectVisible.html +800px-StraightRebar.png +Sketcher_triangle3_fc_small.png +System-log-out.svg +Macro_Connect_And_Sweep_CE.png +Tree_Part_Cylinder_Parametric.svg +24px-DrawStyleWireFrame.png +Robot_Simulate.html +Arch_Nest.html +PartDesign_Body_tree.png +Method.svg +397px-Texture_Topographie.png +ANSI_E_Landscape.svg +1024px-Freecad-bearing.png +Draft_Select.html +Workbench_Draft.svg +Branding.html +Path-Custom.svg +429px-Drawing_tutorial_result.png +24px-TechDraw_GeomHatch.png +256px-EqualConstraint7.png +32px-Constraint_PointOnPoint.png +PartDesign_SubtractiveWedge.html +16px-FEM_RunCalculiXccx.png +32px-Snap_Special.png +Macro_Align_Camera_to_Working_Plane.html +16px-Sketcher_RectangularArray.png +Draft_Rotate.html +Macro_MessageBox.html +FreeCAD-Ship-S60ShipCreationSide.png +250px-Tetra10--fc.png +Sketcher_CreateTriangle.svg +Arch_Stairs.html +Drawing_Documentation.html +1024px-Rockn_house1.png +Sketcher_MapSketch.html +32px-PartDesign_Boolean.png +TechDraw_ProjFrontTopLeft.svg +18px-Macro_FCTreeView_10.png +32px-Arch_Rebar_BentShape.png +24px-PartDesign_Plane.png +Doublecad.jpg +256px-HorizontalConstraint2.png +A2_Landscape_plain.svg +Source_code_management.html +Part_Box.html +TechDraw_Dimension_Length.svg +Macro_Half-Hull_ModelOption1.jpg +32px-FreeCAD-Ship-LoadIco.png +600px-Part_Offset2D_Join.png +780px-WizardShaft_Part.jpg +SpreadsheetAlias.svg +FEM_project.html +400px-Draft_Upgrade_example.jpg +Sketcher_CreateCircle_Constr.svg +480px-Macro_BoundingBox_Tracing_01.png +Workbench_Test.svg +FEM_ResultShow.html +Fem-cut.svg +A3_Landscape.svg +200px-Colorchart.png +FCCircularText_10.png +16px-Std_DuplicateSelection.png +200px-Macro_HighlightDifference_00.png +TechDraw_Module.html +24px-GW_Dim.png +32px-Snap_Midpoint.png +Draft_BSpline.html +Mesh_Ellipsoid.svg +Std_Close.png +1024px-FreeCAD_aeroponic_system.jpg +Ellipse-example.png +32px-Sketcher_Hyperbolic_Arc.png +Draft_API.html +Arch_CloseHoles.svg +Draft_PathArray.html +Constraint_VerticalDistance.svg +CompileOnWindows.html +300px-PartDesign_Fillet-02.png +32px-Techdraw-saveSVG.png +Arch_Rebar_Helical.html +Arch_Rebar_UShape.html +Arch_ToggleIfcBrepFlag.html +16px-Draft_Circle.png +NavigationGesture.svg +Mesh_Export_Mesh.svg +256px-LengthConstraint10.png +FreeCAD05_Tango_Applications-ristretto.svg +Step5_helper_vertex.png +Arch_panel_tutorial_04.jpg +Constraint_Horizontal.svg +Ship_Instance.svg +Draft_WireToBSpline.html +Sketcher_Conic_Sections.html +A4_Portrait_ISO7200TD.svg +800px-TBHS2-2.JPG +FreeCAD_Community_Portal.html +Fem-sphere.svg +Arch_schedule_example02.jpg +24px-Measure.png +Arch_Bimserver_panel.jpg +NavigationOpenCascade_PanAlt.svg +32px-Techdraw-symbol.png +Macro_Half-Hull_ModelImage3.jpg +600px-PartDesignConstraintPointOnPointScriptingFigure3.jpg +Workbench_Test.png +Arch_SplitMesh.svg +Aliasmanager_screenshot.png +650px-Cylinder.png +2Placements800.png +JschremppFCADEdit4.png +Google_Summer_of_Code_2018.html +Macro_Dxf_To_Shape.html +32px-Constraint_PointOnEnd.png +Part_Export.svg +32px-Std_ViewFitAll.png +16px-Draft_Drawing.png +Assembly_Assembly_Part_Tree.svg +Arch_tutorial_45.jpg +TechDraw_Tree_Multi.svg +32px-Path_Dressup.png +480px-FEM_example01_pic00.jpg +ParametersWindowDouble.svg +Arch_E1_Portrait.svg +32px-OpenSCAD_Hull.png +A2_Landscape_ISO7200TD.svg +400px-HolderTop2-11.jpg +Draft_Slope.html +800px-TBHS2-29.JPG +Draft_Polygon.svg +24px-PartDesign_AdditiveLoft.png +Macro_HighlightCommon.html +PartDesign_SubtractiveSphere.png +Part_Revolve.html +Quadrangles.gif +TechDraw_Tree_Section.svg +32px-FEM_MeshNetgenFromShape.png +CameraPosition1_it.png +TorusExampleRadius1.jpg +Sketcher_Trimming.svg +Path-OperationA.svg +32px-Sketcher_CreateArc3Point.png +245px-Macro_FCInfo_05.png +Reference_editable.svg +32px-Sketcher_SelectRedundantConstraints.png +Shapebinder_flow.png +Expressions.html +Arch_site_example_01.jpg +ProjGroupSample.png +FreeCADGui_API.html +FCCircularText_20.png +Sketcher_ViewSketch.svg +Tutorials.html +32px-FEM_PostCreateClipFilter.png +Export_to_STL_or_OBJ.html +30px-Robot_Export.png +600px-Arch_window_openings.png +30px-Robot_Simulate.png +Arch_tutorial_11.jpg +32px-Raytracing_ExportProject.png +FCCamera_Axis_rotation_X.png +338px-CuttingSettings.jpg +FEM_PostApplyChanges.html +800px-TBHS-24.JPG +Path-ToolConfig.gif +Mesh_BoundingBox.html +267px-Draft_selection_01.png +480px-Macro_3d_Printer_Slicer_00.png +500px-Sweep-frenet-comp.png +300px-Macro_Install_HowTo_21.png +Fem-warp.svg +800px-TBHS2-6.JPG +32px-TechDraw_NewArch.png +Sketcher_External.html +TechDraw_Arch_example.jpg +Raytracing_Part.html +FEM_ConstraintTemperature.html +16px-Draft_ToggleConstructionMode.png +Glossary.html +Arch_tutorial_54.jpg +Artwork.html +Path-Hop.svg +Scenegraph.html +Path_Profile_by_Faces.png +NavigationGesture_RotateAlt.svg +Draft_Pattern.html +Macro_FCTreeView_22.png +ViewSection.png +Lou_papet.png +Mesh_Demolding.html +V2_scale.png +Tut17_profile.png +Sketcher_ConstrainTangent.html +Std_ViewExamples.html +NavigationGesture_Zoom.svg +250px-HelicalRebarDialog.png +Macro_FCConvertLines_05.png +US_Letter_landscape.svg +24px-TechDraw_SaveDXF.png +Robot_Edge2Trac.svg +FCCircularText_18.png +Assembly_ConstraintUnidirectional2.svg +Sketcher_PolylineExample1.png +256px-EqualConstraint2.png +PartDesign_SubtractiveWedge.png +Banner.jpeg +Draft_Finish.svg +220px-Macro_CloneConvert_01.png +Macro_Half-Hull_ModelScreenSnapshot2.jpg +Manipulator-WB-Dimension-2.gif +TechDraw_SaveDXF.html +320px-Slice_example_step4.png +200px-FCCircularText_39.png +Fem_ResultDisplacement.svg +Svg_Namespace.html +Std_SetColors2_it.png +Macro_Perpendicular_To_Wire.html +780px-Inkscape_Template_tut_1.png +Draft-tutorial-blocks.jpg +480px-Macro_FCTransparentInfo_00.FCMacro.png +Path-Simulator.svg +267px-FCCircularText_52.png +Mesh_Sphere.svg +Sketcher_Element_SelectionTypeInvalid.svg +FEM_PostCreateClipFilter.html +Arch_Building.html +32px-FEM_ConstraintPulley.png +Mesh_EvaluateCurvature.html +SectionCross1.png +Std_Export.html +Sketcher_BSplineDecreaseDegree.svg +View.svg +400px-Macro_FCWire_To_Volume_01.png +Aeroplane.html +Arch_schedule_example03.jpg +Feature.svg +Std_ViewBoxZoom.html +Macro_Rotate_To_Point.svg +Web_Sketchfab.html +32px-Constraint_Symmetric.png +Document-print.svg +CustomizeToolBar_11.png +Drawing_Orthoviews_Options.png +PartPlane.png +Brga-spessore.png +16px-Arch_Schedule.png +Dxf_Importer_Install_04.png +Arch_tutorial.html +24px-View-unselectable.png +16px-Arch_Panel_Sheet.png +480px-Macro_CenterFace_00.png +300px-Macro_FCInfoGlass_04.png +FEM_ConstraintPulley.html +16px-Arch_Grid.png +Draft_Text.html +800px-FreeCAD011.png +PartDesign_PolarPattern.svg +24px-Mesh_ImportMesh.png +Path_Preferences.html +Mesh_Intersection.html +16px-Std_Edit.png +24px-FCCreaLoft.png +Macro_Half-Hull_ModelOption3.jpg +FEM_ConstraintInitialTemperature.html +32px-Arch_cloneComponent.png +Image_Import.html +FCSpring_Helix_Variable_Icon_03.png +Drawing-orthoviews.svg +32px-Plot_Series.png +32px-Cabinets32.png +Std_Cut.html +FreeCAD_and_Mesh_Import.html +250px-Hexa8--fc.png +32px-FEM_SolverZ88.png +View-rotate-left.svg +Fem-material.svg +Path-Pocket.svg +TechDraw_ProjTop.svg +Draft_AddToGroup.html +32px-Sketcher_CreateFillet.png +FCCircularText_07.png +250px-Hexa8--ccx.png +Tut17_profilewithsideblocks.png +250px-Tria6--ccx.png +500px-HTCaeroplane04.png +PartDesign_SubtractiveEllipsoid_example.svg +Part_Cylinder.svg +780px-Arch_Wall_example.jpg +FEM_EquationFlow.html +View-zoom-border.svg +FCCircularText_06.png +NavigationGesture_SelectTouch.svg +Part_Common.svg +A4_Landscape.svg +600px-FCTexture_007_FreeCAD_ASCII_00.png +Tutorial-normand07.jpg +AppImage-logo.png +Part_Measure_Angular.svg +Mesh_Cylinder.svg +32px-TechDraw_ClipMinus.png +32px-Constraint_HorizontalDistance.png +PD_WB_Tutorial006.png +32px-OpenSCAD_Edgestofaces.png +Constraint_Symmetric.html +Path-3DSurface.svg +FEM_MeshGmshFromShape.html +Draft_Text.png +FCCamera_07.png +Part_Shapebuilder.svg +Path-SelectLoop.svg +FCCamera_Axis_rotation_Z.png +32px-PropertyMemo.png +Macro_Texture_Objects.html +16px-View-rotate-right.png +700px-Figure_11_Deformed_Mesh.png +KukaSegment4.jpg +Fem-control-solver.svg +Document-new.svg +Draft_DelPoint.svg +FEM_ConstraintDisplacement.html +Minkowski_example.jpg +Sketcher_Arc3Point.html +Sketcher_Element_Arc_EndPoint.svg +Arch_Equipment.svg +32px-Draft_VisGroup.png +Draft-tutorial-dims.jpg +ProjectShape1_it.png +Macro_FCSpring_Helix_Variable_03.png +Sketcher_Octagon.html +Macro_Connect_And_Sweep_LR.png +Perpendicularity.svg +267px-FCCircularText_26.png +Std_ViewDockUndockFullscreen.html +PartDesign_MoveFeatureInTree.html +FreeCAD05_Tango_Camera-photo.svg +Draft_Clone.svg +800px-InkXMLNameSpace.png +700px-Pic5.png +Arch_CloseHoles.html +Snap_WorkingPlane.svg +OpenGL_on_MacOS.html +OpenSCAD_ColorCodeShape.svg +32px-PartToVRML.png +GGTuto1_10.PNG +Macro_FCSpring_Helix_Variable_04.png +16px-Part_Fuse.png +Arrow-cw.svg +18px-Macro_FCTreeView_15.png +Ship_PlotGZ.html +PartDesign_SubtractivePrism_example.svg +32px-Part_Mirror.png +Fem-femmesh-netgen-from-shape.svg +640px-Dxf_Importer_Install_04.png +200px-FCCircularText_01.png +Arrow-up.svg +Arch_Fixture.svg +Tetraedres.gif +480px-Freecad-bearing.png +Macro_Build_Utility.html +32px-FEM_RunCalculiXccx.png +Release_notes_0.13.html +32px-Draft_ToggleGrid.png +640px-Draft_drawing_example.jpg +400px-Macro_screw_maker_01.png +A4_Portrait_US_FULL.svg +Customize_Toolbars.html +Assembly_ConstraintDistance.svg +FEM_Material.png +32px-Sketcher_ToggleConstruction.png +32px-Sketcher_CreatePolyline.png +250px-StraightRebarDialog.png +Localisation_Sidebar.html +Civil_Engineering_Workbench.html +32px-FEM_ElementGeometry1D.png +View-axonometric.svg +Preference_Draft_Tab_04.png +32px-FEM_PostPipelineFromResult.png +1024px-Partdesign_example.jpg +32px-Part_Loft.png +Part_Loft_solid_ruled_from3profiles_example_FreeCAD_0_13.jpg +Artwork_Grid.png +30px-Robot_SetHomePos.png +500px-Thread-stack-vs-proper.png +Raytracing_New.html +Drawing-clip.svg +Plot_Axes.html +24px-WF_wf.png +Macro_Delta_xyz.html +Freecadsplash017.png +Axoview-r.JPG +DagViewFail.svg +Techdraw-draft-view.svg +OpenSCAD_IncreaseTolerance.html +Crystal_Clear_app_terminal.png +330px-CuttingResult.jpg +250px-Tetra10--ccx.png +158px-Texture_NanoDesign.png +Preference_Import_Export_Tab_02.png +Constraint_ExternalAngle.svg +Part_Attachment.html +Path-Engrave.svg +TechDraw_Dimension_Diameter.html +32px-Path_Job.png +External_workbenches.html +32px-Constraint_Parallel.png +680px-Macro_CartoucheFC_Modele_02.png +600px-Arch_Grid_example.jpg +16px-Arch_ToggleIfcBrepFlag.png +Macro_Select_Hovering.png +Workbench_Spreadsheet.svg +Sketcher_CreateArc.svg +32px-PartDesign_LinearPattern.png +Snap_Ortho.svg +800px-TBHS-10.JPG +Feature9.jpg +24px-Std_Tool7.png +Mesh_CurvaturePlot.html +100px-Cycloidegear.png +Macro_MacroMenu.html +Sketcher_Element_BSpline_Edge.svg +Sketcher_LeaveSketch.svg +ThicknessEsempio1.png +BSplineSurf.svg +Robot_tutorial.html +TechDraw_ProjFrontTopRight.svg +800px-TBHS-20.JPG +PartDesignWorkbench.svg +200px-Macro_WorkFeatures_10.png +32px-Std_Alignment.png +Arch_Frame_Tree.svg +FCCamera_00.png +Sketcher_Create3PointCircle.svg +Positions.svg +Sketcher_Triangle.html +480px-Macro_View_Rotation_00.png +296px-Macro_Align_Object_to_View_03.png +Reverse_Engineering_Workbench.html +12px-Draft_FinishLine.png +Feature5.jpg +Path-Compound.svg +Kate2.png +KukaSegment5.jpg +16px-Arch_Structure.png +Edit-paste.svg +PySideScreenSnapshot3.jpg +Manipulator-WB-Assembly-Parts.gif +A3_Landscape_ISO7200.svg +SpNav-Tilt.svg +FAQ.html +32px-Std_Refresh.png +32px-Arch_SplitMesh.png +UnsavedDocument.png +32px-Part_Cylinder.png +FreeCAD_development_model.html +16px-Std_DlgPreferences.png +Arch_tutorial_32.jpg +NavigationOpenInventor_Pan.svg +Dxf_Importer_Install_08.png +Macro_FCTreeView_13.png +Arch_tutorial_04.jpg +Cartouche_01_Convention_EU.svg +32px-Constraint_PointOnObject.png +Line.svg +FCCircularText_19.png +400px-Draft_Scale_example.jpg +Tree_Part_Wedge.svg +Std_DlgMacroStop.html +Draft_DelPoint.html +32px-TechDraw_Dimension_Link.png +Sketcher_CreateSlot.svg +16px-Arch_Rebar_Helical.png +Sketcher_RectangularArray_Options.jpg +View-top.svg +640px-Macro_Install_HowTo_37.png +24px-Std_Test_framework.png +24px-FEM_ConstraintForce.png +250px-Tut17_sketchplanes.png +Preference_General_Tab_05.png +PartDesign_MultiTransform.svg +SpreadsheetAlignLeft.svg +Third_Party_Tools.html +Step12_define_ratio.png +315px-Path-WalkThroughResult.gif +32px-Draft_Mirror.png +16px-Path_SimpleCopy.png +Standard_Menu.html +Macro_unrollRuledSurface_01.png +Sketcher_Tutorial.html +640px-Bridge-all.png +16px-PartDesign_InvoluteGear.png +Draft_Rectangle.html +A4_Portrait_1_english.svg +24px-PartDesign_SubtractiveSphere.png +Ship_Module.svg +16px-Drawing_Annotation.png +Arch_DAE.html +32px-Part_Prism.png +Raytracing_Export.html +Macro_CartoucheFC_2.html +16px-Sketcher_MapSketch.png +TechDraw_Dimension_Vertical.html +480px-ObjectInfoIt.png +16px-Part_Common.png +Workbench_Web.svg +300px-Gripper.jpg +24px-PartDesign_AdditiveCone.png +32px-Half_turn_stairs.png +Constraint_InternalAlignment_Ellipse_Focus1.svg +Techdraw-clipminus.svg +32px-PartDesign_Pocket.png +NavigationGesture_RotateTouch.svg +Draft_ToggleContinueMode.html +Arch_BimServer.html +400px-Macro_HighlightDifference_02.png +TechDraw_Dimension.svg +TechDraw_Dimension_Radius.html +Online_Help_Toc.html +Sketcher_Square.html +Sketcher_External.svg +32px-Arch_SelectNonSolidMeshes.png +FEM_CalculiX.html +256px-LengthConstraint3.png +489px-FCCamera_15.png +Px.svg +800px-TBHS-13.JPG +Std_Windows_Menu.html +Std_Tool6.svg +32px-Part_Common.png +Tut17_final_refined.png +800px-JoinFeatures-Algo-Cutout.png +FEM_Mesh.html +16px-Sketcher_CreateTriangle.png +1024px-Rim_bling.png +200px-FCCircularText_33.png +Mesh_Evaluation.html +Stickyfonts.jpg +24px-Techdraw-image.png +Constraint_InternalAlignment_Ellipse_Focus2.svg +Arch_Git.html +32px-Std_DebugToggle.png +24px-Macro_Global_Variable_Watcher.png +Sketcher_Element_Point_StartingPoint.svg +250px-Attacher_mode_FrenetTB.png +Macro_FCInfoGlass.html +256px-LengthConstraint8.png +TorusExampleAngle3.jpg +400px-HTCaeroplane02.png +Tutorial-normand05.jpg +Workbench_Raytracing.svg +Part_Box.svg +16px-Constraint_Horizontal.png +Part_CompJoinFeatures.html +Part_RegularPolygon.html +Plot_Positions.html +Assembly_Add_Existing_Part.svg +Arch_Material.svg +Snap_Angle.svg +Accessories-text-editor.svg +Arch_panel_tutorial_05.jpg +24px-Std_Tool6.png +Arch_Rebar_Straight.html +FeatureSelectionView.jpg +FreeCAD05_Tango_Dialog-error.svg +256px-HorizontalConstraint5.png +32px-Arch_Rebar_Helical.png +Path_ProfileFace.html +24px-Std_WindowTileVer.png +400px-HolderTop2-18.jpg +FEM_PostCreateDataAtPointFilter.html +640px-Draft_WP_preview.png +PartDesign_Subtractive_Box.svg +SpreadsheetController.svg +24px-TechDraw_NewProjGroup.png +Constraint_Length_Driven.svg +256px-SymmetricConstraint1.png +Help-browser.svg +32px-Arch_CloseHoles.png +32px-Std_DuplicateSelection.png +30px-Part_Box.png +Flamingos_frame2.jpg +212px-Exercise_drawing_01.jpg +Part_CheckGeometry.svg +Meshes_RemoveComponents.jpg +ParametersSlab.svg +Arch_materials_01.jpg +Constrain2.png +NavigationMayaGesture_Pan.svg +32px-Part_BooleanFragments.png +800px-TBHS2-13.JPG +Object_API.html +Manipulator-WB-Measure-Angles.gif +Sketcher_CreateHeptagon_Constr.svg +Arch_SelectNonManifold.svg +32px-Mesh_MeshFromShape.png +Kate1.png +24px-Part_SectionCross.png +Sketcher_CreateHeptagon.svg +Sketcher_Element_Line_EndPoint.svg +ArchDesign.png +Chord_length.png +32px-Arch_Rebar_UShape.png +FEM_MaterialMechanicalNonlinear.html +32px-Arch_3Views.png +24px-Macro_Draft_Circle_3_Points.png +FCTreeView.gif +24px-Workbench_PartDesign.png +NavigationGesture_Rotate.svg +Constraint_InternalAngle.html +Arch_E2_Landscape.svg +PartDesign_Hole.html +32px-Std_Print.png +Spiral_y45_it.png +32px-Path-Profile-Face.png +Std_SaveaCopy.html +16px-Draft_Heal.png +Manipulator-WB-Dimension.gif +Macro_FCSpring_Helix_Variable_08.png +Std_ViewScreenShot.html +Path_inspector.jpg +Hexaedres.gif +Workbench_Mesh.svg +User.svg +Arch_schedule_example01.jpg +Macro_FCTreeView_16.png +32px-Ship_Load_Example.png +32px-PartDesign_Draft.png +Draft_ShapeString.png +Part_Thickness.html +Macro_Install_HowTo_09.png +800px-TBHS-7.JPG +Step12_define_rectangle.png +Macro_ObjectInfo.html +24px-PartDesign_SubtractiveCone.png +Raytracing_ResetCamera.html +24px-Macro_Compound_Plus.png +256px-LockConstraint6.png +WhatsThis.svg +Zoom-out.svg +Arch_ToggleSubs.html +16px-Drawing_Symbol.png +Spinning.html +Drawing_templates.html +16px-Sketcher_ViewSketch.png +Drawing_Annotation.html +TBHS-0.png +Mesh_TrimMesh.png +Std_FreeCADWebsite.html +70px-Select-touchpad.png +Workbench_Inspection.svg +16px-Sketcher_CreatePentagon.png +Dxf_Importer_Install_01.png +Draft_VisGroup.html +Arch_Component_Clone.svg +A4_Landscape_plain.svg +Part_Sphere.svg +Path-Profile-Edges.svg +32px-Std_About.png +24px-Macro_makeCube.png +Arch_schedule_example05.jpg +Macro_FCTreeView_10.png +640px-Macro_Install_HowTo_04.png +32px-Std_DlgParameter.png +PartDesign_SubtractiveCone.html +Sketcher_CreateHexagon.svg +Appveyor.svg +Part_Fillet.html +Draft_Extension.html +Path_FromShapes.html +Rectellipse.png +Arch_Add.html +24px-Workbench_Draft.png +Drawing_Orthoviews.html +Draft_Polygon.png +16px-Spreadsheet_Controller.png +267px-Sketcher_ConstructionMode_fr_02.png +Arch_Structure.html +Sketcher_SelectVerticalAxis.html +599px-Figure_11_Deformed_Mesh.png +Macro_Half-Hull_ModelImage6.jpg +640px-Macro_Install_HowTo_31.png +Threadform.PNG +Meshes_RegularSolid_Cube.jpg +Assembly2_example.jpg +Path_Customization.html +32px-Std_Paste.png +Path-Holding.svg +DumpObjectsGui2.jpg +640px-Macro_Install_HowTo_03.png +Tutorial-normand06.jpg +120px-Blade.JPG +Draft-tutorial-01.jpg +Macro_FCInfo_Alternate_Linux.html +Placement_API.html +Part_Fillet.svg +Grid.svg +24px-PartDesign_AdditiveBox.png +Macro_DeepCopy.html +Draft_ShapeString_tutorial.html +Robot.jpg +View-front.svg +600px-Sketcher_ConsraintTangent_mode4.png +Arch_Window_Tree.svg +32px-Ship_TankCapacity.png +Draft_Macro.svg +32px-Draft_Array.png +Dxf_Importer_Install_10.png +500px-Thread-by-vertical-profile.png +PartDesign_project.html +150px-Tache_Placement_Translation_X_fr.gif +PartDesign_Body_tree-03.png +Constraint_PointToObject.svg +680px-Macro_CartoucheFC_Full_00.png +32px-Draft_Near.png +32px-Arch_SectionPlane.png +Part_Spiral_Parametric.svg +File_browser.png +480px-Macro_Connect_And_Sweep_00.png +Std_Group.html +Macro_Half-Hull_ModelKnownProblems1.jpg +ShapeString_To_Sketch.gif +800px-JoinFeatures-Algo-Embed.png +800px-FreeCAD-Ship-HydrostaticsCurves.png +Draft_ShapeString.svg +Draft_Shape2DView_example.jpg +800px-TBHS2-12.JPG +32px-FEM_CreateNodesSet.png +267px-FCCircularText_56.png +TechDraw_NewView.html +ArchExample.png +GeometryCheck_Errors.jpg +NavigationMayaGesture_PanTouchAlt.svg +Path-3DPocket.svg +MacroEditor.svg +Dxf_Importer_Install_05.png +Kate3.png +267px-Macro_FCSpring_Helix_Variable_18.png +Draft_Dot.svg +24px-Macro_Overlap.png +Preferences-openscad.svg +Feature1.jpg +Macro_FCTreeView_31.png +Std_Revert.html +Labels.svg +32px-Draft_Dimensions.png +Arch_Roof.svg +Macro_MeshToPart.html +Step14_rectangle_with_golden_ratio.png +32px-Std_OnlineHelp.png +Fem-constraint-planerotation.svg +Macro_Guitar_fretboard.html +300px-Loft_Number_of_verts_match.png +32px-PartDesign_Mirrored.png +Property.svg +Techdraw-projgroup.svg +Macro_Rotate_To_Point_00.png +Path-JobCreationDialog.png +PartDesign_SubtractiveTorus_example.svg +32px-PartDesign_Thickness.png +NavigationTouchpad.svg +32px-Raytracing_Part.png +1024px-JMG.png +Meshes_Boolean_Intersection.jpg +32px-Macro_Toggle_Views_Visibility.png +320px-JoinFeatures_Example_step4_Embed.png +Arch_Wikihouse_03.jpg +SpiralDefault_it.png +Screenshot_classbrowser.jpg +500px-Std_Alignment2.png +1024px-Style_Sheets.png +CustomizeToolBar_08.png +Spreadsheet_Workbench.html +Snap_Dimensions.svg +Path_Custom.html +Arch_Window.html +Draft_Line.html +PartVertexProperty_it.png +PARTMirrorBeforev11.png +600px-Macro_3D_Parametric_Curve.png +500px-Sketcher_helper_constraint_example1.png +TechDraw_Tree_Page.svg +TechDraw_ProjBottom.svg +Part_Section.svg +16px-Arch_Rebar_Straight.png +Command_Reference.html +Whiffle_Ball_tutorial.html +Std_Open.html +KukaAxisData.jpg +16px-Draft_Facebinder.png +Macro_FCTreeView_04.png +ANSI_E_Portrait.svg +Utube-alignment-STEP-models.png +Arch_Pipe.svg +ProjectShapeOptions_it.png +Path-OperationB.svg +Std_DebugToggle.html +Raytrace_New.svg +Arch_Wikihouse_01.jpg +16px-WF_wf.png +24px-Macro_Toggle_Views_Visibility.png +CustomizeToolBar_04.png +16px-Arch_Site.png +Part_Cone.html +Path-Shape.svg +16px-Path_GcodeFromShape.png +NavigationGesture_Pan.svg +256px-Tache_Placement_fr_04.png +Part_BooleanFragments.svg +700px-Arch_panel_wave.jpg +OpenSCAD_Edgestofaces.html +640px-Spreadsheet_screenshot.jpg +Sketcher_CreateText.svg +Arch_pipe_example_04.jpg +Macro_Manage_Navigational_Styles2.png +Macro_Animated_Constrain.html +32px-Path_Custom.png +Freecadsplash15.png +24px-Sketcher_Point.png +Assembly_ConstraintOpposite.svg +Fem-constraint-initial-flow-velocity.svg +Arch_pipe_example_03.jpg +Std_Help_Menu.html +Feature_spreadsheet.png +32px-Macro_FCConvertLines.png +Fem-plane.svg +32px-FEM_ConstraintHeatflux.png +Draft_Style_01.png +PartDesign_SubtractiveCylinder.png +Arch_A_Landscape.svg +32px-Snap_Near.png +FEM_ConstraintFixed.html +DraftPatternSample.png +32px-Std_DlgMacroExecute.png +Arch_tutorial_27.jpg +16px-TechDraw-spreadsheet.png +100px-Bevelgear.png +250px-Bodycs.png +Macro_Sheet_Metal_Unfolder.html +Sketcher_CreateEllipse_Constr.svg +A3_Landscape_US_Text_Complet_With_Convention_EU.svg +TechDraw_Dimension_Diameter.svg +Draft_Rectangle.png +PD_WB_Tutorial019.png +Preference_Arch_Tab_01.png +16px-Draft_Dimension.png +Constraint_PointOnObject.svg +Cut.svg +24px-Macro_Dump_Objects.png +ClippingPlane1_it.png +200px-Macro_WorkFeatures_07.png +Material_editor.jpg +Constraint_Draft_Code01.gif +Fem-equation-fluxsolver.svg +Path-ExportTemplate.svg +JschremppFCADEdit1.png +FCTexture_Example.gif +32px-Path_ToolNumberToLoad.png +400px-Draft_construction_mode_example.jpg +Macro_Solid_Sweep.html +Part_Box-Properties.jpg +200px-PartDesign_AdditivePrism_example.png +Part_Measure_Toggle_Delta.svg +Plot_Legend.png +Part_Circle.html +32px-Std_OnlineHelpWebsite.png +Draft_BezSymNode.svg +Techdraw-new-default.svg +640px-Arch_Stairs_example.jpg +256px-IconAnatomy.png +250px-LShapeDialog.png +24px-Part_ExportCAD.png +NavigationBlender_Rotate.svg +Web-stop.svg +Std_ClippingPlane.png +16px-Constraint_EqualLength.png +A3_Landscape_ISO7200TD.svg +Workbench_Path.svg +Screenshot_arch_multiwall.jpg +Drawing_Template_HowTo.html +18px-Macro_FCTreeView_13.png +Tache_Placement_en_03.png +Fem-femmesh-gmsh-from-shape.svg +Workbench_Part.svg +Mesh_Difference.png +FlamingoBlob.png +Drawing_Module.html +480px-PreferencesDecimals_01_en.png +NavigationGesture_PanTouch.svg +640px-Dxf_Importer_Install_01.png +32px-TechDraw_Hatch.png +Draft_Point.html +16px-Part_Thickness.png +Draft_Upgrade.html +Ship_AreaCurve.svg +OpenSCAD_Workbench.html +Mesh_Merge.html +View-rotate-right.svg +32px-Snap_Center.png +Draft_FinishLine.html +Macros.html +Part_Offset.html +32px-Macro_Draft_Circle_3_Points.png +Constraint_Concentric.html +Tut17_rechtangleholeunconstrained.png +KukaAxisPosition.jpg +Raytrace_Lux.svg +Plot_Labels.html +DiameterSample.png +Macro_FCTreeView_12.png +16px-Drawing_Openbrowser.png +407px-Sketcher_ArcExample2.png +24px-PartDesign_Line.png +Arch_Cell_Tree.svg +PartDesign_LinearPattern.html +PD_WB_Tutorial009.png +FreeCAD_and_DWG_Import.html +32px-Arch_MultiMaterial.png +Freecad-solar-diagram.jpg +Inkscape_Template_tut_4.png +MIBA.html +Techdraw-saveSVG.svg +Assembly_ConstraintEqual.svg +32px-Snap_Endpoint.png +142px-Draft_Selection_Menu.png +32px-Draft_Circle.png +Naming_project.html +Save.svg +Part_Module.html +32px-Std_PythonWebsite.png +1024px-Pic_06.jpg +32px-FEM_PurgeResults.png +Raytrace_Part.svg +32px-Techdraw-arch-view.png +32px-Path_Helix.png +300px-Macro_Install_HowTo_28.png +Mesh_API.html +32px-Macro_Copy3DViewToClipboard.png +32px-Path_Fixture.png +351px-Macro_Work_Features_Cutting_07.png +16px-Constraint_Radius.png +Arch_pipe_example_07.jpg +24px-Sketcher_Expressions.png +Arch_Wikihouse_02.jpg +Draft_SelectGroup.svg +freecad.qhp +PartDesign_Line.html +Draft_Coordinates.jpg +JschremppFCADEdit3.png +Raytracing_Module.html +Part_Classes.jpg +Arch_Remove.svg +Sketcher_Circle3Point.html +Tree_Mesh.svg +400px-Macro_Connect_And_Sweep_04.png +CompleteWorkbench.svg +250px-BentShapeDialog.png +FreeCAD-Ship-OutlineDrawIco.png +Std_Refresh.html +Path_Area.html +Arch_Panel_Sheet.svg +Pipeline.PNG +Ship_Logo.svg +Raytracing_Workbench.html +32px-Sketcher_Conics.png +Arch_E_Portrait.svg +400px-Productcs.png +16px-Std_Copy.png +32px-Arch_Rebar_Straight.png +Sketcher_Element_Ellipse_Edge_2.svg +32px-Std_ProjectInfo.png +Dxf_Importer_Install_03.png +Arch_panel_tutorial_11.jpg +Transportation_Workbench.html +TechDraw_GeomHatch.png +TechDraw_Dimension_Vertical.svg +Frame_exercise_dimensions.png +TechDraw_ProjFrontBottomLeft.svg +Tut17_innerplane.png +View-unselectable.svg +GGTuto1_5.PNG +Touch_Pinch.svg +16px-Draft_Array.png +Sketcher_CreateRegularPolygon.svg +Macro_Constraint_Draft.html +PartDesign_Body_Create_New.svg +300px-PartDesign_Draft-06.png +Macro_Arch_Axis_System_Repartition.html +200px-PartDesign_AdditiveWedge_example.png +Draft_FlipDimension.svg +200px-FCCircularText_03.png +NavigationCAD_Pan.svg +PD_move_feature0.png +Macro_FCTreeView_00.png +Sketcher_Slot.html +FreeCAD05_Tango_Face-angel.svg +Manipulator-WB-Aligner.gif +Std_PythonConsole.png +ParametersWindowFixed.svg +Macro_FlattenWire3Points.html +16px-Path-Profile-Face.png +OpenSCAD_Explode_Group.svg +Macro_FCTreeView_02.png +640px-Dxf_Importer_Install_01b.png +FEM_PostPipelineFromResult.html +FreeCAD05_Tango_Applications-games.svg +48px-Macro_SelectVisible2.png +NavigationMayaGesture_RotateTouch.svg +Path_SetupSheet.html +32px-Std_Workbench.png +450px-Spaceball_Buttons.png +Fem-equation-flow.svg +24px-Techdraw-view.png +Path_DressupRampEntry.html +Fem-equation-elasticity.svg +Draft_Downgrade.png +Path_DressupTag.html +Fem-femmesh-region.svg +16px-FEM_ForceConstraint.png +Mesh_Smooth.png +32px-Sketcher_CreatePentagon.png +640px-Macro_Install_HowTo_05.png +Macro_CenterFace.html +24px-Std_RotateRight.png +Path_Inspect.html +133px-Macro_Draft_Circle_3_Points03.png +TechDraw_ProjFront.svg +Arch_tutorial_00.jpg +Sketcher_Element_Parabolic_Arc_Start_Point.svg +267px-FCCircularText_45.png +32px-FEM_ConstraintPlaneRotation.png +700px-Pic10.png +PartWedgeProperty_Inputs.png +FEM_SolverCalculixCxxtools.html +PartConeProperty_en.png +Sketcher_CreatePolyline.svg +600px-Msvc-no-vs_compiler-setup-32.png +Segments.gif +TechDraw_NewProjGroup.html +Macro_Connect_And_Sweep_LL.png +PartDesign_Boolean.svg +Zoom-fit-best.svg +Triangel_angle_small.png +Preference_Display_Tab_01.png +Touch_One-Finger-Drag.svg +Console_API.html +Cross.svg +Part_Common.html +Mesh_TrimMesh.html +Path-Tooltable.png +Path-Array.svg +Mesh_CreateMeshSegment.png +Tut17_profilewithslots.png +View-measurement.svg +Kate2a.png +Project_utility_en.png +88px-FCCircularText_22.png +UTF_Project.html +Robot_SetDefaultOrientation.html +RPH_after.png +32px-Arch_Stairs.png +16px-Draft_SelectGroup.png +PartDesign_Pad.svg +Draft_ToggleConstructionMode.html +300px-Macro_Install_HowTo_27.png +Std_Tool5.svg +Robot_InsertWaypoint.html +32px-FEM_PostCreateCutFilter.png +Manipulator-WB-%40Work.png +300px-TutorialDraftShapeString_Complete.jpg +MaterialProperties.png +24px-Macro_Dxf_To_Shape.png +Macro-execute.svg +Arch_tutorial_07.jpg +DeltaXYZ.png +TechDraw_TemplateHowTo.html +Woodgrain.svg +500px-Product_structure_modeling_Process-Data_diagram.gif +16px-Draft_CloseLine.png +Arch_IfcExplorer.html +24px-PartDesign_SubtractiveBox.png +Touch_Two-Finger-Drag.svg +Macro_Easy_cutouts_for_Enclosure_Design.html +16px-Arch_Frame.png +Part_Shape_from_Mesh.svg +32px-Draft_Line.png +267px-FCCircularText_54.png +600px-Multitransform_example.png +FEM_ElementRotation1D.html +FEM_EquationElasticity.html +800px-InkXMLeditableTag.png +InputField.html +CAM_project.html +Release-0.13-RubberBandSelection.png +480px-Fretboard_freecad2.png +MEPlanD.png +Techdraw-clipplus.svg +Macro_FCCreaLoft_01.png +Macro_FCTreeView_17.png +32px-Draft_Shape2DView.png +Macro_FCTreeView_05.png +Kate5.png +Fem-isosurface.svg +Sketcher_ToggleConstruction.html +267px-FCCircularText_51.png +16px-Std_Delete.png +1000px-ResourceFramework.png +Arch_Floor.html +Sketcher_Pentagon.html +PropertyMemo.png +Dialog-revolve.png +32px-PartDesign_AdditiveCone.png +Creating_a_simple_part_with_PartDesign.html +JschremppFCADEdit2.png +Constraint_Ellipse_Axis_Angle.svg +Copying_Objects.html +Arch_Site.html +Std_Part-tree.png +A3_Landscape_US_Text_Complet_With_Convention_US.svg +PartDesign_Additive_Ellipsoid.svg +Zoom_cursor.png +Drawing-dxf-export.jpg +16px-Arch_AxisSystem.png +32px-Part_Sphere.png +Sketcher_Polyline.html +Draft_SelectGroup.html +Web-previous.svg +32px-Part_Point.png +NavigationGesture_TiltTouch.svg +Sketcher_ToggleConstraint_Driven.svg +Macro_FCSpring_Helix_Variable.html +FreeCAD-Ship-Ico.png +WF_wf.png +256px-LengthConstraint9.png +TechDraw_NewDetail.html +351px-Macro_Work_Features_Cutting_05.png +Std_CommandLine.html +A3_Portrait_US_FULL.svg +32px-Part_CheckGeometry.png +Arch_Wikihouse_04.jpg +Arch_B_Portrait.svg +Sketcher_Reorient.html +24px-CenterFace.png +Macro_Duplicate_Selection.html +Solid.svg +Constraint_H_Distance.png +NavigationOpenCascade_Pan.svg +Green_tones.PNG +16px-Draft_Stretch.png +Constraint_PointOnMidPoint.html +Sketcher_CreateSquare.svg +GGTuto1_2.PNG +32px-Std_SaveAs.png +32px-Dimension_Vertical.png +640px-Macro_Circle_01.png +640px-Drawing_spreadsheetview.jpg +Path_Workbench.html +Tree_Part_Prism.svg +Draft_VisGroup.svg +18px-Macro_FCTreeView_16.png +300px-Translate-sidebar-instruction.png +16px-Std_Refresh.png +32px-Macro_Connect_And_Sweep.png +Part_RuledSurface.svg +SketcherCreateSlotExample.png +32px-Std_PrintPdf.png +NavigationBlender.svg +32px-Draft_Clone.png +Macro_Cross_Section_03.gif +250px-Quad8--fc.png +800px-InkDocProp.png +TechDraw_Arch_piping.jpg +600px-Sketcher_ConsraintPerpendicular_mode4.png +Path_Postprocessor_Customization.html +16px-Std_DlgMacroExecute.png +24px-DrawStyleShaded.png +Robot_Edge2Trac.html +Path-LengthOffset.svg +Dxf_Importer_Install_02.png +640px-Macro_Install_HowTo_02.png +Screenshot_draft.jpg +32px-OpenSCAD_Minkowski.png +32px-Sketcher_Copy.png +267px-Draft_selection_02.png +Spreadsheet_PropertyController.html +32px-Sketcher_Parabolic_Arc.png +32px-Path_Simulator.png +Arch_tutorial_10.jpg +Macro_FCConvertLines_04.png +400px-HolderTop1-8.jpg +200px-Macro_WorkFeatures_02.png +NavigationTouchpad_ZoomAlt.svg +Robot_Edge2Trac_Menu.jpg +SketcherCreatePentagonExample.png +32px-FEM_PostCreateWarpVectorFilter.png +PartDesign_SubtractiveEllipsoid.png +Arch_CutPlane_example.jpg +Manipulator-WB-Measure-Radius.gif +Draft_ToggleContinueMode.png +Drawing-view.svg +Macro_Align_Face_Object_to_View.html +1024px-Rockn_house2.png +Sketcher_Element_Ellipse_MinorAxis.svg +200px-AnnotationSample.png +32px-Dimension_Length.png +Arch_StructuralSystem_Tree.svg +View-zoom-all.svg +800px-TBHS-22.JPG +Feature-raytracing.jpg +24px-Macro_Python_Assistant_Window.png +A4_Landscape_US_Text_Complet_With_Convention_EU.svg +Path-Profile-Face.svg +Arch_tutorial_35.jpg +Manipulator.html +800px-Arch_panel_tutorial_01.jpg +PartDesign_Additive_Wedge.svg +Compile_on_Windows_with_VS2013.html +PartDesign_Pocket_example.svg +Mirrored_parameters.png +480px-Macro_Draft_Circle_3_Points_3D.png +16px-Arch_BimServer.png +296px-Macro_Align_Object_to_View_01.png +24px-FCCamera_03.png +Arch_StructuralSystem.svg +Arch_screenshot.jpg +Sketcher_CreateOctagon.svg +600px-Sketcher_ConsraintAngle_mode1.png +24px-Techdraw-viewsection.png +Draft_BSpline.svg +32px-Macro_Global_Variable_Watcher.png +SketcherCreateHeptagonExample.png +200px-Macro_FCSpring_Helix_Variable_12.png +Plot_Labels.png +Part_JoinBypass.svg +Macro_FCConvertLines_10.png +TechDraw_Tree_ProjGroup.svg +400px-HolderTop2-8.jpg +Arch_Rebar_BentShape.html +Mesh_PolySplit.html +450px-Spaceball_Motion.png +200px-Macro_WorkFeatures_03.png +PartDesign_Additive_Cone.svg +400px-HolderTop1-10.jpg +32px-FEM_ConstraintPressure.png +32px-Robot_TrajectoryDressUp.png +PartDesign_AdditiveLoft.html +Constraint_ExternalAngle.html +Path-FacePocket.svg +Macro_Overlap.html +Sketcher_BSplineIncreaseDegree.svg +Extend_FEM_Module.html +Constraint_Radius_Driven.svg +FEM_FemMesh2Mesh.html +16px-FEM_Solver.png +800px-Rim_bling.png +Arch_Rebar_Stirrup.html +800px-Stirrup.png +PartDesign_Boolean_example.png +FCInfo.png +Arch_Survey.html +32px-Constraint_Tangent.png +600px-CounterclockwiseWire.png +Path-BPlay.svg +Macro_Rotate_View.html +300px-Loft-closed.png +256px-EqualConstraint3.png +32px-Mesh_RegularSolid.png +Preference_Arch_Tab_02.png +FCCircularText_22.png +30px-Robot_InsertWaypointPre.png +Plot_MultiAxes_tutorial.html +351px-Macro_Work_Features_Cutting_08.png +600px-TutorialDraftShapeString_Sketch.jpg +32px-FreeCAD-Ship-OutlineDrawIco.png +Path_ProfileEdges.html +32px-Part_Section.png +Web.png +Sketcher_BSplineIncreaseKnotMultiplicity.svg +250px-UShapeDialog.png +16px-Spreadsheet_Create.png +32px-Drawing_View.png +Sketcher_Element_Hyperbolic_Arc_Edge.svg +Arch_tutorial_41.jpg +Meshes_RegularSolid_Sphere.jpg +Macro_Perpendicular_To_Wire_02.png +96px-Macros_toolbar.jpg +MeasureLinearDelta1.PNG +Path_SelectLoop.html +Path_SimpleCopy.html +Assembly_project.html +Arch_Floor.svg +32px-OpenSCAD_RemoveSubtree.png +Ship_Hydrostatics.svg +PartDesign_NewSketch.html +OpenSCADWorkbench.svg +Arch_Panel_Cut.svg +Sketcher_BSplineApproximate.svg +32px-Snap_WorkingPlane.png +Sketcher_SelectElementsAssociatedWithConstraints.html +32px-Text-x-python.png +1024px-Startcenter.jpg +FEM_ConstraintTransform.html +Macro_JointWire.html +Sketcher_Hyperbolic_Arc.svg +300px-Loft-vertex-insertion.png +Fem-purge-results.svg +800px-TBHS2-16.JPG +Product_structure_modeling_Process-Data_diagram.gif +TopoShape_API.html +267px-FCCircularText_31.png +32px-Std_Import.png +Qtpropeditor.jpg +Path-TreeWithJob.png +32px-Mesh_Cube.png +Constraint_Length.html +PartDesign_Fillet.html +Inkscape_Template_tut_3.png +Drawing-portrait-A1.svg +Draft_AutoGroup_off.svg +Sketcher_Validate_it.png +24px-PartDesign_Boolean.png +16px-Std_Undo.png +1000px-Macro_Boolean_Overlap_Screenshot.png +Std_Revert.png +32px-Part_RefineShape.png +KukaKR16FreeCAD.jpg +Builtin_modules.html +468px-Draft_tutorial_result.png +Macro_Geodesic_Dome.html +Document_structure.html +32px-TechDraw_ClipPlus.png +32px-Techdraw-viewsection.png +16px-Arch_Rebar_Stirrup.png +How_to_install_macros.html +Dxf_Importer_Install_11.png +600px-Part_Offset2D_Fill.png +16px-Path_ToolNumberToLoad.png +TechDraw_Tree_Page_Unsync.svg +800px-LShapeRebarNew.png +Elbow_fix_point_onto_object_52mm.png +32px-Draft_Text.png +Sketcher_CloseShape.svg +32px-Mesh_EvaluateFacet.png +Arch_Site.svg +480px-Macro_ReproWire_00.png +Arch_Component.svg +Material_editor.html +Arch_tutorial_26.jpg +800px-TBHS2-21.JPG +Arch_pipe_example_05.jpg +700px-FEM_example01_pic01.jpg +Path_Walkthrough_for_the_Impatient.html +24px-Constraint_PointOnObject.png +400px-Gripper.jpg +RenderButtons.png +Debugging.html +KukaSegment1.jpg +200px-FCCircularText_35.png +Inkscape_Template_tut_2.png +600px-RoofProfil.png +Movie.png +24px-Gearworkbech.png +Embedding_FreeCADGui.html +Constrain3.png +512px-PianoTaglio4.png +Touch_Rotate.svg +Draft_Arc.svg +FreeCAD05_Tango_Face-grin-braces.svg +A3_Landscape_english.svg +Drawing-landscape-A1.svg +Release-0.13-SketcherDimensions.png +Arch_Pipe_Tree.svg +Sketcher_CreateLine_Constr.svg +Dxf_Importer_Install_07.png +32px-Sketcher_Line.png +FCCreaLoft.png +Spreadsheet_screenshot.jpg +Arch_Site_Tree.svg +800px-TBHS-16.JPG +Ship_Hydrostatics.html +Geneva.png +Screenshot_qcad.jpg +View-zoom-selection.svg +256px-Tache_Placement_01_fr_00.png +Mesh_ExMakeTool.html +FC_Christmas.svg +Fem-constraint-transform.svg +Macro_Half-Hull_ModelImage7.jpg +Interface_screenshot.jpg +PD_WB_Tutorial002.png +600px-Patharray_alignment-XZ.png +24px-PartDesign_SubtractiveCylinder.png +300px-Part_Extrude_dialog.png +Macro_Align_Working_Plane_to_Camera.html +32px-TechDraw_Dimension_Diameter.png +Macro_Half-Hull_ModelOption4.jpg +Feature3.jpg +MaterialListView.png +Constraint_HorizontalDistance.html +Bulb.svg +800px-TBHS2-15.JPG +Path_Sanity.html +800px-TBHS-14.JPG +16px-Sketcher_CreateOctagon.png +Preference_Import_Export_Tab_06.png +Std_SaveAs.html +Std_MeasureClearAll.html +Macro_FCInfoToMouse.html +32px-Arch_Building.png +256px-HorizontalConstraint4.png +Path-WalkThroughResult.gif +Job_4.jpg +Std_ViewCreate.html +32px-Arch_MeshToShape.png +Sketcher_Element_Hyperbolic_Arc_End_Point.svg +32px-TechDraw_Dimension_Length.png +Ship_Load.svg +Spiral_x45_it.png +24px-TechDraw_SaveSVG.png +800px-TBHS-6.JPG +Macro_Rubik_Cube.html +600px-TechDraw_Workbench_Example.png +Sketcher_DraftLine.svg +Surface.svg +32px-Draft_Stretch.png +Mesh_Flip_Normals.svg +Macros_recipes.html +Preferences-system.svg +ANSI_D_Landscape.svg +CompileOnMac.html +640px-Arch_Panel_example.jpg +32px-Drawing_Orthoviews.png +Macro_FCSpring_Helix_Variable_06.png +Arch_tutorial_51.jpg +PartDesign_SubtractiveCylinder.html +Release_notes_0.17.html +16px-PartDesign_Fillet.png +32px-PartDesign_MoveTip.png +400px-Arch_Rebar_example.jpg +Release_notes_011.html +267px-Macro_FCSpring_Helix_Variable_20.png +FCCamera_Axis_rotation_Y.png +Arch_pipe_example_01.jpg +1024px-BaseStation004.JPG +Arch_tutorial_29.jpg +24px-PartDesign_SubtractiveLoft.png +MaterialDragNDrop.png +32px-Sketcher_Circle.png +Button_sort.svg +Center-align-Body-objects.gif +Part_Loft_Liste_Auswahl_3c.png +32px-TechDraw_NewAnnotation.png +32px-FEM_ConstraintGear.png +Inspection_Workbench.html +16px-Part_Extrude.png +OpenSCAD_AddOpenSCADElement.svg +16px-Draft_PathArray.png +Mesh_SplitMesh.png +16px-TechDraw_ClipPlus.png +CustomizeToolBar_15.png +1024px-6DPLEQ2.jpg +24px-FEM_FemMesh2Mesh.png +24px-Raytracing.png +Draft_OCA.html +16px-Draft_Arc.png +256px-LockConstraint1.png +Inkscape_Template_tut_5.png +32px-Constraint_TangentToStart.png +Part_Measure_Clear_All.svg +TechDraw_NewAnnotation.html +FreeCAD05_Tango_Face-grin.svg +Draft_Trimex.svg +OpenSCAD_Hull.html +Dxf_Importer_Install_16.png +32px-Constraint_Lock.png +HighlightDifference.png +600px-JoinFeatures_Cutout.png +32px-Std_Export.png +How_to_install_additional_workbenches.html +GGTuto1_1.PNG +32px-Plot_Labels.png +Fem-result.svg +WebWorkbench.svg +32px-Path-ExportTemplate.png +Preview-rendered.svg +PartDesign_Body_tree-04.png +TechDraw_Roadmap.html +Draft_Polygon.html +32px-Constraint_ExternalAngle.png +Path-JobTools.png +Release011-draft-drawing.jpg +32px-TechDraw_Toggle.png +Part_example.jpg +32px-Std_Undo.png +RoofTable.png +24px-Macro_Connect_And_Sweep.png +32px-Drawing_Clip.png +18px-Macro_FCTreeView_19.png +Std_DependencyGraph.png +24px-Std_Refresh.png +400px-HolderTop1-7.jpg +150px-HelpViewer.jpg +500px-Solid_sweep.png +Units.html +Thread_for_Screw_Tutorial.html +FEM_SolverZ88.html +Mesh_EvaluateFacet.html +500px-Std_Alignment1.png +013-draft-fillet.jpg +Menu_Std_DlgMacroRecord_it.png +Draft_Arc.png +Draft_Snap_example.jpg +Sketcher_Element_Elliptical_Arc_Start_Point.svg +Document-new.png +Sketcher_SelectVerticalAxis.svg +36px-Macro_Make_Arc_3_Points.png +NavigationOpenCascade_Select.svg +600px-Arch_Nest_example.jpg +Sketcher_Create3PointArc.svg +32px-Std_MeasureDistance.png +Macro_FCInfoToMouse_02.png +24px-Part_Measure_Clear_All.png +24px-Workbench_Complete.png +16px-Arch_Rebar.png +200px-Macro_WorkFeatures_09.png +Draft_Stretch.svg +Sketcher_Trimming.html +32px-Std_Group.png +24px-View-zoom-in.png +232px-Texture_001_Logo.png +32px-Part_CreatePrimitives.png +Parallelism.svg +Path_ToolLibraryEdit.html +Arrowopen.svg +32px-Std_Part.png +400px-HolderTop1-11.jpg +Sewing.svg +Macro_FCTreeView_29.png +12px-Draft_UndoLine.png +Mover-ico.png +Constraint_SnellsLaw.svg +256px-LockConstraint4.png +265px-FCCircularText_04.png +Part_ImportCAD.html +Arch_CutPlane.html +Button_up.svg +Arch_Equipment.html +Web-browser.svg +FreeCAD05_Tango_Face-glasses.svg +Path-ToolTable.svg +24px-Draft_Apply.png +Part_Loft_Technical_Details.html +Macro_Python_Assistant_Window.html +CustomizeToolBar_03.png +Touch_Tap-Hold-Drag.svg +24px-Std_Tool8.png +32px-Draft_Label.png +500px-WorkFeature_Rotation_Object.gif +800px-TBHS-23.JPG +30px-Robot_InsertWaypoint.png +400px-Draft_point_example.jpg +PartDesign_BaseFeature.svg +32px-Sketcher_CreatePoint.png +16px-Constraint_Symmetric.png +24px-PartToVRML.png +Sketcher_tutorial.html +Preference_Import_Export_Tab_01.png +Pentaedres.gif +PartDesign_SubtractiveBox_example.png +View-Top.png +200px-PartDesign_AdditiveEllipsoid_example.png +48px-Macro_SelectVisible.png +Interface_Customization.html +PartDesign_SubtractiveCone.png +32px-BoundBoxTracing.png +32px-Draft_Angle.png +NavigationCAD.svg +InspectionWorkbench.svg +24px-Macro_SelectVisible2.png +Macro_CartoucheFC.html +FEM_MeshBoundaryLayer.html +Mesh.png +TechDraw_Spreadsheet.html +16px-Arch_Axis.png +400px-HolderTop2-14.jpg +FreeCAD05_Tango_Face-kiss.svg +24px-Macro_FCTreeView.png +FEM_MaterialFluid.html +Zoom-in.svg +400px-Screenshot_Draft_Dimension.jpg +16px-Arch_Building.png +Macro_ReproWire.png +200px-Macro_WorkFeatures_08.png +Meshes_RegularSolid_Cone.jpg +Dxf_Importer_Install_15.png +Feature7.jpg +600px-RotationAboutZBefore.png +Sketcher_ConstrainHorizontal.svg +Macro_Half-Hull_ModelUi1.jpg +Sketcher_ArcExample1.png +Feature-arch.jpg +190px-Macro_FCPropertyMemo_02.png +24px-Spreadsheet_Create.png +Raytrace_ResetCamera.svg +Std_SelectAll.html +Placement.html +Arch_Window_Clone.svg +600px-Arch_Remove_example.jpg +Button_add_all.svg +KukaKR16.jpg +24px-FCCircularTextButtom.png +32px-FEM_ConstraintTemperature.png +Quality_project.html +Sketcher_Element_Ellipse_Focus1.svg +32px-Macro_Toggle_Drawstyle.png +32px-Plot_Positions.png +32px-Draft_SetWorkingPlaneProxy.png +32px-TechDraw_SaveDXF.png +ReverseEngineeringWorkbench.svg +32px-Std_RotateLeft.png +Manipulators.png +Draft_Dimension.png +Std_Alignment3.png +DrawStyleFlatLines.svg +Arch_Pipe.html +400px-Macro_Connect_And_Sweep_03.png +800px-TutorialOpenSCAD_SampleFile.jpg +400px-Draft_Line_example.jpg +100px-Involutegear.png +32px-Path_Comment.png +Std_DependencyGraph.html +32px-Ship_New.png +400px-KukaKR16FreeCAD.jpg +A3_Modern.svg +GGTuto1_4.PNG +329px-Sketcher_tutorial_result.png +Constraint_PointOnMidPoint.svg +Situation.jpg +Mesh_FillInteractiveHole.html +Import_OpenSCAD_code.html +Draft_Move.svg +Elbow_equality_perpendicular_vertical.png +Property.png +Arch_tutorial_20.jpg +US_Legal_ds_Landscape.svg +View-isometric.svg +OpenSCAD_ExplodeGroup.html +FEM_EquationHeat.html +32px-Sketcher_SwitchVirtualSpace.png +120px-Bottle_detail.jpg +TechDraw_Tree_PageTemplate.svg +Concentric_Constraint_Between_two_non_cylindrical_parts.gif +PartDesign_MoveTip.html +Macro_Dump_Objects.html +Drawing_Openbrowser.html +Std_ViewScreenShot.svg +DagViewPending.svg +Rotate-mouse.svg +Bugreport-workflow.png +250px-Penta15--fc.png +Center-align-faces-in-action.gif +Localization_Older_Methods.html +Arrow-down.svg +TechDraw_Dimension_Horizontal.svg +Macro_Half-Hull_ModelOption10.jpg +Arch_tutorial_22.jpg +800px-InkXMLviewBox.png +Std_Measure_Menu.html +Drawing-landscape-A2.svg +Robot_TrajectoryCompound.svg +GitKraken-Main-Screen-sm.jpg +Release011-dependency.jpg +Macro_FCTreeView_28.png +Preference_General_Tab_04.png +FCSpring_Helix_Variable_Icon_01.png +KukaParts.jpg +Fem-constraint-InitialTemperature.svg +600px-JoinFeatures_Embed.png +Macro_Connect_And_Sweep_01.png +CustomizeToolBar_14.png +32px-PartDesign_AdditiveLoft.png +Feature-assembly.jpg +Fem-constraint-gear.svg +400px-Macro_Connect_And_Sweep_08.png +Concrete.svg +250px-Attacher_mode_FrenetNB.png +Constraint_Tangent.svg +Macro_Copy3DViewToClipboard.html +32px-FEM_Create.png +32px-Arch_Component.png +PartDesign_Scaled.html +SectionCross2.png +Otherwisedefault270degree_Part_Cone.png +12px-Draft_AddPoint.png +Draft_ShapeString16.png +30px-Robot_Edge2Trac.png +32px-Mesh_Torus.png +400px-SphereCutThreeAngles.jpg +FCSpring_Helix_Variable_Icon_02.png +800px-Mt_example2.png +Sketcher_Conics_Ellipse_Center.svg +Icone01.png +Macro_Toggle_Panels_Visibility.html +Path_DressupDogbone.html +Draft_SVG.html +Freecad010.png +32px-Constraint_VerticalDistance.png +Sketcher_Parabolic_Arc.svg +Draft_PathArray_Example.png +SpreadsheetAlignCenter.svg +32px-FEM_MeshGmshFromShape.png +Tutorial_WhiffleBall.jpg +PartDesign_Hole_parameters.png +A3_Landscape_US_Text_Complet_Without_Convention.svg +Steel.svg +600px-Msvc-no-vs_kit-setup-32.png +PartDesign_AdditiveEllipsoid.html +Mantis_logo_262x90.png +Sketcher_ToggleConstruction.svg +256px-EqualConstraint6.png +Sketcher_ConstrainVertical.svg +300px-Thread-by-vertical-profile-rule1.png +TechDraw_Redraw.html +32px-Std_Cut.png +300px-FCGear_bevel_par.png +Macro_Copy3DViewToClipboard.png +File_Format_FCStd.html +FreeCAD_development_model_project.html +24px-Dimension_Horizontal.png +512px-PianoTaglio3.png +PartDesign_Point.html +Std_Paste.html +Blank.png +Arch_OBJ.html +Sketcher_Create_Periodic_BSpline_Constr.svg +Arch_panel_tutorial_10.jpg +Sketcher_SelectElementsAssociatedWithConstraints.svg +CustomizeToolBar_05.png +24px-TechDraw_Tree_Page_Sync.png +Mesh_Smooth.html +Elbow_dimension_length_82_mm.png +PartDesign_SubtractiveCone_example.png +Arch_tutorial_48.jpg +1024px-Drawing_spreadsheetview.jpg +Draft_Drawing.html +32px-Part_ImportCAD.png +Sketcher_ConstrainLock.svg +SpreadsheetImport.svg +Std_Tool3.svg +Tree_PartDesign_Revolution.svg +Macro_Rotate_To_Point.html +32px-Raytracing_ResetCamera.png +32px-OpenSCAD_ColorCodeShape.png +32px-Std_Open.png +32px-Std_ViewScreenShot.png +Mesh_BoundingBox.png +200px-TBHS2-31-bottom.JPG +MEPlan.png +16px-Draft_Shape2DView.png +Macro_Select_Hovering_00.png +204px-Macro_FCPropertyMemo_03.png +Part_Extrude.html +32px-Sketcher_SelectOrigin.png +Fem-cfd-analysis.svg +Fem-constraint-fluid-boundary.svg +Std_About_en.png +Traditional_triangle.png +Std_DebugOver.html +503px-Tutorial_WhiffleBall.jpg +A0_Landscape_ISO7200TD.svg +Dxf_Importer_Install_14.png +32px-Std_SetAppearance.png +Macro_FCSpring_Helix_Variable_05.png +32px-Robot_SetDefaultValues.png +Ship_CapacityCurve.svg +267px-Draft_Downgrade_01.png +32px-TechDraw_Dimension_Radius.png +ThicknessEsempio4.png +ViewOfBox2.png +Param_Text.svg +Macro_Select_Hovering.html +Macro_Half-Hull_ModelImage0.jpg +WF_centerObjectsPlanes.png +Macro_Circular_Text.html +400px-SimpleTorus.jpg +Preference_General_Tab_01.png +FreeCAD-Ship-S60OutlinePlot.png +500px-Macro_FCConvertLines_11.png +ANSI_B_Landscape.svg +24px-Part_Measure_Toggle_All.png +Path-Profile.svg +Part_Prism_Apothem.svg +Fem-add-part.svg +Draft_Ellipse.html +RaytracingWorkbench.svg +Arch_panel_tutorial_07.jpg +Edit-redo.svg +400px-Macro_Connect_And_Sweep_07.png +SpreadsheetAlignVCenter.svg +88px-FCCircularText_20.png +400px-HolderTop2-5.jpg +32px-Arch_ToggleIfcBrepFlag.png +600px-Polarpattern_example.png +Std_Delete.html +Document-save-as.svg +Mesh_CurvatureInfo.html +267px-Macro_FCSpring_Helix_Variable_16.png +32px-Part_ExportCAD.png +Preview-vector.svg +Robot_CreateTrajectory.svg +FEM_SolverRun.html +Macro_cutLine.html +Path-MachineMill.svg +32px-PartDesign_AdditiveSphere.png +Ship_TankCapacity.html +Path_Simulator.html +Macro_Half-Hull_ModelOption2.jpg +Freecad-vista01.jpg +32px-Draft_Apply.png +32px-Path-3DSurface.png +PartDesign_Thickness.html +24px-View-bottom.png +FreeCAD-Ship-TankIco.png +Param_UInt.svg +Complete_Workbench.html +Legend.svg +FreeCAD05_Tango_Applications-graphics.svg +300px-PartDesign_Revolution_en_03.png +Fem-inp-editor.svg +16px-Drawing_Orthoviews.png +32px-Macro_FCInfoGlass.png +Path_Surface.html +Macro_Unbind_Numpad_Shortcuts.html +534px-FEM_tutorial_result.png +Robot_SetDefaultValues.html +Developing_FreeCAD_with_GitKraken.html +16px-FEM_Calculation.png +24px-TechDraw_New_Pick.png +400px-HolderTop1-16.jpg +TechDraw_ProjRear.svg +Project_template.html +250px-Tetra4--fc.png +Braga-secondo_Pad.png +241px-Draft_Preferences_Selection_Couleurs.png +296px-Macro_Align_Object_to_View_04.png +OpenSCAD_RemoveSubtree.html +16px-Path_Profile.png +16px-Path-Profile-Edges.png +32px-Std_RecentFiles.png +Macro_FCConvrtLines_View-top.png +TechDraw_NewSection.html +Mesh_Tree_Curvature_Plot.svg +PD_WB_Tutorial010.png +FEM_MeshNetgenFromShape.html +Add_FEM_Constraint_Tutorial.html +32px-Std_ViewExamples.png +640px-Macro_Install_HowTo_30.png +300px-PartDesign_Revolution_en_04.png +1024px-Easyw_fc.png +Arch_Wikihouse_10.jpg +800px-Measurement.jpeg +Draft_SwitchMode.svg +Part_Point_Parametric.svg +Expression_usage2.png +Dxf_Importer_Install_17.png +Image-import.svg +Tree_Part_Torus_Parametric.svg +200px-Macro_Recipes_MacroHowToInstall.png +Edit-copy.svg +Macro_crank_simul.html +Macro_FCSpring_Helix_Variable_02.png +24px-Macro_Perpendicular_To_Wire.png +Release-0.13-PointTool.png +FramesOn.png +Drawing-openbrowser.svg +Arch_tutorial_12.jpg +Screenshot_inkscape.jpg +18px-Macro_FCTreeView_25.png +800px-TBHS-19.JPG +NavigationOpenInventor.svg +Workbench_Robot.svg +Fem-femmesh-from-shape.svg +PartDesign_Additive_Cylinder.svg +Part_Cut.html +MacroVariableWatcherGui1.jpg +Part_Ellipse_Parametric.svg +300px-AboutFreeCAD_Credits.png +Sketcher_RectangularArray.svg +18px-Macro_FCTreeView_11.png +Step6_symmetry_setting.png +Screenshot_mesh.jpg +ClippingPlane2_it.png +Mesh_EvaluateSolid.png +GGTuto1_6.PNG +18px-Macro_FCTreeView_07.png +Sketcher_MirrorSketch.html +250px-Penta6--ccx.png +Frame_erxercise_pad.png +Sketcher_SelectRedundantConstraints.html +Macro_FCCamera_00.png +Draft_Apply.svg +FCCircularTextButtom.png +Import_Export_Preference.html +480px-ArchAxisSystemRepartition.png +800px-TBHS2-25.JPG +Compiling.html +Part_Torus.svg +SpNav-Zoom.svg +Part_Cylinder.html +Robot_Tutorial_RobotSimulation.gif +Ship_Area.png +Mesh_RemoveComponents.html +Part_Union.html +Fem-femmesh-result.svg +Path-Simple_copy.svg +Sketcher_ConstrainCoincident.svg +Plot_Save.png +800px-TBHS2-31.JPG +Preference_Sketcher_Tab_01.png +32px-Sketcher_CloseShape.png +16px-Arch_Stairs.png +480px-Draft_Draft2Sketch_example.jpg +32px-Sketcher_ConnectLines.png +16px-Arch_Wall.png +267px-Draft_selection_04.png +Arch_D_Landscape.svg +32px-NoIconFound.png +Tut17_sideblock.png +256px-LengthConstraint7.png +400px-Draft_Mirror_example.jpg +16px-Draft_Rotate.png +Draft_Snap.html +250px-Tria3--ccx.png +32px-Mesh_RemoveComponents.png +32px-PartDesign_AdditivePrism.png +24px-Macro_FCSpreadsheet_Extract.png +32px-FEM_FemMesh2Mesh.png +330px-Robot_Tutorial_RobotSimulation.gif +Path-BFastForward.svg +SpNav-PanUD.svg +PartRefineShape_it.png +Macro_Spring.html +Std_DlgMacroExecuteDirect.svg +250px-StirrupDialog.png +Flamingos_pype2.jpg +Mac_installer_1.png +32px-FEM_MaterialFluid.png +TechDraw_Templates.html +32px-Part_Chamfer.png +640px-Macro_Install_HowTo_32.png +32px-Std_ViewIvStereo.png +267px-Draft_Downgrade_02.png +24px-Constraint_InternalAngle.png +400px-HolderTop1-12.jpg +32px-Drawing_Landscape_A3.png +Macro_FCConvrtLines_View-right.png +600px-TutorialDraftShapeString_Position.jpg +Arch_tutorial_28.jpg +TechDraw_Hatch.html +RoofExample.png +32px-PartDesign_Chamfer.png +Patharray_NoAlign.png +Release-0.13-SketcherFullyConstrained.png +32px-Ship_Hydrostatics.png +24px-DrawStyleAsIs.png +24px-View-front.png +Edit-select-all.svg +32px-Part_JoinEmbed.png +64px-Freecadsplash017.png +FemWorkbench.svg +Sketcher_Element_Parabolic_Arc_End_Point.svg +32px-Std_Delete.png +Macro_Draft_Circle_3_Points.html +Points_Module.html +Job_1.jpg +PartDesign_SubtractiveBox.html +Staeubli_important_points.png +Arch_Panel.svg +Arch_tutorial_13.jpg +32px-Part_Booleans.png +Web-next.svg +TorusExampleOverviewParameters.jpg +Dxf_Importer_Install_20.png +480px-Drawing_tutorial_result.png +600px-Sketcher_ConsraintTangent_mode2.png +TechDraw_ClipPlus.html +Sketcher_ConstrainDistance.svg +Screenshot_treeview.jpg +32px-Draft_WorkingPlane.png +Techdraw-viewdetail.svg +400px-HolderTop2-19.jpg +Job_3.jpg +AngleSample.png +Assembly_Assembly_Create_New.svg +ShipExample.png +PartDesign_SubtractivePrism.png +Macro_FCConvertLines_012.png +FileSaveAs.png +Fem-data.svg +Draft_Stretch.html +400px-HolderTop1-2.jpg +Assembly_ConstraintUnidirectional1.svg +300px-UpdateAnnotation.png +Macro_Draw_2D_Function.html +Macro_FCSpring_Helix_Variable_01.png +PartDesign_Scaled.svg +Macro_FCConvertLines_03.png +Mesh_ExMakeUnion.html +32px-View-zoom-all.png +PySideScreenSnapshot2.jpg +Sketcher_BSplineDecreaseKnotMultiplicity.svg +Macro_Perpendicular_To_Wire.gif +32px-Path_Drilling.png +NavigationCAD_Rotate.svg +32px-Std_SelectAll.png +Sketcher_Element_Ellipse_All.svg +70px-Touchpad.png +400px-Draft_Wire2BSpline_example.jpg +Macro_screw_maker1_2.html +88px-FCCircularText_21.png +32px-FEM_Analysis.png +Arch_Material_Group.svg +32px-Draft_Move.png +VerticalSample.png +MeshWorkbench.svg +800px-Drawing_extraction.png +PD_move_feature2.png +24px-Techdraw-arch-view.png +300px-Macro_Install_HowTo_17.png +Std_PrintPdf.html +800px-TBHS2-26.JPG +463px-Exercise_cabin_01.jpg +Macro_FCTreeView_08.png +700px-Arch_Panel_example.jpg +Install_on_Mac.html +Meshes_Boolean_Union.jpg +Braga-primoPad.png +400px-Draft_BezCurve_Example.png +32px-Std_MeasureToggle3D.png +Macro_FCTreeView_20.png +24px-Part_Box.png +FCTexture_Example_Mesh.png +250px-Attacher_mode_FrenetTN.png +32px-TechDraw_Redraw.png +351px-Macro_Work_Features_Cutting_02.png +Release_notes_0.16.html +Section-down.svg +16px-Arch_Check.png +Macro_FCConvertLines.html +Freecadsplash016.png +16px-Arch_SelectNonSolidMeshes.png +Macro_Rotate_View_view_90_Degrees.png +Robot_Workbench.svg +Macro_Corner_shapes_wizard.html +Sketcher_CreateBSpline_Constr.svg +Part_Helix_Parametric.svg +PartDesign_Plane.svg +Drawing_tutorial.html +PD_WB_Tutorial012.png +NavigationMayaGesture.svg +351px-Macro_Work_Features_Cutting_06.png +SpreadsheetStyleItalic.svg +DrawStyleWireFrame.svg +256px-LengthConstraint2.png +24px-Std_Part.png +Part_Slice.svg +32px-Path-Job.png +32px-Mesh_ImportMesh.png +Preference_Fem_Tab_05.png +Preferences-fem.svg +600px-Arch_Nest_panel.jpg +Sketcher_ConstrainParallel.svg +NavigationMayaGesture_Zoom.svg +16px-Arch_CommitGit.png +18px-Macro_FCTreeView_01.png +32px-Draft_AddToGroup.png +Scenegraph.gif +250px-Quad4--ccx.png +Tutorial-normand02.jpg +Preference_General_Tab_03.png +CustomizeToolBar_09.png +Arch_tutorial_03.jpg +Rotate-mouse-MMB%2BRMB.svg +600px-Arch_Window_example.jpg +PartDesign_SubtractiveTorus.html +Macro_Rotate_View_with_Y_pointing_upwards_.png +Robot_Simulation_Player.jpg +Part_Refine_Shape.svg +Macro_PartsLibrary.html +16px-Draft_Offset.png +32px-Robot_Simulate.png +Macro_Replace_Part_in_Assembly.html +Techdraw-multiview.svg +Std_PrintPreview.html +300px-Netgen.jpg +PartDesign_Body_Tree.svg +Import_text_and_geometry_from_Inkscape.html +Macro_Assembly.html +Arch_materials_02.jpg +FEM_ConstraintBearing.html +Feature8.jpg +Path-Drilling.svg +24px-Macro_Make_Arc_3_Points.png +PartDesign_Body_tree-01.png +32px-Sketcher_External.png +Cartouche_02_US.svg +1024px-Wheel.JPG +FC017_Sketcher_B-spline_01.png +16px-Draft_Slope.png +SpreadsheetSplitCell.svg +Macro_FCConvertLines_Title.png +TechDraw_Arch_rendering.jpg +32px-Path_ExportTemplate.png +Freecad16.svg +FCCircularText_Correction.gif +Command.html +PartDesign_Mirrored_axis_fromconstructionlines.jpg +16px-Techdraw-geomhatch.png +1024px-Cura_export.png +Draft_Upgrade.png +24px-Freecad.png +Draft_ToggleDisplayMode.html +Tree_Python.svg +Ship_Area.html +16px-Case_a_cocher_O.png +Macro_PartToVRML.html +PartDesign_Body_tree-02.png +24px-Workbench_OpenSCAD.png +32px-Draft_ToggleConstructionMode.png +24px-LinkDimension.png +Arch_Structure_example.jpg +256px-SymmetricConstraint3.png +296px-Macro_Align_Object_to_View_02.png +StartWorkbench.svg +24px-PartDesign_Groove.png +18px-Macro_FCTreeView_26.png +640px-Macro_Install_HowTo_16.png +Std_Panels.png +256px-EqualConstraint8.png +32px-Sketcher_CreateOctagon.png +KukaSegment6.jpg +16px-Draft_VisGroup.png +Sketcher_Rectangle.png +Fem_Preferences.html +ImageConv.html +400px-Draft_Clone_example.jpg +32px-Part_Extrude.png +Ship_Outline.html +Arch_Grid.html +Constraint_InternalAlignment_Ellipse_MajorAxis.svg +Assembly_Workbench.html +Mesh_Cut.html +320px-JoinFeatures_Example_step3_Connect.png +CustomizeToolBar_13.png +Draft_Special.html +32px-Constraint_PointToObject.png +Mesh_Merge.png +Plot_Series.png +Bug_Triage.html +Std_Axis.svg +GGTuto1_0.PNG +32px-Sketcher_LeaveSketch.png +Part_CrossSections.svg +Arch_E1_Landscape.svg +Screenshot-customize.jpg +Mesh_Transform.html +Path-Copy.svg +Tutorial-normand01.jpg +16px-Arch_SplitMesh.png +16px-Path-ExportTemplate.png +Cabinettop.png +FCSpring_Helix_Variable_Icon_02b.png +Macro_Perpendicular_To_Wire.png +PD_WB_Tutorial003.png +Arch_multimaterial_example.png +Sketcher_helper_constraint.html +PartDesign_Subtractive_Cone.svg +FCCircularText_09.png +Start_up_and_Configuration.html +Raytrace_Render.svg +480px-Macro_MessageBox_00.png +Wood.svg +Splash011.png +300px-Countersink_settings.png +Std_ViewIvStereo.html +PartDesign_MoveFeature.html +32px-Part_Thickness.png +Part_XOR.svg +TechDraw_Image.html +Std_Part_example.png +Draft_Heal.html +Dialog-fillet.jpg +Plot_Save_Path.png +PySide_Advanced_Examples.html +Part_CreateSimpleCopy.png +Macro_Cut_Line.html +32px-Draft_ToggleSnap.png +Manipulator-WB-Mover-with-App_Part%26Body.gif +Preference_Import_Export_Tab_09.png +18px-Macro_FCTreeView_12.png +300px-FCGear_involuterack_par.png +16px-Arch_Component.png +PartDesign_Revolution_example.svg +32px-PartDesign_Groove.png +30px-Robot_SetDefaultValues.png +OpenSCAD_Preferences.html +Draft_Center.html +Draft_SetWorkingPlaneProxy.html +SpNav-Spin.svg +800px-TBHS2-18.JPG +Fem-beam-section.svg +Splashscreen09.png +32px-Part_Ellipse.png +300px-FCCamera_09.png +32px-Snap_Angle.png +16px-Draft_Point.png +OpenSCAD_IncreaseToleranceFeature.svg +Part_Loft_geschlossen.png +Arch_tutorial_38.jpg +24px-TechDraw_NewDraft.png +400px-HolderTop1-4.jpg +A1_Landscape_plain.svg +Sketcher_Element_Circle_Edge.svg +Step3_making_SB_600x400.png +TechDraw_Preferences2.png +Python.svg +Preference_Fem_Tab_01.png +Part_Slice.html +24px-PartDesign_MoveTip.png +PartDesign_ShapeBinder.svg +32px-Techdraw-view.png +Mesh_pipette.svg +Mesh_Import.html +Sketcher_LeaveSketch.html +Macro_cutCircle.html +480px-Macro_Mouse_Cross_00.png +16px-Path_Pocket.png +32px-Part_Slice.png +A4_Landscape_ISO7200TD.svg +Gitkraken-add-remote.gif +32px-Std_DlgMacroRecord.png +480px-Macro_CircularStair.png +Constraint_InternalAlignment.svg +Arch_Wikihouse_06.jpg +Macro_3D_Parametric_Curve.html +Sketcher_Element_Ellipse_Edge_1.svg +32px-Std_Edit.png +poweredby_mediawiki_88x31.png +Std_CloseAll.html +Downloads.html +GGTuto1_3.PNG +32px-Macro_Python_Assistant_Window.png +32px-Draft_Facebinder.png +FreeCAD05_Tango_Face-smile-big.svg +Draft-linestyle.jpg +600px-TBHS-model.png +PartDesign_AdditivePipe.html +Robot_TrajectoryDressUp.svg +Pan_cursor.png +300px-PartDesign_Draft-05.png +Diagonal1.svg +Macro_CartoucheFC_Full.png +24px-Workbench_Assembly.png +PartDesign_Subtractive_Sphere.svg +TechDraw_Dimension_Link.svg +400px-HolderTop1-17.jpg +200px-FCCircularText_38.png +16px-Part_Cut.png +Arch_Concept.html +Constraint_Ellipse_Radii.svg +Macro_WorkFeatures.html +Macro_Toggle_Drawstyle.html +200px-Macro_FCInfo_07.png +32px-Sketcher_ConstrainLock.png +Arch_E3_Portrait.svg +32px-Mesh_Sphere.png +480px-Macro_Airfoil_Import_%26_Scale_00.png +PartDesign_Plane.html +Total_run-out.svg +760px-Freecad-parts-library.jpg +600px-Patharray_alignment.png +32px-Sketcher_Arc.png +200px-TBHS2-31-top.JPG +32px-Arch_Axis.png +32px-Sketcher_RectangularArray.png +500px-Sketcher_ArcOfEllipseExample1.png +32px-Robot_InsertWaypoint.png +Part_Plane.html +Part_JoinEmbed.html +Preference_Fem_Tab_04.png +32px-Constraint_Concentric.png +SpreadsheetAlignBottom.svg +256px-LockConstraint7.png +Std_PerspectiveCamera.html +24px-Std_RotateLeft.png +PartDesign_Hole.svg +32px-FEM_ElementFluid1D.png +PartDesign_Additive_Prism.svg +32px-FCSpring_Helix_Variable.png +Sketcher_SelectHorizontalAxis.html +300px-ViewDetail.png +FEM_ConstraintContact.html +Spring_00.gif +16px-Path_Dressup.png +Param_Int.svg +Plot_Save.html +32px-Part_Revolve.png +Sketchfab.svg +16px-FEM_Material.png +32px-Techdraw-geomhatch.png +Series.svg +Frame_erxercise_failed_sketch.png +Matrix_API.html +50px-Macro_Center_Align_Objects_with_Faces_or_Edges.png +640px-CustomizeToolBar_02.png +Macro_Half-Hull_ModelOption9.jpg +300px-TaskViewSection.png +NavigationTouchpad_SelectTouch.svg +Web-zoom-out.svg +300px-Screenshot_mesh.jpg +Ship_Tank.svg +Splineextrudeloft.png +Installing.html +Std_Workbench.html +Mesh_Regular_Solid.svg +32px-OpenSCAD_RefineShapeFeature.png +Arch_Window.svg +PartDesign_Mirrored.svg +24px-PartDesign_Clone.png +Tree_Part_Cone_Parametric.svg +US_Ledger_ds_Landscape.svg +Arch_Wikihouse_09.jpg +Workbench_Ship.svg +Part_Sweep_simple.png +400px-Draft_Circle_example.jpg +CustomizeToolBar_06.png +Complete.png +400px-HolderTop2-2-1.jpg +640px-Dxf_Importer_Install_05b.png +300px-Macro_Install_HowTo_25.png +250px-Geometry.png +MEPlanT.png +Macro_ArrayCopy.html +Fem-DataAlongLine.svg +Spaceball_button.svg +32px-Std_Help.png +200px-Macro_HighlightDifference_01.png +Sketcher_ToggleNormal.svg +GitKraken-Clone-Repo-dialogue.png +Drawing-symbol.svg +Std_ViewIvIssueCamPos.png +24px-Dimension_Radius.png +Arch_pipe_example_06.jpg +680px-Textured_objects.jpg +Part_Measure_Step_Done.svg +PD_WB_Tutorial013.png +Sketcher_Element_Ellipse_Focus2.svg +Brick01.svg +Draft_Constrain_example.jpg +220px-Macro_screw_maker_02.png +Fem-run-solver.svg +Path_Profile.html +Import_Export.html +OpenSCAD_RefineShapeFeature.svg +150px-Tache_Placement_Translation_Y_fr.gif +Arch_tutorial_24.jpg +Std_Exit.html +32px-Techdraw-draft-view.png +DraftPlaneToolbarMode.png +Macro_Manage_Navigational_Styles1.png +Sketcher_CreateSquare_Constr.svg +800px-TBHS2-30.JPG +PartDesign_AdditiveCone.html +Section-right.svg +Draft_Rectangle.svg +340px-Draft-tutorial05.jpg +Macro_FCConvertLines_08.png +Fctutorial-complete.jpg +Macro_Half_turn_stairs.html +Geofeaturegroup.svg +Macro_FCSpring_Helix_Variable_07.png +32px-Macro_CartoucheFC_Full.png +Arch_Material_Multi.svg +Draft_Shape2DView.html +Goldener_Schnitt_Konstr_beliebt.svg +FCCircularText_24.png +Freecad-doc.png +16px-Std_BoxSelection.png +Std_Close.html +32px-Plot_Axes.png +Macro_Dxf_To_Shape.png +1024px-Obijuan2.png +1024px-Freecad-interface.jpg +Arch_Building.svg +FreeCAD-Ship-AreaCurveIco.png +Example.png +Raytracing_Render.html +Arch_CutPlane.svg +Std_OrthographicCamera.html +32px-Macro_FCSpreadsheet_Extract.png +Arch_tutorial_01.jpg +CornerShape1.png +24px-Macro_CartoucheFC_Full.png +Sketcher_Arc_of_Ellipse.html +200px-Macro_WorkFeatures_06.png +16px-FEM_PurgeResults.png +Tracker.html +PartDesign_CoordinateSystem.svg +Sketcher_CreateEllipse_3points_Constr.svg +Draft_Circle.png +32px-Std_ViewCreate.png +24px-FCCamera_07.png +Part_Spline_Parametric.svg +Arch_Structure_Tree.svg +FC017_Navigation_Indicator_01.png +Sketcher_CreateHexagon_Constr.svg +600px-Sketcher_ConsraintTangent_mode3.png +Part_Fuse.svg +FCInfoSpreadsheet.png +Path-Area.svg +240px-Macro_FCInfoToMouse_03.png +32px-Gearworkbech.png +Simple.svg +32px-Macro_SelectVisible2.png +Arch_tutorial_02.jpg +400px-Part_Box.jpg +Sketcher_Element_Parabolic_Arc_Centre_Point.svg +PartDesign_Revolution_axis_fromconstructionlines1.jpg +PartDesign_Draft.html +A4_Portrait_plain.svg +16px-Std_DlgMacroExecuteDirect.png +400px-PartDesign_Example.png +Pan-mouse-Ctrl.svg +Macro_FCConvertLines_09.png +PD_WB_Tutorial004.png +Arch_ToggleSubs.svg +Path-ToolAdd.gif +32px-OpenSCAD_IncreaseTolerance.png +Button_right.svg +167px-Qt_Example_01.png +267px-Sketcher_ConstructionMode_fr_01.png +Path_Copy.html +32px-Draft_Polygon.png +Path-Helix.svg +Tut17_profilewithsideblocksrearplane.png +Mesh_AddTriangle.png +Flamingo_Workbench.html +FreeCAD05_Tango_Face-wink.svg +Std_Tool1.svg +Freecad.svg +Std_SceneInspector.html +Draft_DXF.html +32px-TechDraw_New_Detail.png +32px-FEM_FixedConstraint.png +Std_OnlineHelp.html +Path-Tags.svg +Constraint_Vertical.html +12px-Draft_CloseLine.png +NavigationGesture_Select.svg +PartDesign_AdditiveCylinder.html +800px-TBHS-8.JPG +250px-Penta15--ccx.png +Draft_Draft2Sketch.svg +NavigationMayaGesture_Tilt.svg +24px-Workbench_Sketcher.png +32px-FEM_ConstraintInitialTemperature.png +Arch_tutorial_39.jpg +Macro_Half-Hull_ModelOption7.jpg +32px-Part_Wedge.png +800px-BldgComponents.png +FEM_ConstraintForce.html +32px-Sketcher_CreateCircle3Point.png +PartDesign_Subtractive_Ellipsoid.svg +Workbench_Points.svg +Arch_MultiMaterial.html +PartDesign_Pocket.svg +32px-Part_Sweep.png +Draft_Perpendicular.html +200px-FCCircularText_27.png +300px-HTCaeroplane01.png +Macro_Print_SceneGraph.html +320px-JoinFeatures_Example_step4_Connect.png +800px-RebarDistribution.png +600px-PartDesignConstraintPointOnPointScriptingFigure2.jpg +32px-Std_UnitsCalculator.png +24px-Std_ViewScreenShot.png +120px-Bottle_detail_interpol.jpg +Path-Machine.svg +Macro_Rubik_Cube.png +Arch_ToggleIfcBrepFlag.svg +Fem_Workbench.html +Path_objects.html +Thread-by-vertical-profile-rule2.png +16px-Drawing_Clip.png +Macro_Half-Hull_ModelImage3a.jpg +18px-Macro_FCTreeView_14.png +Arch_Module.html +PartDesign_SubtractivePipe.html +NavigationOpenCascade_Rotate.svg +PartDesign_SubtractiveCylinder_example.svg +PartDesign_ShapeBinder.html +24px-FEM_MaterialMechanicalNonlinear.png +32px-Part_Cut.png +640px-Arch_Frame_example.jpg +32px-Part_Torus.png +Std_ClippingPlane.html +320px-JoinFeatures_Example_step1.png +300px-Macro_FCSpring_Helix_Variable_09.png +Circular_run-out.svg +NavigationMayaGesture_Select.svg +Sketcher_triangle3_small.png +Macro_FCTreeView_005.png +Path-BStep.svg +Tut17_sideblockconstraind.png +Snap_Perpendicular.svg +64px-Background.png +32px-Arch_RemoveShape.png +16px-Sketcher_NewSketch.png +MeshFace.svg +Macro-record.svg +Mesh_EvaluateSolid.html +Sketcher_CircleExample1.png +32px-Part_Shapebuilder.png +NavigationOpenCascade_Zoom.svg +96px-Vue_Lighting_fr_00.png +400px-FEM_example01_pic04.jpg +Sketcher_Fillet.html +Arch_panel_tutorial_19.jpg +RenderTaskView.png +400px-HolderTop1-6.jpg +640px-Macro_Install_HowTo_29.png +Ship.png +FCCircularText_13.png +Std_MergeProject.html +32px-Sketcher_Point.png +800px-TutorialOpenSCAD_ImportFile.jpg +PartCheckGeometry.png +Constraint_InternalAngle_Driven.svg +Arch_Space.html +250px-Hexa20--ccx.png +OpenSCAD_ReplaceObject.svg +24px-TechDraw_New_Default.png +500px-Macro_FCConvertLines_013.png +Offsite_tutorials.html +Path_ExportTemplate.html +Tree_PartDesign_Pad.svg +800px-PartDesign017-teaser-motor-core.png +Crystal_Clear_app_tutorials.png +Zoom-mouse.svg +200px-Macro_WorkFeatures_01.png +400px-HolderTop1-3.jpg +FEM_PostCreateWarpVectorFilter.html +Fem-femmesh-to-mesh.svg +Sketcher_Element_Circle_MidPoint.svg +250px-Tria3--fc.png +32px-Arch_Nest.png +Macro_FreeCAD_to_Kerkythea.html +Expression_usage3.png +Arch_panel_tutorial_14.jpg +Mesh_Harmonize_Normals.svg +Path-Job.svg +ANSI_A_Portrait.svg +Path_DressupTag.png +Macro_Loft.html +32px-PartDesign_Revolution.png +Draft_Dimensions.html +Arch_Wikihouse_05.jpg +200px-TechDraw_Spreadsheetview.png +FEMforceonline.PNG +24px-Macro_Select_Hovering.png +Drawing_View_Properties.png +32px-FEM_ConstraintForce.png +16px-Draft_FlipDimension.png +Arch_PipeConnector.html +Freecad-vista02.jpg +Path_experimental.html +ANSI_D_Portrait.svg +480px-Texture_001_Logo.png +32px-Part_Offset2D.png +Draft_Offset.html +Class.png +32px-Force_Recompute.png +PartFeature.svg +Std_OnlineHelpWebsite.html +120px-WaWue_SphrerFit.jpg +Process-stop.svg +ParametersBeam.svg +Macro_Half-Hull_ModelScreenBoatInABottle.jpg +PrintPreview1.png +Macro_Compound_Plus.html +800px-Part_BooleanOperations.png +Preference_Display_Tab_02.png +32px-FCCircularTextButtom.png +24px-Std_WindowNext.png +Std_Save.html +600px-RotationOffsetBefore.png +NavigationMayaGesture_TiltTouch.svg +32px-Arch_Frame.png +640px-Macro_Work_Features_GitHub_00.png +32px-Draft_PathArray.png +600px-ParametricCurve.png +Std_Macro_Menu.html +24px-TechDraw_Hatch.png +Third_Party_Libraries.html +TechDraw_Clip.html +24px-Macro_SelectVisible.png +32px-TechDraw_Clip.png +Part_JoinConnect.svg +Feature_list.html +Arch_Workbench.html +Sketcher_Hexagon.html +PlacePyConv10.png +32px-Ship_Outline.png +Draft-tutorial-elevation.jpg +32px-Path_Copy.png +32px-Draft_Extension.png +Mesh_Workbench.html +PartOffset2_it.png +Part_JoinEmbed.svg +Arch_tutorial_47.jpg +Part_JoinConnect.html +Scripting_examples.html +Std_Help.html +Macro_Install_HowTo_12.png +400px-HolderTop2-6.jpg +Techdraw-arch-view.svg +Path_Fixture.html +256px-Tache_Placement_fr_05.png +Raytrace_Export.svg +Mesh_VertexCurvature.html +24px-Macro_FCInfoGlass.png +32px-PartDesign_PolarPattern.png +013-arch-vrm.jpg +PartDesign_Legacy.html +Preference_Path_Tab_01_3.png +12px-Draft_Wipe.png +Part_Chamfer.html +32px-Part_Fuse.png +FCCircularText_23.png +UnbiasedRendering.png +167px-Qt_Example_00.png +24px-FCCamera_05.png +Part_Line.html +Sketcher_CarbonCopy.svg +Path_Pocket_3D.html +Mesh_Union.html +32px-FEM_ConstraintContact.png +Part_ReverseShapes.html +Macro_FCTreeView_33.png +400px-Draft_Downgrade_example.jpg +Macro_SpreadsheetTools.html +400px-HolderTop2-17.jpg +1000px-PartDesign_ModlingObjectsHirachy.png +Arch_Space.svg +Std_Tool9.svg +Type_module.svg +PartDesign_WizardShaft.html +32px-Macro_MeasureCircle.png +480px-Sketcher_ConstructionMode_fr_01.png +320px-Slice_example_step1.png +Mesh_example.jpg +24px-PartDesign_AdditiveSphere.png +Edit_Cancel.svg +Macro_Half-Hull_ModelUsage3.jpg +Param_Bool.svg +Arch_Floor_Tree.svg +Fem-solver.svg +Edit-cleartext.svg +24px-Replace_Part.png +Path-Workbench.svg +256px-ConstrainRadius1.png +32px-TechDraw_New_Default.png +Dxf_Importer_Install_09.png +Robot_InsertWaypoint.svg +Help-btn.png +Draft_Circle.html +Position.svg +Arch_Panel_Tree.svg +32px-WF_wf.png +Raytracing_Preferences.html +Workbench_Plot.svg +MEpipe02.png +267px-FCCircularText_46.png +32px-Draft_CloseLine.png +Macro_Cut_Circle.html +Scripting.html +Windows.png +Sketcher_CreatePentagon.svg +640px-Dxf_Importer_Install_02.png +Chamfer-example.png +Std_DebugStop.html +300px-PartDesign_Fillet-01.png +Accessories-calculator.svg +16px-Arch_Pipe.png +TBHS-model.png +400px-HolderTop2-4.jpg +Macro_FCTreeView_09.png +FEM_ConstraintPressure.html +GGTuto1_9.PNG +NamingExample.jpg +250px-Hexa20--fc.png +Cartouche_01_US.svg +Macro_Connect_And_Sweep.html +Macro_FCConvertLines_06.png +Dxf_Importer_Install.html +250px-Quad4--fc.png +PartDesign_Subtractive_Pipe.svg +Arch_Cell.svg +Sketcher_SelectHorizontalAxis.svg +800px-DrawingScriptResult.jpg +Sketcher_CreateBSpline.svg +Qttestdialog.jpg +Arch_Roof_Tree.svg +Points_ImportPoints.html +32px-Plot_Legend.png +189px-Style_of_navigation.png +Dimension_partitions_flipped.png +Draft_ShowSnapBar.html +300px-TutorialDraftShapeString_DraftShapestring.jpg +Mesh_Import_Mesh.svg +32px-FEM_ConstraintBearing.png +Sketcher_Create_Periodic_BSpline.svg +Constraint_TangentToStart.svg +ParametersIbeam.svg +32px-Path_Profile_Edges.png +24px-FEM_Analysis.png +400px-Macro_cutLine_00.png +700px-Pic2.png +Sketcher_Element_Elliptical_Arc_End_Point.svg +PartDesign_Sphere_Parameter_en.jpg +PD_WB_Tutorial001.png +Diagonal2.svg +Part_Circle_Parametric.svg +300px-Expressions-demo.png +Std_RotateLeft.html +FreeCAD05.png +452px-Exercise_raytracing_05.jpg +Std_Redo.html +TechDraw_API.html +Std_OnlineHelpPython.html +Sketcher_AlterFillet.svg +30px-Robot_SetDefaultOrientation.png +16px-Draft_Ellipse.png +Draft_Style_Style.png +Draft_Move.html +16px-Arch_CloseHoles.png +24px-Techdraw-viewdetail.png +600px-Part_Offset2D_Mode.png +Clone.png +Arch_Grid.svg +Part_Workbench.svg +FEM_ElementGeometry1D.html +Macro_Make_Circle_3_Points.html +Sketcher_Conics_Constr.svg +16px-Path_ToolLibraryEdit.png +Preferences-techdraw.svg +Draft_PathArray.svg +32px-Sketcher_SelectConstraints.png +400px-Draft_Offset_example.jpg +Std_ViewXX.html +Constrain1.png +256px-ConstrainRadius5.png +Draft_Lock.svg +Assembly_ConstraintOrientation.svg +32px-Drawing_Annotation.png +Std_SaveaCopy.png +Draft_Arc.html +ParametersWindowSimple.svg +600px-Mantisbt-ticket-shortcut-example.jpg +Arch_MeshToShape.html +Button_left.svg +374px-Exercise_table_complete.jpg +Sketcher_AlterConstruction.svg +32px-Macro_Rotate_To_Point.png +Macro_Half-Hull_ModelUsage4.jpg +32px-Arch_MergeWalls.png +1024px-Spark-Plug-Plane.jpg +Misc_templates.html +NavigationOpenInventor_Rotate.svg +MeasureLinear3DandDelta1.PNG +Draft_Ellipse.png +Arch_Axis_Tree.svg +32px-Draft_BezCurve.png +32px-Sketcher_AlterConstruction.png +Sketcher_Point.html +32px-Arch_Floor.png +FreeCAD_Raytracing.jpg +16px-Draft_Upgrade.png +16px-Arch_Cell.png +32px-Techdraw-projgroup.png +32px-OpenSCAD_ExpandPlacements.png +3Dconnexion_input_devices.html +16px-FEM_FixedConstraint.png +Plus.svg +Arch_CloneComponent.html +Drawing_Workbench.html +PartDesign_CompPrimitiveSubtractive.html +FreeCAD-Ship_s60_tutorial_(II).html +32px-FEM_MaterialSolid.png +320px-JoinFeatures_Example_step2.png +Fem-femmesh-print-info.svg +Snap_Parallel.svg +Part_Loft_Ikon_Ballon_Hilfe.png +32px-Std_Redo.png +Tut17_profilewithslotsrearplane.png +256px-EqualConstraint1.png +PartDesign_Groove.html +Drawing-portrait-A0.svg +Fem-material-fluid.svg +Sketcher_Conics_Ellipse_3points.svg +120px-Wawue_Side.jpg +Sketcher_Ellipse_by_3_Points.html +16px-Path_Comment.png +PartDesign_Migrate.html +200px-PartDesign_AdditiveSphere_example.png +16px-Std_Paste.png +A1_Landscape_ISO7200.svg +Macro_3d_Printer_Slicer.html +Draft_WorkingPlane.html +32px-Sketcher_ConstrainBlock.png +Constraint_TangentToEnd.html +24px-BoundBoxTracing.png +800px-TBHS2-24.JPG +32px-Snap_Lock.png +Macro_Cross_Section_02.png +32px-Draft_Parallel.png +PartPlaneProperty.png +Tree_Part_Plane_Parametric.svg +32px-Std_PrintPreview.png +256px-EqualConstraint9.png +200px-Macro_HighlightDifference_02.png +Contributors.html +Embedding_FreeCAD.html +Macro_FCTexture.html +JoinFeatures_dropdownToolbarButton.png +16px-Std_Cut.png +32px-Arch_Panel.png +32px-Drawing_Openbrowser.png +Draft_PutOnSheet.png +267px-Macro_screw_maker_03.png +Draft_Wire.svg +16px-Spreadsheet_PropertyController.png +300px-TechDraw_Workbench_Example.png +Screenshot_pythoninterpreter.jpg +TechDraw_Preferences1.png +32px-Sketcher_MirrorSketch.png +Mesh_boundary.svg +400px-Macro_CutCircle_00.png +1024px-PrzemoF.png +Arch_PipeConnector.svg +Splashscreen012.png +32px-FEM_MaterialMechanicalNonlinear.png +32px-Path_FromShapes.png +351px-Macro_Work_Features_Cutting_03.png +Arch_tutorial_53.jpg +DrawStylePoints.svg +SketcherTrimExample3.png +600px-RoofExample.png +32px-Std_ViewZoom.png +Sketcher_Element_Hyperbolic_Arc_Start_Point.svg +Sketcher_CreateRectangle_Constr.svg +256px-EqualConstraint4.png +Macro_FCTreeView_32.png +Truggy_differential_full.jpg +Std_New.html +Macro_FCTreeView_18.png +PartDesign_MoveTip.svg +24px-Sketcher_RectangularArray.png +480px-Macro_unfoldBox1.png +600px-Arch_Window_example2.jpg +FEM_MeshPrintInfo.html +Assembly_ConstraintAlignment.svg +600px-JoinFeatures_Connect.png +Sketcher_Sketch.svg +PySideScreenSnapshot8.jpg +Macro_FCTreeView_25.png +Sketcher_Element_Ellipse_MajorAxis.svg +Type_enum.svg +NavigationCAD_RotateAlt.svg +16px-Draft_DelPoint.png +Arch_Cell_example.jpg +PartDesign_Subtractive_Wedge.svg +400px-SimpleSphere.jpg +Half_turn_stairs.png +600px-PartDesignConstraintPointOnPointScriptingFigure5.jpg +Macro_Half-Hull_ModelImage1.jpg +32px-Draft_Endpoint.png +Arch_Survey.svg +Workbench_Image.svg +AddonManager.svg +32px-Draft_UndoLine.png +ANSI_templates.html +24px-PartDesign_Pad.png +Std_WhatsThis.html +32px-Std_CommandLine.png +TechDraw_NewDraft.html +Colors.svg +Pan-mouse-CTRL.svg +Preference_Part_Design_Tab_01.png +32px-Draft_BSpline.png +Part_RuledSurface.html +Macro_circle.html +600px-Mantisbt-mention-example.jpg +96px-Vue_DisplayModePartDesign_fr_00.png +Workbench_Drawing.svg +640px-Macro_Install_HowTo_06.png +Arch_tutorial_44.jpg +MEPlanI.png +Mesh_Module.html +Tut17_sketcherempty.png +32px-Draft_DelPoint.png +Draft_Preferences.html +Step1_rectangle_600x400.png +Snap_Special.svg +32px-Part_ShapeFromMesh.png +24px-Techdraw-projgroup.png +Applications-accessories.svg +16px-Path_Simulator.png +Macro_Stairs.html +DrawingWorkbench.svg +200px-Macro_WorkFeatures_04.png +32px-Dimension_Diameter.png +32px-Macro_Compound_Plus.png +32px-Std_Save.png +Sketcher_SelectRedundantConstraints.svg +267px-Macro_FCSpring_Helix_Variable_17.png +16px-Draft_WireToBSpline.png +480px-Draft_tutorial_result.png +Axle_constraint.svg +Arch_tutorial_25.jpg +267px-Macro_FCSpring_Helix_Variable_15.png +Draft_WireToBSpline.svg +Spreadsheet_Create.html +Path-Stop.svg +32px-Sketcher_CreateSlot.png +800px-TBHS2-9.JPG +32px-TechDraw_ExportPage.png +24px-FCInfo.png +NavigationBlender_PanAlt.svg +Std_Tool8.svg +Macros_toolbar.jpg +Macro_FCConvrtLines_View-front.png +400px-Draft_trimex_example.jpg +32px-Arch_BimServer.png +ParametersDoorGlass.svg +FCCircularText_15.png +700px-PIC9.png +24px-View-isometric.png +350px-Partcs.png +Sketcher_SelectOrigin.html +FreeCAD_and_DXF_Import.html +Part_Loft.html +Tutorial_WhiffleBall_UnfinishedShape.jpg +32px-Sketcher_CreateHeptagon.png +32px-Arch_Schedule.png +32px-Aliasmanager_icon.png +32px-Std_Placement.png +Fem-constraint-displacement.svg +32px-TechDraw_Dimension_Vertical.png +Draft_AddPoint.svg +Raytrace_Camera.svg +482px-FCTexture_008.png +256px-ConstrainRadius2.png +Part_MakeCompound.png +Macro_FCTreeView_24.png +ParametersStairs.svg +Basic_Part_Design_Tutorial.html +Arch_Structure_Clone.svg +Macro_FCConvertLines_DashDot.png +Sketcher_Create3PointCircle_Constr.svg +24px-Workbench_Image.png +Parameter_Editor.jpg +Sketcher_Element_Ellipse_CentrePoint.svg +PartDesign_Chamfer.svg +Draft_Downgrade.svg +400px-Draft_Text_example.jpg +Constraint_VerticalDistance.html +Mesh_to_Part.html +FEM_PostApplyChanges.png +Draft_UndoLine.html +640px-Macro_Install_HowTo_23.png +32px-Mesh_FillInteractiveHole.png +Macro_Alias_Manager.html +Path_DressupDragKnife.html +35px-Nuvola_apps_download_manager.png +Arch_tutorial_21.jpg +16px-PartDesign_Pocket.png +CustomizeToolBar_16.png +About_FreeCAD.html +Mesh_FromGeometry.html +Part_CheckGeometry.html +750px-SI-Derived-Units.jpg +Workbench_OpenSCAD.svg +FEM_CreateNodesSet.html +Download.html +Sketcher_Workbench.html +Std_Placement.html +FEMForceConstraintProperties.PNG +24px-TechDraw_Dimension_Link.png +FreeCAD05_Tango_Process-stop.svg +Draft_AddConstruction.html +Spreadsheet_legacy.html +12px-Draft_DelPoint.png +PartLinePrimitivesOptions_it.png +1000px-Macro_Section_Screenshot.png +PartDesign_AdditivePrism.html +FEM_ConstraintGear.html +32px-Sketcher_ToggleConstraint.png +Fem-constraint-fixed.svg +DumpObjectsGui1.jpg +FreeCAD011.png +Macro_FCConvertLines_01.png +Macro_Toggle_Visibility2.html +Tutorial_WhiffleBall_BasicShape.jpg +Part_CreatePrimitives.html +Inspect_pipette.svg +FEM_ConstraintBodyHeatSource.html +16px-Draft_Label.png +400px-TruncateSpring00.png +18px-Macro_FCTreeView_27.png +Python_scripting_tutorial.html +32px-Draft_Dimension.png +16px-Sketcher_CreateSlot.png +Std_ProjectInfo.html +Draft_Midpoint.html +Media-playback-stop.svg +Std_DlgMacroStop_02.png +24px-View-rear.png +Draft_AddConstruction.png +Icon.svg +Arch_tutorial_23.jpg +32px-Std_SceneInspector.png +TechDraw_Workbench.html +640px-Bridge-detail.png +Std_BoxSelection.html +400px-Macro_Connect_And_Sweep_05.png +Std_About.html +16px-Arch_Survey.png +FreeCAD-Ship-WeightIco.png +Arch_equipment_example.jpg +640px-Arch_Add_example.jpg +Macro_FCTreeView_15.png +32px-Macro_Make_Arc_3_Points.png +A3_Clean.svg +320px-JoinFeatures_Example_step3_Embed.png +Robot_RestoreHomePos.svg +TorusExampleRadius2.jpg +100px-Involuterack.png +16px-Draft_Edit.png +200px-FCCircularText_40.png +Macro_Airfoil_Import_%26_Scale.html +Sketcher_ExternalEsempio1.png +ViewObject_API.html +24px-Part_ImportCAD.png +Std_Exit.png +Preferences-general.svg +32px-Draft_PutOnSheet.png +Preference_Import_Export_Tab_07.png +PartDesign_PolarPattern.html +Manipulator_Workbench.html +260px-Valves_Assembly_IN_EX.png +Path_Comment.html +Edit_OK.svg +32px-PartDesign_AdditiveEllipsoid.png +Arch_Wall_Tree_Assembly.svg +32px-Spreadsheet_Controller.png +640px-Macro_Install_HowTo_14.png +Fem-equation-electrostatic.svg +OpenSCAD_AddOpenSCADElement.html +Arch_tutorial_19.jpg +A4_LandscapeTD.svg +Arch_MeshToShape.svg +32px-Dimension_Horizontal.png +Arch_equipment_mesh.jpg +150px-Drawing_View_Iso_SmoothLines.png +32px-Dimension_Angle.png +FEM_EquationFluxsolver.html +Sketcher_LineExample1.png +FreeCAD-Ship-ShipInstance.png +PartDesign_Bearingholder_Tutorial_I.html +Release_notes_012.html +LuxRenderExecPath.png +Macro_WireXYZ.html +FCSpring_Helix_Variable_Icon_04.png +A3_Portrait_plain.svg +Tree_Part_Sphere_Parametric.svg +16px-Draft_Apply.png +Robot_TrajectoryCompound.html +200px-PartDesign_AdditiveTorus_example.png +PartDesign_Thickness.svg +32px-Path_Array.png +32px-FEM_RunSolver.png +32px-Part_XOR.png +Ray_Tracing_Workbench.html +24px-DrawStylePoints.png +Macro_FCTreeView_27.png +PartDesign_Body.html +Swept-path_Analysis_GSoC_Project.html +Arch_Axis.html +FCCamera_02.png +TechDraw_ClipMinus.html +Git.svg +SpreadsheetStyleBold.svg +Sketcher_ConstrainBlock.svg +32px-Draft_WireToBSpline.png +FEM_Tutorial_Python.html +Job_5.jpg +FreeCAD_Build_Tool.html +32px-Mesh_HarmonizeNormals.png +24px-View-zoom-all.png +DraftPlaneAuto.png +MeasureAngular1.PNG +32px-PartDesign_InternalExternalGear.png +Arrowtick.svg +32px-Macro_FCWire_To_Volume.png +Arch_Rebar.html +Ship_Workbench.html +32px-Draft_Point.png +Povray.jpg +200px-TBHS2-30-draft.JPG +32px-PartDesign_Clone.png +PartRuledSurface_it.png +32px-Arch_Grid.png +PartDesign_Groove.svg +Part_Ellipse.html +Debug-stop.svg +Document.svg +Path-Kurve.svg +32px-Macro_Dxf_To_Shape.png +300px-Group_with_objects.png +300px-FCCamera_11.png +400px-Draft_ellipse_example.jpg +32px-FCTexture.png +800px-TBHS-18.JPG +Arch_SectionPlane.html +600px-MultiModel.png +400px-HolderTop1-15.jpg +MEpipe01.png +Draft_Label.svg +KukaSegment3.jpg +A1_Portrait_plain.svg +600px-Mantisbt-source-integration-markup.jpg +30px-Robot_CreateTrajectory.png +Sketcher_Hyperbolic_Arc_Constr.svg +32px-Draft_Trimex.png +32px-Draft_Edit.png +Fem-femmesh-create-node-by-poly.svg +SpreadsheetMergeCells.svg +Arch_RemoveShape.svg +Selection_API.html +FCCircularTextButtom.svg +550px-Save_picture.png +Draft_Snap.svg +Std_Tools_Menu.html +Preferences-import-export.svg +Testing.html +Plot_Series.html +32px-Std_DlgMacroStop.png +PlotWorkbench.svg +32px-Path_Contour.png +Workingplane_example.jpg +24px-PartDesign_AdditiveTorus.png +Fem-constraint-bearing.svg +Macro_FCInfo_08.png +16px-Sketcher_CreateSquare.png +Tut17_sidblockunconstrained.png +Draft-tutorial-typical-tree.jpg +Constraint_EqualLength.html +500px-Macro_FCConvertLines_11b.png +Sketcher_Copy.html +Macro_FCTreeView_03.png +250px-Penta6--fc.png +Arch_SetMaterial.html +Macro_Dxf_To_Shape_Convert_Wire_To_BSplineCurve02.gif +32px-FEM_ElementGeometry2D.png +Std_WindowCascade.svg +88px-FCCircularText_23.png +32px-Sketcher_CreateEllipse3Point.png +Debug-start.svg +24px-Symbol.png +300px-Hing_01.png +ThicknessEsempio2.png +Release011-translation.jpg +32px-FCInfoToMouse.png +Arch_multimaterial_panel.png +Dxf_Importer_Install_13.png +Draft_BSpline.png +BoundBoxTracing.png +Assembly_ConstraintGeneral.svg +Draft_Intersection.html +800px-HelicalRebar.png +640px-Macro_Install_HowTo_33.png +FitSurface.svg +800px-PathContourToolExample.png +32px-Sketcher_CreateTriangle.png +PartVertexPrimitivesOptions_it.png +PySideScreenSnapshot4.jpg +24px-Dimension_Vertical.png +32px-Raytracing_Camera.png +24px-FCCamera_02.png +120px-Band.JPG +Fem-material-nonlinear.svg +Macro_Install_HowTo_10.png +Fem-cylinder.svg +Drawing_Open_SVG.html +Workbenches.html +Draft_AutoGroup_on.svg +Qtdesigner-screenshot.jpg +Draft_Facebinder.html +Preferences-path.svg +Arch_Nest.svg +256px-LockConstraint3.png +133px-Macro_Draft_Circle_3_Points05.png +PartDesign_SubtractiveTorus.png +Std_ViewFitSelection.html +32px-Drawing_DraftView.png +32px-Draft_ShowSnapBar.png +Part_CompoundFilter.svg +FEM_CalculiX_Cantilever_3D.html +PartDesign_Involute_Gear_01.png +Robot_CreateRobot.html +Std_MeasureAngular.html +267px-FCCircularText_50.png +Drawing_View.html +Path-FaceProfile.svg +400px-Draft_Label_example.jpg +Fem-clip.svg +Arch_panel_tutorial_06.jpg +Select-mouse.svg +PolygonPick.svg +Part_ExportCAD.html +16px-Draft_ToggleDisplayMode.png +Arch_Schedule.html +PD_WB_Tutorial018.png +Constraint_PointOnPoint.svg +Draft_SelectPlane.svg +20px-Std_DlgMacroStop.png +Section-left.svg +32px-FreeCAD_Doc.png +16px-Draft_Scale.png +Draft_Line.svg +32px-FEM_ForceConstraint.png +Draft_Point.svg +Sketcher_Validate.html +250px-Style_of_navigation_menu.png +32px-Raytracing_Render.png +Points_Import_Point_cloud.svg +TechDraw_Clipview.png +Exercise_path_02.jpg +Member.svg +600px-Part_BooleanFragments_Demo.png +ParametersDoorSimple.svg +Fem-beam-rotation.svg +Cartouche_01_Convention_US.svg +Button_invalid.svg +700px-FEM_example01_pic05.jpg +Draft_tutorial_Outdated.html +Part_Loft_Liste_Auswahl_3b.png +SSFontSelect.png +24px-Workbench_Start.png +960px-Arch_precast_example.jpg +Arch_AxisSystem.html +PartDesign_PolarPattern_EdgeReference.gif +Macro_Shake_Sketch.html +32px-Path-Engrave.png +24px-Macro_CloneConvert.png +TechDraw_Dimension_Radius.svg +Draft_DAT.html +32px-Std_DlgPreferences.png +24px-FEM_PostPipelineFromResult.png +Media-record.svg +CompassRose.svg +32px-TechDraw_Spreadsheet.png +Macro_BoundingBox_Tracing.html +Macro_Connect_And_Sweep_TR.png +Macro_Align_View_to_Face.html +32px-Std_RotateRight.png +Path_Drilling.html +Orthographic_Perspective.gif +800px-TBHS-2.JPG +Sketcher_CloseShape.html +Mesh_RemoveCompByHand.html +32px-Part_Prism_Apothem.png +24px-Dimension_Angle.png +Draft_Clone.png +Tree_Part_Box_Parametric.svg +Draft_BezTanNode.svg +24px-FCCamera_06.png +32px-Sketcher_Trimming.png +Constraint_Ellipse_Minor_Radius.svg +Hing_00.gif +Std_Tool4.svg +256px-ConstrainRadius3.png +Drawing-landscape-A3.svg +FreeCAD_Configuration_Management_Project.html +PartToVRML.png +Draft_Coordinates.html +Arch_Wall.html +16px-Draft_FinishLine.png +200px-LengthSample.png +Path-Simulation.gif +FCCamera_Axis_rotation_D.png +Std_Print.html +32px-Path_Inspect.png +Path-EditTool-Dialog.PNG +300px-FCGear_involutegear_par.png +Drawing-portrait-A4.svg +Circle_on_3_points.png +NavigationOpenInventor_Zoom.svg +Macro_FCInfo.html +16px-View-refresh.png +Techdraw-view.svg +Arch_Stairs.svg +256px-LockConstraint2.png +Techdraw-spreadsheet.svg +Robot_Export.svg +A1_Landscape_ISO7200TD.svg +Draft_Heal.svg +NavigationGesture_ZoomTouch.svg +Std_Undo.html +Mouse_LMB%2BRMB.svg +24px-Force_Recompute.png +840px-Pathwb.png +LocalZAfter2.png +32px-Draft_Slope.png +Part_Sweep.html +Fem-constraint-electrostatic-potential.svg +US_Letter_ds_Landscape.svg +Assembly_ConstraintParallel.svg +256px-LengthConstraint5.png +PartDesign_CompPrimitiveAdditive.html +Arch_tutorial_52.jpg +800px-TBHS2-4.JPG +Draft_Offset.svg +PartDesign_SubtractiveSphere_example.svg +Crank_00.gif +Fem-add-material.svg +Meshes_Boolean_Difference.jpg +16px-Path_Fixture.png +32px-Path_SimpleCopy.png +Sketcher_ToggleConstraint_Driving.svg +Release011-draft.jpg +FreeCAD-Ship-HydrostaticsIco.png +Arch_panel_tutorial_12.jpg +Constraint_Perpendicular.html +16px-Arch_MeshToShape.png +32px-FEM_ControlSolver.png +267px-FCCircularText_48.png +32px-Draft_ShapeString.png +Path-Post.svg +Sketcher_Element_Arc_StartingPoint.svg +Mesh_Mesh_from_Shape.svg +SIMTUT_05.PNG +Cross-section.png +NavigationOpenInventor_Select.svg +FreeCAD05_Tango_Face-surprise.svg +1024px-Shaftwizard1.jpg +Tut17_rectangleunconstrained.png +32px-Std_FreezeViews.png +Draft_ShapeString_Example400.png +24px-TechDraw_Dimension_Length.png +Macro_FCConvertLines_Hand.png +Part_Ellipsoid_screenshot.jpg +Button_down.svg +32px-FEM_Solver.png +NavigationGesture_PanTouchAlt.svg +32px-Snap_Extension.png +ParametersDent.svg +Gui_Command.html +PyQt.html +Step4_make_SB_construction_line_600x400.png +32px-Draft_AddPoint.png +32px-Ship_PlotGZ.png +Path-Sanity.svg +Tree_Dimension.svg +Macro_FCWire_To_Volume_00.png +Drawing-annotation.svg +Dimension_partitions_parallel.png +32px-Path_ToolLibraryEdit.png +Preference_Fem_Tab_02.png +PartDesign_AdditiveWedge.html +PartDesign_SubtractiveBox.png +Step7_arc_defining_BC.png +Manipulator-ico.png +320px-JoinFeatures_Example_step3_Cutout.png +Arch_Panel.html +Robot_Export.html +24px-Macro_DeepCopy.png +Constraint_PointOnEnd.svg +Sketcher_ConnectLines.html +Macro_Half-Hull_ModelImage5.jpg +32px-Path-Area-Workplane.png +FCTexture.png +Std_Alignment.html +640px-Macro_Install_HowTo_08.png +Draft_Facebinder.svg +PartDesign_SubtractivePipe.png +Constraint_Horizontal.html +FCSpring_Helix_Variable_Icon_06.png +Axes.svg +Raytracing_Lux.html +Raytrace_NewPartSegment.svg +32px-SelectVisible.png +Dxf_Importer_Install_21.png +ImageWorkbench.svg +IFC.svg +32px-Mesh_MakeSegment.png +1024px-Rockn.png +FreeCAD-0.17-missing-Graphviz-error-dialogue.png +Fem-constraint-pressure.svg +FreeCAD_API.html +View-bottom.svg +SectionCross3.png +Page.svg +267px-FCCircularText_44.png +480px-Sketcher_tutorial_result.png +Switch_DraftWorkbench.JPG +Units_Calculator_it.png +400px-Tango-Palette.png +TechDraw_Tree_Hatch.svg +300px-Part_BooleanOperations.png +Ship_Weight.html +Macro_FCCamera_00b.png +32px-Arch_AxisSystem.png +32px-Std_TipOfTheDay.png +Preference_Draft_Tab_01.png +Sketcher_Copy.svg +Mesh_BoundingsInfo.jpg +Path-Speed.svg +24px-PartDesign_Mirrored.png +Macro_FCCreaLoft.html +PartDesign_Groove_example.svg +FCTexture.svg +Constraint180_600x400.png +300px-PartDesign_Draft-02.png +FEM_Mesh_CalculiX.html +32px-FCCamera_00.png +24px-Cabinets32.png +32px-Path_Profile_Face.png +ANSI_C_Landscape.svg +Part_Extrude.svg +500px-Part_BooleanOperations.png +Std_Tool12.svg +32px-Macro_Overlap.png +24px-Macro_Half_Hull_Model.png +32px-Arch_Git.png +24px-PartDesign_NewSketch.png +Complete.jpg +32px-PartDesign_Scaled.png +Macro_Connect_And_Sweep_TL.png +PySideScreenSnapshot1.jpg +Sketcher_ConstructionMode.html +Part_Import.svg +32px-Sketcher_MapSketch.png +Constraint_Draft00.gif +Std_Part-tree-active.png +Macro_installer_02.jpg +Draft_Near.html +Macro_FCGear.html +640px-Macro_Install_HowTo_36.png +32px-Sketcher_SelectElementsAssociatedWithConstraints.png +FCCamera_05.png +480px-Sketcher_Point_fr_01.png +NavigationBlender_Select.svg +24px-Part_Section.png +Ship_LoadCondition.svg +Sketcher_Symmetry.svg +Mesh_Remove_Components.svg +400px-HolderTop1-9.jpg +Macro_FC_Convert_Lines.html +Arch_Preferences.html +Arch_E_Landscape.svg +Plot_Basic_tutorial.html +Sketcher_ToggleConstraint.svg +A3_Landscape_US_FULL.svg +Part_Mirror.svg +Sketcher_ConstrainTangent.png +24px-View-perspective.png +Std_DlgMacroExecuteDirect.html +Tut17_wrongplaneforpocket.png +NavigationBlender_Zoom.svg +16px-Draft_Line.png +24px-FCCamera_01.png +Draft_Line.png +Property_editor.html +32px-Std_MeasureLinear.png +Macro_FCWire_To_Volume.html +Macro_Ellipse-Center%2B2Points.html +DagViewVisible.svg +Draft_Upgrade.svg +182px-Texture_Nano_Photo.png +Sketcher_Ellipse.html +32px-Std_DebugOver.png +Arch_Wall_Tree.svg +Preference_Draft_Tab_03.png +PartDesign_Additive_Loft.svg +Macro_Rectellipse.html +32px-Std_MeasureAngular.png +800px-TBHS2-7.JPG +24px-SelectVisible.png +200px-SpaceNavigator.jpg +Techdraw-viewsection.svg +FreeCAD_Scripting_Basics.html +Basic_modeling_tutorial.html +Draft_AutoGroup.svg +Arch_Cell.html +Path_Engrave.png +800px-FreeCAD-Ship-s60Areas.png +Multitransfrom_parameters.png +18px-Macro_FCTreeView_20.png +24px-Std_WindowCascade.png +Sketcher_Parabolic_Arc_Constr.svg +480px-Macro_FCInfo_00_en.png +NavigationMayaGesture_ZoomTouch.svg +Path-SetupSheet.svg +OpenSCAD_MeshBoolean.html +TreeView_SpeadSheet.gif +Std_Part.html +300px-FCGear_cycloide_par.png +32px-Part_Cone.png +PartOffset1_it.png +16px-Arch_3Views.png +Fem-box.svg +Part_Spiral.html +Drawing_Save.html +Draft_Ellipse.svg +32px-Mesh_FlipNormals.png +32px-Plot_Grid.png +Macro_SuperWire.html +PartDesign_Workbench.html +Arch_tutorial_06.jpg +CoordinateSystem.svg +PointsWorkbench.svg +32px-Std_PerspectiveCamera.png +600px-Arch_SectionPlane_CutView.jpg +256px-HorizontalConstraint1.png +Constraint_InternalAngle.svg +Screenshot_from_2017-09-02_20-01-49.png +FreeCAD_Howto_Import_Export.html +Arch_tutorial_50.jpg +32px-FEM_ShowResult.png +FCCircularText_17.png +SpreadsheetExport.svg +480px-Raytracing_tutorial_result.png +Assembly_ConstraintLock.svg +Raytracing_ExportProject.html +Preference_Display_Tab_03.png +Part_ShapeFromMesh.html +32px-Sketcher_RestoreInternalAlignmentGeometry.png +32px-Draft_FinishLine.png +Screenshot-gcad.jpg +HorizontalSample.png +Step11_last_arc.png +PartDesign_Clone.svg +640px-Macro_Install_HowTo_01.png +299px-Texture_003_napperon.png +View-refresh.svg +Angularity.svg +View-perspective.svg +16px-Sketcher_CreateHeptagon.png +Sketcher_Element_Parabolic_Arc_Edge.svg +Arch_panel_tutorial_13.jpg +Macro_Cabinets32.html +NavigationTouchpad_Zoom.svg +32px-Mesh_Cut.png +Raytrace_ExportProject.svg +32px-Constraint_Length.png +30px-Robot_CreateRobot.png +Snap_Near.svg +OpenSCAD_ColorCodeShape.html +24px-PartDesign_AdditiveEllipsoid.png +32px-Constraint_InternalAngle.png +800px-TBHS2-5.JPG +Filling.svg +32px-FreeCAD-Ship-Ico.png +Assembly_Assembly_Tree.svg +267px-FCCircularText_32.png +300px-Macro_FCInfoGlass_01.png +32px-PartDesign_Line.png +1000px-Thread-by-horz-profile-profileMake.png +640px-Macro_Install_HowTo_22.png +OpenSCAD_ReplaceObject.html +MEPlanFC.png +Drawing-landscape-A4.svg +Fcstd_file_format.html +TechDraw_Tree_Page_Sync.svg +GitKraken-Rebasing.gif +PD_WB_Tutorial017.png +16px-Draft_SelectPlane.png +24px-TechDraw_New_Detail.png +Rotate-mouse-SHIFT.svg +32px-Std_MeasureClearAll.png +Release_notes_014.html +Arch_Equipment_Clone.svg +32px-Snap_Parallel.png +48px-Macro_HiddenAlls.png +267px-Macro_FCSpring_Helix_Variable_14.png +SketcherCreateTriangleExample.png +NavigationTouchpad_Pan.svg +PartHelixProperty_en.png +Part_ConvertToSolid.png +800px-TBHS-5.JPG +24px-Arch.png +Constraint_Radius.svg +32px-Draft_Center.png +150px-Macro_Cross_Section_01.png +Draft_Drawing.png +300px-Texture_002_Fe_FC.png +Macro_FCTreeView_004.png +Macro_Easy_cutouts_for_Enclosure_Design_icon.png +Part_CreatePrimitives_example_FreeCAD_0_13.jpg +32px-Std_Copy.png +Concentricity.svg +Std_DlgParameter.svg +Add_FEM_Equation_Tutorial.html +Arch_Git_panel.jpg +24px-Mesh_ExportMesh.png +PartDesign_SubtractiveEllipsoid.html +500px-Sketcher_SnellsLaw_Example1.png +FEM_MaterialSolid.html +Robot_SetHomePos.html +400px-HolderTop1-5.jpg +16px-Draft_AddToGroup.png +Triangle_isosceles_small.png +Preference_Fem_Tab_03.png +TechDraw_ProjRight.svg +Draft_Downgrade.html +Manipulator-WB-Parallel-Planes-Distance.gif +cc-by.png +Draft_Endpoint.html +500px-Std_Alignment4.png +Sketcher_BSplineKnotMultiplicity.svg +NavigationTouchpad_ZoomTouch.svg +PartDesign_AddLoft_example.png +Custom_extruder.jpg +STEP_project.html +300px-Macro_FCInfoGlass_02.png +320px-Slice_example_step3.png +TorusExampleAngle2.jpg +32px-Sketcher_CreateRectangle.png +32px-Freecad.png +FreeCAD05_Tango_Text-x-python.svg +800px-TBHS2-17.JPG +32px-Draft_Downgrade.png +Tut17_refine.png +Dialog_creation.html +3D_input_devices.html +Workbench_Complete.svg +32px-Std_DebugMacro.png +1024px-Gsuter.png +640px-Macro_Install_HowTo_34.png +Drawing-landscape-A0.svg +Sketcher_ConstrainLock_Driven.svg +300px-FCCamera_13.png +400px-Draft_Rotate_example.jpg +FEM_SolverElmer.html +Drawing_Clip.html +32px-Macro_ReproWire.png +Sketcher_SelectConflictingConstraints.svg +Basic_Part_Design_Tutorial_017.html +Sketcher_Symmetry.html +Draft_Grid.svg +Part_Measure_Toggle_3d.svg +200px-PartDesign_AdditiveBox_example.png +24px-Std_WindowPrev.png +32px-Arch_Panel_Cut.png +Draft_Array.svg +Mesh_AddTriangle.html +32px-Drawing_SpreadsheetView.png +24px-FreeCAD_Doc.png +32px-FEM_ConstraintFluidBoundary.png +Tut17_slot_unconstrained.png +1024px-Hhassey.png +Path-Plane.svg +Constraint_PointOnPoint.html +1024px-Freecad_jeep.png +Circel.png +Sketcher_SelectOrigin.svg +TechDraw_Hatching.html +32px-Draft_Intersection.png +32px-View-axometric.png +32px-Part_Spiral.png +Render_project.html +16px-Draft_BezCurve.png +32px-Techdraw-toggleframe.png +32px-Raytracing_New.png +Arch_tutorial_17.jpg +16px-Draft_Clone.png +Ship_Wieght.svg +FEM_PostCreateDataAlongLineFilter.html +Constraint_VerticalDistance_Driven.svg +500px-MacroBuildUtilityTreeDiagram.jpg +PartDesign_Additive_Sphere.svg +Arch_Panel_Cut.html +Sketcher_ExternalEsempio3.png +Path_wb_enable_experimental_features.PNG +Robot_Module.html +Sketcher_CreateArc_Constr.svg +Path-Area-Workplane.svg +Path_Array.html +Path-Contour.svg +Arch_Wikihouse_12.jpg +API_documentation.html +24px-Plot_Save.png +Workbench_Concept.html +700px-Pic3.png +PartDesign_AdditiveSphere.html +Splash_screen.html +Draft_mapping_files.html +32px-Part_Line.png +400px-Macro_Connect_And_Sweep_02.png +ABP_Screenshot.png +Meshes_RegularSolid_Cylinder.jpg +PartDesign_Additive_Pipe.svg +Macro_Half-Hull_ModelUsage5.jpg +24px-Macro_Center_Align_Objects_with_Faces_or_Edges.png +Arch_tutorial_40.jpg +FCInfoToMouse.png +TechDraw_NewArch.html +FEM_MeshGroup.html +32px-Constraint_TangentToEnd.png +300px-PartDesign_Draft-04.png +Arch_tutorial_49.jpg +FromShape_image_0.png +800px-InkMuchTooBig.png +Fem-thermomechanical-analysis.svg +24px-Macro_BOLTS.png +Path_Profile_by_Edges.png +Constraint_Internal_Alignment.html +MEPlanPY.png +SelectFace.png +Macro_Rotate_To_Point_01.gif +254px-FCCircularText_03.png +32px-Mesh_Regular_Solid.png +400px-FEM_example01_pic03.jpg +250px-Seg3--ccx.png +List_of_Commands.html +32px-Drawing_Open_SVG.png +32px-Path-Area.png +32px-Draft_Arc.png +Sketcher_CreateSlot_Constr.svg +Arch_panel_tutorial_16.jpg +200px-RadiusSample.png +Web-home.svg +640px-Macro_Install_HowTo_15.png +640px-Macro_Install_HowTo_20.png +Std_Edit_Menu.html +Drawing_ProjectShape.html +32px-Draft_Midpoint.png +Draft_Workbench.html +DependencyGraph1.png +CustomizeToolBar_12.png +Sketcher_EditSketch.html +TechDraw_Toggle.html +Source_Code_Management.html +AddonManager.html +SpreadsheetAlignRight.svg +600px-PartDesignConstraintPointOnPointScriptingFigure1.jpg +Preference_General_Tab_06.png +Arch_Stairs_Tree.svg +Mesh_SplitMesh.html +FreeCAD-Ship-S60TankGeometry.png +256px-HorizontalConstraint3.png +Constraint_PointOnEnd.html +PartDesignExample.png +Drawing-portrait-A2.svg +SketcherCreateRectangleExample.png +800px-TBHS-11.JPG +Mesh_SelectMesh.html +Macro_Automatic_drawing.html +85px-Macro_FCSpring_Helix_Variable_10.png +400px-Draft_Polyline_example.jpg +32px-OpenSCAD_ReplaceObject.png +Path_Core_Concepts.html +Step2_rectangle_with_symmetry_600x400.png +FreeCAD05_Tango_Measure.svg +FEM_Shear_of_a_Composite_Block.html +Path-Heights.svg +Path-Dressup.svg +Arch_SectionPlane_Tree.svg +Part_MakeCompound.html +A0_Landscape_plain.svg +BezSurf.svg +Addon_manager.png +32px-Arch_Roof.png +View-C3P.png +32px-Base_ExampleCommandModel.png +GGTuto1_12.PNG +PartDesign_Clone.html +32px-Sketcher_MergeSketch.png +300px-Counterbore_settings.png +Arch_Survey_spreadsheet.jpg +Tutorial-normand03.jpg +300px-HolderTop2-9.jpg +Mesh_FillHoles.png +FEM_PostCreateScalarClipFilter.html +Step8_arc_BC_finishing.png +Part_ShapeInfo.svg +24px-PartDesign_Hole.png +32px-Constraint_Vertical.png +320px-Slice_example_step2.png +Mesh_RemoveCompByHand.png +TechDraw_Dimension_Angle.png +120px-LaserLine.JPG +Sketcher_Show_Hide_Internal_Geometry.html +Meshes_Smooth.jpg +Arrowdot.svg +Rotate_cursor.png +Type_class.svg +NavigationGesture_Tilt.svg +32px-FEM_ConstraintFixed.png +Sketcher_CarbonCopy_Constr.svg +CustomizeToolBar_10.png +480px-CartoucheFC.png +700px-FEM_example01_pic00.jpg +A4_Simple.svg +PlacementDialogv10b.png +ThicknessEsempio3.png +16px-Arch_MultiMaterial.png +FEM_PostCreateCutFilter.html +480px-Macro_unrollRuledSurface_00.png +250px-Quad8--ccx.png +PartDesign_Additive_Box.svg +32px-FreeCAD-Ship-TankIco.png +Arch_tutorial_05.jpg +FEM_ConstraintSelfWeight.html +600px-Sketcher_ConsraintPerpendicular_mode2.png +32px-Robot_SetHomePos.png +FEM_Analysis.html +Workbench_creation.html +Arch_panel_tutorial_20.jpg +Delete.svg +Macro_FCConvertLines_Zigzag.png +400px-FCTexture_006.png +Path_MillFace.html +Fem-constraint-selfweight.svg +Wikihouse_porting_tutorial.html +Fem-static-analysis.svg +ParametersWindowStash.svg +Arch_panel_tutorial_17.jpg +Sketcher_CreateRegularPolygon_Constr.svg +Meshes_RegularSolid_Ellipsoid.jpg +NavigationTouchpad_RotateTouchAlt.svg +Arch_A_Portrait.svg +Macro_Creating_faces_from_a_DXF_file.html +Sketcher_SelectConstraints.html +400px-HolderTop2-2.png +32px-Arch_Rebar.png +Arch_panel_tutorial.html +24px-PartDesign_Revolution.png +32px-Sketcher_Reorient.png +Plot_Grid.png +Workbench_Sketcher.svg +FreeCAD-Ship-S60Outline3DSections.png +Wedge_examples.png +32px-Macro_CloneConvert.png +Mesh_SelectMesh.png +640px-Arch_Rebar_preview.png +32px-Part_CompJoinFeatures.png +Arch_templates.html +24px-PartDesign_Thickness.png +CustomizeWorkbenches.png +Plot_Positions.png +Path-Face.svg +16px-Draft_ShapeString.png +Arch_3Views.html +Sketcher_ViewSketch.html +Std_MeasureDistance.html +Macro_FCPropertyMemo_01.png +FreeCAD_start_center.jpg +120px-Wawue_Top.jpg +Macro_Mouse_Cross.html +Resource_framework_project.html +1024px-Arch_workflow_example.jpg +Std_ViewZoom.html +32px-Arch_Window.png +Part_JoinCutout.svg +Macro_CloneConvert.png +Macro_View_Rotation.html +32px-Macro_Select_Hovering.png +32px-Std_DebugStop.png +View-select.svg +ShipWorkbench.svg +Arch_Frame.svg +Sketcher_MapSketch_00.png +18px-Macro_FCTreeView_28.png +Arch_tutorial_16.jpg +PartDesign_Additive_Torus.svg +OpenSCAD_ExpandPlacements.html +Draft_Draft.svg +Feature-CAM.jpg +SpreadsheetCellPropDialog.png +TextDocument.svg +PartDesign_SubtractivePrism.html +32px-PartDesign_InvoluteGear.png +Sketcher_EditSketch.svg +View-Left.png +PartDesign_Preferences.html +24px-PartDesign_AdditiveCylinder.png +Raytracing_InsertPart.html +Arch_MakeIfcSpreadsheet.html +Fem-constraint-contact.svg +32px-Robot_Export.png +Techdraw-geomhatch.svg +Icone03.png +Sketcher_Module.html +16px-Path_Custom.png +A3_Classic.svg +Quantity.html +Assembly_ConstraintAngle.svg +Macro_Center_Align_Objects_with_Faces_or_Edges.html +32px-Macro_Half_Hull_Model.png +Drawing-draft-view.svg +TechDraw_Dimension_Link.html +Release_notes_013.html +FEM_MeshRegion.html +Sketcher_ConnectLines.svg +NavigationTouchpad_Rotate.svg +32px-Sketcher_CreateHexagon.png +16px-Path_Stop.png +CenterFace.png +Part_CreateSimpleCopy.html +Braga-secondoschizzo.png +200px-Macro_WorkFeatures_11.png +32px-Dimension_Radius.png +32px-Arch_Panel_Sheet.png +TestWorkbench.svg +A4_Portrait_ISO7200.svg +DraftPlaneTasks.png +Macro_FCTreeView_07.png +Robot_Workbench.html +FreeCAD05_Tango_Preferences-system.svg +Draft_AddToGroup.svg +24px-FCCamera_04.png +400px-HolderTop2-3.jpg +PartDesign_Revolution.svg +32px-FEM_PostCreateScalarClipFilter.png +Sketcher_Element_Hyperbolic_Arc_Centre_Point.svg +Preference_Import_Export_Tab_03.png +TechDraw_Tree_View.svg +32px-Arch_ToggleSubs.png +Partdesign_groove_parameters.png +Pyramides.gif +512px-PianoTaglio2.png +434px-Dxf_Importer_Install_11.png +32px-Arch_IfcExplorer.png +16px-Std_DlgMacroRecord.png +480px-PartDesign_pocket_exercise.png +Arch_3DS.html +16px-Constraint_Length.png +CAD_Modeling.gif +32px-Constraint_Perpendicular.png +Arrow-ccw.svg +Sketcher_MirrorSketch.svg +WizardShaft.svg +Plot_Legend.html +800px-Mt_example3.png +512px-PianoTaglio5.png +50px-Travis-logo.png +Sketcher_Conics.svg +Draft_Constrain.html +PARTMirrorAfterv11.png +24px-Aliasmanager_icon.png +Assembly_Assembly_Constraints_Tree.svg +GuiCommand_model.html +Zoom-border.svg +DumpObjectsScreenSnapshot.jpg +282px-Constrain3.png +A2_Landscape_ISO7200.svg +Perspective.png +32px-Sketcher_SelectHorizontalAxis.png +Right_triangle_sketcher.png +Sketcher_Element_Line_Edge.svg +Macro_Line_Length.html +Draft_Point.png +Draft_BezSharpNode.svg +Macro_Apothem_Based_Prism_GUI.html +18px-Macro_FCTreeView_02.png +240px-Project_utility_en.png +24px-PartDesign_ShapeBinder.png +View-Front.png +32px-Path_Inspect_G-code.png +Sceenshot-reversevid.jpg +013-draft-snap.jpg +FCSpring_Helix_Variable_Icon_03b.png +Macro_Half-Hull_ModelUsage2.jpg +400px-HolderTop2-13.jpg +Arch_tutorial_30.jpg +Arch_3Views.svg +300px-FCCamera_10.png +Std_Plane.svg +Macro_Remove_parametric_history.html +24px-Macro_FCWire_To_Volume.png +200px-PartDesign_AdditiveCone_example.png +32px-Techdraw-hatch.png +64px-Macro_FCInfoGlass.png +1024px-Draft_dimensions_recode.jpg +267px-FCCircularText_28.png +32px-Robot_CreateRobot.png +Constraint_Draft01.gif +MeasureLinear3D1.png +32px-Draft_AutoGroup.png +ArchWorkbench.svg +16px-Draft_AutoGroup.png +Drawing-landscape-new.svg +TechDraw_Tree_Spreadsheet.svg +600px-Part_Offset2D_Intersection.png +Edit-undo.svg +Cartouche_04_US.svg +Sketcher_Heptagon.html +Constraint_SnellsLaw.html +FreeCAD05_Tango_Camera-video.svg +32px-Sketcher_SelectVerticalAxis.png +Pages.svg +RebarDistributionDialog.png +Triangles.gif +Sketcher_MergeSketch.svg +300px-TaskProjGroup.png +Fem-constraint-temperature.svg +NavigationCAD_Zoom.svg +Std_MeasureToggle3D.html +18px-Macro_FCTreeView_06.png +Assembly_Add_New_Part.svg +Macro_Half-Hull_ModelOption6.jpg +Part_Prism.html +Robot_6-Axis.html +Macro_FCTreeView_21.png +Arch_structural_nodes.jpg +16px-Draft_AddPoint.png +Part_API.html +Constraint_PointToObject.html +KukaSegment2.jpg +800px-TBHS2-20.JPG +24px-Workbench_Mesh.png +Freecadsplash14.png +32px-Constraint_SnellsLaw.png +FEM_SolverCalculiX.html +Snap_Extension.svg +Arch_Remove.html +Draft_SelectPlane.html +32px-FCInfo.png +800px-TBHS2-10.JPG +320px-Slice_example_step5.png +Mesh_ToolMesh.html +Arch_Panel_Sheet.html +SketcherTrimExample1.png +32px-Sketcher_SelectConflictingConstraints.png +FCSpring_Helix_Variable.png +Macros.png +PartDesign_Subtractive_Prism.svg +480px-Texture_004_Honda.png +Sketcher_Elliptical_Arc_Constr.svg +Std_FreezeViews.html +Macro_Geneva_Wheel.html +Mesh_TrimMeshWithPlane.html +Mesh_Union.png +24px-2364.png +Arrow-right.svg +Std_SetColors.html +Sketcher_Element_Line_StartingPoint.svg +List-add.svg +500px-PythonAssistantWindowScreenSnapshot.jpg +800px-TBHS-v2.jpg +Mirrored_parameters_v017.png +DraftPlaneNone.png +480px-Jj62l.png +Material_data_model.html +512px-PianoTaglio1.png +Part_Mirror.html +TechDraw_Tree_Annotation.svg +Extra_python_modules.html +PartDesign_Mirrored.html +Path-Depths.svg +Part_Workbench.html +Screenshot_console.jpg +FEM_PostCreateFunctions.html +Constraint_Radius.html +FEM_ResultsPurge.html +Std_Tool7.svg +Datum_plane.png +700px-FEM_example01_pic02.jpg +32px-Std_ViewDockUndockFullscreen.png +640px-Macro_Install_HowTo_24.png +256px-ConstrainParallel1.png +Material.html +351px-Macro_Work_Features_Cutting_04.png +FEM_EquationElectrostatic.html +Path-Area-View.svg +Part_Wedge.html +Macro_Normal_Vector.html +Assy.gif +Sketcher_CreateCircle.svg +400px-Draft_edit_example.jpg +Constraint_PointOnStart.svg +32px-OpenSCAD_MeshBoolean.png +32px-Draft_Ortho.png +400px-Draft_Array_example.jpg +800px-TBHS2-1.JPG +Sketcher_CreatePoint.svg +Arch_Structure.svg +300px-Counterbore_settings2.png +24px-Workbench_Drawing.png +800px-TBHS2-19.JPG +24px-Macro_DXF_to_Face_and_Sketch.png +32px-Mesh_Cone.png +Breakpoint.svg +32px-Macro_Perpendicular_To_Wire.png +300px-PartDesign_Draft-03.png +Mesh_EvaluateCurvature.png +FCCamera_03.png +Draft_Edit.html +32px-Sketcher_EditSketch.png +32px-Path-3DPocket.png +410px-GGTuto1_Vue.PNG +32px-Path-CompleteLoop.png +Part_Measure_Step_Active.svg +PartDesign_InternalExternalGear.svg +1024px-Arch_clip_plane.jpg +FEM_ConstraintInitialFlowVelocity.html +ProjectShapeSet_it.png +Fem-elmer.svg +24px-PartDesign_AdditivePipe.png +256px-ConstrainParallel2.png +Sketcher_Element_Arc_Edge.svg +32px-Ship_Loading.png +32px-PartDesign_Plane.png +Release_notes_015.html +Std_PythonWebsite.html +Plot_Grid.html +Arch_Axis_System_Tree.svg +480px-Macro_BoundingBox_Tracing_00.png +Document-properties.svg +400px-HolderTop1-13.jpg +TechDraw_Tree_Symbol.svg +1024px-Scharniergreifer_render.jpg +32px-Std_DlgMacroExecuteDirect.png +Web-refresh.svg +32px-Raytracing_Lux.png +24px-PartDesign_Point.png +32px-Draft_Upgrade.png +600px-RotationAboutZAfter.png +Arch_Component.html +Macro_FCConvertLines_DashDotDot.png +Google_Summer_of_Code.html +Draft_Stretch_Example.jpg +FEM_ConstraintPlaneRotation.html +32px-Path_PostProcess.png +Fem-linearizedstresses.svg +Arch_tutorial_37.jpg +Draft_Parallel.html +32px-Part_JoinConnect.png +Cabinetside.png +24px-View-axonometric.png +PartDesign_Subtractive_Cylinder.svg +Tree_Part_Ellipsoid_Parametric.svg +32px-Plot_Save.png +32px-Std_BoxSelection.png +Compiling_(Speeding_up).html +Draft_Ortho.html +Sketcher_SelectConstraints.svg +300px-FCCircularText_42.png +Preferences-arch.svg +32px-Arch_Space.png +300px-PartDesign_Fillet-03.png +400px-HolderTop2-7.jpg +32px-Macro_BOLTS.png +120px-Bottle_raw.jpg +Workbench_FEM.svg +Sketcher_CreateLine.svg +Ship_TankNew.html +CompileOnCygwin.html +16px-Arch_Rebar_LShape.png +Workbench_select_sketcher.png +600px-Arch_door.jpg +32px-Path_Stop.png +Path-Inspect.svg +600px-Part_Offset2D_Demo.png +PySideScreenSnapshot7.jpg +1024px-216.png +PartDesign_AdditiveTorus.html +16px-Constraint_Parallel.png +600px-Sketcher_ConsraintPerpendicular_mode1.png +Std_Panels.html +Macro_FCInfoToMouse_01.png +DraftPlaneTop.png +18px-Macro_FCTreeView_29.png +Draft_Label.html +A4_Landscape_US_FULL.svg +LuxRenderOutput.png +Macro_FCTreeView_11.png +267px-Draft_selection_03.png +Arch_Schedule.svg +Macro_FCTreeView.png +Utube-alignment-tool-tutorial.png +Macro_FCTreeView_006.png +FCCircularText_16.png +NavigationMayaGesture_SelectTouch.svg +Base_API.html +Path_Pocket_Shape.html +Robot_CreateRobot.svg +FileOpenSavePath.png +Arch_site_example_02.jpg +32px-Constraint_PointOnStart.png +Draft_BezCurve.svg +Sketcher_SelectConflictingConstraints.html +32px-Dimension_Link.png +Qt_Example_02.png +Macro_Connect_And_Sweep.png +A4_Landscape_english.svg +16px-Draft_Downgrade.png +267px-FCCircularText_47.png +Splashscreen010.png +Draft_taskview.jpg +Assembly_ConstraintCoincidence.svg +480px-Background.jpg +Mesh_MeshFromShape.html +Arch_panel_tutorial_02.jpg +Macro_Section.html +PartDesign_Draft.svg +600px-Arch_AxisSystem_example.jpg +TechDraw_ProjFrontBottomRight.svg +InspectionEx.png +640px-Arch_IfcExplorer_example.jpg +32px-Std_ViewXX.png +Macro_Perpendicular_To_Wire_03.png +Edit-edit.svg +267px-FCCircularText_49.png +400px-FEM_example01_pic06.jpg +300px-FCCamera_12.png +Freecad-doc.svg +32px-Std_FreeCADWebsite.png +32px-FreeCAD-Ship-WeightIco.png +Symmetrie.svg +Path_Helix.html +Release_notes_0.15.html +267px-Macro_FCInfo_02.png +32px-Robot_RestoreHomePos.png +600px-Sketcher_ConsraintAngle_mode3.png +640px-Dxf_Importer_Install_03.png +Fem-constraint-force.svg +Mesh_MakeSegment.html +252px-FCCircularText_05.png +Std_PythonConsole.html +Constraint_TangentToStart.html +Fem-shell-thickness.svg +Arch_Add.svg +Macro_Toggle_Drawstyle_00_.png +24px-View-zoom-selection.png +500px-Drawing_Page.png +Macros_config.jpg +Techdraw-annotation.svg +Macro_MatrixTransform.html +Robot_Simulate.svg +Macro-stop.svg +256px-SymmetricConstraint2.png +Sketcher_RectangularArray.html +32px-OpenSCAD_AddOpenSCADElement.png +Hole_Pad002.png +Sketcher_BSplineDegree.svg +TorusExampleAngle1.jpg +Part_Revolve.svg +24px-Macro_ReproWire.png +Std_Import.html +600px-Thread-by-horz-profile.png +200px-PartDesign_AdditiveCylinder_example.png +Partdesign_revolution_parameters.png +NavigationCAD_Select.svg +300px-Svg_Namespace_01.png +Std_WindowPrev.svg +32px-Part_SectionCross.png +100px-Tutorial-treeview.jpg +FEM_ConstraintHeatflux.html +200px-Texture_002.png +Sketcher_ProfilesHexagon1.svg +200px-Macro_WorkFeatures_05.png +Part_Booleans.svg +Mesh_EvaluateRepair.html +300px-MantisBT-setting-Feature-Request.jpg +32px-Techdraw-viewdetail.png +PySideScreenSnapshot6.jpg +Bound-expression-unset.svg +32px-Drawing_New.png +Macro_Half-Hull_ModelOption8.jpg +TechDraw_New_Default.html +Flamingos_utils.jpg +Release011-robot.jpg +32px-PartDesign_AdditivePipe.png +Std_SetAppearance.html +Part_Booleans.html +OpenSCAD_Hull.svg +ANSI_A_Landscape.svg +WebTools_Workbench.html +Draft_Array.html +Constraint_HorizontalDistance.svg +Constraint_SnellsLaw_Driven.svg +Macro_FCCamera_Align_To_Face.gif +Preferences-part_design.svg +Draft_Style_Couleur_Face.png +Preference_Path_Tab_02.png +Part_JoinCutout.html +Wire.png +Kate4.png +Screenshot_arch_window.jpg +32px-Draft_Scale.png +Macro_hinge.html +FCCircularText_14.png +Constraint_PointOnObject.html +Draft_Linestyle.html +Arch_Equipment_Tree.svg +Mesh_ExMakeMesh.html +Arch_MergeWalls.html +32px-Techdraw-annotation.png +600px-Sketcher_ConsraintAngle_mode2.png +Macro_Half-Hull_ModelImage9.jpg +Macro_ForceRecompute.html +Scripted_objects.html +Arch_tutorial_36.jpg +800px-TBHS-17.JPG +Help_FreeCAD.html +Line_drawing_function.html +Workbench_PartDesign.png +30px-Robot_RestoreHomePos.png +Profile_of_surface.svg +24px-PartDesign_SubtractivePipe.png +DrawStyleShaded.svg +Arch_Panel_Clone.svg +Pocket_options.png +32px-Part_Circle.png +PartDesign_Chamfer.html +32px-Mesh_Cylinder.png +Path_profile_example.jpg +Techdraw-image.svg +Arch_SectionPlane.svg +Drawing_ProjectShape.png +18px-Macro_FCTreeView_24.png +640px-Macro_Install_HowTo_35.png +Macro_EdgesToArc.html +Std_DlgParameter.html +32px-Arch_Pipe.png +Path-OpCopy.svg +Dxf_Importer_Install_12.png +Assembly_ConstraintBidirectional.svg +Hull_example.jpg +Draft_FlipDimension.html +480px-Cercle3Points2D_anaglyphe.png +Mesh_Difference.html +24px-PartDesign_LinearPattern.png +Param_Float.svg +300px-PD_WB_Tutorial018.png +NavigationOpenCascade_ZoomAlt.svg +300px-PartDesign_Chamfer-03.png +267px-FCCircularText_29.png +Sketcher_Line.html +1024px-FreeCAD-guitar.jpg +48px-Macro_VisibleAlls2.png +Part_Offset2D.html +16px-Arch_Window.png +Arrowopendot.svg +400px-Loft_B-spline.png +Macro_Half-Hull_ModelScreenSnapshot1.jpg +Draft_AddPoint.html +Part_Offset2D.svg +Loading.png +Arch_Rebar_LShape.html +800px-FreeCAD-Ship-s60GZ.png +Macro_Half-Hull_ModelImage8.jpg +32px-Draft_Wire.png +PartDesign_Line.svg +Arch_tutorial_09.jpg +Std_MeasureLinear.html +300px-PartDesign_Draft-01.png +PD_WB_Tutorial007.png +32px-Part_RegularPolygon.png +Path-Comment.svg +32px-TechDraw_NewView.png +32px-Draft_ToggleDisplayMode.png +Mesh_Export.html +Sketcher_Validate.png +16px-Std_DlgMacroStop.png +Macro_MeasureCircle.html +Sketchfab_exporter.jpg +Macro_Global_Variable_Watcher.html +600px-Patharray_alignment_annotated.png +Std_RecentFiles.html +Mesh_Scripting.html +32px-Part_Fillet.png +Macro_Draw_Parametric_2D_Function.html +Release011-sketcher.jpg +150px-Tache_Placement_Translation_Z_fr.gif +Part_Chamfer.svg +OpenSCAD_Minkowski.svg +Workbench_PartDesign.svg +Spreadsheet_Module.html +500px-PythonAssistantWindowGui2.jpg +24px-FreeCAD-Ship-Ico.png +List-remove.svg +24px-Macro_Toggle_Drawstyle.png +Sketcher_Element_BSpline_StartPoint.svg +16px-Path-3DPocket.png +ParametersPillar.svg +Std_Workbench_Menu.html +Preferences-raytracing.svg +ParametersPanel.svg +32px-TechDraw_Tree_Page_Sync.png +CompileOnUnix.html +Raytracing_project.html +Fem-femmesh-clear-mesh.svg +Tutorial-normand04.jpg +Macro_DXF_to_Face_and_Sketch.html +Macro_HealArcs.html +NavigationMayaGesture_Rotate.svg +Points_ExportPoints.html +400px-Draft_facebinder_example.jpg +32px-TechDraw_Symbol.png +24px-Macro_Copy3DViewToClipboard.png +Method.png +KicadStepUp_Workbench.html +32px-FEM_ConstraintTransform.png +TemplateExample.svg +Tache_Placement_Tangage_fr_Mini.gif +200px-FCCircularText_34.png +Mesh_FillHoles.html +Video_tutorials.html +16px-Arch_Equipment.png +32px-Std_New.png +32px-Std_Project_utility.png +Arch_C_Landscape.svg +FEM_tutorial.html +32px-PartDesign_WizardShaft.png +16px-Arch_ToggleSubs.png +32px-Constraint_PointOnMidPoint.png +Job_2.jpg +Part_Loft_Liste3.png +Spreadsheet_Controller.html +32px-Techdraw-image.png +93px-Macro_FCSpring_Helix_Variable_11.png +Dxf_Importer_Install_19.png +1024px-DrawingWB.png +TechDraw_SaveSVG.html +TechDraw_Pages.svg +16px-Std_SelectAll.png +200px-FCCircularText_25.png +Mesh_EvaluateRepairMesh.jpg +OpenSCAD_CSG.html +84px-Cam.JPG +400px-Macro_FCConvertLines_00.png +Macro_Half-Hull_ModelImage2.jpg +Std_Edit.html +Macro_FCConvertLines_Dash.png +Mesh_cut.svg +PD_WB_Tutorial015.png +Std_ToggleVisibility.html +TechDraw_Symbol.html +800px-TBHS2-23.JPG +200px-FCCircularText_37.png +Preferences_Editor.html +Snap_Midpoint.svg +Arch_panel_tutorial_08.jpg +wiki.css +1024px-Screenshot_from_2018-01-25_20-53-18.jpg +480px-PartDesign_multitransform_exercise.png +Macro_FCTreeView_26.png +Part_Shapebuilder.html +Draft_BezCurve.html +Mesh_PolyCut.html +400px-HolderTop2-15.jpg +640px-Macro_Install_HowTo_26.png +Macro_PropertyMemo.html +Fem-constraint-pulley.svg +800px-TBHS2-14.JPG +Sketcher_Elliptical_Arc.svg +18px-Macro_FCTreeView_23.png +Sketcher_Clone.svg +Edit-delete.svg +SpNav-PanLR.svg +Path_NewTool.html +Assembly_Basic_Tutorial.html +Macro_DXF_To_Shape_00.png +48px-Macro_If_Selected_Stay_If_Not_Then_Delete.png +A0_Landscape_ISO7200.svg +640px-Arch_Survey_example.jpg +32px-Draft_Perpendicular.png +PartBooleansDialog.png +300px-Loft_nonparallel.png +013-draft-shape2dview.jpg +24px-Macro_Rotate_To_Point.png +32px-Path_SelectLoop.png +Constraint_Tangent.html +FreeCAD05_Tango_Face-crying.svg +Triangle_equilateral_small.png +Std_ViewIvIssueCamPos.html +FreeCAD-Ship-SignCriteria.jpg +Arch_schedule_example04.jpg +482px-Exercise_meshing_03.jpg +Part_Cone.svg +FCTemplateHow.png +Arch_Check.html +300px-Loft_Coplanar.png +Preference_Raytracing_Tab_01.png +Save_picture.png +View-left.svg +30px-Robot_TrajectoryDressUp.png +ANSI_C_Portrait.svg +PartDesign_Subtractive_Torus.svg +32px-Std_DebugInto.png +Ship_Weight.png +600px-Mantisbt-comment-shortcut-example.jpg +640px-Macro_Circle_02.png +800px-TBHS-12.JPG +48px-Macro_VisibleAlls.png +Ship_OutlineDraw.svg +Macro_Align_Object_to_View.html +Pan-mouse.svg +Straightness.svg +200px-FramesOff.png +Mesh_PolySegm.html +32px-Arch_Equipment.png +32px-PartDesign_AdditiveWedge.png +600px-Sketcher_ConsraintPerpendicular_mode3.png +View-fullscreen.svg +640px-Macro_Install_HowTo_19.png +400px-Draft_Arc_example.jpg +Mesh_Curvature_Plot.svg +Fem-frequency-analysis.svg +Draft_ShapeString.html +TechDraw_ProjLeft.svg +Preference_Part_Design_Tab_02.png +PySideScreenSnapshot5.jpg +346px-TutorialDraftShapeString_Complete.jpg +351px-Macro_Work_Features_Cutting_01.png +600px-Macro_FCSpring_Helix_Variable_19.png +16px-TechDraw_ClipMinus.png +Internet-web-browser.svg +Path_scripting.html +Sketcher_Element_BSpline_EndPoint.svg +PartDesign_Revolution.html +32px-GW_Dim.png +16px-Draft_Mirror.png +Std_MeasureToggleAll.html +default.html +DatumPoint.png +24px-FCCamera_08.png +24px-FCCamera_00.png +Macro_Assemblage_Imprimante_3D.html +Draft_Scale.html +32px-Arch_Check.png +32px-Path_3DPocket.png +Arch_SelectNonSolidMeshes.html +Std_ViewFitAll.html +24px-Macro_Build_Utility.png +Arch_Wikihouse_11.jpg +Release_notes_016.html +300px-Macro_Install_HowTo_18.png +320px-Slice_example_step6.png +Points_Export_Point_cloud.svg +FreeCAD_Screenshot.png +PartDesign_SubtractiveLoft.png +A2_Portrait_plain.svg +Part_ReverseShapes.png +Sketcher_ToggleConstraint.html +32px-Sketcher_Symmetry.png +Std_RotateRight.html +24px-PartDesign_SubtractiveTorus.png +Mesh_EvaluateRepair.png +267px-FCCircularText_55.png +Splash013.jpg +Draft_Dimension.svg +Constraint_Perpendicular.svg +TechDraw_Preferences.html +700px-Pic8.png +Macro_Rotate_To_Point.png +Preference_Sketcher_Tab_02.png +Window-new.svg +Licence.html +267px-Macro_FCSpring_Helix_Variable_13.png +PartDesign_NewSketch.png +ApplyingForceToFace.PNG +Macro_Compound_Plus_00.png +Arch_Rebar_Tree.svg +32px-Draft_Rotate.png +Arch_Frame.html +Sketcher_CreateRectangle.svg +245px-Macro_FCInfo_04.png +Path_ToolNumberToLoad.html +Arch_Bimserver.svg +DraftPlaneView.png +200px-FCCircularText_36.png +Screenshot_arch_rebar.jpg +Sketcher_NewSketch.html +Camera-photo.svg +Part_Sweep.svg +Draft_AutoGroup_example.jpg +Part_Loft.svg +16px-Arch_SetMaterial.png +SketcherWorkbech.svg +SpreadsheetWorkbench.svg +History.html +24px-Anaglyph_Tango.png +PySide_Beginner_Examples.html +Qt_Example.html +24px-DrawStyleFlatLines.png +267px-FCCircularText_58.png +Draft_Angle.html +A3_Landscape_plain.svg +Tache_Placement_en_02.png +TechDraw_Dimension_Angle.html +32px-Part_RuledSurface.png +Media-playback-start.svg +Raytracing_Camera.html +16px-Std_Redo.png +FCSpring_Helix_Variable_Icon_05.png +Constraint_Concentric.svg +Macro_Unfold_Box.html +Release_notes_0.18.html +800px-TBHS-3.JPG +Macro_Dxf_To_Shape_Convert_Wire_To_BSplineCurve.gif +Macro_Perpendicular_To_Wire_01.png +PySide_Medium_Examples.html +Mesh_Torus.svg +600px-Geodesic_macro.png +32px-Spreadsheet_PropertyController.png +32px-Draft_ApplyStyle.png +Macro_FlattenWire.html +Std_WindowNext.svg +Sketcher_SwitchVirtualSpace.svg +16px-Arch_Panel.png +PartDesign_InvoluteGear.svg +32px-Robot_TrajectoryCompound.png +MEPlanF.png +FreeCAD-Ship_s60_tutorial.html +Path_Engrave.html +Aligner-ico.png +Constraint_Length.svg +1024px-VIIC_2.jpg +PartDesign_LinearPattern_example.svg +Datum_line.png +Arch_Wikihouse_08.jpg +Arch_tutorial_31.jpg +32px-Arch_Rebar_LShape.png +32px-Arch_SetMaterial.png +118px-WaWue.JPG +32px-Path-Face.png +Sketcher_BSplineComb.svg +Draft_Style_Epaisseur_Ligne.png +Draft_Scale.svg +16px-Draft_Text.png +Sketcher_CreateEllipse.svg +PlacementDialogv10.png +PartDesign_tutorial.html +Material.svg +PartDesign_Body_example.png +500px-Drawing_Views.png +Zoom-mouse-CTRL-SHIFT.svg +PartDesign_Boolean.html +16px-Path_Contour.png +400px-Draft_polygon_example.jpg +32px-Macro_Center_Align_Objects_with_Faces_or_Edges.png +Sketcher_CreateTriangle_Constr.svg +32px-Arch_Rebar_Stirrup.png +267px-FCCircularText_61.png +32px-Sketcher_CreateEllipse.png +Macro_Half-Hull_ModelUsage1.jpg +Fem-equation-heat.svg +PD_WB_Tutorial008.png +Toothbrush_Head_Stand.html +Square.svg +640px-CustomizeToolBar_01.png +Constraint_HorizontalDistance_Driven.svg +534px-Raytracing_tutorial_result.png +16px-Draft_SetWorkingPlaneProxy.png +PartDesign.png +PartWedgeProperty.png +013-arch-axes.jpg +Introduction_to_Python.html +Robot_SetHomePos.svg +freecad.qhcp +Sketcher_Element_Elliptical_Arc_Centre_Point.svg +SketcherCreateHexagonExample.png +32px-Std_MergeProject.png +480px-Macro_GMSH.png +Mesh_HarmonizeNormals.html +Part_Polygon_Parametric.svg +013-arch-wall.jpg +Edit-select-box.svg +800px-Footing_UShapeRebar.png +FCCircularText_11.png +Sketcher_Clone.html +Macro_makeCube.png +Macro_FCTreeView_19.png +Arch_Roof.html +267px-FCCircularText_57.png +32px-Std_OrthographicCamera.png +DlgPreferences.jpg +Zoom-all.svg +Draft_Draft2Sketch.html +Snap_Center.svg +32px-Path_Pocket.png +Fem-constraint-heatflux.svg +Fcblender.jpg +Macro_BOLTS.html +FEM_Install.html +CustomizeToolBar_07.png +1024px-Staeubli_step_import.png +PlacementPropertiesv10-800x800.png +32px-Draft_SelectGroup.png +Robot_SetDefaultOrientation.svg +Sketcher_CreateEllipse_3points.svg +Path-MachineLathe.svg +600px-Sketcher_ConsraintTangent_mode1.png +Path_EditToolsTable.html +Inkscape_Template_tut_6.png +PARTMirrorDialogv11.png +400px-HolderTop2-10.jpg +600px-Arch_Section_example3.jpg +Std_File_Menu.html +VRML_Preparation_for_Robot_Simulation.html +16px-Draft_UndoLine.png +Snap_Lock.svg +Snap_Grid.svg +Tree_Part.svg +600px-Part_Extrude_demo.png +16px-Std_DlgMacroStop_02.png +24px-FCTexture.png +32px-Sketcher_CreateSquare.png +20px-Menu_Std_DlgMacroExecute_fr_02.png +PartDesign_InvoluteGear.html +Draft_Module.html +Arch_SplitMesh.html +Linearpattern_parameters_v017.png +OpenSCAD_RefineShapeFeature.html +Screenshots.html +Path_Contour.html +600px-Arch_Window_options.jpg +Closed_triangle_with_pointer_small.png +A3_LandscapeTD.svg +Topological_data_scripting.html +FEM_Module.html +Const_member.svg +Unfolding_test2.png +Install_on_Windows.html +GW_Dim.png +300px-Addon_manager.png +32px-PartDesign_AdditiveBox.png +Document-save.svg +640px-Macro_Install_HowTo_07.png +PartDesign_SubtractiveLoft.html +Macro_FCTreeView.html +Part_Ellipsoid.html +S60OutlineTransversal.png +300px-Svg_Namespace_02.png +FEM_ConstraintFluidBoundary.html +240px-Background.png +1024px-Draft_hatches.jpg +16px-Path_Array.png +Macro_Unroll_Ruled_Surface.html +Dialog-chamfer.png +Pad_parameters_cropped.png +32px-Sketcher_CreateEllipse_3points.png +24px-FreeCADIco.png +NavigationTouchpad_RotateAlt.svg +Preference_Path_Tab_03.png +Std_Tool2.svg +351px-Macro_Work_Features_Cutting_09.png +32px-FEM_PostCreateFunctions.png +16px-FEM_Analysis.png +32px-Path_Sanity.png +SketcherCreateOctagonExample.png +Customize_ToolsBar.html +32px-Image_Import.png +PartDesign_LinearPattern.svg +32px-PartDesign_Fillet.png +32px-TechDraw_Dimension_Horizontal.png +Macro_Recompute_Profiler.html +Arch_tutorial_14.jpg +32px-Drawing_Symbol.png +Macro_FCTreeView_003.png +Path-SquarePocketModel.png +16px-Arch_SectionPlane.png +Manipulator-WB-Mover.gif +Common_Airfoil_Data_Import.html +1024px-R_tec.jpeg +400px-Draft_bspline_example.jpg +Scaled_parameters.png +32px-Draft_Rectangle.png +Expression_usage1.png +16px-Arch_Remove.png +16px-Sketcher_LeaveSketch.png +32px-Std_ToggleVisibility.png +Macro_FCConvertLines.png +NavigationTouchpad_RotateTouch.svg +800px-BentShapeRebar.png +Mesh_CreateMeshSegment.html +Draft_Trimex.html +Macro_Toggle_Visibility.html +Part_Measure_Toggle_All.svg +18px-Macro_FCTreeView_21.png +Touch_Tap.svg +32px-View-rotate-right.png +300px-TutorialDraftShapeString_BasicShape.jpg +Std_SetColors1_it.png +600px-Arch_Axis_example.jpg +24px-Workbench_Part.png +150px-Drawing_View_Iso.png +Workbench_Reverse_Engineering.svg +Sketcher_Micro_Tutorial_-_Constraint_Practices.html +640px-Arch_Door_preview.png +Arch_tutorial_08.jpg +GGTuto1_11.PNG +Macro_cross_section.html +250px-Attacher_mode_Folding.png +800px-TBHS2-11.JPG +400px-HolderTop1-1.jpg +Macro_Replace_Part_in_Assembly.jpg +800px-Release017_Title.jpg +640px-Macro_Install_HowTo_38.png +Freecad09.jpg +16px-Arch_Add.png +Part_CreatePrimitives.svg +Std_DlgMacroExecute.html +32px-FreeCAD-Ship-AreaCurveIco.png +TechDraw_GeomHatch.html +Sketcher_Arc.html +32px-CenterFace.png +780px-Arch_wall_snap.jpg +PD_WB_Tutorial016.png +Draft_Edit.svg +Macro_CartoucheFC_Full.html +Circularity.svg +Spreadsheet.svg +FEM_ConstraintFlowVelocity.html +32px-Robot_InsertWaypointPre.png +Snells_law2_witheq.svg +Macro_FCConvertLines_02.png +16px-Arch_Rebar_BentShape.png +32px-Snap_Perpendicular.png +Assembly_ConstraintPerpendicular.svg +Sketcher_ExternalEsempio2.png +Path-BaseGeometry.svg +24px-PartDesign_SubtractiveEllipsoid.png +Constraint_InternalAlignment_Ellipse_MinorAxis.svg +PianoTaglio6.png +Python_Development_Environment.html +TechDraw_Image.png +Macro_GMSH.html +NavigationCADAlt.svg +Arch_tutorial_42.jpg +250px-Setup_WaWue.JPG +Parallax.jpg +Profile_of_line.svg +32px-Path-Helix.png +Robot_SetDefaultValues.svg +96px-Part_Revolve_fr_06.png +Fem-clip-scalar.svg +24px-Macro_MeasureCircle.png +Sketcher_project.html +32px-Sketcher_NewSketch.png +24px-Techdraw-hatch.png +Robot_project.html +256px-EqualConstraint5.png +Techdraw-symbol.svg +Macro_Image_Scaling.html +32px-PartDesign_ShapeBinder.png +Arch_pipe_example_02.jpg +Continuous_Integration.html +800px-TaskPanel.jpg +800px-FreeCAD013.jpg +Arch_Axis_System.svg +XY_Title_v2.svg +Arch_panel_tutorial_15.jpg +267px-FCCircularText_43.png +Ship_Geometries_Examples.html +32px-Raytracing_InsertPart.png +32px-PartDesign_Point.png +Switch_PartWorkbench.JPG +Macro_FCTreeView_06.png +PartDesign_Point.svg +32px-Mesh_CurvaturePlot.png +Tut17_rectangleconstrained.png +PartDesignConstraintPointOnPointScriptingFigure3Bis.jpg +250px-Seg2.png +Sketcher_MergeSketch.html +Macro_FCSpringHelixVariable_Example_02.gif +32px-Constraint_Radius.png +FreeCAD05_Tango_Face-devil-grin.svg +24px-681.jpg +1024px-Lhf.jpg +Mesh_Cone.svg +Sketcher_CreateOctagon_Constr.svg +Macro_FCSpring_Helix_Variable_02_2.png +16px-Arch_Floor.png +Online_Help_Startpage.html +A3_Showcase.svg +24px-FCInfoToMouse.png +300px-FC_ConstrainedSketch.png +Arrow-left.svg +16px-Draft_Trimex.png +300px-Macro_FCInfoGlass_03.png +Preference_Import_Export_Tab_04.png +Drawing_SpreadsheetView.html +Ship_New.html +1024px-Draft_subdivisions.jpg +Path_Stop.html +Importing_From_Sketchup.html +Zoom-selection.svg +Drawing_Symbol.html +Part_Sphere.html +Mesh_Cube.svg +480px-Macro_drawParametric2Dfunction.png +FEM_SolverControl.html +Std_Copy.html +Project_utility.html +32px-Draft_SelectPlane.png +PartDesign_Pad_example.svg +Path-InspectWindow.gif +Sketcher_Preferences.html +Macro_FCCamera.html +Arrowfilled.svg +GGTuto1_7.PNG +Drawing-portrait-A3.svg +16px-TechDraw_Clip.png +32px-FEM_MeshGroup.png +Std_DebugMacro.html +480px-PartDesign_revolution_exercise.png +OpenSCAD_Module.html +32px-FEM_MeshRegion.png +FCCircularText_08.png +700px-Pic4.png +A4_Portrait_US_Text_Complet_With_Convention_EU.svg +32px-Drawing_Save.png +Std_WindowTileVer.svg +XY_Working_v2.svg +700px-Multiple_material.jpg +300px-Sketcher-v0.16-demo.png +Std_Tool10.svg +16px-Draft_Draft2Sketch.png +FreeCAD-Ship-S60WeightsPreview.png +Preferences-display.svg +24px-TechDraw_NewSection.png +24px-PartDesign_AdditiveWedge.png +600px-Arch_SectionPlane_example.jpg +Draft_Text.svg +Release_process.html +Sketcher_Element_Arc_MidPoint.svg +Std_DebugInto.html +FreeCAD_vector_math_library.html +1024px-Obijuan.png +Macro_Triangle_AH.html +32px-Arch_CutPlane.png +133px-Macro_Draft_Circle_3_Points02.png +IconSize.png +A4_Landscape_ISO7200.svg +Arch_MergeWalls.svg +1024px-Mesh_curvature_plot1.jpeg +DraftWorkbench.svg +Constraint_PointOnStart.html +Getting_started.html +16px-Arch_Nest.png +600px-Mantisbt-strikeout-text-example.jpg +Mesh_Intersection.png +Constraint_Vertical.svg +Robot_InsertWaypointPre.html +800px-TBHS-21.JPG +Preference_General_Tab_02.png +Arch_C_Portrait.svg +32px-Macro_FCTreeView.png +277px-Macro_FCInfo_03.gif +Std_MeasureToggleDelta.html +478px-Exercise_lego_01.jpg +24px-View-right.png +SceneOutput.png +Draft_Wire.html +ANSI_B_Portrait.svg +Sketcher_Extend.svg +Workbench_TechDraw.svg +FreeCAD-Ship-S60WeightsTanksPreview.png +300px-FCCamera_14.png +142px-FreeCAD_Menu_Edition_Peferences.png +TechDrawGui_API.html +800px-TBHS2-27.JPG +Macro_Draft_Circle_3_Points_3D.html +NavigationUndefined.svg +Std_UnitsCalculator.html +32px-Std_ViewFitSelection.png +480px-Part_Cut_01.png +1024px-Freecad_default.jpg +400px-HTCaeroplane03.png +32px-FEM_ConstraintSelfWeight.png +32px-Part_JoinCutout.png +FCInfo_begin_00.gif +TechDraw_LineGroup.html +View-rear.svg +Flatness.svg +NavigationTouchpad_PanTouch.svg +800px-TBHS-4.JPG +PartDesign_Fillet.svg +FEM_PostCreateLinearizedStressesFilter.html +Draft_AutoGroup.html +480px-Macro_Draft_Circle_3_Points01.png +Part_ConvertToSolid.html +PartDesign_Bearingholder_Tutorial_II.html +16px-Path_Copy.png +Start_Workbench.html +MaterialSelection.png +DrawStyleAsIs.svg +Part_Torus.html +Sketcher_BSplinePolygon.svg +Mesh_TrimMeshWithPlane.png +Snap_Endpoint.svg +32px-Macro_Dump_Objects.png +Image_Module.html + + +
      +
      diff --git a/localwiki/poweredby_mediawiki_88x31.png b/localwiki/poweredby_mediawiki_88x31.png new file mode 100644 index 0000000..6883e1c Binary files /dev/null and b/localwiki/poweredby_mediawiki_88x31.png differ diff --git a/localwiki/wiki.css b/localwiki/wiki.css new file mode 100644 index 0000000..601b871 --- /dev/null +++ b/localwiki/wiki.css @@ -0,0 +1,82 @@ +/* Basic CSS for offline wiki rendering */ + +body { + font-family: Fira Sans,Arial,Helvetica,sans-serif; + font-size: 14px; + text-align: justify; + /*background: #fff; + color: #000;*/ + max-width: 800px; + } + +h1 { + font-size: 2.4em; + font-weight: bold; + padding: 5px; + border-radius: 5px; + } + +h2 { + font-weight: normal; + font-size: 1.6em; + border-bottom: 1px solid #ddd; + } + +h3 { + padding-left: 20px; + } + +img { + max-width: 100%; + } + +li { + margin-top: 10px; + } + +pre, .mw-code { + text-align: left; + /*background: #eee;*/ + padding: 5px 5px 5px 20px; + font-family: mono; + border-radius: 2px; + } + +a:link, a:visited { + font-weight: bold; + text-decoration: none; + color: #2969C4; + } + +a:hover { + text-decoration: underline; + } + +.printfooter { + font-size: 0.8em; + color: #333333; + border-top: 1px solid #333; + margin-top: 20px; + } + +.wikitable #toc { + font-size: 0.8em; + } + +.ct, .ctTitle, .ctOdd, .ctEven th { + font-size: 1em; + text-align: left; + width: 190px; + float: right; + /*background: #eee;*/ + margin-top: 10px; + border-radius: 2px; + } + +.ct { + margin-left: 15px; + padding: 10px; + } +#mw-navigation { + display:none; /*TODO remove on next build (included below)*/ + } diff --git a/revisions.txt b/revisions.txt new file mode 100644 index 0000000..c8dcb2e --- /dev/null +++ b/revisions.txt @@ -0,0 +1,1100 @@ +Localisation:242538 +PyQt:249982 +PySide_Advanced_Examples:145518 +PySide_Medium_Examples:145880 +PySide_Beginner_Examples:151549 +Localisation_Sidebar:151540 +Localization_Older_Methods:247187 +Branding:225825 +Splash_screen:84605 +Start_up_and_Configuration:280543 +Organization_chart:218190 +Licence:146321 +Compiling:147867 +CompileOnMinGW:151075 +CompileOnCygwin:151067 +Help_FreeCAD:234777 +Google_Summer_of_Code:262586 +Google_Summer_of_Code_2018:262586 +Swept-path_Analysis_GSoC_Project:262033 +FEM_Analysis:257609 +FEM_ConstraintPressure:257745 +Fem_Workbench:247560 +FEM_project:186356 +Development_roadmap:224164 +Release_process:156424 +Robot_project:123658 +Land_Survey_Workbench_Blueprint:186359 +CAM_project:245726 +Python_3:234795 +Material_data_model:124459 +Units:126439 +Quantity:241767 +InputField:101941 +Gui_Command:234797 +Draft_Line:199108 +Release_notes_0.16:286826 +Path_scripting:177497 +Macro_GMSH:240442 +Customize_Toolbars:222558 +How_to_install_macros:220525 +Macro_screw_maker1_2:278093 +Macro_Apothem_Based_Prism_GUI:240723 +Std_DlgMacroStop:143321 +Std_DebugMacro:105223 +Std_Macro_Menu:105110 +Std_DebugToggle:105235 +Std_DebugInto:105232 +Std_DebugOver:105229 +Std_DlgMacroExecute:134984 +Std_DlgMacroExecuteDirect:105214 +Std_DebugStop:105226 +Std_DlgMacroRecord:143943 +Macros_recipes:281047 +How_to_install_additional_workbenches:231434 +Macro_PropertyMemo:241176 +Macro_Corner_shapes_wizard:241163 +Macro_FCGear:241155 +Macro_Stairs:241149 +Macro_Half-Hull_Model:241141 +Macro_Half_turn_stairs:241133 +Macro_Cabinets32:241124 +Macro_Geneva_Wheel_GUI:241116 +Macro_Geneva_Wheel:241110 +Macro_Airfoil_Import_%26_Scale:241097 +Common_Airfoil_Data_Import:212180 +Macro_Unfold_Box:241085 +Macro_Unroll_Ruled_Surface:241073 +Macro_Sheet_Metal_Unfolder:241062 +Macro_Unbind_Numpad_Shortcuts:276947 +Macro_merge_duplicate_materials:241055 +Macro_Arch_Axis_System_Repartition:241045 +Macro_BoundingBox_Tracing:246441 +Macro_Print_SceneGraph:254208 +Macro_cross_section:274023 +Macro_HighlightDifference:241016 +Macro_HighlightCommon:241008 +Macro_Toggle_Drawstyle:241000 +Macro_Replace_Part_in_Assembly:240991 +Macro_Shake_Sketch:240984 +Macro_Recompute_Profiler:244726 +Macro_ForceRecompute:240968 +Std_Refresh:165288 +Std_Edit_Menu:105095 +Std_DlgPreferences:187447 +Std_Edit:103308 +Std_Alignment:182747 +Std_Placement:179841 +Aeroplane:211693 +Part_Union:202246 +Part_RefineShape:234830 +OpenSCAD_RefineShapeFeature:284460 +Part_Common:200252 +Part_Cut:200492 +Complete_Workbench:101932 +Part_Booleans:200238 +Part_Box:246389 +Part_CreatePrimitives:92354 +Part_RegularPolygon:86897 +Part_Point:90248 +Part_Line:97578 +Part_Ellipse:88522 +Part_Circle:94511 +Part_Spiral:88553 +Part_Helix:270960 +Part_Sweep:287076 +Part_Loft:285298 +Part_Loft_Technical_Details:285299 +Thread_for_Screw_Tutorial:200324 +Draft_Upgrade:200237 +Draft_Downgrade:279644 +Part_Mirror:176724 +Draft_Array:220425 +Draft_PathArray:208388 +Sketcher_Workbench:166840 +Sketcher_Micro_Tutorial_-_Constraint_Practices:177364 +Sketcher_tutorial:242332 +Constraint_Tangent:150463 +Sketcher_ToggleConstruction:155116 +Sketcher_Tutorial:243763 +Sketcher_Preferences:283681 +Sketcher_RectangularArray:252674 +Sketcher_Copy:181420 +Sketcher_Clone:181423 +Sketcher_Symmetry:181440 +Sketcher_Show_Hide_Internal_Geometry:133380 +Sketcher_SelectElementsAssociatedWithConstraints:181322 +Sketcher_SelectConflictingConstraints:181372 +Sketcher_SelectRedundantConstraints:181359 +Sketcher_SelectHorizontalAxis:181334 +Sketcher_SelectVerticalAxis:181347 +Sketcher_SelectOrigin:181384 +Sketcher_SelectConstraints:181396 +Sketcher_ConnectLines:182493 +Sketcher_CloseShape:181464 +Sketcher_MirrorSketch:180415 +Sketcher_MergeSketch:258606 +Sketcher_Validate:74241 +Sketcher_Reorient:182095 +Sketcher_MapSketch:234977 +Sketcher_ViewSketch:55343 +Sketcher_LeaveSketch:57212 +Sketcher_EditSketch:187149 +Sketcher_NewSketch:153789 +Constraint_Internal_Alignment:133218 +Constraint_SnellsLaw:142266 +Constraint_InternalAngle:179102 +Constraint_Radius:93900 +Constraint_Length:95250 +Constraint_VerticalDistance:197886 +Constraint_HorizontalDistance:94989 +Constraint_Lock:93884 +Spreadsheet_Workbench:282300 +Spreadsheet_legacy:186796 +Spreadsheet_CSV:84612 +Spreadsheet_PropertyController:282401 +Spreadsheet_Controller:282383 +Spreadsheet_Create:282371 +Release_notes_0.17:281336 +Civil_Engineering_Workbench:271284 +External_workbenches:270373 +WebTools_Workbench:230117 +Web_Sketchfab:225440 +Arch_Git:251650 +Fcstd_file_format:151878 +File_Format_FCStd:151878 +ImageConv:73428 +Arch_BimServer:251642 +Arch_Building:281552 +Arch_Remove:263263 +Arch_Wall:279022 +Release_notes_0.18:281000 +Arch_Component:286916 +Draft_Rotate:279606 +Draft_Move:279593 +Arch_DAE:172562 +Importing_From_Sketchup:123339 +Arch_OBJ:189855 +Export_to_STL_or_OBJ:281861 +Mesh_MeshFromShape:192535 +Import_from_STL_or_OBJ:189868 +Arch_Add:263285 +Arch_Floor:284641 +Arch_Site:211291 +Arch_IFC:273102 +KicadStepUp_Workbench:271251 +Transportation_Workbench:271358 +Flamingo_Workbench:271710 +Manipulator_Workbench:271794 +Path_DressupDragKnife:246045 +Path_DressupRampEntry:287124 +Path_DressupTag:244999 +Path_DressupDogbone:277172 +Path_Simulator:245592 +Path_Inspect:244989 +Path_ToolLibraryEdit:256963 +Path_EditToolsTable:256936 +Path_NewTool:257296 +Path_Post:246082 +Path_Job:288738 +Path_Pocket_3D:249746 +Path_Drilling:253542 +Path_ProfileFace:246864 +Path_Pocket_Shape:287382 +Path_MillFace:282072 +Path_Contour:245841 +PartDesign_Point:254608 +PartDesign_Line:258642 +PartDesign_Plane:263394 +PartDesign_Thickness:255227 +Part_Thickness:182481 +Part_Offset:227592 +PartDesign_AdditivePipe:255126 +PartDesign_AdditiveLoft:264898 +PartDesign_CompPrimitiveAdditive:268879 +PartDesign_AdditiveWedge:264868 +PartDesign_AdditiveTorus:268444 +PartDesign_AdditiveSphere:250906 +PartDesign_AdditivePrism:250916 +PartDesign_AdditiveEllipsoid:267472 +PartDesign_AdditiveCylinder:264809 +PartDesign_AdditiveCone:264805 +PartDesign_AdditiveBox:248458 +PartDesign_CompPrimitiveSubtractive:268578 +PartDesign_SubtractiveWedge:265158 +PartDesign_SubtractiveTorus:268508 +PartDesign_SubtractiveSphere:265089 +PartDesign_SubtractivePrism:250919 +PartDesign_SubtractiveEllipsoid:264994 +PartDesign_SubtractiveCylinder:264972 +PartDesign_SubtractiveCone:264950 +PartDesign_SubtractiveBox:250586 +PartDesign_Body:288640 +PartDesign_MoveTip:255200 +PartDesign_MoveFeatureInTree:269292 +PartDesign_MoveFeature:273235 +Std_Group:252771 +Arch_tutorial:286413 +Arch_Survey:236809 +Draft_Drawing:221076 +Draft_Text:140113 +Draft_Dimension:285212 +Draft_FlipDimension:230468 +Drawing_View:141381 +Drawing_Landscape_A3:55977 +Drawing_templates:207135 +Misc_templates:135977 +Arch_templates:147688 +ANSI_templates:147694 +Svg_Namespace:86852 +Drawing_Template_HowTo:177230 +Draft_Shape2DView:243725 +Raytracing_Workbench:159871 +Raytracing_tutorial:271602 +Render_project:264448 +Raytracing_Preferences:283604 +Raytracing_Part:183379 +Raytracing_Camera:183409 +Std_PerspectiveCamera:187406 +Std_OrthographicCamera:228060 +Std_View_Menu:277237 +Std_PythonConsole:186900 +Std_Panels:187136 +Std_Workbench:104423 +Std_MeasureDistance:178392 +Std_Measure_Menu:213350 +Std_MeasureToggleDelta:104807 +Std_MeasureToggle3D:104798 +Std_MeasureToggleAll:105328 +Std_MeasureClearAll:104790 +Std_MeasureAngular:105320 +Std_MeasureLinear:105312 +Std_SetAppearance:103278 +Std_SetColors:102452 +Std_ToggleVisibility:187043 +Std_ClippingPlane:187298 +Std_ViewDockUndockFullscreen:105909 +Std_ViewBoxZoom:187613 +Std_ViewZoom:102227 +Std_ViewIvIssueCamPos:187847 +Std_ViewIvStereo:187861 +Std_FreezeViews:101701 +Std_RotateRight:277319 +Std_RotateLeft:277307 +Std_ViewFitSelection:187564 +Std_ViewFitAll:187528 +Std_ViewCreate:101852 +Raytracing_Export:183394 +Raytracing_Render:183437 +Raytracing_ExportProject:215055 +Raytracing_ResetCamera:265114 +Raytracing_InsertPart:182607 +Raytracing_Lux:182642 +Raytracing_New:182649 +Draft_DelPoint:139997 +Draft_BSpline:204599 +Draft_CloseLine:140021 +Draft_FinishLine:279659 +Draft_AddPoint:139926 +Draft_Edit:140058 +Draft_Circle:279525 +Draft_Pattern:116373 +Draft_Polygon:279540 +Draft_Ellipse:274735 +Draft_Arc:139936 +Draft_Offset:227741 +Draft_Draft2Sketch:242250 +Draft_ToggleDisplayMode:279769 +Draft_Clone:242391 +Draft_Trimex:279626 +Draft_Scale:235822 +Draft_DXF:141309 +Draft_mapping_files:100546 +Draft_Preferences:282800 +Dxf_Importer_Install:184321 +Release_notes_0.13:90174 +FreeCAD-Ship_s60_tutorial:185338 +FreeCAD-Ship_s60_tutorial_(II):185379 +Draft_Point:279568 +Drawing_Orthoviews:260256 +Drawing_Annotation:76114 +Drawing_Openbrowser:76097 +Drawing_Clip:92533 +Release_notes_014:108266 +Arch_Frame:280152 +Arch_Space:135652 +Draft_BezCurve:279580 +Property:70368 +Draft_Facebinder:135693 +Drawing_Symbol:76100 +PartDesign_InvoluteGear:278046 +PartDesign_Pad:256439 +OpenSCAD_Workbench:282951 +Import_OpenSCAD_code:243434 +OpenSCAD_Preferences:283616 +OpenSCAD_Minkowski:176558 +OpenSCAD_Hull:176536 +OpenSCAD_MeshBoolean:178548 +OpenSCAD_AddOpenSCADElement:212203 +OpenSCAD_ExplodeGroup:176360 +OpenSCAD_ExpandPlacements:182625 +OpenSCAD_Edgestofaces:176351 +OpenSCAD_IncreaseTolerance:176368 +OpenSCAD_RemoveSubtree:176383 +OpenSCAD_ReplaceObject:189597 +OpenSCAD_ColorCodeShape:184793 +OpenSCAD_CSG:84362 +Part_MakeCompound:154597 +Arch_Stairs:230744 +Arch_Roof:230725 +Draft_AddToGroup:252792 +Draft_SelectGroup:252804 +Part_Attachment:270878 +Part_Revolve:172599 +Part_Extrude:261670 +Part_Offset2D:227706 +Part_Slice:200025 +Part_CompJoinFeatures:154612 +Part_BooleanFragments:194649 +Draft_Label:243267 +Draft_Stretch:217410 +Draft_SetWorkingPlaneProxy:234773 +Draft_Slope:279920 +Draft_AutoGroup:279950 +Draft_VisGroup:279892 +Arch_3DS:255764 +Arch_MultiMaterial:267611 +Arch_Nest:280580 +Arch_Panel:287068 +Wikihouse_porting_tutorial:280138 +Arch_Panel_Sheet:234627 +Arch_Panel_Cut:280123 +Arch_Grid:281411 +Arch_AxisSystem:263071 +Arch_Axis:263046 +Arch_Window:287285 +Arch_Rebar:260020 +Arch_Structure:230681 +Arch_Pipe:263077 +Draft_Special:199304 +Arch_Equipment:230785 +Arch_3Views:280268 +Arch_PipeConnector:263089 +Std_Part:251685 +Std_DependencyGraph:279733 +Std_ViewScreenShot:101342 +MIBA:88413 +Std_Export:99758 +Std_Import:79985 +Std_Open:105173 +Std_Save:93906 +Std_File_Menu:173523 +Std_Exit:187113 +Std_RecentFiles:179682 +Std_PrintPdf:99676 +Std_PrintPreview:99774 +Std_Print:99822 +Std_ProjectInfo:184377 +Std_MergeProject:183448 +Std_Revert:185985 +Std_SaveaCopy:186942 +Std_CloseAll:187090 +Std_Close:105180 +Std_New:105170 +Std_SaveAs:186928 +Std_Tools_Menu:282669 +Spinning:109447 +Project_utility:104424 +Std_SceneInspector:101338 +Std_DlgParameter:187477 +AddonManager:262359 +Download:283349 +Release_notes_0.15:159895 +Arch_CutPlane:235462 +Draft_Dimensions:180592 +Constraint_Symmetric:94385 +Constraint_EqualLength:197875 +Sketcher_ConstrainTangent:243710 +Constraint_Perpendicular:138563 +Constraint_Parallel:94408 +Constraint_Horizontal:95165 +Constraint_Vertical:93588 +Constraint_PointOnObject:231297 +Constraint_PointOnPoint:216651 +Sketcher_helper_constraint:200650 +Sketcher_ConstructionMode:101440 +PartDesign_Revolution:264655 +Sketcher_External:276191 +Sketcher_Trimming:92909 +Sketcher_Fillet:63715 +Sketcher_Slot:137440 +Sketcher_Octagon:187242 +Sketcher_Heptagon:187217 +Sketcher_Hexagon:187229 +Sketcher_Pentagon:187255 +Sketcher_Square:187267 +Sketcher_Triangle:187283 +Sketcher_Rectangle:94959 +Sketcher_Polyline:287229 +Sketcher_Arc_of_Ellipse:133231 +Sketcher_Ellipse_by_3_Points:171219 +Sketcher_Ellipse:133135 +Sketcher_Conic_Sections:143702 +Sketcher_Circle3Point:179664 +Sketcher_Circle:93792 +Sketcher_Arc3Point:179659 +Sketcher_Arc:93781 +Sketcher_Line:93560 +Sketcher_Point:288463 +Part_Wedge:228584 +Part_Prism:96568 +Part_Torus:260340 +Part_Ellipsoid:88532 +Part_Sphere:261129 +Part_Cone:109104 +Part_Plane:92588 +Part_Shapebuilder:186835 +Part_Cylinder:92870 +Placement:282677 +Placement_API:133208 +Tasks_Placement:166229 +Std_Delete:102912 +Std_SelectAll:186952 +Std_BoxSelection:187642 +Std_DuplicateSelection:108214 +Copying_Objects:190347 +Part_CreateSimpleCopy:178417 +PartDesign_MultiTransform:93388 +PartDesign_Scaled:206315 +PartDesign_PolarPattern:189289 +PartDesign_LinearPattern:268125 +PartDesign_Mirrored:268077 +Std_Paste:190436 +Std_Copy:213867 +Std_Cut:102992 +Std_Redo:213880 +Std_Undo:186997 +Macro_MacroMenu:240956 +Macro_Easy_cutouts_for_Enclosure_Design:240948 +Macro_Center_Align_Objects_with_Faces_or_Edges:273083 +Macro_CenterFace:240928 +Macro_FCSpreadSheet_Extract:280901 +Macro_SpreadsheetTools:257169 +Macro_Alias_Manager:240919 +Macro_FreeCAD_to_Kerkythea:240913 +Macro_3d_Printer_Slicer:240898 +Macro_Overlap:240892 +Macro_Section:277937 +Part_Section:276386 +Part_SectionCross:276365 +Macro_Connect_And_Sweep:240879 +Macro_Repro_Wire:240716 +Macro_MatrixTransform:240871 +Macro_Image_Scaling:282111 +Macro_CloneConvert:271161 +Macro_HealArcs:240838 +Macro_SuperWire:240824 +Macro_Remove_parametric_history:240805 +Macro_JointWire:240788 +Macro_FlattenWire3Points:240779 +Macro_FlattenWire:240757 +Macro_ArrayCopy:240737 +Macro_Guitar_fretboard:245858 +Macro_FCSpring_Helix_Variable:271884 +Macro_ReproWire:240716 +Macro_WireXYZ:240709 +Macro_FCCircularText:247231 +Macro_Circular_Text:247231 +Macro_FCCreaLoft:240694 +Macro_Loft:240694 +Macro_Texture:240681 +Macro_FCTexture:240681 +Macro_triangleAH:240674 +Macro_Triangle_AH:240674 +Macro_cutCircle:240667 +Macro_Cut_Circle:240667 +Macro_circle:288422 +Macro_Circle:288422 +Macro_cutLine:240652 +Macro_Cut_Line:240652 +Macro_Line_Length:240641 +Macro_Geodesic_Dome:240633 +Macro_Solid_Sweep:240619 +Macro_Make_Cube:240605 +Macro_WorkFeatures:253141 +Macro_Draw_Parametric_2D_Function:240581 +Macro_Draw_2D_Function:240566 +Macro_3D_Parametric_Curve:240556 +Macro_PartsLibrary:240546 +Macro_BOLTS:240535 +Macro_MeasureCircle:240514 +Macro_Dump_Objects:240508 +Macro_ObjectInfo:240496 +Macro_Delta_xyz:240486 +Macro_FCInfoToMouse:270677 +Customize_ToolsBar:222558 +Macro_FCInfoGlass:240474 +Macro_FCInfo_Alternate_Linux:240464 +Macro_FCInfo:246618 +Macro_Dxf_To_Shape:253524 +Macro_Compound_Plus:254253 +Macro_DXF_to_Face_and_Sketch:242195 +Macro_Creating_faces_from_a_DXF_file:240419 +Macro_EdgesToArc:240409 +Macro_FCConvertLines:240403 +Macro_FC_Convert_Lines:240403 +Macro_Ellipse-Center%2B2Points:240393 +Macro_Make_Arc_3_Points:240387 +Macro_Draft_Circle_3_Points_3D:240377 +Macro_Draft_Circle_3_Points:240367 +Macro_Make_Circle_3_Points:240357 +Macro_Rectellipse:240345 +Macro_Normal_Vector:240160 +Macro_CartoucheFC_2:240148 +Misc_templates_Full:211173 +Macro_CartoucheFC_Full:240137 +Macro_CartoucheFC:240125 +Macro_Automatic_drawing:240113 +Macro_DeepCopy:264483 +Macro_FCWire_To_Volume:240107 +Macro_FaceToSketch:240097 +Macro_PartToVRML:240090 +Macro_MeshToPart:240074 +Macro_Extract_Wires_from_Mesh:240067 +Macro_Global_Variable_Watcher:240038 +Macro_Build_Utility:240031 +Macro_Python_Assistant_Window:240025 +Macro_MessageBox:240013 +Macro_Rubik_Cube:254235 +Macro_Constraint_Draft:240006 +Macro_Assemblage_Imprimante_3D:240000 +Macro_Animated_Constrain:239994 +Macro_Assembly:239988 +Macro_hinge:239980 +Macro_Spring:239974 +Macro_crank_simul:239967 +Macro_Select_Hovering:245741 +Macro_FCTreeView:281286 +Macro_Rotate_To_Point:270931 +Macro_Perpendicular_To_Wire:259929 +Macro_Copy3DViewToClipboard:239944 +Macro_Duplicate_Selection:239938 +Macro_Manage_Navigational_Style:239931 +Macro_SelectVisible:239921 +Macro_Toggle_Visibility2:239919 +Macro_Toggle_Visibility:239913 +Macro_FCCamera:259936 +Macro_Toggle_Panels_Visibility:239901 +Macro_Align_Face_Object_to_View:239895 +Macro_Align_Working_Plane_to_Camera:239871 +Macro_Align_Camera_to_Working_Plane:239865 +Macro_Align_Object_to_View:239859 +Macro_Align_View_to_Face:239847 +Macro_Mouse_Cross:239835 +Macro_Texture_Objects:239820 +Macro_View_Rotation:239808 +Macro_Rotate_View:239792 +Arch_Schedule:200380 +Arch_SectionPlane:281940 +TechDraw_NewArch:257225 +TechDraw_New_Default:247847 +TechDraw_Templates:248911 +TechDraw_TemplateHowTo:257336 +TechDraw_Preferences:283803 +TechDraw_GeomHatch:247819 +TechDraw_NewDetail:213321 +TechDraw_LineGroup:273076 +TechDraw_NewSection:264598 +TechDraw_Hatching:262477 +TechDraw_Hatch:251978 +TechDraw_NewProjGroup:288793 +TechDraw_New_Pick:207692 +Material:163706 +Arch_SetMaterial:169358 +Material_editor:169441 +Drawing_SpreadsheetView:168001 +Draft_Rectangle:279554 +Draft_Mirror:212155 +Expressions:271753 +Sketcher_ToggleConstraint:155129 +Part_JoinCutout:154654 +Part_JoinEmbed:200305 +Part_JoinConnect:200314 +Release_notes_011:209941 +Draft_API:133199 +Release_notes_012:96089 +Release_notes_013:90174 +Release_notes_0.14:108266 +Release_notes_015:159895 +Draft_UndoLine:279673 +Draft_Constrain:69277 +Draft_Snap:282536 +Draft_ToggleSnap:279789 +Draft_WorkingPlane:180371 +Draft_Ortho:101135 +Draft_Near:180300 +Draft_Extension:101103 +Draft_Center:180475 +Draft_Angle:180481 +Draft_Endpoint:180264 +Draft_Parallel:180314 +Draft_Intersection:180585 +Draft_ToggleGrid:180252 +Draft_Perpendicular:105976 +Draft_Midpoint:180194 +Draft_Coordinates:69348 +Draft_Linestyle:91452 +Draft_Select:129717 +Draft_Apply:279717 +Draft_SelectPlane:270473 +Basic_modeling_tutorial:268800 +Part_Fillet:164325 +PartDesign_Fillet:212223 +Part_Chamfer:235172 +Part_API:188249 +TopoShape_API:158195 +Draft_Wire:204594 +GuiCommand_model:276322 +Draft_ShapeString:282229 +Draft_ShapeString_tutorial:274922 +Import_text_and_geometry_from_Inkscape:192813 +Std_UnitsCalculator:65717 +UTF_Project:123532 +Raytracing_project:123427 +Quality_project:123230 +Robot_SetDefaultOrientation:98113 +Std_WhatsThis:105238 +Std_Help_Menu:184860 +Std_About:164760 +Std_Help:187592 +Std_ViewXX:1178 +Std_ViewExamples:1149 +Std_TipOfTheDay:1133 +Std_PythonWebsite:102154 +Std_OnlineHelpWebsite:102005 +Std_OnlineHelpPython:101985 +Std_OnlineHelp:101253 +Std_FreeCADWebsite:101592 +Std_CommandLine:102787 +Mesh_VertexCurvature:854 +Mesh_Transform:850 +Mesh_ToolMesh:848 +Mesh_PolySplit:813 +Mesh_PolySegm:811 +Mesh_PolyCut:809 +Mesh_FromGeometry:796 +Mesh_ExMakeUnion:780 +Mesh_ExMakeTool:778 +Mesh_ExMakeMesh:776 +Mesh_Evaluation:774 +Mesh_EvaluateSolid:179527 +Mesh_Demolding:766 +Mesh_CurvatureInfo:764 +Resource_framework_project:123852 +Units_project:122689 +Arch_Concept:122795 +Assembly_project:122006 +Assembly_Basic_Tutorial:258202 +PartDesign_project:122801 +PartDesign_Bearingholder_Tutorial_II:192788 +PartDesign_Bearingholder_Tutorial_I:261266 +Sketcher_project:121579 +FreeCAD_development_model_project:122797 +FreeCAD_development_model:129917 +Naming_project:188424 +STEP_project:67368 +Project_template:122804 +FEM_CalculiX:229212 +FEM_Mesh_CalculiX:262170 +FEM_Element_Types:164410 +FEM_Mesh:262650 +Add_FEM_Constraint_Tutorial:261187 +Add_FEM_Equation_Tutorial:253378 +Extend_FEM_Module:253392 +FEM_Shear_of_a_Composite_Block:249716 +FEM_Tutorial_Python:243962 +FEM_CalculiX_Cantilever_3D:229313 +Fem_Preferences:283218 +FEM_MeshPrintInfo:258732 +FEM_MeshClear:258731 +FEM_PostCreateFunctions:258742 +FEM_PostCreateDataAtPointFilter:258741 +FEM_PostCreateLinearizedStressesFilter:258740 +FEM_PostCreateDataAlongLineFilter:258739 +FEM_PostCreateWarpVectorFilter:258738 +FEM_PostCreateCutFilter:258737 +FEM_PostCreateScalarClipFilter:258736 +FEM_PostCreateClipFilter:258735 +FEM_PostPipelineFromResult:266050 +FEM_PostApplyChanges:258733 +FEM_ResultShow:257589 +FEM_ResultsPurge:257579 +FEM_SolverRun:257569 +FEM_SolverControl:257559 +FEM_EquationFlow:258730 +FEM_EquationFluxsolver:258729 +FEM_EquationElectrostatic:258728 +FEM_EquationElasticity:258727 +FEM_EquationHeat:258726 +FEM_SolverZ88:258725 +FEM_SolverElmer:258724 +FEM_SolverCalculiX:258723 +FEM_SolverCalculixCxxtools:271506 +FEM_FemMesh2Mesh:257599 +FEM_CreateNodesSet:257639 +FEM_MeshGroup:258722 +FEM_MeshRegion:258721 +FEM_MeshBoundaryLayer:258720 +FEM_MeshGmshFromShape:257359 +FEM_MeshNetgenFromShape:225263 +FEM_ConstraintFlowVelocity:258718 +FEM_ConstraintFluidBoundary:258717 +FEM_ConstraintInitialFlowVelocity:258716 +FEM_ConstraintBodyHeatSource:258715 +FEM_ConstraintTemperature:257518 +FEM_ConstraintHeatflux:257531 +FEM_ConstraintInitialTemperature:257544 +FEM_ConstraintPulley:257486 +FEM_ConstraintGear:257476 +FEM_ConstraintBearing:257757 +FEM_ConstraintSelfWeight:257729 +FEM_ConstraintTransform:258714 +FEM_ConstraintContact:257715 +FEM_ConstraintPlaneRotation:257701 +FEM_ConstraintDisplacement:257689 +FEM_ElementFluid1D:257671 +FEM_ElementGeometry2D:257402 +FEM_ElementRotation1D:258713 +FEM_ElementGeometry1D:257662 +FEM_MaterialMechanicalNonlinear:258679 +FEM_MaterialFluid:258680 +FEM_Install:242274 +FEM_ConstraintForce:267199 +FEM_ConstraintFixed:257676 +FEM_MaterialSolid:266056 +FEM_tutorial:229171 +TechDraw_Module:278986 +TechDraw_Roadmap:288639 +TechDraw_API:278997 +TechDrawGui_API:247925 +TechDraw_Redraw:247789 +TechDraw_Toggle:208412 +TechDraw_Image:222877 +TechDraw_Symbol:207863 +TechDraw_SaveDXF:287563 +TechDraw_SaveSVG:282651 +TechDraw_Dimension_Link:207743 +TechDraw_Dimension_Angle:251977 +TechDraw_Dimension_Diameter:251976 +TechDraw_Dimension_Radius:251975 +TechDraw_Dimension_Vertical:251974 +TechDraw_Dimension_Horizontal:251973 +TechDraw_Dimension_Length:251971 +TechDraw_ClipMinus:258630 +TechDraw_ClipPlus:258632 +TechDraw_Clip:258633 +TechDraw_Spreadsheet:258619 +TechDraw_NewDraft:254909 +TechDraw_NewAnnotation:208463 +TechDraw_NewView:288795 +TechDraw_Enhancement_Project:257223 +FreeCAD_Configuration_Management_Project:262031 +Artwork:247485 +Bugtracker:242108 +Source_Code_Management:243449 +Source_code_management:243449 +Developing_FreeCAD_with_GitKraken:235424 +Bug_Triage:234617 +Command:268764 +Category:Command_Reference:231637 +Drawing_Save:92291 +Drawing_ProjectShape:186142 +Drawing_Open_SVG:92674 +Draft_WireToBSpline:140152 +Draft_ToggleContinueMode:279702 +Draft_ToggleConstructionMode:279685 +Draft_ShowSnapBar:94051 +Draft_Heal:279856 +Draft_AddConstruction:279970 +Constraint_TangentToStart:105946 +Constraint_TangentToEnd:105937 +Constraint_PointToObject:105931 +Constraint_PointOnStart:104538 +Constraint_PointOnMidPoint:104523 +Constraint_PointOnEnd:104507 +Constraint_ExternalAngle:104491 +Constraint_Concentric:104476 +Arch_ToggleSubs:280287 +Arch_ToggleIfcBrepFlag:280258 +Arch_SplitMesh:263202 +Arch_SelectNonSolidMeshes:139555 +Arch_RemoveShape:135236 +Arch_Rebar_UShape:284437 +Custom_Spacing:250297 +Arch_Rebar_Straight:284577 +Arch_Rebar_Stirrup:284526 +Arch_Rebar_LShape:284532 +Arch_Rebar_Helical:250249 +Arch_Rebar_BentShape:284551 +Arch_MeshToShape:282169 +Arch_MergeWalls:146654 +Arch_IfcExplorer:263099 +Arch_CloseHoles:263143 +Arch_CloneComponent:230985 +Arch_Check:280242 +Arch_Cell:174354 +Scripting_examples:149073 +Python_Development_Environment:235656 +Scripted_objects:234658 +PySide:249982 +Scenegraph:137998 +Topological_data_scripting:277846 +Scripting:216267 +FreeCAD_Community_Portal:164860 +David:277809 +FreeCAD_vector_math_library:235986 +Embedding_FreeCADGui:160241 +PythonOCC:84426 +Workbench_creation:189364 +Builtin_modules:122811 +ViewObject_API:133211 +Object_API:133204 +Selection_API:133209 +FreeCADGui_API:266794 +Console_API:133198 +Matrix_API:133202 +Vector_API:250812 +Base_API:122977 +FreeCAD_API:133200 +Installing_more_workbenches:202574 +Mesh_Scripting:143815 +Mesh_API:216835 +Macros:236380 +Standard_Menu:105005 +Std_Windows_Menu:227999 +Std_Workbench_Menu:185386 +FreeCAD_Scripting_Basics:221161 +Introduction_to_Python:222332 +List_of_Commands:231637 +Arch_MakeIfcSpreadsheet:283868 +Interface_Customization:222103 +Robot_Workbench:178309 +VRML_Preparation_for_Robot_Simulation:177698 +Robot_TrajectoryCompound:180078 +Robot_TrajectoryDressUp:181176 +Robot_Edge2Trac:181926 +Robot_InsertWaypointPre:179972 +Robot_InsertWaypoint:179956 +Robot_SetDefaultValues:180024 +Robot_CreateTrajectory:179941 +Robot_RestoreHomePos:179916 +Robot_SetHomePos:183790 +Robot_Export:181163 +Robot_Simulate:181231 +Robot_CreateRobot:178503 +Robot_tutorial:196210 +Robot_6-Axis:177579 +Ray_Tracing_Workbench:159871 +Drawing_Workbench:286458 +Drawing_tutorial:288527 +Draft_tutorial:288525 +Drawing_Documentation:128121 +Arch_Workbench:288799 +Arch_panel_tutorial:268285 +Arch_JSON:255757 +Arch_Preferences:283178 +Part_Workbench:269324 +Whiffle_Ball_tutorial:285176 +Import_Export_Preference:283392 +Draft_OCA:69114 +Draft_SVG:136332 +FreeCAD_and_DXF_Import:282420 +Part_CheckGeometry:206910 +Part_ReverseShapes:178374 +Part_ConvertToSolid:178258 +Part_ShapeFromMesh:182434 +Part_ExportCAD:283531 +Part_ImportCAD:283522 +Part_RuledSurface:73087 +Mesh_Workbench:283400 +FreeCAD_and_Mesh_Import:189861 +Mesh_CurvaturePlot:186857 +Mesh_CreateMeshSegment:179553 +Mesh_TrimMeshWithPlane:179552 +Mesh_TrimMesh:179551 +Mesh_MakeSegment:179550 +Mesh_SplitMesh:179548 +Mesh_Cut:179547 +Mesh_SelectMesh:179545 +Mesh_Merge:181844 +Mesh_Difference:179898 +Mesh_Intersection:179885 +Mesh_Union:181849 +Mesh_BuildRegularSolid:181295 +Mesh_BoundingBox:181280 +Mesh_EvaluateCurvature:179528 +Mesh_EvaluateFacet:181270 +Mesh_EvaluateRepair:181258 +Mesh_Smooth:181239 +Mesh_AddTriangle:179524 +Mesh_RemoveCompByHand:180663 +Mesh_RemoveComponents:180697 +Mesh_FillInteractiveHole:213684 +Mesh_FillHoles:180720 +Mesh_FlipNormals:180738 +Mesh_HarmonizeNormals:180747 +Mesh_Export:179538 +Mesh_Import:179539 +PartDesign_Workbench:288528 +Basic_Part_Design_Tutorial_017:280870 +Basic_Part_Design_Tutorial:275611 +Creating_a_simple_part_with_PartDesign:288140 +PartDesign_Preferences:283020 +PartDesign_WizardShaft:212233 +PartDesign_Migrate:255246 +PartDesign_Boolean:268607 +PartDesign_Draft:98835 +PartDesign_Chamfer:57498 +PartDesign_SubtractivePipe:255135 +PartDesign_SubtractiveLoft:255130 +PartDesign_Groove:265306 +PartDesign_Hole:257502 +PartDesign_Pocket:266419 +PartDesign_Clone:288512 +PartDesign_ShapeBinder:261682 +PartDesign_NewSketch:248506 +PartDesign_Legacy:259043 +PartDesign_tutorial:229906 +Assembly_Workbench:122006 +Draft_Workbench:285785 +Draft_tutorial_Outdated:212187 +FreeCAD_and_DWG_Import:260330 +Draft_DAT:83901 +Workbench_Concept:286525 +Preferences_Editor:288581 +Document_structure:132779 +Mouse_Model:282827 +3D_input_devices:45721 +3Dconnexion_input_devices:271106 +Manipulator:219625 +Installing:288506 +Installing_Helpfile:288705 +About_FreeCAD:159757 +History:271993 +Release_notes_016:286826 +Tutorials:283328 +Path_Walkthrough_for_the_Impatient:249709 +Toothbrush_Head_Stand:269629 +Video_tutorials:266401 +Offsite_tutorials:172815 +FAQ:234510 +FreeCAD_Howto_Import_Export:132600 +Getting_started:271994 +Downloads:283349 +Screenshots:270429 +Feature_list:272058 +Online_Help_Toc:243648 +Glossary:283817 +Contributors:235785 +Extra_python_modules:277136 +Continuous_Integration:226668 +Testing:225820 +Debugging:235853 +Module_Creation:287228 +FreeCAD_Build_Tool:179342 +Third_Party_Tools:115032 +Third_Party_Libraries:247614 +Compiling_(Speeding_up):236182 +CompileOnMac:243451 +OpenGL_on_MacOS:227131 +CompileOnUnix:283835 +CompileOnWindows:284019 +CompileOnWindows_-_Reducing_Disk_Footprint:155591 +Compile_on_Windows_with_VS2013:149595 +Tracker:242108 +Dialog_creation:245340 +Qt_Example:234423 +Line_drawing_function:172570 +Code_snippets:285192 +API_documentation:150947 +Embedding_FreeCAD:287194 +Pivy:217957 +Mesh_to_Part:137999 +Python_scripting_tutorial:270719 +TechDraw_Workbench:278986 +Path_Workbench:283545 +Path_FAQ:284165 +Path_Preferences:283577 +Path_Sanity:245377 +Path_experimental:262241 +Path_Area_Workplane:245383 +Path_Area:245382 +Path_Surface:245380 +Path_SimpleCopy:167410 +Path_Array:245017 +Path_Copy:167029 +Path_FromShapes:270413 +Path_Custom:246023 +Path_Stop:246110 +Path_Comment:166710 +Path_Fixture:246061 +Path_Helix:253534 +Path_Engrave:244221 +Path_ProfileEdges:246577 +Path_SelectLoop:250340 +Path_ExportTemplate:245566 +Path_SetupSheet:249686 +Path_Core_Concepts:249438 +Path_Customization:249437 +Path_Postprocessor_Customization:249436 +Path_objects:246758 +Path_Profile:256950 +Path_ToolNumberToLoad:166664 +Robot_Module:178309 +OpenSCAD_Module:282951 +Points_Module:188525 +Points_ExportPoints:185902 +Points_ImportPoints:189796 +Start_Workbench:101499 +Reverse_Engineering_Workbench:162233 +Ship_Workbench:194212 +Ship_PlotGZ:185863 +Ship_Loading:185859 +Ship_TankCapacity:185855 +Ship_TankNew:185852 +Ship_Weight:185847 +Ship_Hydrostatics:185842 +Ship_Area:185839 +Ship_Outline:185831 +Ship_New:185830 +Ship_Geometries_Examples:185829 +Web_Workbench:230019 +Plot_Module:140523 +Plot_MultiAxes_tutorial:177531 +Plot_Basic_tutorial:177511 +Plot_Positions:99350 +Plot_Labels:184825 +Plot_Legend:184834 +Plot_Grid:99363 +Plot_Series:99356 +Plot_Axes:99343 +Plot_Save:140537 +Spreadsheet_Module:282300 +Sketcher_Module:166840 +Raytracing_Module:159871 +Part_Module:269324 +Mesh_Module:283400 +Inspection_Workbench:162196 +Image_Module:194211 +Image_Import:187021 +FEM_Module:247560 +Drawing_Module:286458 +Draft_Module:285785 +Arch_Module:288799 +Import_Export:247071 +Workbenches:286525 +Property_editor:45494 +Install_on_Mac:228210 +Install_on_Unix:275809 +Install_on_Windows:138495 +Online_Help_Startpage:156421 diff --git a/todolist.txt b/todolist.txt new file mode 100644 index 0000000..e69de29 diff --git a/update.py b/update.py new file mode 100755 index 0000000..9f35ed5 --- /dev/null +++ b/update.py @@ -0,0 +1,198 @@ +#!/usr/bin/env python + +#*************************************************************************** +#* * +#* Copyright (c) 2017 Yorik van Havre * +#* * +#* This program is free software; you can redistribute it and/or modify * +#* it under the terms of the GNU Lesser General Public License (LGPL) * +#* as published by the Free Software Foundation; either version 2 of * +#* the License, or (at your option) any later version. * +#* for detail see the LICENCE text file. * +#* * +#* This program is distributed in the hope that it will be useful, * +#* but WITHOUT ANY WARRANTY; without even the implied warranty of * +#* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * +#* GNU Library General Public License for more details. * +#* * +#* You should have received a copy of the GNU Library General Public * +#* License along with this program; if not, write to the Free Software * +#* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 * +#* USA * +#* * +#*************************************************************************** + +__title__="update.py" +__author__ = "Yorik van Havre " +__url__ = "http://www.freecadweb.org" + +""" +This script needs to be run after the wiki has been fully downloaded. It has three usages: + +1) If no revisions.txt file is found, it parses the contents of the wikifiles.txt file + and, for each entry, it retrieves a corresponding revision ID, and creates a revisions.txt file + +2) If a revisions.txt file exists but no update.txt file exists, it crawls through all entries of + wikifiles.txt, and for each one, compares the current revision with the one stored in revisions.txt. + An update.txt file is created with all pages that have different revision IDs + +3) If update.txt exists, each entry of it will be scanned again for new links and all the needed + files downloaded. Revision.txt and wikifiles.txt get also updated. +""" + +import sys, os, re, tempfile, getopt +from urllib2 import urlopen, HTTPError + +# CONFIGURATION ################################################# + +URL = "https://www.freecadweb.org/wiki" #default URL if no URL is passed +GETTRANSLATIONS = False # Set true if you want to get the translations too. +MAXFAIL = 3 # max number of retries if download fails +VERBOSE = True # to display what's going on. Otherwise, runs totally silent. + +# END CONFIGURATION ############################################## + +wikiindex = "/index.php?title=" + +def update(pagename=None): + + if not os.path.exists("revisions.txt"): # case 1) + if not os.path.exists("wikifiles.txt"): + print "No wikifiles.txt found. Aborting" + sys.exit() + pages = [] + f = open("wikifiles.txt","r") + if VERBOSE: print "Reading existing list..." + for l in f.readlines(): + if l.strip() != "": + if not "/wiki/" in l: + if VERBOSE: print "Adding ",l.strip() + pages.append(l.strip()) + f.close() + if VERBOSE: print "Added ",str(len(pages))," entries" + i = 1 + revs = [] + for page in pages: + rev = getRevision(page) + if VERBOSE: print str(i)," revision: ",rev + revs.append(page+":"+rev) + i += 1 + writeList(revs,"revisions.txt") + print "All done. Successfully written revisions.txt with ",len(revs)," entries." + + elif os.path.exists("revisions.txt") and (not os.path.exists("updates.txt")): # case 2) + f = open("revisions.txt","r") + if VERBOSE: print "Reading revisions list..." + revisions = {} + for l in f.readlines(): + if l.strip() != "": + r = l.strip().split(":") + p = ":".join(r[:-1]) + if VERBOSE: print "Adding ",p + revisions[p] = r[1] + f.close() + if VERBOSE: print "Added ",str(len(revisions.keys()))," entries" + updates = [] + i = 1 + for page in revisions.keys(): + rev = getRevision(page) + if rev != revisions[page]: + if VERBOSE: print str(i),page," has a new revision: ",rev + updates.append(page) + else: + if VERBOSE: print str(i),page," is up to date " + i += 1 + if updates: + writeList(updates,"updates.txt") + print "All done. Successfully written updates.txt with ",len(updates)," entries." + else: + print "Everything up to date. Nothing to be done." + + elif os.path.exists("revisions.txt") and os.path.exists("updates.txt"): # case 3) + if not os.path.exists("wikifiles.txt"): + print "No wikifiles.txt found. Aborting" + sys.exit() + wikifiles = [] + f = open("wikifiles.txt","r") + if VERBOSE: print "Reading wikifiles list..." + for l in f.readlines(): + if l.strip() != "": + wikifiles.append(l.strip()) + f.close() + if VERBOSE: print "Read ",str(len(wikifiles))," entries" + f = open("revisions.txt","r") + if VERBOSE: print "Reading revisions list..." + revisions = {} + for l in f.readlines(): + if l.strip() != "": + r = l.strip().split(":") + p = ":".join(r[:-1]) + revisions[p] = r[1] + f.close() + todo = [] + f = open("updates.txt","r") + if VERBOSE: print "Reading updates list..." + for l in f.readlines(): + if l.strip() != "": + todo.append(l.strip()) + f.close() + if VERBOSE: print str(len(todo))," pages to scan..." + import buildwikiindex + buildwikiindex.WRITETHROUGH = False + buildwikiindex.VERBOSE = VERBOSE + updates = [] + for t in todo: + if VERBOSE: print "Scanning ",t + updates.extend(buildwikiindex.crawl(t)) + updates = [u for u in updates if not u in wikifiles] + if VERBOSE: print str(len(updates))," files to download..." + import downloadwiki + i = 1 + for u in updates: + if VERBOSE: print i, ": Fetching ", u + downloadwiki.get(u) + if not "/wiki/" in u: + rev = getRevision(u) + revisions[u] = rev + if not u in wikifiles: + wikifiles.append(u) + i += 1 + if VERBOSE: print "Updating wikifiles and revisions..." + writeList(wikifiles,"wikifiles.txt") + updatedrevs = [] + for k in revisions.keys(): + updatedrevs.append(k+":"+revisions[k]) + writeList(updatedrevs,"revisions.txt") + os.remove("updates.txt") + if VERBOSE: print "All done!" + +def getRevision(page): + html = fetchPage(page) + revs = re.findall("wgCurRevisionId\"\:(.*?),",html) + if len(revs) == 1: + return revs[0] + print 'Error: unable to get revision ID of ' + page + sys.exit() + +def fetchPage(page): + "retrieves given page from the wiki" + print "fetching: ",page + failcount = 0 + while failcount < MAXFAIL: + try: + html = (urlopen(URL + wikiindex + page).read()) + return html + except HTTPError: + failcount += 1 + print 'Error: unable to fetch page ' + page + sys.exit() + +def writeList(pages,filename): + f = open(filename,"wb") + for p in pages: + f.write(p+"\n") + f.close() + if VERBOSE: print "written ",filename + +if __name__ == "__main__": + update(sys.argv[1:]) diff --git a/updates.txt b/updates.txt new file mode 100644 index 0000000..6caa82f --- /dev/null +++ b/updates.txt @@ -0,0 +1 @@ +Category:Command_Reference diff --git a/wikifiles.txt b/wikifiles.txt new file mode 100644 index 0000000..c2a20a8 --- /dev/null +++ b/wikifiles.txt @@ -0,0 +1,5519 @@ +Localisation +/wiki/resources/assets/licenses/cc-by.png +/wiki/resources/assets/poweredby_mediawiki_88x31.png +PyQt +/wiki/images/8/85/PySideScreenSnapshot1.jpg +/wiki/images/8/8f/PySideScreenSnapshot2.jpg +PySide_Advanced_Examples +PySide_Medium_Examples +/wiki/images/3/38/PySideScreenSnapshot3.jpg +/wiki/images/4/45/PySideScreenSnapshot4.jpg +PySide_Beginner_Examples +/wiki/images/a/a6/PySideScreenSnapshot5.jpg +/wiki/images/5/56/PySideScreenSnapshot6.jpg +/wiki/images/e/e9/PySideScreenSnapshot7.jpg +/wiki/images/5/52/PySideScreenSnapshot8.jpg +Localisation_Sidebar +/wiki/images/thumb/6/6d/Translate-sidebar-instruction.png/300px-Translate-sidebar-instruction.png +Localization_Older_Methods +Branding +Splash_screen +Start_up_and_Configuration +Organization_chart +Licence +Compiling +/wiki/images/b/ba/Windows.png +/wiki/images/6/6c/Linux.png +/wiki/images/6/69/Mac.png +CompileOnMinGW +CompileOnCygwin +Help_FreeCAD +/wiki/images/2/22/Bugreport-workflow.png +Google_Summer_of_Code +Google_Summer_of_Code_2018 +Swept-path_Analysis_GSoC_Project +FEM_Analysis +/wiki/images/thumb/5/57/FEM_Analysis.png/32px-FEM_Analysis.png +/wiki/images/thumb/5/57/FEM_Analysis.png/24px-FEM_Analysis.png +FEM_ConstraintPressure +/wiki/images/thumb/f/f0/FEM_ConstraintPressure.png/32px-FEM_ConstraintPressure.png +Fem_Workbench +/wiki/images/8/88/FemWorkbench.jpg +/wiki/images/4/4b/Fem-analysis.svg +/wiki/images/7/7e/Fem-material.svg +/wiki/images/1/16/Fem-material-fluid.svg +/wiki/images/0/0b/Fem-material-nonlinear.svg +/wiki/images/f/f4/Fem-beam-section.svg +/wiki/images/b/b6/Fem-beam-rotation.svg +/wiki/images/b/b5/Fem-shell-thickness.svg +/wiki/images/f/f8/Fem-fluid-section.svg +/wiki/images/b/ba/Fem-constraint-fixed.svg +/wiki/images/b/b1/Fem-constraint-displacement.svg +/wiki/images/3/3f/Fem-constraint-planerotation.svg +/wiki/images/d/d1/Fem-constraint-contact.svg +/wiki/images/f/f2/Fem-constraint-transform.svg +/wiki/images/9/90/Fem-constraint-force.svg +/wiki/images/7/7d/Fem-constraint-pressure.svg +/wiki/images/5/5c/Fem-constraint-selfweight.svg +/wiki/images/c/ca/Fem-constraint-bearing.svg +/wiki/images/e/ed/Fem-constraint-gear.svg +/wiki/images/7/75/Fem-constraint-pulley.svg +/wiki/images/8/8e/Fem-constraint-InitialTemperature.svg +/wiki/images/9/90/Fem-constraint-heatflux.svg +/wiki/images/e/ec/Fem-constraint-temperature.svg +/wiki/images/9/9a/Fem-constraint-initial-flow-velocity.svg +/wiki/images/4/44/Fem-constraint-fluid-boundary.svg +/wiki/images/d/d1/Fem-constraint-flow-velocity.svg +/wiki/images/9/9b/Fem-femmesh-netgen-from-shape.svg +/wiki/images/2/28/Fem-femmesh-gmsh-from-shape.svg +/wiki/images/0/07/Fem-femmesh-boundary-layer.svg +/wiki/images/1/13/Fem-femmesh-region.svg +/wiki/images/b/b8/Fem-femmesh-from-shape.svg +/wiki/images/6/69/Fem-femmesh-create-node-by-poly.svg +/wiki/images/f/f7/Fem-femmesh-to-mesh.svg +/wiki/images/d/de/Fem-solver.svg +/wiki/images/3/38/Fem-elmer.svg +/wiki/images/f/fb/Fem-equation-heat.svg +/wiki/images/d/d3/Fem-equation-elasticity.svg +/wiki/images/9/99/Fem-equation-electrostatic.svg +/wiki/images/7/7b/Fem-equation-fluxsolver.svg +/wiki/images/6/66/Fem-equation-flow.svg +/wiki/images/b/b2/Fem-control-solver.svg +/wiki/images/7/74/Fem-run-solver.svg +/wiki/images/7/7d/Fem-purge-results.svg +/wiki/images/2/22/Fem-result.svg +/wiki/images/6/62/FEM_PostApplyChanges.png +/wiki/images/e/ef/Fem-data.svg +/wiki/images/2/21/Fem-clip.svg +/wiki/images/a/aa/Fem-clip-scalar.svg +/wiki/images/6/66/Fem-cut.svg +/wiki/images/b/b9/Fem-warp.svg +/wiki/images/8/8b/Fem-DataAlongLine.svg +/wiki/images/a/a6/Fem-linearizedstresses.svg +/wiki/images/3/3a/Fem-sphere.svg +/wiki/images/0/00/Fem-femmesh-clear-mesh.svg +/wiki/images/a/a2/Fem-femmesh-print-info.svg +/wiki/images/0/0e/Std_DlgParameter.svg +FEM_project +/wiki/images/thumb/2/2a/Netgen.jpg/300px-Netgen.jpg +Development_roadmap +Release_process +Robot_project +/wiki/images/3/3f/Robot.jpg +Land_Survey_Workbench_Blueprint +CAM_project +Python_3 +Material_data_model +Units +Quantity +/wiki/images/thumb/4/4b/SI-Derived-Units.jpg/750px-SI-Derived-Units.jpg +InputField +Gui_Command +/wiki/images/thumb/8/8a/Tango-Palette.png/400px-Tango-Palette.png +/wiki/images/thumb/9/9b/Colorchart.png/200px-Colorchart.png +Draft_Line +/wiki/images/thumb/a/a8/Draft_Line.png/32px-Draft_Line.png +/wiki/images/thumb/6/6c/Draft_Line_example.jpg/400px-Draft_Line_example.jpg +/wiki/images/thumb/a/a8/Draft_Line.png/16px-Draft_Line.png +/wiki/images/thumb/d/dd/Draft_UndoLine.png/12px-Draft_UndoLine.png +Release_notes_0.16 +/wiki/images/thumb/c/c7/Satnogs_Rotator_FreeCAD.jpg/1024px-Satnogs_Rotator_FreeCAD.jpg +/wiki/images/thumb/9/9e/Expressions-demo.png/300px-Expressions-demo.png +/wiki/images/thumb/a/ae/Sketcher-v0.16-demo.png/300px-Sketcher-v0.16-demo.png +/wiki/images/thumb/4/46/Multiple_material.jpg/700px-Multiple_material.jpg +/wiki/images/thumb/3/37/Draft_subdivisions.jpg/1024px-Draft_subdivisions.jpg +/wiki/images/thumb/0/02/Drawing_spreadsheetview.jpg/1024px-Drawing_spreadsheetview.jpg +/wiki/images/thumb/f/f2/Arch_clip_plane.jpg/1024px-Arch_clip_plane.jpg +/wiki/images/a/ae/Exercise_path_02.jpg +/wiki/images/c/c6/Macro_installer_02.jpg +Path_scripting +/wiki/images/thumb/9/93/Base_ExampleCommandModel.png/32px-Base_ExampleCommandModel.png +Macro_GMSH +/wiki/images/thumb/2/2c/Text-x-python.png/32px-Text-x-python.png +/wiki/images/thumb/a/a2/Macro_GMSH.png/480px-Macro_GMSH.png +Customize_Toolbars +/wiki/images/thumb/f/f7/CustomizeToolBar_01.png/640px-CustomizeToolBar_01.png +/wiki/images/thumb/5/50/CustomizeToolBar_02.png/640px-CustomizeToolBar_02.png +/wiki/images/c/c8/CustomizeToolBar_03.png +/wiki/images/6/65/CustomizeToolBar_04.png +/wiki/images/9/9c/CustomizeToolBar_05.png +/wiki/images/c/c3/CustomizeToolBar_06.png +/wiki/images/7/7b/CustomizeToolBar_07.png +/wiki/images/6/6f/CustomizeToolBar_08.png +/wiki/images/d/d2/CustomizeToolBar_09.png +/wiki/images/3/30/CustomizeToolBar_10.png +/wiki/images/0/06/Freecad.svg +/wiki/images/3/32/CustomizeToolBar_11.png +/wiki/images/6/69/CustomizeToolBar_12.png +/wiki/images/b/b8/CustomizeToolBar_13.png +/wiki/images/6/64/CustomizeToolBar_14.png +/wiki/images/6/6c/CustomizeToolBar_15.png +/wiki/images/7/78/CustomizeToolBar_16.png +/wiki/images/4/41/CustomizeToolBar_17.png +/wiki/images/thumb/a/af/CustomizeToolBar_18.png/640px-CustomizeToolBar_18.png +How_to_install_macros +/wiki/images/4/40/Macro-record.svg +/wiki/images/7/7b/Macro-stop.svg +/wiki/images/f/f7/Std_DlgMacroExecuteDirect.svg +/wiki/images/5/54/Macro-execute.svg +/wiki/images/4/4c/Debug-start.svg +/wiki/images/5/5c/Debug-stop.svg +/wiki/images/thumb/5/56/Dxf_Importer_Install_01.png/640px-Dxf_Importer_Install_01.png +/wiki/images/thumb/c/c2/Dxf_Importer_Install_02.png/640px-Dxf_Importer_Install_02.png +/wiki/images/thumb/4/49/Dxf_Importer_Install_03.png/640px-Dxf_Importer_Install_03.png +/wiki/images/thumb/2/2f/Dxf_Importer_Install_04.png/640px-Dxf_Importer_Install_04.png +/wiki/images/1/13/Macro_Install_HowTo_09.png +/wiki/images/9/96/Macro_Install_HowTo_10.png +/wiki/images/9/97/Macro_Install_HowTo_11.png +/wiki/images/7/79/Macro_Install_HowTo_12.png +/wiki/images/thumb/e/eb/Macro_Install_HowTo_14.png/640px-Macro_Install_HowTo_14.png +/wiki/images/thumb/d/d3/Macro_Install_HowTo_15.png/640px-Macro_Install_HowTo_15.png +/wiki/images/thumb/c/c3/Macro_Install_HowTo_16.png/640px-Macro_Install_HowTo_16.png +/wiki/images/thumb/8/8b/Macro_Install_HowTo_29.png/640px-Macro_Install_HowTo_29.png +/wiki/images/7/7e/Macro_Install_HowTo_13.png +/wiki/images/4/4e/Part_Prism_Apothem.svg +/wiki/images/thumb/6/60/Macro_Install_HowTo_28.png/300px-Macro_Install_HowTo_28.png +/wiki/images/thumb/c/c0/Macro_Install_HowTo_17.png/300px-Macro_Install_HowTo_17.png +/wiki/images/thumb/9/9b/Macro_Install_HowTo_18.png/300px-Macro_Install_HowTo_18.png +/wiki/images/thumb/6/62/Macro_Install_HowTo_19.png/640px-Macro_Install_HowTo_19.png +/wiki/images/thumb/9/9c/Macro_Install_HowTo_20.png/640px-Macro_Install_HowTo_20.png +/wiki/images/thumb/7/7f/Macro_Install_HowTo_27.png/300px-Macro_Install_HowTo_27.png +/wiki/images/thumb/b/b9/Macro_Install_HowTo_21.png/300px-Macro_Install_HowTo_21.png +/wiki/images/thumb/4/45/Macro_Install_HowTo_22.png/640px-Macro_Install_HowTo_22.png +/wiki/images/2/29/Document-new.svg +/wiki/images/thumb/0/0d/Macro_Install_HowTo_23.png/640px-Macro_Install_HowTo_23.png +/wiki/images/thumb/2/24/Macro_Install_HowTo_24.png/640px-Macro_Install_HowTo_24.png +/wiki/images/thumb/5/52/Macro_Install_HowTo_25.png/300px-Macro_Install_HowTo_25.png +/wiki/images/thumb/6/64/Macro_Install_HowTo_26.png/640px-Macro_Install_HowTo_26.png +/wiki/images/thumb/9/99/Macro_Install_HowTo_01.png/640px-Macro_Install_HowTo_01.png +/wiki/images/thumb/5/55/Macro_Install_HowTo_02.png/640px-Macro_Install_HowTo_02.png +/wiki/images/thumb/4/45/Macro_Install_HowTo_03.png/640px-Macro_Install_HowTo_03.png +/wiki/images/thumb/d/d0/Macro_Install_HowTo_04.png/640px-Macro_Install_HowTo_04.png +/wiki/images/thumb/c/ce/Macro_Install_HowTo_05.png/640px-Macro_Install_HowTo_05.png +/wiki/images/thumb/2/2d/Macro_Install_HowTo_06.png/640px-Macro_Install_HowTo_06.png +/wiki/images/thumb/7/75/Macro_Install_HowTo_07.png/640px-Macro_Install_HowTo_07.png +/wiki/images/thumb/2/2d/Macro_Install_HowTo_08.png/640px-Macro_Install_HowTo_08.png +/wiki/images/thumb/2/27/Macro_Install_HowTo_30.png/640px-Macro_Install_HowTo_30.png +/wiki/images/thumb/0/0d/Macro_Install_HowTo_31.png/640px-Macro_Install_HowTo_31.png +/wiki/images/thumb/7/7f/Macro_Install_HowTo_32.png/640px-Macro_Install_HowTo_32.png +/wiki/images/thumb/e/e9/Macro_Install_HowTo_33.png/640px-Macro_Install_HowTo_33.png +/wiki/images/thumb/b/b2/Macro_Install_HowTo_34.png/640px-Macro_Install_HowTo_34.png +/wiki/images/thumb/9/92/Macro_Install_HowTo_35.png/640px-Macro_Install_HowTo_35.png +/wiki/images/thumb/f/f7/Macro_Install_HowTo_36.png/640px-Macro_Install_HowTo_36.png +/wiki/images/thumb/8/82/Case_a_cocher_O.png/16px-Case_a_cocher_O.png +/wiki/images/thumb/f/f7/Macro_Install_HowTo_37.png/640px-Macro_Install_HowTo_37.png +/wiki/images/thumb/c/cb/Macro_Install_HowTo_38.png/640px-Macro_Install_HowTo_38.png +Macro_screw_maker1_2 +/wiki/images/thumb/7/76/Macro_screw_maker_01.png/400px-Macro_screw_maker_01.png +/wiki/images/thumb/9/92/Macro_screw_maker_02.png/220px-Macro_screw_maker_02.png +/wiki/images/thumb/1/10/Macro_screw_maker_03.png/267px-Macro_screw_maker_03.png +Macro_Apothem_Based_Prism_GUI +/wiki/images/thumb/0/0f/Part_Prism_Apothem.png/32px-Part_Prism_Apothem.png +/wiki/images/f/f7/ABP_Screenshot.png +Std_DlgMacroStop +/wiki/images/thumb/2/26/Std_DlgMacroStop.png/32px-Std_DlgMacroStop.png +/wiki/images/thumb/2/26/Std_DlgMacroStop.png/20px-Std_DlgMacroStop.png +/wiki/images/thumb/0/09/Macros_toolbar.jpg/96px-Macros_toolbar.jpg +/wiki/images/thumb/6/66/Std_DlgMacroRecord.png/16px-Std_DlgMacroRecord.png +/wiki/images/5/5c/Std_DlgMacroStop_02.png +/wiki/images/thumb/5/5c/Std_DlgMacroStop_02.png/16px-Std_DlgMacroStop_02.png +/wiki/images/thumb/1/1c/Std_DlgMacroExecuteDirect.png/16px-Std_DlgMacroExecuteDirect.png +Std_DebugMacro +/wiki/images/thumb/e/ee/Std_DebugMacro.png/32px-Std_DebugMacro.png +Std_Macro_Menu +Std_DebugToggle +/wiki/images/thumb/0/0f/Std_DebugToggle.png/32px-Std_DebugToggle.png +Std_DebugInto +/wiki/images/thumb/6/67/Std_DebugInto.png/32px-Std_DebugInto.png +Std_DebugOver +/wiki/images/thumb/2/21/Std_DebugOver.png/32px-Std_DebugOver.png +Std_DlgMacroExecute +/wiki/images/thumb/d/d3/Std_DlgMacroExecute.png/32px-Std_DlgMacroExecute.png +/wiki/images/thumb/d/d3/Std_DlgMacroExecute.png/16px-Std_DlgMacroExecute.png +/wiki/images/thumb/0/02/Menu_Std_DlgMacroExecute_fr_02.png/20px-Menu_Std_DlgMacroExecute_fr_02.png +Std_DlgMacroExecuteDirect +/wiki/images/thumb/1/1c/Std_DlgMacroExecuteDirect.png/32px-Std_DlgMacroExecuteDirect.png +Std_DebugStop +/wiki/images/thumb/9/90/Std_DebugStop.png/32px-Std_DebugStop.png +Std_DlgMacroRecord +/wiki/images/thumb/6/66/Std_DlgMacroRecord.png/32px-Std_DlgMacroRecord.png +/wiki/images/2/2b/Menu_Std_DlgMacroRecord_it.png +/wiki/images/thumb/2/26/Std_DlgMacroStop.png/16px-Std_DlgMacroStop.png +Macros_recipes +/wiki/images/6/64/Part_CheckGeometry.svg +/wiki/images/thumb/2/2c/Text-x-python.png/24px-Text-x-python.png +/wiki/images/thumb/d/d0/Macro_Toggle_Views_Visibility.png/24px-Macro_Toggle_Views_Visibility.png +/wiki/images/thumb/2/25/FCCamera_00.png/24px-FCCamera_00.png +/wiki/images/thumb/4/42/Macro_SelectVisible.png/24px-Macro_SelectVisible.png +/wiki/images/thumb/d/d7/Macro_SelectVisible2.png/24px-Macro_SelectVisible2.png +/wiki/images/thumb/5/51/SelectVisible.png/24px-SelectVisible.png +/wiki/images/thumb/8/84/Macro_Copy3DViewToClipboard.png/24px-Macro_Copy3DViewToClipboard.png +/wiki/images/thumb/0/0c/Macro_Perpendicular_To_Wire.png/24px-Macro_Perpendicular_To_Wire.png +/wiki/images/thumb/b/b4/Macro_Rotate_To_Point.png/24px-Macro_Rotate_To_Point.png +/wiki/images/thumb/6/64/Macro_FCTreeView.png/24px-Macro_FCTreeView.png +/wiki/images/thumb/d/d8/Macro_Select_Hovering.png/24px-Macro_Select_Hovering.png +/wiki/images/e/e5/Draft_FlipDimension.svg +/wiki/images/c/ce/Applications-python.svg +/wiki/images/thumb/4/45/Macro_Python_Assistant_Window.png/24px-Macro_Python_Assistant_Window.png +/wiki/images/thumb/8/87/Macro_Build_Utility.png/24px-Macro_Build_Utility.png +/wiki/images/thumb/c/c1/Macro_Global_Variable_Watcher.png/24px-Macro_Global_Variable_Watcher.png +/wiki/images/f/f0/Arch_MeshToShape.svg +/wiki/images/thumb/f/f8/PartToVRML.png/24px-PartToVRML.png +/wiki/images/thumb/f/f2/Macro_FCWire_To_Volume.png/24px-Macro_FCWire_To_Volume.png +/wiki/images/thumb/0/0a/Macro_DeepCopy.png/24px-Macro_DeepCopy.png +/wiki/images/f/f8/Drawing-orthoviews.svg +/wiki/images/thumb/6/68/Macro_CartoucheFC_Full.png/24px-Macro_CartoucheFC_Full.png +/wiki/images/b/b4/Draft_BSpline.svg +/wiki/images/thumb/1/10/Macro_Draft_Circle_3_Points.png/24px-Macro_Draft_Circle_3_Points.png +/wiki/images/thumb/9/92/Macro_Make_Arc_3_Points.png/24px-Macro_Make_Arc_3_Points.png +/wiki/images/thumb/e/e2/Macro_FCConvertLines.png/24px-Macro_FCConvertLines.png +/wiki/images/thumb/6/6d/Macro_DXF_to_Face_and_Sketch.png/24px-Macro_DXF_to_Face_and_Sketch.png +/wiki/images/thumb/f/fd/Macro_Compound_Plus.png/24px-Macro_Compound_Plus.png +/wiki/images/thumb/f/f4/Macro_Dxf_To_Shape.png/24px-Macro_Dxf_To_Shape.png +/wiki/images/b/b5/Fem_ResultDisplacement.svg +/wiki/images/a/a6/Part_Measure_Clear_All.svg +/wiki/images/thumb/5/53/FCInfo.png/24px-FCInfo.png +/wiki/images/thumb/6/6b/Macro_FCInfoGlass.png/24px-Macro_FCInfoGlass.png +/wiki/images/thumb/1/10/FCInfoToMouse.png/24px-FCInfoToMouse.png +/wiki/images/thumb/2/2e/Macro_Dump_Objects.png/24px-Macro_Dump_Objects.png +/wiki/images/thumb/b/bd/Macro_MeasureCircle.png/24px-Macro_MeasureCircle.png +/wiki/images/7/7d/Draft_VisGroup.svg +/wiki/images/thumb/5/50/Macro_BOLTS.png/24px-Macro_BOLTS.png +/wiki/images/thumb/9/9d/FreeCAD_Doc.png/24px-FreeCAD_Doc.png +/wiki/images/f/fc/Bound-expression.svg +/wiki/images/thumb/9/9d/WF_wf.png/24px-WF_wf.png +/wiki/images/2/2f/IFC.svg +/wiki/images/d/de/Workbench_Image.svg +/wiki/images/thumb/3/36/Macro_makeCube.png/24px-Macro_makeCube.png +/wiki/images/thumb/9/90/FCTexture.png/24px-FCTexture.png +/wiki/images/thumb/2/29/FCCreaLoft.png/24px-FCCreaLoft.png +/wiki/images/thumb/c/c1/FCCircularTextButtom.png/24px-FCCircularTextButtom.png +/wiki/images/thumb/a/a3/Macro_ReproWire.png/24px-Macro_ReproWire.png +/wiki/images/thumb/0/0f/Part_Prism_Apothem.png/24px-Part_Prism_Apothem.png +/wiki/images/thumb/6/69/FCSpring_Helix_Variable.png/24px-FCSpring_Helix_Variable.png +/wiki/images/3/39/Workbench_PartDesign.svg +/wiki/images/thumb/0/0a/Macro_CloneConvert.png/24px-Macro_CloneConvert.png +/wiki/images/thumb/c/c9/Macro_Connect_And_Sweep.png/24px-Macro_Connect_And_Sweep.png +/wiki/images/thumb/a/ab/Part_Section.png/24px-Part_Section.png +/wiki/images/thumb/a/ac/Macro_Overlap.png/24px-Macro_Overlap.png +/wiki/images/6/6d/View.svg +/wiki/images/4/48/Preferences-raytracing.svg +/wiki/images/e/e0/Spreadsheet.svg +/wiki/images/thumb/d/d7/Aliasmanager_icon.png/24px-Aliasmanager_icon.png +/wiki/images/thumb/d/d5/Macro_FCSpreadsheet_Extract.png/24px-Macro_FCSpreadsheet_Extract.png +/wiki/images/a/a9/Arch_Survey.svg +/wiki/images/thumb/1/16/CenterFace.png/24px-CenterFace.png +/wiki/images/thumb/b/bb/Macro_Center_Align_Objects_with_Faces_or_Edges.png/24px-Macro_Center_Align_Objects_with_Faces_or_Edges.png +/wiki/images/thumb/2/2d/Macro_Easy_Cutouts_for_Enclosures.png/24px-Macro_Easy_Cutouts_for_Enclosures.png +/wiki/images/thumb/8/88/Force_Recompute.png/24px-Force_Recompute.png +/wiki/images/thumb/0/07/Replace_Part.png/24px-Replace_Part.png +/wiki/images/thumb/0/0b/Macro_Toggle_Drawstyle.png/24px-Macro_Toggle_Drawstyle.png +/wiki/images/2/2e/HighlightDifference.png +/wiki/images/thumb/6/60/BoundBoxTracing.png/24px-BoundBoxTracing.png +/wiki/images/4/48/Bulb.svg +/wiki/images/thumb/8/8d/GW_Dim.png/24px-GW_Dim.png +/wiki/images/thumb/a/a9/Cabinets32.png/24px-Cabinets32.png +/wiki/images/thumb/4/44/Macro_Half_Hull_Model.png/24px-Macro_Half_Hull_Model.png +/wiki/images/thumb/9/95/Gearworkbech.png/24px-Gearworkbech.png +/wiki/images/thumb/f/f2/PropertyMemo.png/24px-PropertyMemo.png +/wiki/images/thumb/5/52/Std_FreeCADWebsite.png/32px-Std_FreeCADWebsite.png +/wiki/images/thumb/4/4f/2364.png/24px-2364.png +/wiki/images/thumb/0/09/681.jpg/24px-681.jpg +/wiki/images/thumb/6/6d/Macro_Recipes_MacroHowToInstall.png/200px-Macro_Recipes_MacroHowToInstall.png +How_to_install_additional_workbenches +Macro_PropertyMemo +/wiki/images/thumb/f/f2/PropertyMemo.png/32px-PropertyMemo.png +/wiki/images/2/23/Macro_FCPropertyMemo_00.png +/wiki/images/2/29/Macro_FCPropertyMemo_01.png +/wiki/images/thumb/5/57/Macro_FCPropertyMemo_02.png/190px-Macro_FCPropertyMemo_02.png +/wiki/images/thumb/e/eb/Macro_FCPropertyMemo_03.png/204px-Macro_FCPropertyMemo_03.png +/wiki/images/f/f2/PropertyMemo.png +Macro_Corner_shapes_wizard +/wiki/images/8/85/CornerShape1.png +Macro_FCGear +/wiki/images/thumb/9/95/Gearworkbech.png/32px-Gearworkbech.png +/wiki/images/b/b2/FCGear_00.png +/wiki/images/thumb/3/33/Involutegear.png/100px-Involutegear.png +/wiki/images/thumb/8/86/FCGear_involutegear_par.png/300px-FCGear_involutegear_par.png +/wiki/images/thumb/2/2e/Involuterack.png/100px-Involuterack.png +/wiki/images/thumb/0/06/FCGear_involuterack_par.png/300px-FCGear_involuterack_par.png +/wiki/images/thumb/a/a0/Cycloidegear.png/100px-Cycloidegear.png +/wiki/images/thumb/0/0a/FCGear_cycloide_par.png/300px-FCGear_cycloide_par.png +/wiki/images/thumb/f/f6/Bevelgear.png/100px-Bevelgear.png +/wiki/images/thumb/9/94/FCGear_bevel_par.png/300px-FCGear_bevel_par.png +Macro_Stairs +/wiki/images/thumb/7/72/Macro_CircularStair.png/480px-Macro_CircularStair.png +Macro_Half-Hull_Model +/wiki/images/thumb/4/44/Macro_Half_Hull_Model.png/32px-Macro_Half_Hull_Model.png +/wiki/images/2/23/Macro_Half-Hull_ModelScreenBoatInABottle.jpg +/wiki/images/8/8f/Macro_Half-Hull_ModelImage0.jpg +/wiki/images/1/12/Macro_Half-Hull_ModelImage1.jpg +/wiki/images/9/94/Macro_Half-Hull_ModelImage2.jpg +/wiki/images/3/31/Macro_Half-Hull_ModelImage3.jpg +/wiki/images/f/fb/Macro_Half-Hull_ModelImage3a.jpg +/wiki/images/d/d1/Macro_Half-Hull_ModelImage4.jpg +/wiki/images/9/9f/Macro_Half-Hull_ModelImage5.jpg +/wiki/images/2/26/Macro_Half-Hull_ModelImage6.jpg +/wiki/images/9/9c/Macro_Half-Hull_ModelImage7.jpg +/wiki/images/2/2e/Macro_Half-Hull_ModelImage8.jpg +/wiki/images/2/25/Macro_Half-Hull_ModelImage9.jpg +/wiki/images/4/4d/Macro_Half-Hull_ModelUsage1.jpg +/wiki/images/3/30/Macro_Half-Hull_ModelUsage2.jpg +/wiki/images/f/f1/Sketcher_NewSketch.svg +/wiki/images/0/0a/Macro_Half-Hull_ModelUsage3.jpg +/wiki/images/3/3a/Sketcher_LeaveSketch.svg +/wiki/images/5/57/Macro_Half-Hull_ModelScreenSnapshot1.jpg +/wiki/images/1/1c/Macro_Half-Hull_ModelUsage4.jpg +/wiki/images/a/a4/Document-save.svg +/wiki/images/d/dc/View-top.svg +/wiki/images/8/88/Macro_Half-Hull_ModelUsage5.jpg +/wiki/images/2/22/Macro_Half-Hull_ModelScreenSnapshot2.jpg +/wiki/images/d/d3/Macro_Half-Hull_ModelUi1.jpg +/wiki/images/2/25/Macro_Half-Hull_ModelOption1.jpg +/wiki/images/3/3d/Macro_Half-Hull_ModelOption2.jpg +/wiki/images/2/2d/Macro_Half-Hull_ModelOption3.jpg +/wiki/images/2/23/Macro_Half-Hull_ModelOption4.jpg +/wiki/images/1/13/Macro_Half-Hull_ModelOption5.jpg +/wiki/images/2/2a/Macro_Half-Hull_ModelOption6.jpg +/wiki/images/8/87/Macro_Half-Hull_ModelOption7.jpg +/wiki/images/d/d1/Macro_Half-Hull_ModelOption8.jpg +/wiki/images/5/59/Macro_Half-Hull_ModelOption9.jpg +/wiki/images/0/07/Macro_Half-Hull_ModelOption10.jpg +/wiki/images/3/30/Macro_Half-Hull_ModelKnownProblems1.jpg +Macro_Half_turn_stairs +/wiki/images/thumb/b/b8/Half_turn_stairs.png/32px-Half_turn_stairs.png +/wiki/images/b/b8/Half_turn_stairs.png +Macro_Cabinets32 +/wiki/images/thumb/a/a9/Cabinets32.png/32px-Cabinets32.png +/wiki/images/e/e9/Cabinetside.png +/wiki/images/2/2e/Cabinettop.png +Macro_Geneva_Wheel_GUI +/wiki/images/thumb/8/8d/GW_Dim.png/32px-GW_Dim.png +/wiki/images/8/8d/GW_Dim.png +/wiki/images/d/df/New_GW_GUI.png +Macro_Geneva_Wheel +/wiki/images/7/7d/Geneva.png +Macro_Airfoil_Import_%26_Scale +/wiki/images/thumb/4/43/Macro_Airfoil_Import_%26_Scale_00.png/480px-Macro_Airfoil_Import_%26_Scale_00.png +/wiki/images/0/09/File_browser.png +/wiki/images/f/f8/Chord_length.png +/wiki/images/b/b1/V2_scale.png +Common_Airfoil_Data_Import +Macro_Unfold_Box +/wiki/images/thumb/b/b7/Macro_unfoldBox1.png/480px-Macro_unfoldBox1.png +Macro_Unroll_Ruled_Surface +/wiki/images/thumb/7/7f/Macro_unrollRuledSurface_00.png/480px-Macro_unrollRuledSurface_00.png +/wiki/images/f/f6/Macro_unrollRuledSurface_01.png +Macro_Sheet_Metal_Unfolder +/wiki/images/a/a4/Unfolding_test2.png +Macro_Unbind_Numpad_Shortcuts +Macro_merge_duplicate_materials +Macro_Arch_Axis_System_Repartition +/wiki/images/thumb/8/87/ArchAxisSystemRepartition.png/480px-ArchAxisSystemRepartition.png +Macro_BoundingBox_Tracing +/wiki/images/thumb/6/60/BoundBoxTracing.png/32px-BoundBoxTracing.png +/wiki/images/thumb/b/bb/Macro_BoundingBox_Tracing_00.png/480px-Macro_BoundingBox_Tracing_00.png +/wiki/images/thumb/6/66/Macro_BoundingBox_Tracing_01.png/480px-Macro_BoundingBox_Tracing_01.png +/wiki/images/6/60/BoundBoxTracing.png +Macro_Print_SceneGraph +Macro_cross_section +/wiki/images/2/20/Cross-section.png +/wiki/images/d/d1/Macro_Cross_Section_02.png +/wiki/images/thumb/9/98/Macro_Cross_Section_01.png/150px-Macro_Cross_Section_01.png +/wiki/images/0/02/Macro_Cross_Section_03.gif +Macro_HighlightDifference +/wiki/images/thumb/6/65/Macro_HighlightDifference_02.png/400px-Macro_HighlightDifference_02.png +/wiki/images/thumb/5/5f/Macro_HighlightDifference_00.png/200px-Macro_HighlightDifference_00.png +/wiki/images/thumb/6/65/Macro_HighlightDifference_02.png/200px-Macro_HighlightDifference_02.png +/wiki/images/thumb/d/dd/Macro_HighlightDifference_01.png/200px-Macro_HighlightDifference_01.png +Macro_HighlightCommon +/wiki/images/c/c1/Captura_de_pantalla_de_2015-09-10_11-17-30.png +Macro_Toggle_Drawstyle +/wiki/images/thumb/0/0b/Macro_Toggle_Drawstyle.png/32px-Macro_Toggle_Drawstyle.png +/wiki/images/8/81/Macro_Toggle_Drawstyle_00_.png +Macro_Replace_Part_in_Assembly +/wiki/images/thumb/0/07/Replace_Part.png/32px-Replace_Part.png +/wiki/images/2/22/Macro_Replace_Part_in_Assembly.jpg +Macro_Shake_Sketch +Macro_Recompute_Profiler +Macro_ForceRecompute +/wiki/images/thumb/8/88/Force_Recompute.png/32px-Force_Recompute.png +/wiki/images/f/fc/View-refresh.svg +Std_Refresh +/wiki/images/thumb/a/ac/Std_Refresh.png/32px-Std_Refresh.png +/wiki/images/a/ac/Std_Refresh.png +Std_Edit_Menu +/wiki/images/thumb/a/a7/Std_Undo.png/16px-Std_Undo.png +/wiki/images/thumb/b/bf/Std_Redo.png/16px-Std_Redo.png +/wiki/images/thumb/e/e9/Std_Cut.png/16px-Std_Cut.png +/wiki/images/thumb/8/83/Std_Copy.png/16px-Std_Copy.png +/wiki/images/thumb/9/9f/Std_Paste.png/16px-Std_Paste.png +/wiki/images/thumb/7/73/Std_DuplicateSelection.png/16px-Std_DuplicateSelection.png +/wiki/images/thumb/a/ac/Std_Refresh.png/16px-Std_Refresh.png +/wiki/images/thumb/2/2a/Std_BoxSelection.png/16px-Std_BoxSelection.png +/wiki/images/thumb/7/7b/Std_SelectAll.png/16px-Std_SelectAll.png +/wiki/images/thumb/a/a2/Std_Delete.png/16px-Std_Delete.png +/wiki/images/thumb/a/a1/Std_Edit.png/16px-Std_Edit.png +/wiki/images/thumb/5/5e/Std_DlgPreferences.png/16px-Std_DlgPreferences.png +Std_DlgPreferences +/wiki/images/thumb/5/5e/Std_DlgPreferences.png/32px-Std_DlgPreferences.png +/wiki/images/e/e7/DlgPreferences.jpg +Std_Edit +/wiki/images/thumb/a/a1/Std_Edit.png/32px-Std_Edit.png +Std_Alignment +/wiki/images/thumb/6/60/Std_Alignment.png/32px-Std_Alignment.png +/wiki/images/thumb/2/25/Std_Alignment1.png/500px-Std_Alignment1.png +/wiki/images/thumb/1/10/Std_Alignment2.png/500px-Std_Alignment2.png +/wiki/images/6/68/Std_Alignment3.png +/wiki/images/thumb/8/85/Std_Alignment4.png/500px-Std_Alignment4.png +Std_Placement +/wiki/images/thumb/3/34/Std_Placement.png/32px-Std_Placement.png +Aeroplane +/wiki/images/thumb/d/d4/Part_Cylinder.png/32px-Part_Cylinder.png +/wiki/images/thumb/8/8f/HTCaeroplane01.png/300px-HTCaeroplane01.png +/wiki/images/thumb/8/8a/HTCaeroplane02.png/400px-HTCaeroplane02.png +/wiki/images/thumb/c/cd/HTCaeroplane03.png/400px-HTCaeroplane03.png +/wiki/images/thumb/a/a5/Part_Box.png/32px-Part_Box.png +/wiki/images/thumb/8/89/Part_Booleans.png/32px-Part_Booleans.png +/wiki/images/thumb/c/c6/Part_Fuse.png/32px-Part_Fuse.png +/wiki/images/thumb/d/d1/HTCaeroplane04.png/500px-HTCaeroplane04.png +/wiki/images/1/12/Tache_Placement_Lacet_fr_Mini.gif +/wiki/images/7/7a/Tache_Placement_Tangage_fr_Mini.gif +/wiki/images/c/c0/Tache_Placement_Roulis_fr_Mini.gif +Part_Union +/wiki/images/thumb/c/c6/Part_Fuse.png/16px-Part_Fuse.png +Part_RefineShape +/wiki/images/thumb/6/68/Part_RefineShape.png/32px-Part_RefineShape.png +/wiki/images/0/0e/PartRefineShape_it.png +OpenSCAD_RefineShapeFeature +/wiki/images/thumb/9/93/OpenSCAD_RefineShapeFeature.png/32px-OpenSCAD_RefineShapeFeature.png +Part_Common +/wiki/images/thumb/9/9a/Part_Common.png/32px-Part_Common.png +/wiki/images/thumb/9/9a/Part_Common.png/16px-Part_Common.png +Part_Cut +/wiki/images/thumb/4/4a/Part_Cut.png/32px-Part_Cut.png +/wiki/images/thumb/8/8e/Part_Cut_01.png/480px-Part_Cut_01.png +/wiki/images/thumb/4/4a/Part_Cut.png/16px-Part_Cut.png +Complete_Workbench +Part_Booleans +/wiki/images/2/26/PartBooleansDialog.png +Part_Box +/wiki/images/thumb/b/b6/Part_Box.jpg/400px-Part_Box.jpg +/wiki/images/thumb/a/a5/Part_Box.png/30px-Part_Box.png +/wiki/images/6/6b/Part_Box-Properties.jpg +Part_CreatePrimitives +/wiki/images/thumb/8/8a/Part_CreatePrimitives.png/32px-Part_CreatePrimitives.png +/wiki/images/3/39/Part_CreatePrimitives_example_FreeCAD_0_13.jpg +Part_RegularPolygon +/wiki/images/thumb/7/7d/Part_RegularPolygon.png/32px-Part_RegularPolygon.png +Part_Point +/wiki/images/thumb/9/9e/Part_Point.png/32px-Part_Point.png +/wiki/images/6/64/PartVertexPrimitivesOptions_it.png +/wiki/images/1/1a/PartVertexProperty_it.png +Part_Line +/wiki/images/thumb/b/b7/Part_Line.png/32px-Part_Line.png +/wiki/images/5/5e/PartLinePrimitivesOptions_it.png +/wiki/images/9/9b/PartLineProperty_it.png +Part_Ellipse +/wiki/images/thumb/0/02/Part_Ellipse.png/32px-Part_Ellipse.png +Part_Circle +/wiki/images/thumb/c/c6/Part_Circle.png/32px-Part_Circle.png +Part_Spiral +/wiki/images/thumb/a/a2/Part_Spiral.png/32px-Part_Spiral.png +/wiki/images/7/7a/SpiralDefault_it.png +/wiki/images/f/fe/Spiral_x45_it.png +/wiki/images/e/e0/Spiral_y45_it.png +Part_Helix +/wiki/images/thumb/6/69/Part_Helix.png/32px-Part_Helix.png +/wiki/images/b/b7/PartHelixPrimitivesOptions_en.png +/wiki/images/a/af/PartHelixProperty_en.png +Part_Sweep +/wiki/images/thumb/7/79/Part_Sweep.png/32px-Part_Sweep.png +/wiki/images/6/66/Part_Sweep_simple.png +/wiki/images/thumb/7/79/Part_Sweep.png/16px-Part_Sweep.png +/wiki/images/thumb/3/3a/Sweep-frenet-comp.png/500px-Sweep-frenet-comp.png +Part_Loft +/wiki/images/thumb/e/ef/Part_Loft.png/32px-Part_Loft.png +/wiki/images/7/72/Part_Loft_solid_ruled_from3profiles_example_FreeCAD_0_13.jpg +/wiki/images/3/32/Part_Loft_Ikon_Ballon_Hilfe.png +/wiki/images/5/5f/Part_Loft_Liste3.png +/wiki/images/2/26/Part_Loft_Liste_Auswahl_3b.png +/wiki/images/8/8e/Part_Loft_Liste_Auswahl_3c.png +/wiki/images/e/eb/Part_Loft_Liste_Auswahl_3d.png +/wiki/images/b/be/Part_Loft_geschlossen.png +Part_Loft_Technical_Details +/wiki/images/thumb/7/7b/Loft-vertex-insertion.png/300px-Loft-vertex-insertion.png +/wiki/images/thumb/3/33/Loft_crescent_pentagon.png/300px-Loft_crescent_pentagon.png +/wiki/images/thumb/8/89/Loft_Number_of_verts_match.png/300px-Loft_Number_of_verts_match.png +/wiki/images/thumb/5/5a/Loft_B-spline.png/400px-Loft_B-spline.png +/wiki/images/thumb/e/e5/Loft_nonparallel.png/300px-Loft_nonparallel.png +/wiki/images/thumb/b/bb/Loft_Coplanar.png/300px-Loft_Coplanar.png +/wiki/images/thumb/b/ba/Loft-closed.png/300px-Loft-closed.png +Thread_for_Screw_Tutorial +/wiki/images/thumb/9/9a/Thread-stack-vs-proper.png/500px-Thread-stack-vs-proper.png +/wiki/images/thumb/c/c2/Thread-by-vertical-profile.png/500px-Thread-by-vertical-profile.png +/wiki/images/thumb/a/a6/Thread-by-vertical-profile-rule1.png/300px-Thread-by-vertical-profile-rule1.png +/wiki/images/5/55/Thread-by-vertical-profile-rule2.png +/wiki/images/thumb/f/f7/Thread-by-horz-profile.png/600px-Thread-by-horz-profile.png +/wiki/images/thumb/2/2d/Thread-by-horz-profile-profileMake.png/1000px-Thread-by-horz-profile-profileMake.png +/wiki/images/5/59/Splineextrudeloft.png +/wiki/images/0/00/Threadform.PNG +Draft_Upgrade +/wiki/images/thumb/b/be/Draft_Upgrade.png/32px-Draft_Upgrade.png +/wiki/images/thumb/5/54/Draft_Upgrade_example.jpg/400px-Draft_Upgrade_example.jpg +/wiki/images/thumb/b/be/Draft_Upgrade.png/16px-Draft_Upgrade.png +Draft_Downgrade +/wiki/images/thumb/8/86/Draft_Downgrade.png/32px-Draft_Downgrade.png +/wiki/images/thumb/4/42/Draft_Downgrade_example.jpg/400px-Draft_Downgrade_example.jpg +/wiki/images/thumb/8/86/Draft_Downgrade.png/16px-Draft_Downgrade.png +/wiki/images/thumb/8/8d/Draft_Downgrade_01.png/267px-Draft_Downgrade_01.png +/wiki/images/thumb/7/7d/Draft_Downgrade_02.png/267px-Draft_Downgrade_02.png +Part_Mirror +/wiki/images/thumb/9/93/Part_Mirror.png/32px-Part_Mirror.png +/wiki/images/2/2d/PARTMirrorBeforev11.png +/wiki/images/3/38/PARTMirrorAfterv11.png +/wiki/images/d/d1/PARTMirrorDialogv11.png +Draft_Array +/wiki/images/thumb/c/c8/Draft_Array.png/32px-Draft_Array.png +/wiki/images/thumb/3/3e/Draft_Array_example.jpg/400px-Draft_Array_example.jpg +/wiki/images/thumb/c/c8/Draft_Array.png/16px-Draft_Array.png +Draft_PathArray +/wiki/images/thumb/c/c1/Draft_PathArray.png/32px-Draft_PathArray.png +/wiki/images/1/15/Draft_PathArray_Example.png +/wiki/images/thumb/c/c1/Draft_PathArray.png/16px-Draft_PathArray.png +/wiki/images/a/ae/Patharray_NoAlign.png +/wiki/images/thumb/e/e1/Patharray_alignment_annotated.png/600px-Patharray_alignment_annotated.png +/wiki/images/thumb/7/73/Patharray_alignment.png/600px-Patharray_alignment.png +/wiki/images/thumb/c/c9/Patharray_alignment-XZ.png/600px-Patharray_alignment-XZ.png +/wiki/images/thumb/7/73/Patharray_alignment-YZ.png/600px-Patharray_alignment-YZ.png +Sketcher_Workbench +/wiki/images/thumb/7/71/FC_ConstrainedSketch.png/300px-FC_ConstrainedSketch.png +/wiki/images/thumb/e/e9/Sketcher_CreatePoint.png/32px-Sketcher_CreatePoint.png +/wiki/images/thumb/7/72/Sketcher_Line.png/32px-Sketcher_Line.png +/wiki/images/thumb/1/15/Sketcher_Arc.png/32px-Sketcher_Arc.png +/wiki/images/thumb/7/74/Sketcher_CreateArc3Point.png/32px-Sketcher_CreateArc3Point.png +/wiki/images/thumb/d/da/Sketcher_Circle.png/32px-Sketcher_Circle.png +/wiki/images/thumb/2/27/Sketcher_CreateCircle3Point.png/32px-Sketcher_CreateCircle3Point.png +/wiki/images/thumb/e/ec/Sketcher_Conics.png/32px-Sketcher_Conics.png +/wiki/images/thumb/7/76/Sketcher_CreateEllipse.png/32px-Sketcher_CreateEllipse.png +/wiki/images/thumb/a/ac/Sketcher_CreateEllipse_3points.png/32px-Sketcher_CreateEllipse_3points.png +/wiki/images/thumb/1/13/Sketcher_Elliptical_Arc.png/32px-Sketcher_Elliptical_Arc.png +/wiki/images/thumb/8/89/Sketcher_Hyperbolic_Arc.png/32px-Sketcher_Hyperbolic_Arc.png +/wiki/images/thumb/e/ec/Sketcher_Parabolic_Arc.png/32px-Sketcher_Parabolic_Arc.png +/wiki/images/thumb/a/aa/Sketcher_CreatePolyline.png/32px-Sketcher_CreatePolyline.png +/wiki/images/thumb/a/ad/Sketcher_CreateRectangle.png/32px-Sketcher_CreateRectangle.png +/wiki/images/thumb/d/d7/Sketcher_CreateTriangle.png/32px-Sketcher_CreateTriangle.png +/wiki/images/thumb/8/85/Sketcher_CreateSquare.png/32px-Sketcher_CreateSquare.png +/wiki/images/thumb/c/c0/Sketcher_CreatePentagon.png/32px-Sketcher_CreatePentagon.png +/wiki/images/thumb/d/d8/Sketcher_CreateHexagon.png/32px-Sketcher_CreateHexagon.png +/wiki/images/thumb/d/df/Sketcher_CreateHeptagon.png/32px-Sketcher_CreateHeptagon.png +/wiki/images/thumb/0/00/Sketcher_CreateOctagon.png/32px-Sketcher_CreateOctagon.png +/wiki/images/thumb/1/16/Sketcher_CreateSlot.png/32px-Sketcher_CreateSlot.png +/wiki/images/thumb/f/f0/Sketcher_CreateFillet.png/32px-Sketcher_CreateFillet.png +/wiki/images/thumb/2/2c/Sketcher_Trimming.png/32px-Sketcher_Trimming.png +/wiki/images/thumb/b/b5/Sketcher_External.png/32px-Sketcher_External.png +/wiki/images/thumb/4/4f/Sketcher_ToggleConstruction.png/32px-Sketcher_ToggleConstruction.png +/wiki/images/thumb/e/e3/Constraint_PointOnPoint.png/32px-Constraint_PointOnPoint.png +/wiki/images/thumb/7/7d/Constraint_PointOnObject.png/32px-Constraint_PointOnObject.png +/wiki/images/thumb/d/d6/Constraint_Vertical.png/32px-Constraint_Vertical.png +/wiki/images/thumb/3/3f/Constraint_Horizontal.png/32px-Constraint_Horizontal.png +/wiki/images/thumb/0/0b/Constraint_Parallel.png/32px-Constraint_Parallel.png +/wiki/images/thumb/3/39/Constraint_Perpendicular.png/32px-Constraint_Perpendicular.png +/wiki/images/thumb/1/1a/Constraint_Tangent.png/32px-Constraint_Tangent.png +/wiki/images/thumb/b/bb/Constraint_EqualLength.png/32px-Constraint_EqualLength.png +/wiki/images/thumb/b/be/Constraint_Symmetric.png/32px-Constraint_Symmetric.png +/wiki/images/thumb/e/e8/Sketcher_ConstrainBlock.png/32px-Sketcher_ConstrainBlock.png +/wiki/images/thumb/6/6c/Sketcher_ConstrainLock.png/32px-Sketcher_ConstrainLock.png +/wiki/images/thumb/5/57/Constraint_HorizontalDistance.png/32px-Constraint_HorizontalDistance.png +/wiki/images/thumb/b/ba/Constraint_VerticalDistance.png/32px-Constraint_VerticalDistance.png +/wiki/images/thumb/a/a3/Constraint_Length.png/32px-Constraint_Length.png +/wiki/images/thumb/5/58/Constraint_Radius.png/32px-Constraint_Radius.png +/wiki/images/thumb/7/75/Constraint_InternalAngle.png/32px-Constraint_InternalAngle.png +/wiki/images/thumb/9/9e/Constraint_SnellsLaw.png/32px-Constraint_SnellsLaw.png +/wiki/images/thumb/3/33/Constraint_InternalAlignment.png/32px-Constraint_InternalAlignment.png +/wiki/images/thumb/a/a9/Sketcher_ToggleConstraint.png/32px-Sketcher_ToggleConstraint.png +/wiki/images/thumb/4/46/Sketcher_NewSketch.png/32px-Sketcher_NewSketch.png +/wiki/images/thumb/4/4c/Sketcher_EditSketch.png/32px-Sketcher_EditSketch.png +/wiki/images/thumb/c/ce/Sketcher_LeaveSketch.png/32px-Sketcher_LeaveSketch.png +/wiki/images/thumb/4/40/Sketcher_ViewSketch.png/32px-Sketcher_ViewSketch.png +/wiki/images/thumb/4/45/Sketcher_MapSketch.png/32px-Sketcher_MapSketch.png +/wiki/images/thumb/7/79/Sketcher_MergeSketch.png/32px-Sketcher_MergeSketch.png +/wiki/images/thumb/4/4c/Sketcher_MirrorSketch.png/32px-Sketcher_MirrorSketch.png +/wiki/images/thumb/4/49/Sketcher_CloseShape.png/32px-Sketcher_CloseShape.png +/wiki/images/thumb/5/5c/Sketcher_ConnectLines.png/32px-Sketcher_ConnectLines.png +/wiki/images/thumb/5/58/Sketcher_SelectConstraints.png/32px-Sketcher_SelectConstraints.png +/wiki/images/thumb/0/08/Sketcher_SelectOrigin.png/32px-Sketcher_SelectOrigin.png +/wiki/images/thumb/d/d9/Sketcher_SelectVerticalAxis.png/32px-Sketcher_SelectVerticalAxis.png +/wiki/images/thumb/c/cc/Sketcher_SelectHorizontalAxis.png/32px-Sketcher_SelectHorizontalAxis.png +/wiki/images/thumb/5/5a/Sketcher_SelectRedundantConstraints.png/32px-Sketcher_SelectRedundantConstraints.png +/wiki/images/thumb/f/f6/Sketcher_SelectConflictingConstraints.png/32px-Sketcher_SelectConflictingConstraints.png +/wiki/images/thumb/f/fc/Sketcher_SelectElementsAssociatedWithConstraints.png/32px-Sketcher_SelectElementsAssociatedWithConstraints.png +/wiki/images/thumb/f/fe/Sketcher_Element_Ellipse_All.png/32px-Sketcher_Element_Ellipse_All.png +/wiki/images/thumb/1/12/Sketcher_Symmetry.png/32px-Sketcher_Symmetry.png +/wiki/images/thumb/a/ad/Sketcher_Clone.png/32px-Sketcher_Clone.png +/wiki/images/thumb/8/86/Sketcher_Copy.png/32px-Sketcher_Copy.png +/wiki/images/thumb/c/c4/Sketcher_RectangularArray.png/32px-Sketcher_RectangularArray.png +/wiki/images/thumb/e/ea/Sketcher_SwitchVirtualSpace.png/32px-Sketcher_SwitchVirtualSpace.png +/wiki/images/thumb/6/6d/Std_DlgParameter.png/32px-Std_DlgParameter.png +Sketcher_Micro_Tutorial_-_Constraint_Practices +/wiki/images/1/1d/Constrain1.png +/wiki/images/0/08/Constrain2.png +/wiki/images/7/71/Constrain3.png +Sketcher_tutorial +/wiki/images/thumb/6/6f/Sketcher_tutorial_result.png/480px-Sketcher_tutorial_result.png +Constraint_Tangent +/wiki/images/thumb/e/ee/Sketcher_ConsraintTangent_mode1.png/600px-Sketcher_ConsraintTangent_mode1.png +/wiki/images/thumb/3/34/Sketcher_ConsraintTangent_mode2.png/600px-Sketcher_ConsraintTangent_mode2.png +/wiki/images/thumb/2/25/Sketcher_ConsraintTangent_mode3.png/600px-Sketcher_ConsraintTangent_mode3.png +/wiki/images/thumb/e/e7/Sketcher_ConsraintTangent_mode4.png/600px-Sketcher_ConsraintTangent_mode4.png +Sketcher_ToggleConstruction +Sketcher_Tutorial +/wiki/images/0/00/Traditional_triangle.png +/wiki/images/5/59/Document-new.png +/wiki/images/3/3a/Workbench_select_sketcher.png +/wiki/images/5/5c/Closed_triangle_with_pointer_small.png +/wiki/images/b/b9/Sketcher_triangle3_small.png +/wiki/images/2/27/Triangel_angle_small.png +/wiki/images/6/66/Right_triangle_sketcher.png +/wiki/images/e/ec/Triangle_equilateral_small.png +/wiki/images/4/4a/Triangle_isosceles_small.png +/wiki/images/thumb/a/a7/Constraint_Lock.png/32px-Constraint_Lock.png +/wiki/images/3/35/Sketcher_triangle3_fc_small.png +/wiki/images/0/07/Dimension_partitions_parallel.png +/wiki/images/e/e2/Dimension_partitions_flipped.png +/wiki/images/0/05/Constraint180_600x400.png +/wiki/images/b/b1/Elbow_equality_horizontal_vertical.png +/wiki/images/8/87/Elbow_fix_point_onto_object_52mm.png +/wiki/images/e/e7/Elbow_equality_perpendicular_vertical.png +/wiki/images/0/0a/Elbow_dimension_length_82_mm.png +/wiki/images/9/92/Elbow_equality_90%C2%B0to_vertical.png +/wiki/images/thumb/2/2a/Sketcher_AlterConstruction.png/32px-Sketcher_AlterConstruction.png +/wiki/images/1/1c/Goldener_Schnitt_Konstr_beliebt.svg +/wiki/images/8/8d/Sketcher_Rectangle.png +/wiki/images/a/a5/Step1_rectangle_600x400.png +/wiki/images/7/72/Step2_rectangle_with_symmetry_600x400.png +/wiki/images/thumb/7/75/Constraint_InternalAngle.png/24px-Constraint_InternalAngle.png +/wiki/images/9/9c/Step3_making_SB_600x400.png +/wiki/images/d/d5/Step4_make_SB_construction_line_600x400.png +/wiki/images/thumb/8/83/Sketcher_Point.png/32px-Sketcher_Point.png +/wiki/images/9/92/Step5_helper_vertex.png +/wiki/images/2/2a/Step6_symmetry_setting.png +/wiki/images/e/e5/Step7_arc_defining_BC.png +/wiki/images/6/64/Step8_arc_BC_finishing.png +/wiki/images/5/51/Step9_triangle_ready.png +/wiki/images/7/76/Step10_second_arc.png +/wiki/images/1/10/Step11_last_arc.png +/wiki/images/e/ed/Step12_define_ratio.png +/wiki/images/3/39/Step12_define_rectangle.png +/wiki/images/0/0d/Step14_rectangle_with_golden_ratio.png +/wiki/images/c/c6/Frame_erxercise_pad.png +/wiki/images/1/14/Frame_exercise_dimensions.png +/wiki/images/d/d0/Frame_erxercise_failed_sketch.png +Sketcher_Preferences +/wiki/images/a/a1/Preference_Sketcher_Tab_01.png +/wiki/images/3/3d/Preference_Sketcher_Tab_02.png +Sketcher_RectangularArray +/wiki/images/thumb/c/c4/Sketcher_RectangularArray.png/24px-Sketcher_RectangularArray.png +/wiki/images/thumb/c/c4/Sketcher_RectangularArray.png/16px-Sketcher_RectangularArray.png +/wiki/images/9/9d/Sketcher_RectangularArray_Options.jpg +Sketcher_Copy +Sketcher_Clone +Sketcher_Symmetry +Sketcher_Show_Hide_Internal_Geometry +/wiki/images/thumb/9/94/Sketcher_RestoreInternalAlignmentGeometry.png/32px-Sketcher_RestoreInternalAlignmentGeometry.png +Sketcher_SelectElementsAssociatedWithConstraints +Sketcher_SelectConflictingConstraints +Sketcher_SelectRedundantConstraints +Sketcher_SelectHorizontalAxis +Sketcher_SelectVerticalAxis +Sketcher_SelectOrigin +Sketcher_SelectConstraints +Sketcher_ConnectLines +Sketcher_CloseShape +Sketcher_MirrorSketch +Sketcher_MergeSketch +Sketcher_Validate +/wiki/images/2/29/Sketcher_Validate.png +/wiki/images/b/b0/Sketcher_Validate_it.png +Sketcher_Reorient +/wiki/images/thumb/f/fc/Sketcher_Reorient.png/32px-Sketcher_Reorient.png +Sketcher_MapSketch +/wiki/images/6/6a/Sketcher_MapSketch_00.png +/wiki/images/thumb/4/45/Sketcher_MapSketch.png/16px-Sketcher_MapSketch.png +/wiki/images/7/77/JschremppFCADEdit1.png +/wiki/images/a/a2/JschremppFCADEdit2.png +/wiki/images/7/77/JschremppFCADEdit3.png +/wiki/images/7/7e/JschremppFCADEdit4.png +Sketcher_ViewSketch +/wiki/images/thumb/4/40/Sketcher_ViewSketch.png/16px-Sketcher_ViewSketch.png +Sketcher_LeaveSketch +Sketcher_EditSketch +Sketcher_NewSketch +Constraint_Internal_Alignment +Constraint_SnellsLaw +/wiki/images/4/42/Snells_law2_witheq.svg +/wiki/images/thumb/3/30/Sketcher_SnellsLaw_Example1.png/500px-Sketcher_SnellsLaw_Example1.png +Constraint_InternalAngle +/wiki/images/thumb/a/ae/Sketcher_ConsraintAngle_mode1.png/600px-Sketcher_ConsraintAngle_mode1.png +/wiki/images/thumb/0/0d/Sketcher_ConsraintAngle_mode2.png/600px-Sketcher_ConsraintAngle_mode2.png +/wiki/images/thumb/7/79/Sketcher_ConsraintAngle_mode3.png/600px-Sketcher_ConsraintAngle_mode3.png +/wiki/images/thumb/e/ec/Sketcher_ConsraintAngle_mode4.png/600px-Sketcher_ConsraintAngle_mode4.png +Constraint_Radius +/wiki/images/thumb/4/4f/ConstrainRadius1.png/256px-ConstrainRadius1.png +/wiki/images/thumb/7/79/ConstrainRadius2.png/256px-ConstrainRadius2.png +/wiki/images/thumb/5/58/Constraint_Radius.png/16px-Constraint_Radius.png +/wiki/images/thumb/5/5a/ConstrainRadius3.png/256px-ConstrainRadius3.png +/wiki/images/thumb/9/9a/ConstrainRadius4.png/256px-ConstrainRadius4.png +/wiki/images/thumb/9/92/ConstrainRadius5.png/256px-ConstrainRadius5.png +Constraint_Length +/wiki/images/thumb/4/49/LengthConstraint1.png/256px-LengthConstraint1.png +/wiki/images/thumb/e/e1/LengthConstraint2.png/256px-LengthConstraint2.png +/wiki/images/thumb/a/a3/Constraint_Length.png/16px-Constraint_Length.png +/wiki/images/thumb/5/50/LengthConstraint3.png/256px-LengthConstraint3.png +/wiki/images/thumb/4/41/LengthConstraint4.png/256px-LengthConstraint4.png +/wiki/images/thumb/f/fa/LengthConstraint5.png/256px-LengthConstraint5.png +/wiki/images/thumb/7/76/LengthConstraint6.png/256px-LengthConstraint6.png +/wiki/images/thumb/4/40/LengthConstraint7.png/256px-LengthConstraint7.png +/wiki/images/thumb/d/d5/LengthConstraint8.png/256px-LengthConstraint8.png +/wiki/images/thumb/9/98/LengthConstraint9.png/256px-LengthConstraint9.png +/wiki/images/thumb/5/59/LengthConstraint10.png/256px-LengthConstraint10.png +Constraint_VerticalDistance +Constraint_HorizontalDistance +/wiki/images/1/17/Constraint_H_Distance.png +Constraint_Lock +/wiki/images/thumb/2/2b/LockConstraint1.png/256px-LockConstraint1.png +/wiki/images/thumb/d/d0/LockConstraint2.png/256px-LockConstraint2.png +/wiki/images/thumb/e/e2/LockConstraint3.png/256px-LockConstraint3.png +/wiki/images/thumb/c/cf/LockConstraint4.png/256px-LockConstraint4.png +/wiki/images/6/6b/LockConstraint5.png +/wiki/images/thumb/8/8d/LockConstraint6.png/256px-LockConstraint6.png +/wiki/images/thumb/f/fe/LockConstraint7.png/256px-LockConstraint7.png +Spreadsheet_Workbench +/wiki/images/2/25/Spreadsheet_screenshot.jpg +/wiki/images/1/16/SpreadsheetCellPropDialog.png +/wiki/images/f/f8/Expression_usage1.png +/wiki/images/a/a5/Expression_usage2.png +/wiki/images/7/78/Expression_usage3.png +Spreadsheet_legacy +/wiki/images/8/8f/Arch_tutorial_53.jpg +/wiki/images/thumb/c/cb/Spreadsheet_Create.png/16px-Spreadsheet_Create.png +/wiki/images/thumb/4/4f/Spreadsheet_Controller.png/16px-Spreadsheet_Controller.png +/wiki/images/thumb/d/df/Spreadsheet_PropertyController.png/16px-Spreadsheet_PropertyController.png +Spreadsheet_CSV +Spreadsheet_PropertyController +/wiki/images/thumb/d/df/Spreadsheet_PropertyController.png/32px-Spreadsheet_PropertyController.png +Spreadsheet_Controller +/wiki/images/thumb/4/4f/Spreadsheet_Controller.png/32px-Spreadsheet_Controller.png +Spreadsheet_Create +/wiki/images/thumb/c/cb/Spreadsheet_Create.png/32px-Spreadsheet_Create.png +Release_notes_0.17 +/wiki/images/thumb/6/62/Release017_Title.jpg/800px-Release017_Title.jpg +/wiki/images/3/3a/PartDesign_Body_tree.png +/wiki/images/thumb/e/e6/Addon_manager.png/300px-Addon_manager.png +/wiki/images/thumb/2/24/FC017_Sketcher_B-spline_01.png/300px-FC017_Sketcher_B-spline_01.png +/wiki/images/thumb/0/02/TechDraw_Workbench_Example.png/300px-TechDraw_Workbench_Example.png +/wiki/images/d/df/FC017_Navigation_Indicator_01.png +/wiki/images/2/28/FC017_Navigation_Indicator_02.png +/wiki/images/thumb/3/35/AboutFreeCAD_Credits.png/300px-AboutFreeCAD_Credits.png +/wiki/images/thumb/0/06/Arch_Rebar_preview.png/640px-Arch_Rebar_preview.png +/wiki/images/thumb/5/52/Arch_Door_preview.png/640px-Arch_Door_preview.png +/wiki/images/thumb/f/fa/Draft_WP_preview.png/640px-Draft_WP_preview.png +/wiki/images/thumb/5/5a/Draft_Label_Preview.png/640px-Draft_Label_Preview.png +/wiki/images/thumb/f/f0/Bridge-all.png/640px-Bridge-all.png +/wiki/images/thumb/4/49/Bridge-detail.png/640px-Bridge-detail.png +/wiki/images/thumb/8/80/PartDesign017-teaser-motor-core.png/800px-PartDesign017-teaser-motor-core.png +/wiki/images/2/24/FC017_Sketcher_B-spline_01.png +Civil_Engineering_Workbench +External_workbenches +/wiki/images/6/64/Assembly2_example.jpg +/wiki/images/f/f2/Drawing_Dimensioning_example.jpg +/wiki/images/thumb/9/9d/WF_wf.png/16px-WF_wf.png +/wiki/images/thumb/9/99/WF.png/640px-WF.png +WebTools_Workbench +/wiki/images/thumb/3/30/Arch_BimServer.png/32px-Arch_BimServer.png +/wiki/images/thumb/e/e3/Arch_Git.png/32px-Arch_Git.png +/wiki/images/thumb/f/f8/Web_Sketchfab.png/32px-Web_Sketchfab.png +Web_Sketchfab +/wiki/images/2/2d/Sketchfab_exporter.jpg +Arch_Git +/wiki/images/thumb/f/ff/Arch_CommitGit.png/16px-Arch_CommitGit.png +/wiki/images/0/01/Arch_Git_panel.jpg +Fcstd_file_format +/wiki/images/thumb/2/20/Project_utility_en.png/240px-Project_utility_en.png +File_Format_FCStd +ImageConv +Arch_BimServer +/wiki/images/thumb/3/30/Arch_BimServer.png/16px-Arch_BimServer.png +/wiki/images/7/7e/Arch_Bimserver_panel.jpg +Arch_Building +/wiki/images/thumb/2/29/Arch_Building.png/32px-Arch_Building.png +/wiki/images/thumb/2/29/Arch_Building.png/16px-Arch_Building.png +/wiki/images/thumb/d/d2/Arch_Add.png/16px-Arch_Add.png +/wiki/images/thumb/d/dc/Arch_Remove.png/16px-Arch_Remove.png +Arch_Remove +/wiki/images/thumb/d/dc/Arch_Remove.png/32px-Arch_Remove.png +/wiki/images/thumb/a/a3/Arch_Remove_example.jpg/600px-Arch_Remove_example.jpg +Arch_Wall +/wiki/images/thumb/a/a5/Arch_Wall.png/32px-Arch_Wall.png +/wiki/images/thumb/c/c7/Arch_Wall_example.jpg/780px-Arch_Wall_example.jpg +/wiki/images/thumb/a/a5/Arch_Wall.png/16px-Arch_Wall.png +/wiki/images/thumb/4/45/Arch_wall_snap.jpg/780px-Arch_wall_snap.jpg +Release_notes_0.18 +Arch_Component +/wiki/images/thumb/9/93/Arch_Component.png/32px-Arch_Component.png +/wiki/images/thumb/9/93/Arch_Component.png/16px-Arch_Component.png +Draft_Rotate +/wiki/images/thumb/5/5a/Draft_Rotate.png/32px-Draft_Rotate.png +/wiki/images/thumb/3/31/Draft_Rotate_example.jpg/400px-Draft_Rotate_example.jpg +/wiki/images/thumb/5/5a/Draft_Rotate.png/16px-Draft_Rotate.png +Draft_Move +/wiki/images/thumb/c/c5/Draft_Move.png/32px-Draft_Move.png +/wiki/images/thumb/0/04/Draft_Move_example.jpg/400px-Draft_Move_example.jpg +/wiki/images/thumb/c/c5/Draft_Move.png/16px-Draft_Move.png +/wiki/images/1/1d/Pref_Draft_Snapping.png +Arch_DAE +Importing_From_Sketchup +Arch_OBJ +Export_to_STL_or_OBJ +/wiki/images/thumb/1/13/Part_Cone.png/32px-Part_Cone.png +/wiki/images/0/0b/Mesh_Mesh_from_Shape.svg +/wiki/images/thumb/0/0f/Mesh_ExportMesh.png/32px-Mesh_ExportMesh.png +Mesh_MeshFromShape +/wiki/images/thumb/2/24/Mesh_MeshFromShape.png/32px-Mesh_MeshFromShape.png +/wiki/images/1/15/Mesh_Mesher_Standard.jpg +/wiki/images/7/70/Mesh_Mesher_Mefisto.jpg +/wiki/images/a/a7/Mesh_Mesher_Netgen.jpg +Import_from_STL_or_OBJ +/wiki/images/thumb/2/29/Mesh_RegularSolid.png/32px-Mesh_RegularSolid.png +/wiki/images/thumb/0/01/Mesh_HarmonizeNormals.png/32px-Mesh_HarmonizeNormals.png +/wiki/images/thumb/8/81/Mesh_FillInteractiveHole.png/32px-Mesh_FillInteractiveHole.png +/wiki/images/thumb/5/50/Part_ShapeFromMesh.png/32px-Part_ShapeFromMesh.png +Arch_Add +/wiki/images/thumb/d/d2/Arch_Add.png/32px-Arch_Add.png +/wiki/images/thumb/2/28/Arch_Add_example.jpg/640px-Arch_Add_example.jpg +Arch_Floor +/wiki/images/thumb/b/b9/Arch_Floor.png/32px-Arch_Floor.png +/wiki/images/thumb/b/b9/Arch_Floor.png/16px-Arch_Floor.png +Arch_Site +/wiki/images/thumb/9/9a/Arch_Site.png/32px-Arch_Site.png +/wiki/images/thumb/9/9a/Arch_Site.png/16px-Arch_Site.png +/wiki/images/b/b3/Arch_site_example_01.jpg +/wiki/images/1/14/Arch_site_example_02.jpg +/wiki/images/0/0b/Arch_site_example_03.jpg +/wiki/images/1/18/Freecad-solar-diagram.jpg +Arch_IFC +KicadStepUp_Workbench +Transportation_Workbench +Flamingo_Workbench +/wiki/images/8/85/FlamingoBlob.png +/wiki/images/9/9e/Flamingos_frame2.jpg +/wiki/images/0/06/Flamingos_pype2.jpg +/wiki/images/d/d2/Flamingos_utils.jpg +Manipulator_Workbench +/wiki/images/5/50/Manipulator-ico.png +/wiki/images/c/c2/Aligner-ico.png +/wiki/images/8/8b/Mover-ico.png +/wiki/images/e/ee/Caliper-ico.png +/wiki/images/5/5f/Help-btn.png +/wiki/images/0/0a/Manipulator-WB-%40Work.png +/wiki/images/6/60/Manipulator-WB-Aligner.gif +/wiki/images/b/b0/Manipulator-WB-Mover.gif +/wiki/images/f/f4/Manipulator-WB-Mover-with-App_Part%26Body.gif +/wiki/images/2/25/Manipulator-WB-Mover-with-External-Reference.gif +/wiki/images/1/14/Manipulator-WB-Measure-Radius.gif +/wiki/images/f/fe/Manipulator-WB-Measure-Angles.gif +/wiki/images/c/cf/Manipulator-WB-Dimension.gif +/wiki/images/5/5a/Manipulator-WB-Dimension-2.gif +/wiki/images/d/d2/Manipulator-WB-Parallel-Planes-Distance.gif +/wiki/images/b/be/Manipulator-WB-Assembly-Parts.gif +Path_DressupDragKnife +/wiki/images/4/43/Path_DressupTag.png +/wiki/images/thumb/f/f9/Path_Dressup.png/16px-Path_Dressup.png +Path_DressupRampEntry +Path_DressupTag +Path_DressupDogbone +Path_Simulator +/wiki/images/thumb/a/ab/Path_Simulator.png/32px-Path_Simulator.png +/wiki/images/f/f8/Path-Simulation.gif +/wiki/images/thumb/a/ab/Path_Simulator.png/16px-Path_Simulator.png +Path_Inspect +/wiki/images/thumb/a/a7/Path_Inspect_G-code.png/32px-Path_Inspect_G-code.png +/wiki/images/0/06/Path_inspector.jpg +/wiki/images/thumb/9/9f/Path_Inspect.png/16px-Path_Inspect.png +Path_ToolLibraryEdit +/wiki/images/thumb/1/19/Path_ToolLibraryEdit.png/32px-Path_ToolLibraryEdit.png +/wiki/images/d/d9/Path-Tooltable.png +/wiki/images/thumb/1/19/Path_ToolLibraryEdit.png/16px-Path_ToolLibraryEdit.png +/wiki/images/8/86/Path-ToolAdd.gif +Path_EditToolsTable +/wiki/images/thumb/a/a6/NoIconFound.png/32px-NoIconFound.png +Path_NewTool +/wiki/images/5/55/Path-EditTool-Dialog.PNG +Path_Post +/wiki/images/thumb/3/39/Path_PostProcess.png/32px-Path_PostProcess.png +Path_Job +/wiki/images/thumb/7/71/Path_Job.png/32px-Path_Job.png +/wiki/images/thumb/b/b6/Path-Job.png/16px-Path-Job.png +/wiki/images/3/3b/Job_1.jpg +/wiki/images/3/3b/Job_2.jpg +/wiki/images/4/40/Job_3.jpg +/wiki/images/e/e7/Job_4.jpg +/wiki/images/d/d2/Job_5.jpg +Path_Pocket_3D +/wiki/images/thumb/e/ed/Path_3DPocket.png/32px-Path_3DPocket.png +/wiki/images/thumb/a/a9/Path-3DPocket.png/16px-Path-3DPocket.png +Path_Drilling +/wiki/images/thumb/9/93/Path_Drilling.png/32px-Path_Drilling.png +Path_ProfileFace +/wiki/images/thumb/2/2e/Path_Profile_Face.png/32px-Path_Profile_Face.png +/wiki/images/6/62/Path_Profile_by_Faces.png +/wiki/images/thumb/a/a9/Path-Profile-Face.png/16px-Path-Profile-Face.png +Path_Pocket_Shape +/wiki/images/thumb/c/c2/Path_Pocket.png/32px-Path_Pocket.png +/wiki/images/a/a8/Path_Pocket_Shape.png +/wiki/images/thumb/c/c2/Path_Pocket.png/16px-Path_Pocket.png +Path_MillFace +/wiki/images/thumb/2/2e/Path-Face.png/32px-Path-Face.png +Path_Contour +/wiki/images/thumb/d/de/Path_Contour.png/32px-Path_Contour.png +/wiki/images/thumb/f/ff/PathContourToolExample.png/800px-PathContourToolExample.png +/wiki/images/thumb/d/de/Path_Contour.png/16px-Path_Contour.png +PartDesign_Point +/wiki/images/thumb/8/80/PartDesign_Point.png/32px-PartDesign_Point.png +/wiki/images/c/c4/DatumPoint.png +/wiki/images/thumb/8/80/PartDesign_Point.png/24px-PartDesign_Point.png +PartDesign_Line +/wiki/images/thumb/c/c8/PartDesign_Line.png/32px-PartDesign_Line.png +/wiki/images/e/e1/Datum_line.png +/wiki/images/thumb/c/c8/PartDesign_Line.png/24px-PartDesign_Line.png +PartDesign_Plane +/wiki/images/thumb/4/4a/PartDesign_Plane.png/32px-PartDesign_Plane.png +/wiki/images/5/5a/Datum_plane.png +/wiki/images/thumb/4/4a/PartDesign_Plane.png/24px-PartDesign_Plane.png +PartDesign_Thickness +/wiki/images/thumb/b/bd/PartDesign_Thickness.png/32px-PartDesign_Thickness.png +/wiki/images/thumb/b/bd/PartDesign_Thickness.png/24px-PartDesign_Thickness.png +/wiki/images/2/27/Braga-primoPad.png +/wiki/images/7/75/Braga-secondoschizzo.png +/wiki/images/b/b9/Braga-secondo_Pad.png +/wiki/images/7/71/Brga-spessore.png +Part_Thickness +/wiki/images/thumb/e/e7/Part_Thickness.png/32px-Part_Thickness.png +/wiki/images/thumb/e/e7/Part_Thickness.png/16px-Part_Thickness.png +/wiki/images/e/eb/ThicknessEsempio1.png +/wiki/images/5/5d/ThicknessEsempio2.png +/wiki/images/6/6c/ThicknessEsempio3.png +/wiki/images/9/9e/ThicknessEsempio4.png +Part_Offset +/wiki/images/thumb/9/9f/Part_Offset.png/32px-Part_Offset.png +/wiki/images/f/f7/PartOffset1_it.png +/wiki/images/4/4e/PartOffset2_it.png +PartDesign_AdditivePipe +/wiki/images/thumb/5/52/PartDesign_AdditivePipe.png/32px-PartDesign_AdditivePipe.png +/wiki/images/1/12/PartDesign_AdditivePipe_example.svg +/wiki/images/thumb/5/52/PartDesign_AdditivePipe.png/24px-PartDesign_AdditivePipe.png +PartDesign_AdditiveLoft +/wiki/images/thumb/5/55/PartDesign_AdditiveLoft.png/32px-PartDesign_AdditiveLoft.png +/wiki/images/d/db/PartDesign_AddLoft_example.png +/wiki/images/thumb/5/55/PartDesign_AdditiveLoft.png/24px-PartDesign_AdditiveLoft.png +PartDesign_CompPrimitiveAdditive +/wiki/images/thumb/d/dc/PartDesign_AdditiveBox.png/32px-PartDesign_AdditiveBox.png +/wiki/images/thumb/c/cd/PartDesign_AdditiveCone.png/32px-PartDesign_AdditiveCone.png +/wiki/images/thumb/8/80/PartDesign_AdditiveCylinder.png/32px-PartDesign_AdditiveCylinder.png +/wiki/images/thumb/e/eb/PartDesign_AdditiveEllipsoid.png/32px-PartDesign_AdditiveEllipsoid.png +/wiki/images/thumb/7/74/PartDesign_AdditivePrism.png/32px-PartDesign_AdditivePrism.png +/wiki/images/thumb/8/86/PartDesign_AdditiveSphere.png/32px-PartDesign_AdditiveSphere.png +/wiki/images/thumb/c/c1/PartDesign_AdditiveTorus.png/32px-PartDesign_AdditiveTorus.png +/wiki/images/thumb/3/3c/PartDesign_AdditiveWedge.png/32px-PartDesign_AdditiveWedge.png +PartDesign_AdditiveWedge +/wiki/images/thumb/4/4a/PartDesign_AdditiveWedge_example.png/200px-PartDesign_AdditiveWedge_example.png +/wiki/images/thumb/3/3c/PartDesign_AdditiveWedge.png/24px-PartDesign_AdditiveWedge.png +PartDesign_AdditiveTorus +/wiki/images/thumb/4/45/PartDesign_AdditiveTorus_example.png/200px-PartDesign_AdditiveTorus_example.png +/wiki/images/thumb/c/c1/PartDesign_AdditiveTorus.png/24px-PartDesign_AdditiveTorus.png +PartDesign_AdditiveSphere +/wiki/images/thumb/b/be/PartDesign_AdditiveSphere_example.png/200px-PartDesign_AdditiveSphere_example.png +/wiki/images/thumb/8/86/PartDesign_AdditiveSphere.png/24px-PartDesign_AdditiveSphere.png +PartDesign_AdditivePrism +/wiki/images/thumb/3/31/PartDesign_AdditivePrism_example.png/200px-PartDesign_AdditivePrism_example.png +/wiki/images/thumb/7/74/PartDesign_AdditivePrism.png/24px-PartDesign_AdditivePrism.png +PartDesign_AdditiveEllipsoid +/wiki/images/thumb/4/43/PartDesign_AdditiveEllipsoid_example.png/200px-PartDesign_AdditiveEllipsoid_example.png +/wiki/images/thumb/e/eb/PartDesign_AdditiveEllipsoid.png/24px-PartDesign_AdditiveEllipsoid.png +PartDesign_AdditiveCylinder +/wiki/images/thumb/1/1f/PartDesign_AdditiveCylinder_example.png/200px-PartDesign_AdditiveCylinder_example.png +/wiki/images/thumb/8/80/PartDesign_AdditiveCylinder.png/24px-PartDesign_AdditiveCylinder.png +PartDesign_AdditiveCone +/wiki/images/thumb/e/ee/PartDesign_AdditiveCone_example.png/200px-PartDesign_AdditiveCone_example.png +/wiki/images/thumb/c/cd/PartDesign_AdditiveCone.png/24px-PartDesign_AdditiveCone.png +PartDesign_AdditiveBox +/wiki/images/thumb/2/2d/PartDesign_AdditiveBox_example.png/200px-PartDesign_AdditiveBox_example.png +/wiki/images/thumb/d/dc/PartDesign_AdditiveBox.png/24px-PartDesign_AdditiveBox.png +PartDesign_CompPrimitiveSubtractive +/wiki/images/c/c0/PartDesign_SubtractiveBox.png +/wiki/images/a/a1/PartDesign_SubtractiveCone.png +/wiki/images/7/7f/PartDesign_SubtractiveCylinder.png +/wiki/images/c/cc/PartDesign_SubtractiveEllipsoid.png +/wiki/images/a/ae/PartDesign_SubtractivePrism.png +/wiki/images/e/e5/PartDesign_SubtractiveSphere.png +/wiki/images/4/4f/PartDesign_SubtractiveTorus.png +/wiki/images/4/44/PartDesign_SubtractiveWedge.png +PartDesign_SubtractiveWedge +/wiki/images/7/73/PartDesign_SubtractiveWedge_example.svg +/wiki/images/thumb/4/44/PartDesign_SubtractiveWedge.png/24px-PartDesign_SubtractiveWedge.png +PartDesign_SubtractiveTorus +/wiki/images/b/ba/PartDesign_SubtractiveTorus_example.svg +/wiki/images/thumb/4/4f/PartDesign_SubtractiveTorus.png/24px-PartDesign_SubtractiveTorus.png +PartDesign_SubtractiveSphere +/wiki/images/0/00/PartDesign_SubtractiveSphere_example.svg +/wiki/images/thumb/e/e5/PartDesign_SubtractiveSphere.png/24px-PartDesign_SubtractiveSphere.png +PartDesign_SubtractivePrism +/wiki/images/4/4b/PartDesign_SubtractivePrism_example.svg +PartDesign_SubtractiveEllipsoid +/wiki/images/c/c2/PartDesign_SubtractiveEllipsoid_example.svg +/wiki/images/thumb/c/cc/PartDesign_SubtractiveEllipsoid.png/24px-PartDesign_SubtractiveEllipsoid.png +PartDesign_SubtractiveCylinder +/wiki/images/8/83/PartDesign_SubtractiveCylinder_example.svg +/wiki/images/thumb/7/7f/PartDesign_SubtractiveCylinder.png/24px-PartDesign_SubtractiveCylinder.png +PartDesign_SubtractiveCone +/wiki/images/3/3c/PartDesign_SubtractiveCone_example.png +/wiki/images/thumb/a/a1/PartDesign_SubtractiveCone.png/24px-PartDesign_SubtractiveCone.png +PartDesign_SubtractiveBox +/wiki/images/b/b5/PartDesign_SubtractiveBox_example.png +/wiki/images/thumb/c/c0/PartDesign_SubtractiveBox.png/24px-PartDesign_SubtractiveBox.png +PartDesign_Body +/wiki/images/thumb/5/5e/PartDesign_Body.png/32px-PartDesign_Body.png +/wiki/images/2/23/PartDesign_Body_example.png +/wiki/images/d/dc/PartDesign_Body_tree-01.png +/wiki/images/f/f6/PartDesign_Body_tree-02.png +/wiki/images/e/e9/PartDesign_Body_tree-03.png +/wiki/images/3/31/PartDesign_Body_tree-04.png +/wiki/images/thumb/4/4c/PartDesign_MoveTip.png/24px-PartDesign_MoveTip.png +/wiki/images/thumb/5/5e/PartDesign_Body.png/24px-PartDesign_Body.png +PartDesign_MoveTip +/wiki/images/thumb/4/4c/PartDesign_MoveTip.png/32px-PartDesign_MoveTip.png +PartDesign_MoveFeatureInTree +/wiki/images/d/d7/PD_move_feature0.png +/wiki/images/b/bd/Hole_Pad002.png +/wiki/images/3/39/PD_move_feature2.png +PartDesign_MoveFeature +Std_Group +/wiki/images/thumb/8/83/Std_Group.png/32px-Std_Group.png +/wiki/images/thumb/b/b1/Group_with_objects.png/300px-Group_with_objects.png +Arch_tutorial +/wiki/images/0/08/Arch_tutorial_00.jpg +/wiki/images/4/43/Arch_tutorial_01.jpg +/wiki/images/b/bd/Arch_tutorial_02.jpg +/wiki/images/5/58/Arch_tutorial_03.jpg +/wiki/images/2/2f/Arch_tutorial_04.jpg +/wiki/images/4/44/Arch_tutorial_05.jpg +/wiki/images/9/9c/Arch_tutorial_06.jpg +/wiki/images/8/84/Arch_tutorial_07.jpg +/wiki/images/9/93/Arch_tutorial_08.jpg +/wiki/images/3/31/Arch_tutorial_09.jpg +/wiki/images/0/04/Arch_tutorial_10.jpg +/wiki/images/1/1a/Arch_tutorial_11.jpg +/wiki/images/f/f9/Arch_tutorial_12.jpg +/wiki/images/d/d3/Arch_tutorial_13.jpg +/wiki/images/5/5e/Arch_tutorial_14.jpg +/wiki/images/f/f4/Arch_tutorial_15.jpg +/wiki/images/1/15/Arch_tutorial_16.jpg +/wiki/images/2/2c/Arch_tutorial_17.jpg +/wiki/images/b/b4/Arch_tutorial_18.jpg +/wiki/images/9/9c/Arch_tutorial_19.jpg +/wiki/images/c/cf/Arch_tutorial_20.jpg +/wiki/images/7/7c/Arch_tutorial_21.jpg +/wiki/images/5/52/Arch_tutorial_22.jpg +/wiki/images/0/0a/Arch_tutorial_23.jpg +/wiki/images/5/5b/Arch_tutorial_24.jpg +/wiki/images/9/94/Arch_tutorial_25.jpg +/wiki/images/a/a3/Arch_tutorial_26.jpg +/wiki/images/d/d4/Arch_tutorial_27.jpg +/wiki/images/7/77/Arch_tutorial_28.jpg +/wiki/images/d/dc/Arch_tutorial_29.jpg +/wiki/images/6/6a/Arch_tutorial_30.jpg +/wiki/images/e/e7/Arch_tutorial_31.jpg +/wiki/images/9/93/Arch_tutorial_32.jpg +/wiki/images/c/c3/Arch_tutorial_33.jpg +/wiki/images/7/72/Arch_tutorial_34.jpg +/wiki/images/f/f3/Arch_tutorial_35.jpg +/wiki/images/7/74/Arch_tutorial_36.jpg +/wiki/images/d/dc/Arch_tutorial_37.jpg +/wiki/images/e/e0/Arch_tutorial_38.jpg +/wiki/images/1/19/Arch_tutorial_39.jpg +/wiki/images/9/93/Arch_tutorial_40.jpg +/wiki/images/2/2b/Arch_tutorial_41.jpg +/wiki/images/1/12/Arch_tutorial_42.jpg +/wiki/images/c/c3/Arch_tutorial_43.jpg +/wiki/images/3/35/Arch_tutorial_44.jpg +/wiki/images/a/a3/Arch_tutorial_45.jpg +/wiki/images/2/2b/Arch_tutorial_47.jpg +/wiki/images/6/60/Arch_tutorial_48.jpg +/wiki/images/0/00/Arch_tutorial_49.jpg +/wiki/images/f/fc/Arch_tutorial_50.jpg +/wiki/images/c/ca/Arch_tutorial_51.jpg +/wiki/images/2/20/Arch_tutorial_52.jpg +/wiki/images/d/d4/Arch_tutorial_54.jpg +Arch_Survey +/wiki/images/thumb/1/14/Arch_Survey.png/32px-Arch_Survey.png +/wiki/images/thumb/2/2c/Arch_Survey_example.jpg/640px-Arch_Survey_example.jpg +/wiki/images/thumb/1/14/Arch_Survey.png/16px-Arch_Survey.png +/wiki/images/d/d6/Arch_Survey_spreadsheet.jpg +Draft_Drawing +/wiki/images/1/11/Draft_Drawing.png +/wiki/images/thumb/3/3f/Draft_drawing_example.jpg/640px-Draft_drawing_example.jpg +/wiki/images/thumb/1/11/Draft_Drawing.png/16px-Draft_Drawing.png +Draft_Text +/wiki/images/thumb/9/9f/Draft_Text.png/32px-Draft_Text.png +/wiki/images/thumb/4/4f/Draft_Text_example.jpg/400px-Draft_Text_example.jpg +/wiki/images/thumb/9/9f/Draft_Text.png/16px-Draft_Text.png +Draft_Dimension +/wiki/images/thumb/b/b0/Draft_Dimension.png/32px-Draft_Dimension.png +/wiki/images/thumb/8/8f/Screenshot_Draft_Dimension.jpg/400px-Screenshot_Draft_Dimension.jpg +/wiki/images/thumb/b/b0/Draft_Dimension.png/16px-Draft_Dimension.png +Draft_FlipDimension +/wiki/images/thumb/f/fe/Draft_FlipDimension.png/32px-Draft_FlipDimension.png +/wiki/images/thumb/f/fe/Draft_FlipDimension.png/16px-Draft_FlipDimension.png +Drawing_View +/wiki/images/thumb/0/03/Drawing_View.png/32px-Drawing_View.png +/wiki/images/thumb/2/2e/Drawing_Views.png/500px-Drawing_Views.png +/wiki/images/4/4d/Drawing_View_Properties.png +/wiki/images/thumb/2/2d/Drawing_View_Iso.png/150px-Drawing_View_Iso.png +/wiki/images/thumb/3/35/Drawing_View_Iso_SmoothLines.png/150px-Drawing_View_Iso_SmoothLines.png +Drawing_Landscape_A3 +/wiki/images/thumb/2/27/Drawing_Landscape_A3.png/32px-Drawing_Landscape_A3.png +/wiki/images/thumb/c/cc/View-refresh.png/16px-View-refresh.png +/wiki/images/thumb/0/01/Drawing_Page.png/500px-Drawing_Page.png +Drawing_templates +/wiki/images/0/07/XY_Working_v2.svg +/wiki/images/2/24/XY_Title_v2.svg +/wiki/images/2/21/A3_Classic.svg +/wiki/images/a/a0/A3_Clean.svg +/wiki/images/0/04/A3_Modern.svg +/wiki/images/8/8a/A3_Showcase.svg +/wiki/images/f/fa/A3_Landscape_english.svg +/wiki/images/2/28/A4_Landscape_english.svg +/wiki/images/a/a7/A4_Portrait_1_english.svg +/wiki/images/4/40/US_Letter_landscape.svg +/wiki/images/d/db/US_Letter_portrait.svg +/wiki/images/e/e6/US_Letter_ds_Landscape.svg +/wiki/images/9/93/US_Legal_ds_Landscape.svg +/wiki/images/f/f6/US_Ledger_ds_Landscape.svg +Misc_templates +/wiki/images/2/2c/A3_Landscape_US_Text_Complet_With_Convention_EU.svg +/wiki/images/e/e2/A3_Landscape_US_Text_Complet_With_Convention_US.svg +/wiki/images/c/c3/A3_Landscape_US_Text_Complet_Without_Convention.svg +/wiki/images/1/15/A4_Landscape_US_Text_Complet_With_Convention_EU.svg +/wiki/images/0/06/A4_Portrait_US_Text_Complet_With_Convention_EU.svg +/wiki/images/1/11/Cartouche_01_Convention_EU.svg +/wiki/images/9/9a/Cartouche_01_Convention_US.svg +/wiki/images/9/96/Cartouche_01_US.svg +/wiki/images/4/43/Cartouche_02_US.svg +/wiki/images/7/73/Cartouche_03_US.svg +/wiki/images/e/e0/Cartouche_04_US.svg +/wiki/images/5/56/CompassRose.svg +Arch_templates +/wiki/images/f/fa/Arch_A_Landscape.svg +/wiki/images/a/aa/Arch_A_Portrait.svg +/wiki/images/3/3a/Arch_B_Landscape.svg +/wiki/images/e/e9/Arch_B_Portrait.svg +/wiki/images/2/2d/Arch_C_Landscape.svg +/wiki/images/6/63/Arch_C_Portrait.svg +/wiki/images/b/b9/Arch_D_Landscape.svg +/wiki/images/d/da/Arch_D_Portrait.svg +/wiki/images/f/f5/Arch_E_Landscape.svg +/wiki/images/c/c7/Arch_E_Portrait.svg +/wiki/images/e/e1/Arch_E1_Landscape.svg +/wiki/images/c/ca/Arch_E1_Portrait.svg +/wiki/images/0/05/Arch_E2_Landscape.svg +/wiki/images/8/89/Arch_E2_Portrait.svg +/wiki/images/c/ca/Arch_E3_Landscape.svg +/wiki/images/5/54/Arch_E3_Portrait.svg +ANSI_templates +/wiki/images/e/ef/ANSI_A_Landscape.svg +/wiki/images/e/eb/ANSI_A_Portrait.svg +/wiki/images/b/b8/ANSI_B_Landscape.svg +/wiki/images/9/90/ANSI_B_Portrait.svg +/wiki/images/a/a7/ANSI_C_Landscape.svg +/wiki/images/c/c8/ANSI_C_Portrait.svg +/wiki/images/8/84/ANSI_D_Landscape.svg +/wiki/images/d/dc/ANSI_D_Portrait.svg +/wiki/images/6/67/ANSI_E_Landscape.svg +/wiki/images/3/39/ANSI_E_Portrait.svg +Svg_Namespace +/wiki/images/thumb/9/9c/Svg_Namespace_01.png/300px-Svg_Namespace_01.png +/wiki/images/thumb/4/40/Svg_Namespace_02.png/300px-Svg_Namespace_02.png +Drawing_Template_HowTo +/wiki/images/thumb/5/5c/Inkscape_Template_tut_1.png/780px-Inkscape_Template_tut_1.png +/wiki/images/b/b5/Inkscape_Template_tut_2.png +/wiki/images/e/eb/Inkscape_Template_tut_3.png +/wiki/images/a/ae/Inkscape_Template_tut_4.png +/wiki/images/8/87/Inkscape_Template_tut_5.png +/wiki/images/3/3a/Inkscape_Template_tut_6.png +/wiki/images/f/fe/Kate1.png +/wiki/images/0/0b/Kate2.png +/wiki/images/6/6b/Kate2a.png +/wiki/images/4/43/Kate3.png +/wiki/images/d/de/Kate4.png +/wiki/images/9/9b/Kate5.png +/wiki/images/f/fb/TemplateExample.svg +Draft_Shape2DView +/wiki/images/thumb/9/9f/Draft_Shape2DView.png/32px-Draft_Shape2DView.png +/wiki/images/d/da/Draft_Shape2DView_example.jpg +/wiki/images/thumb/9/9f/Draft_Shape2DView.png/16px-Draft_Shape2DView.png +Raytracing_Workbench +/wiki/images/thumb/a/a4/Raytracing_example.jpg/1024px-Raytracing_example.jpg +/wiki/images/thumb/5/59/Raytracing_New.png/32px-Raytracing_New.png +/wiki/images/thumb/0/05/Raytracing_Lux.png/32px-Raytracing_Lux.png +/wiki/images/thumb/9/9e/Raytracing_InsertPart.png/32px-Raytracing_InsertPart.png +/wiki/images/thumb/9/92/Raytracing_ResetCamera.png/32px-Raytracing_ResetCamera.png +/wiki/images/thumb/3/38/Raytracing_ExportProject.png/32px-Raytracing_ExportProject.png +/wiki/images/thumb/c/c5/Raytracing_Render.png/32px-Raytracing_Render.png +/wiki/images/thumb/0/00/Raytracing_Export.png/32px-Raytracing_Export.png +/wiki/images/thumb/d/d0/Raytracing_Camera.png/32px-Raytracing_Camera.png +/wiki/images/thumb/c/c7/Raytracing_Part.png/32px-Raytracing_Part.png +/wiki/images/8/80/FreeCAD_Raytracing.jpg +/wiki/images/1/12/Povray.jpg +/wiki/images/thumb/2/2e/Scharniergreifer_render.jpg/1024px-Scharniergreifer_render.jpg +Raytracing_tutorial +/wiki/images/thumb/5/56/Raytracing_tutorial_result.png/480px-Raytracing_tutorial_result.png +Render_project +/wiki/images/d/d7/LuxRenderExecPath.png +/wiki/images/7/7d/RenderTaskView.png +/wiki/images/7/70/Example.png +/wiki/images/3/39/RenderButtons.png +/wiki/images/0/02/Loading.png +/wiki/images/8/86/SceneOutput.png +/wiki/images/e/ed/UnbiasedRendering.png +/wiki/images/b/ba/MaterialSelection.png +/wiki/images/5/5f/MaterialDragNDrop.png +/wiki/images/4/44/MaterialProperties.png +/wiki/images/9/9c/MaterialListView.png +Raytracing_Preferences +/wiki/images/e/e5/Preference_Raytracing_Tab_01.png +Raytracing_Part +Raytracing_Camera +Std_PerspectiveCamera +/wiki/images/thumb/b/b8/Std_PerspectiveCamera.png/32px-Std_PerspectiveCamera.png +/wiki/images/4/47/Orthographic_Perspective.gif +/wiki/images/c/c3/View-perspective.svg +Std_OrthographicCamera +/wiki/images/thumb/e/e4/Std_OrthographicCamera.png/32px-Std_OrthographicCamera.png +/wiki/images/thumb/6/63/View-isometric.png/24px-View-isometric.png +Std_View_Menu +/wiki/images/thumb/d/d1/View-perspective.png/24px-View-perspective.png +/wiki/images/thumb/7/7b/View-zoom-all.png/24px-View-zoom-all.png +/wiki/images/thumb/b/b2/View-zoom-selection.png/24px-View-zoom-selection.png +/wiki/images/thumb/0/05/View-axonometric.png/24px-View-axonometric.png +/wiki/images/thumb/9/98/View-front.png/24px-View-front.png +/wiki/images/thumb/a/a2/View-top.png/24px-View-top.png +/wiki/images/thumb/5/50/View-right.png/24px-View-right.png +/wiki/images/thumb/2/27/View-rear.png/24px-View-rear.png +/wiki/images/thumb/f/fc/View-bottom.png/24px-View-bottom.png +/wiki/images/thumb/6/6d/View-left.png/24px-View-left.png +/wiki/images/thumb/d/dc/Std_RotateLeft.png/24px-Std_RotateLeft.png +/wiki/images/thumb/d/df/Std_RotateRight.png/24px-Std_RotateRight.png +/wiki/images/thumb/9/99/DrawStyleAsIs.png/24px-DrawStyleAsIs.png +/wiki/images/thumb/0/0d/DrawStyleFlatLines.png/24px-DrawStyleFlatLines.png +/wiki/images/thumb/f/ff/DrawStyleShaded.png/24px-DrawStyleShaded.png +/wiki/images/thumb/d/df/DrawStyleWireFrame.png/24px-DrawStyleWireFrame.png +/wiki/images/thumb/d/d3/DrawStylePoints.png/24px-DrawStylePoints.png +/wiki/images/thumb/d/d5/Std_Tool7.png/24px-Std_Tool7.png +/wiki/images/thumb/9/99/Std_Tool6.png/24px-Std_Tool6.png +/wiki/images/thumb/6/6f/Std_Tool8.png/24px-Std_Tool8.png +/wiki/images/thumb/b/b2/View-zoom-in.png/24px-View-zoom-in.png +/wiki/images/thumb/4/47/View-zoom-out.png/24px-View-zoom-out.png +/wiki/images/thumb/1/15/View-zoom-border.png/24px-View-zoom-border.png +/wiki/images/thumb/9/9d/View-unselectable.png/24px-View-unselectable.png +/wiki/images/thumb/d/de/Part_Measure_Toggle_All.png/24px-Part_Measure_Toggle_All.png +/wiki/images/thumb/e/e6/Part_Measure_Clear_All.png/24px-Part_Measure_Clear_All.png +/wiki/images/thumb/f/ff/Measure.png/24px-Measure.png +/wiki/images/thumb/3/32/Arch.png/24px-Arch.png +/wiki/images/thumb/d/d5/Workbench_Assembly.png/24px-Workbench_Assembly.png +/wiki/images/thumb/b/bc/Workbench_Complete.png/24px-Workbench_Complete.png +/wiki/images/thumb/1/16/Workbench_Draft.png/24px-Workbench_Draft.png +/wiki/images/thumb/8/85/Workbench_Drawing.png/24px-Workbench_Drawing.png +/wiki/images/thumb/c/c5/Workbench_Mesh.png/24px-Workbench_Mesh.png +/wiki/images/thumb/e/e2/Workbench_Image.png/24px-Workbench_Image.png +/wiki/images/thumb/c/c7/Freecad.png/24px-Freecad.png +/wiki/images/thumb/b/b2/Workbench_OpenSCAD.png/24px-Workbench_OpenSCAD.png +/wiki/images/thumb/c/c7/Workbench_Part.png/24px-Workbench_Part.png +/wiki/images/thumb/8/89/Workbench_PartDesign.png/24px-Workbench_PartDesign.png +/wiki/images/thumb/f/f6/Plot_Save.png/24px-Plot_Save.png +/wiki/images/thumb/b/bb/Raytracing.png/24px-Raytracing.png +/wiki/images/thumb/d/d4/Workbench_Robot.png/24px-Workbench_Robot.png +/wiki/images/thumb/a/a1/FreeCAD-Ship-Ico.png/24px-FreeCAD-Ship-Ico.png +/wiki/images/thumb/e/e4/Workbench_Sketcher.png/24px-Workbench_Sketcher.png +/wiki/images/thumb/c/cb/Spreadsheet_Create.png/24px-Spreadsheet_Create.png +/wiki/images/thumb/c/cd/Workbench_Start.png/24px-Workbench_Start.png +/wiki/images/thumb/1/13/Std_Test_framework.png/24px-Std_Test_framework.png +/wiki/images/thumb/d/d9/Workbench_Web.png/24px-Workbench_Web.png +Std_PythonConsole +/wiki/images/7/79/Std_PythonConsole.png +Std_Panels +/wiki/images/0/0c/Std_Panels.png +Std_Workbench +/wiki/images/thumb/c/ca/Std_Workbench.png/32px-Std_Workbench.png +Std_MeasureDistance +/wiki/images/thumb/a/a5/Std_MeasureDistance.png/32px-Std_MeasureDistance.png +Std_Measure_Menu +/wiki/images/thumb/c/c5/Std_MeasureLinear.png/32px-Std_MeasureLinear.png +/wiki/images/thumb/c/c8/Std_MeasureAngular.png/32px-Std_MeasureAngular.png +/wiki/images/thumb/9/99/Std_MeasureClearAll.png/32px-Std_MeasureClearAll.png +/wiki/images/thumb/0/0b/Std_MeasureToggleAll.png/32px-Std_MeasureToggleAll.png +/wiki/images/thumb/3/32/Std_MeasureToggle3D.png/32px-Std_MeasureToggle3D.png +/wiki/images/thumb/d/d6/Std_MeasureToggleDelta.png/32px-Std_MeasureToggleDelta.png +Std_MeasureToggleDelta +Std_MeasureToggle3D +Std_MeasureToggleAll +/wiki/images/d/d3/MeasureLinear3DandDelta1.PNG +Std_MeasureClearAll +Std_MeasureAngular +/wiki/images/f/f7/MeasureAngular1.PNG +Std_MeasureLinear +/wiki/images/e/ef/MeasureLinear3D1.png +/wiki/images/b/be/MeasureLinearDelta1.PNG +Std_SetAppearance +/wiki/images/thumb/4/40/Std_SetAppearance.png/32px-Std_SetAppearance.png +Std_SetColors +/wiki/images/c/c8/Std_SetColors1_it.png +/wiki/images/f/f1/Std_SetColors2_it.png +Std_ToggleVisibility +/wiki/images/thumb/3/34/Std_ToggleVisibility.png/32px-Std_ToggleVisibility.png +Std_ClippingPlane +/wiki/images/d/df/Std_ClippingPlane.png +/wiki/images/2/27/ClippingPlane1_it.png +/wiki/images/d/df/ClippingPlane2_it.png +/wiki/images/thumb/b/b3/PianoTaglio1.png/512px-PianoTaglio1.png +/wiki/images/thumb/b/b8/PianoTaglio2.png/512px-PianoTaglio2.png +/wiki/images/thumb/3/31/PianoTaglio3.png/512px-PianoTaglio3.png +/wiki/images/thumb/f/f2/PianoTaglio4.png/512px-PianoTaglio4.png +/wiki/images/thumb/1/13/PianoTaglio5.png/512px-PianoTaglio5.png +/wiki/images/f/ff/PianoTaglio6.png +Std_ViewDockUndockFullscreen +/wiki/images/thumb/a/a0/Std_ViewDockUndockFullscreen.png/32px-Std_ViewDockUndockFullscreen.png +Std_ViewBoxZoom +/wiki/images/thumb/8/8e/Std_ViewBoxZoom.png/32px-Std_ViewBoxZoom.png +Std_ViewZoom +/wiki/images/thumb/0/00/Std_ViewZoom.png/32px-Std_ViewZoom.png +Std_ViewIvIssueCamPos +/wiki/images/6/6c/Std_ViewIvIssueCamPos.png +/wiki/images/1/13/CameraPosition1_it.png +Std_ViewIvStereo +/wiki/images/thumb/e/e5/Std_ViewIvStereo.png/32px-Std_ViewIvStereo.png +Std_FreezeViews +/wiki/images/thumb/5/5e/Std_FreezeViews.png/32px-Std_FreezeViews.png +Std_RotateRight +/wiki/images/thumb/d/df/Std_RotateRight.png/32px-Std_RotateRight.png +Std_RotateLeft +/wiki/images/thumb/d/dc/Std_RotateLeft.png/32px-Std_RotateLeft.png +Std_ViewFitSelection +/wiki/images/thumb/6/60/Std_ViewFitSelection.png/32px-Std_ViewFitSelection.png +Std_ViewFitAll +/wiki/images/thumb/0/0e/Std_ViewFitAll.png/32px-Std_ViewFitAll.png +Std_ViewCreate +/wiki/images/thumb/8/85/Std_ViewCreate.png/32px-Std_ViewCreate.png +Raytracing_Export +Raytracing_Render +Raytracing_ExportProject +Raytracing_ResetCamera +Raytracing_InsertPart +Raytracing_Lux +Raytracing_New +Draft_DelPoint +/wiki/images/thumb/1/18/Draft_DelPoint.png/32px-Draft_DelPoint.png +/wiki/images/thumb/1/18/Draft_DelPoint.png/16px-Draft_DelPoint.png +/wiki/images/thumb/5/51/Draft_Edit.png/12px-Draft_Edit.png +Draft_BSpline +/wiki/images/thumb/a/af/Draft_BSpline.png/32px-Draft_BSpline.png +/wiki/images/thumb/a/a0/Draft_bspline_example.jpg/400px-Draft_bspline_example.jpg +/wiki/images/thumb/a/af/Draft_BSpline.png/16px-Draft_BSpline.png +/wiki/images/thumb/c/c1/Draft_FinishLine.png/12px-Draft_FinishLine.png +/wiki/images/thumb/d/dc/Draft_CloseLine.png/12px-Draft_CloseLine.png +/wiki/images/thumb/8/86/Draft_Wipe.png/12px-Draft_Wipe.png +Draft_CloseLine +/wiki/images/thumb/d/dc/Draft_CloseLine.png/32px-Draft_CloseLine.png +/wiki/images/thumb/d/dc/Draft_CloseLine.png/16px-Draft_CloseLine.png +Draft_FinishLine +/wiki/images/thumb/c/c1/Draft_FinishLine.png/32px-Draft_FinishLine.png +/wiki/images/thumb/c/c1/Draft_FinishLine.png/16px-Draft_FinishLine.png +Draft_AddPoint +/wiki/images/thumb/9/9e/Draft_AddPoint.png/32px-Draft_AddPoint.png +/wiki/images/thumb/9/9e/Draft_AddPoint.png/16px-Draft_AddPoint.png +Draft_Edit +/wiki/images/thumb/5/51/Draft_Edit.png/32px-Draft_Edit.png +/wiki/images/thumb/9/9e/Draft_edit_example.jpg/400px-Draft_edit_example.jpg +/wiki/images/thumb/5/51/Draft_Edit.png/16px-Draft_Edit.png +/wiki/images/thumb/9/9e/Draft_AddPoint.png/12px-Draft_AddPoint.png +/wiki/images/thumb/1/18/Draft_DelPoint.png/12px-Draft_DelPoint.png +Draft_Circle +/wiki/images/thumb/1/10/Draft_Circle.png/32px-Draft_Circle.png +/wiki/images/thumb/4/4b/Draft_Circle_example.jpg/400px-Draft_Circle_example.jpg +/wiki/images/thumb/1/10/Draft_Circle.png/16px-Draft_Circle.png +Draft_Pattern +/wiki/images/8/8c/DraftPatternSample.png +Draft_Polygon +/wiki/images/thumb/8/8e/Draft_Polygon.png/32px-Draft_Polygon.png +/wiki/images/thumb/5/5f/Draft_polygon_example.jpg/400px-Draft_polygon_example.jpg +/wiki/images/thumb/8/8e/Draft_Polygon.png/16px-Draft_Polygon.png +Draft_Ellipse +/wiki/images/thumb/1/13/Draft_Ellipse.png/32px-Draft_Ellipse.png +/wiki/images/thumb/c/c0/Draft_ellipse_example.jpg/400px-Draft_ellipse_example.jpg +/wiki/images/thumb/1/13/Draft_Ellipse.png/16px-Draft_Ellipse.png +Draft_Arc +/wiki/images/thumb/a/a8/Draft_Arc.png/32px-Draft_Arc.png +/wiki/images/thumb/b/ba/Draft_Arc_example.jpg/400px-Draft_Arc_example.jpg +/wiki/images/thumb/a/a8/Draft_Arc.png/16px-Draft_Arc.png +Draft_Offset +/wiki/images/thumb/e/eb/Draft_Offset.png/32px-Draft_Offset.png +/wiki/images/thumb/2/24/Draft_Offset_example.jpg/400px-Draft_Offset_example.jpg +/wiki/images/thumb/e/eb/Draft_Offset.png/16px-Draft_Offset.png +Draft_Draft2Sketch +/wiki/images/thumb/b/b2/Draft_Draft2Sketch.png/32px-Draft_Draft2Sketch.png +/wiki/images/thumb/9/98/Draft_Draft2Sketch_example.jpg/480px-Draft_Draft2Sketch_example.jpg +/wiki/images/thumb/b/b2/Draft_Draft2Sketch.png/16px-Draft_Draft2Sketch.png +Draft_ToggleDisplayMode +/wiki/images/thumb/0/00/Draft_ToggleDisplayMode.png/32px-Draft_ToggleDisplayMode.png +/wiki/images/thumb/0/00/Draft_ToggleDisplayMode.png/16px-Draft_ToggleDisplayMode.png +Draft_Clone +/wiki/images/thumb/3/39/Draft_Clone.png/32px-Draft_Clone.png +/wiki/images/thumb/f/fe/Draft_Clone_example.jpg/400px-Draft_Clone_example.jpg +/wiki/images/thumb/3/39/Draft_Clone.png/16px-Draft_Clone.png +Draft_Trimex +/wiki/images/thumb/e/e7/Draft_Trimex.png/32px-Draft_Trimex.png +/wiki/images/thumb/a/ac/Draft_trimex_example.jpg/400px-Draft_trimex_example.jpg +/wiki/images/thumb/e/e7/Draft_Trimex.png/16px-Draft_Trimex.png +Draft_Scale +/wiki/images/thumb/c/c9/Draft_Scale.png/32px-Draft_Scale.png +/wiki/images/thumb/a/ad/Draft_Scale_example.jpg/400px-Draft_Scale_example.jpg +/wiki/images/thumb/c/c9/Draft_Scale.png/16px-Draft_Scale.png +Draft_DXF +/wiki/images/4/4a/Screenshot_qcad.jpg +Draft_mapping_files +Draft_Preferences +/wiki/images/e/e6/Preference_Draft_Tab_01.png +/wiki/images/7/79/Preference_Draft_Tab_02.png +/wiki/images/d/dd/Preference_Draft_Tab_03.png +/wiki/images/c/cb/Preference_Draft_Tab_04.png +Dxf_Importer_Install +/wiki/images/thumb/2/2d/Dxf_Importer_Install_01b.png/640px-Dxf_Importer_Install_01b.png +/wiki/images/5/56/Dxf_Importer_Install_01.png +/wiki/images/c/c2/Dxf_Importer_Install_02.png +/wiki/images/4/49/Dxf_Importer_Install_03.png +/wiki/images/2/2f/Dxf_Importer_Install_04.png +/wiki/images/thumb/b/bb/Dxf_Importer_Install_05b.png/640px-Dxf_Importer_Install_05b.png +/wiki/images/4/4d/Dxf_Importer_Install_05.png +/wiki/images/e/ea/Dxf_Importer_Install_06.png +/wiki/images/d/dc/Dxf_Importer_Install_07.png +/wiki/images/0/0c/Dxf_Importer_Install_08.png +/wiki/images/8/8c/Dxf_Importer_Install_09.png +/wiki/images/f/f1/Dxf_Importer_Install_15.png +/wiki/images/d/da/Dxf_Importer_Install_10.png +/wiki/images/c/c3/Dxf_Importer_Install_11.png +/wiki/images/7/72/Dxf_Importer_Install_12.png +/wiki/images/1/19/Dxf_Importer_Install_13.png +/wiki/images/4/47/Dxf_Importer_Install_14.png +/wiki/images/3/3e/Dxf_Importer_Install_16.png +/wiki/images/6/6a/Dxf_Importer_Install_17.png +/wiki/images/d/d6/Dxf_Importer_Install_18.png +/wiki/images/c/c7/Dxf_Importer_Install_19.png +/wiki/images/f/fa/Dxf_Importer_Install_20.png +/wiki/images/b/b6/Dxf_Importer_Install_21.png +Release_notes_0.13 +/wiki/images/thumb/3/39/FreeCAD013.jpg/800px-FreeCAD013.jpg +/wiki/images/6/6c/Release-0.13-PointTool.png +/wiki/images/3/37/Release-0.13-Origin.png +/wiki/images/3/37/Release-0.13-SketcherDimensions.png +/wiki/images/7/75/Release-0.13-SketcherFullyConstrained.png +/wiki/images/7/73/Release-0.13-RubberBandSelection.png +/wiki/images/a/a3/013-draft-snap.jpg +/wiki/images/9/98/013-draft-fillet.jpg +/wiki/images/5/58/013-draft-shape2dview.jpg +/wiki/images/3/3b/013-arch-wall.jpg +/wiki/images/5/59/013-arch-vrm.jpg +/wiki/images/6/61/013-arch-axes.jpg +FreeCAD-Ship_s60_tutorial +/wiki/images/f/fc/FreeCAD-Ship-SignCriteria.jpg +/wiki/images/c/c0/FreeCAD-Ship-LoadIco.png +/wiki/images/a/a1/FreeCAD-Ship-Ico.png +/wiki/images/e/e5/FreeCAD-Ship-S60ShipCreationFront.png +/wiki/images/7/70/FreeCAD-Ship-S60ShipCreationSide.png +/wiki/images/6/61/FreeCAD-Ship-ShipInstance.png +/wiki/images/e/ec/FreeCAD-Ship-OutlineDrawIco.png +/wiki/images/c/ce/S60OutlineTransversal.png +/wiki/images/4/47/FreeCAD-Ship-S60Outline3DSections.png +/wiki/images/8/82/FreeCAD-Ship-S60OutlinePlot.png +/wiki/images/0/0b/FreeCAD-Ship-AreaCurveIco.png +/wiki/images/thumb/2/23/FreeCAD-Ship-s60Areas.png/800px-FreeCAD-Ship-s60Areas.png +/wiki/images/0/02/FreeCAD-Ship-HydrostaticsIco.png +/wiki/images/thumb/2/21/FreeCAD-Ship-HydrostaticsCurves.png/800px-FreeCAD-Ship-HydrostaticsCurves.png +FreeCAD-Ship_s60_tutorial_(II) +/wiki/images/4/44/FreeCAD-Ship-WeightIco.png +/wiki/images/1/1e/FreeCAD-Ship-S60WeightsPreview.png +/wiki/images/4/48/FreeCAD-Ship-S60TankGeometry.png +/wiki/images/5/50/FreeCAD-Ship-TankIco.png +/wiki/images/1/15/FreeCAD-Ship-S60WeightsTanksPreview.png +/wiki/images/c/ca/Ship_GZ.svg +/wiki/images/thumb/0/06/FreeCAD-Ship-s60GZ.png/800px-FreeCAD-Ship-s60GZ.png +Draft_Point +/wiki/images/thumb/c/c5/Draft_Point.png/32px-Draft_Point.png +/wiki/images/thumb/4/44/Draft_point_example.jpg/400px-Draft_point_example.jpg +/wiki/images/thumb/c/c5/Draft_Point.png/16px-Draft_Point.png +Drawing_Orthoviews +/wiki/images/thumb/7/7f/Drawing_Orthoviews.png/32px-Drawing_Orthoviews.png +/wiki/images/thumb/7/7f/Drawing_Orthoviews.png/16px-Drawing_Orthoviews.png +/wiki/images/5/5d/Drawing_Orthoviews_Options.png +Drawing_Annotation +/wiki/images/thumb/7/74/Drawing_Annotation.png/32px-Drawing_Annotation.png +/wiki/images/thumb/7/74/Drawing_Annotation.png/16px-Drawing_Annotation.png +Drawing_Openbrowser +/wiki/images/thumb/0/02/Drawing_Openbrowser.png/32px-Drawing_Openbrowser.png +/wiki/images/thumb/0/02/Drawing_Openbrowser.png/16px-Drawing_Openbrowser.png +Drawing_Clip +/wiki/images/thumb/b/b9/Drawing_Clip.png/32px-Drawing_Clip.png +/wiki/images/thumb/b/b9/Drawing_Clip.png/16px-Drawing_Clip.png +Release_notes_014 +/wiki/images/thumb/5/56/Freecad_jeep.png/1024px-Freecad_jeep.png +/wiki/images/thumb/f/fa/Freecad-bearing.png/1024px-Freecad-bearing.png +/wiki/images/thumb/b/b7/Style_Sheets.png/1024px-Style_Sheets.png +/wiki/images/f/f3/Part_Create_Primitives1.jpeg +/wiki/images/thumb/f/fa/DrawingWB.png/1024px-DrawingWB.png +/wiki/images/thumb/c/c7/Draft_dimensions_recode.jpg/1024px-Draft_dimensions_recode.jpg +/wiki/images/thumb/2/23/Draft_hatches.jpg/1024px-Draft_hatches.jpg +/wiki/images/e/e6/Screenshot_arch_window.jpg +/wiki/images/1/17/Screenshot_arch_multiwall.jpg +/wiki/images/b/bf/Screenshot_arch_rebar.jpg +Arch_Frame +/wiki/images/thumb/e/ef/Arch_Frame.png/32px-Arch_Frame.png +/wiki/images/thumb/5/59/Arch_Frame_example.jpg/640px-Arch_Frame_example.jpg +/wiki/images/thumb/e/ef/Arch_Frame.png/16px-Arch_Frame.png +Arch_Space +/wiki/images/thumb/8/83/Arch_Space.png/32px-Arch_Space.png +/wiki/images/thumb/c/c7/Arch_Space_example.jpg/640px-Arch_Space_example.jpg +/wiki/images/thumb/8/83/Arch_Space.png/16px-Arch_Space.png +Draft_BezCurve +/wiki/images/thumb/3/34/Draft_BezCurve.png/32px-Draft_BezCurve.png +/wiki/images/thumb/c/c2/Draft_BezCurve_Example.png/400px-Draft_BezCurve_Example.png +/wiki/images/thumb/3/34/Draft_BezCurve.png/16px-Draft_BezCurve.png +/wiki/images/9/9b/Draft_BezSharpNode.svg +/wiki/images/0/09/Draft_BezTanNode.svg +/wiki/images/2/21/Draft_BezSymNode.svg +Property +Draft_Facebinder +/wiki/images/thumb/9/93/Draft_Facebinder.png/32px-Draft_Facebinder.png +/wiki/images/thumb/0/0c/Draft_facebinder_example.jpg/400px-Draft_facebinder_example.jpg +/wiki/images/thumb/9/93/Draft_Facebinder.png/16px-Draft_Facebinder.png +Drawing_Symbol +/wiki/images/thumb/0/0a/Drawing_Symbol.png/32px-Drawing_Symbol.png +/wiki/images/thumb/0/0a/Drawing_Symbol.png/16px-Drawing_Symbol.png +PartDesign_InvoluteGear +/wiki/images/thumb/a/a7/PartDesign_InvoluteGear.png/32px-PartDesign_InvoluteGear.png +/wiki/images/5/5f/PartDesign_Involute_Gear_01.png +/wiki/images/thumb/a/a7/PartDesign_InvoluteGear.png/16px-PartDesign_InvoluteGear.png +PartDesign_Pad +/wiki/images/thumb/7/7e/PartDesign_Pad.png/32px-PartDesign_Pad.png +/wiki/images/c/cc/PartDesign_Pad_example.svg +/wiki/images/thumb/7/7e/PartDesign_Pad.png/24px-PartDesign_Pad.png +/wiki/images/6/6f/Pad_parameters_cropped.png +OpenSCAD_Workbench +/wiki/images/c/c7/OpenSCADexamaple1.png +/wiki/images/thumb/3/3f/OpenSCAD_ColorCodeShape.png/32px-OpenSCAD_ColorCodeShape.png +/wiki/images/thumb/1/14/OpenSCAD_ReplaceObject.png/32px-OpenSCAD_ReplaceObject.png +/wiki/images/thumb/0/09/OpenSCAD_RemoveSubtree.png/32px-OpenSCAD_RemoveSubtree.png +/wiki/images/thumb/b/b1/OpenSCAD_IncreaseTolerance.png/32px-OpenSCAD_IncreaseTolerance.png +/wiki/images/thumb/f/f2/OpenSCAD_Edgestofaces.png/32px-OpenSCAD_Edgestofaces.png +/wiki/images/thumb/d/de/OpenSCAD_ExpandPlacements.png/32px-OpenSCAD_ExpandPlacements.png +/wiki/images/thumb/4/4d/OpenSCAD_ExplodeGroup.png/32px-OpenSCAD_ExplodeGroup.png +/wiki/images/thumb/c/c4/OpenSCAD_AddOpenSCADElement.png/32px-OpenSCAD_AddOpenSCADElement.png +/wiki/images/thumb/2/28/OpenSCAD_MeshBoolean.png/32px-OpenSCAD_MeshBoolean.png +/wiki/images/thumb/e/ec/OpenSCAD_Hull.png/32px-OpenSCAD_Hull.png +/wiki/images/thumb/c/ca/OpenSCAD_Minkowski.png/32px-OpenSCAD_Minkowski.png +Import_OpenSCAD_code +/wiki/images/thumb/c/c0/TutorialOpenSCAD_SampleFile.jpg/800px-TutorialOpenSCAD_SampleFile.jpg +/wiki/images/thumb/d/dd/TutorialOpenSCAD_ImportFile.jpg/800px-TutorialOpenSCAD_ImportFile.jpg +OpenSCAD_Preferences +/wiki/images/f/f6/Preference_OpenSCAD_Tab_01.png +OpenSCAD_Minkowski +/wiki/images/c/c5/Minkowski_example.jpg +OpenSCAD_Hull +/wiki/images/c/ca/Hull_example.jpg +OpenSCAD_MeshBoolean +OpenSCAD_AddOpenSCADElement +OpenSCAD_ExplodeGroup +OpenSCAD_ExpandPlacements +OpenSCAD_Edgestofaces +OpenSCAD_IncreaseTolerance +OpenSCAD_RemoveSubtree +OpenSCAD_ReplaceObject +OpenSCAD_ColorCodeShape +OpenSCAD_CSG +Part_MakeCompound +/wiki/images/9/9b/Part_MakeCompound.png +Arch_Stairs +/wiki/images/thumb/b/b6/Arch_Stairs.png/32px-Arch_Stairs.png +/wiki/images/thumb/a/a5/Arch_Stairs_example.jpg/640px-Arch_Stairs_example.jpg +/wiki/images/thumb/b/b6/Arch_Stairs.png/16px-Arch_Stairs.png +Arch_Roof +/wiki/images/thumb/a/a2/Arch_Roof.png/32px-Arch_Roof.png +/wiki/images/thumb/6/6b/RoofExample.png/600px-RoofExample.png +/wiki/images/thumb/b/b2/CounterclockwiseWire.png/600px-CounterclockwiseWire.png +/wiki/images/thumb/a/a2/Arch_Roof.png/16px-Arch_Roof.png +/wiki/images/4/4a/RoofTable.png +/wiki/images/thumb/1/16/RoofProfil.png/600px-RoofProfil.png +Draft_AddToGroup +/wiki/images/thumb/5/56/Draft_AddToGroup.png/32px-Draft_AddToGroup.png +/wiki/images/thumb/5/56/Draft_AddToGroup.png/16px-Draft_AddToGroup.png +Draft_SelectGroup +/wiki/images/thumb/d/d9/Draft_SelectGroup.png/32px-Draft_SelectGroup.png +/wiki/images/thumb/d/d9/Draft_SelectGroup.png/16px-Draft_SelectGroup.png +Part_Attachment +/wiki/images/2/20/Part_Offset_Tasks.png +/wiki/images/thumb/3/34/Attacher_mode_FrenetNB.png/250px-Attacher_mode_FrenetNB.png +/wiki/images/thumb/a/aa/Attacher_mode_FrenetTN.png/250px-Attacher_mode_FrenetTN.png +/wiki/images/thumb/6/6d/Attacher_mode_FrenetTB.png/250px-Attacher_mode_FrenetTB.png +/wiki/images/thumb/c/cd/Attacher_mode_Folding.png/250px-Attacher_mode_Folding.png +Part_Revolve +/wiki/images/thumb/1/12/Part_Revolve.png/32px-Part_Revolve.png +/wiki/images/9/9a/Dialog-revolve.png +Part_Extrude +/wiki/images/thumb/d/df/Part_Extrude.png/32px-Part_Extrude.png +/wiki/images/thumb/0/00/Part_Extrude_demo.png/600px-Part_Extrude_demo.png +/wiki/images/thumb/d/df/Part_Extrude.png/16px-Part_Extrude.png +/wiki/images/thumb/7/76/Part_Extrude_dialog.png/300px-Part_Extrude_dialog.png +Part_Offset2D +/wiki/images/thumb/8/8e/Part_Offset2D.png/32px-Part_Offset2D.png +/wiki/images/thumb/0/07/Part_Offset2D_Demo.png/600px-Part_Offset2D_Demo.png +/wiki/images/thumb/5/52/Part_Offset2D_Mode.png/600px-Part_Offset2D_Mode.png +/wiki/images/thumb/e/ef/Part_Offset2D_Join.png/600px-Part_Offset2D_Join.png +/wiki/images/thumb/3/31/Part_Offset2D_Intersection.png/600px-Part_Offset2D_Intersection.png +/wiki/images/thumb/4/4c/Part_Offset2D_Fill.png/600px-Part_Offset2D_Fill.png +Part_Slice +/wiki/images/thumb/f/f7/Part_Slice.png/32px-Part_Slice.png +/wiki/images/thumb/a/a9/Part_Slice_Demo.png/600px-Part_Slice_Demo.png +/wiki/images/thumb/e/e1/Slice_example_step1.png/320px-Slice_example_step1.png +/wiki/images/thumb/f/f2/Slice_example_step2.png/320px-Slice_example_step2.png +/wiki/images/thumb/4/42/Slice_example_step3.png/320px-Slice_example_step3.png +/wiki/images/thumb/a/a0/Slice_example_step4.png/320px-Slice_example_step4.png +/wiki/images/thumb/c/cb/Slice_example_step5.png/320px-Slice_example_step5.png +/wiki/images/thumb/3/3b/Slice_example_step6.png/320px-Slice_example_step6.png +Part_CompJoinFeatures +/wiki/images/thumb/e/ee/Part_CompJoinFeatures.png/32px-Part_CompJoinFeatures.png +/wiki/images/7/79/JoinFeatures_dropdownToolbarButton.png +/wiki/images/thumb/d/d2/JoinFeatures_demo.png/668px-JoinFeatures_demo.png +Part_BooleanFragments +/wiki/images/thumb/f/fc/Part_BooleanFragments.png/32px-Part_BooleanFragments.png +/wiki/images/thumb/c/cf/Part_BooleanFragments_Demo.png/600px-Part_BooleanFragments_Demo.png +Draft_Label +/wiki/images/thumb/8/82/Draft_Label.png/32px-Draft_Label.png +/wiki/images/thumb/8/81/Draft_Label_example.jpg/400px-Draft_Label_example.jpg +/wiki/images/thumb/8/82/Draft_Label.png/16px-Draft_Label.png +Draft_Stretch +/wiki/images/thumb/7/7b/Draft_Stretch.png/32px-Draft_Stretch.png +/wiki/images/d/d4/Draft_Stretch_Example.jpg +/wiki/images/thumb/7/7b/Draft_Stretch.png/16px-Draft_Stretch.png +Draft_SetWorkingPlaneProxy +/wiki/images/thumb/0/03/Draft_SetWorkingPlaneProxy.png/32px-Draft_SetWorkingPlaneProxy.png +/wiki/images/thumb/0/03/Draft_SetWorkingPlaneProxy.png/16px-Draft_SetWorkingPlaneProxy.png +Draft_Slope +/wiki/images/thumb/5/5c/Draft_Slope.png/32px-Draft_Slope.png +/wiki/images/thumb/5/5c/Draft_Slope.png/16px-Draft_Slope.png +Draft_AutoGroup +/wiki/images/thumb/8/8c/Draft_AutoGroup.png/32px-Draft_AutoGroup.png +/wiki/images/8/84/Draft_AutoGroup_example.jpg +/wiki/images/thumb/8/8c/Draft_AutoGroup.png/16px-Draft_AutoGroup.png +Draft_VisGroup +/wiki/images/thumb/8/81/Draft_VisGroup.png/32px-Draft_VisGroup.png +/wiki/images/thumb/8/81/Draft_VisGroup.png/16px-Draft_VisGroup.png +Arch_3DS +Arch_MultiMaterial +/wiki/images/thumb/c/c3/Arch_MultiMaterial.png/32px-Arch_MultiMaterial.png +/wiki/images/5/55/Arch_multimaterial_example.png +/wiki/images/thumb/c/c3/Arch_MultiMaterial.png/16px-Arch_MultiMaterial.png +/wiki/images/a/a5/Arch_multimaterial_panel.png +Arch_Nest +/wiki/images/thumb/a/a7/Arch_Nest.png/32px-Arch_Nest.png +/wiki/images/thumb/9/96/Arch_Nest_example.jpg/600px-Arch_Nest_example.jpg +/wiki/images/thumb/0/06/Arch_Nest_panel.jpg/600px-Arch_Nest_panel.jpg +/wiki/images/thumb/a/a7/Arch_Nest.png/16px-Arch_Nest.png +Arch_Panel +/wiki/images/thumb/0/00/Arch_Panel.png/32px-Arch_Panel.png +/wiki/images/thumb/4/4b/Arch_Panel_example.jpg/700px-Arch_Panel_example.jpg +/wiki/images/thumb/1/10/Arch_panel_wave.jpg/700px-Arch_panel_wave.jpg +/wiki/images/thumb/0/00/Arch_Panel.png/16px-Arch_Panel.png +Wikihouse_porting_tutorial +/wiki/images/5/5d/Arch_Wikihouse_05.jpg +/wiki/images/f/f4/Arch_Wikihouse_06.jpg +/wiki/images/9/9a/Arch_Wikihouse_08.jpg +/wiki/images/8/8e/Arch_Wikihouse_07.jpg +/wiki/images/2/28/Arch_Wikihouse_09.jpg +/wiki/images/8/83/Arch_Wikihouse_10.jpg +/wiki/images/6/68/Arch_Wikihouse_11.jpg +/wiki/images/5/51/Arch_Wikihouse_12.jpg +/wiki/images/8/89/Arch_Wikihouse_01.jpg +/wiki/images/7/73/Arch_Wikihouse_02.jpg +/wiki/images/b/b9/Arch_Wikihouse_03.jpg +/wiki/images/e/e2/Arch_Wikihouse_04.jpg +Arch_Panel_Sheet +/wiki/images/thumb/8/82/Arch_Panel_Sheet.png/32px-Arch_Panel_Sheet.png +/wiki/images/thumb/8/82/Arch_Panel_Sheet.png/16px-Arch_Panel_Sheet.png +Arch_Panel_Cut +/wiki/images/thumb/4/42/Arch_Panel_Cut.png/32px-Arch_Panel_Cut.png +/wiki/images/thumb/4/42/Arch_Panel_Cut.png/16px-Arch_Panel_Cut.png +Arch_Grid +/wiki/images/thumb/d/d5/Arch_Grid.png/32px-Arch_Grid.png +/wiki/images/thumb/3/30/Arch_Grid_example.jpg/600px-Arch_Grid_example.jpg +/wiki/images/thumb/d/d5/Arch_Grid.png/16px-Arch_Grid.png +Arch_AxisSystem +/wiki/images/thumb/0/0c/Arch_AxisSystem.png/32px-Arch_AxisSystem.png +/wiki/images/thumb/c/c1/Arch_AxisSystem_example.jpg/600px-Arch_AxisSystem_example.jpg +/wiki/images/thumb/0/0c/Arch_AxisSystem.png/16px-Arch_AxisSystem.png +Arch_Axis +/wiki/images/thumb/b/be/Arch_Axis.png/32px-Arch_Axis.png +/wiki/images/thumb/4/47/Arch_Axis_example.jpg/600px-Arch_Axis_example.jpg +/wiki/images/thumb/b/be/Arch_Axis.png/16px-Arch_Axis.png +Arch_Window +/wiki/images/thumb/a/a4/Arch_Window.png/32px-Arch_Window.png +/wiki/images/thumb/0/08/Arch_Window_example.jpg/600px-Arch_Window_example.jpg +/wiki/images/thumb/1/13/Arch_Window_example2.jpg/600px-Arch_Window_example2.jpg +/wiki/images/thumb/a/a4/Arch_Window.png/16px-Arch_Window.png +/wiki/images/f/fc/ParametersDoorGlass.svg +/wiki/images/9/96/ParametersDoorSimple.svg +/wiki/images/5/54/ParametersWindowDouble.svg +/wiki/images/d/d1/ParametersWindowFixed.svg +/wiki/images/7/78/ParametersWindowSimple.svg +/wiki/images/0/09/ParametersWindowStash.svg +/wiki/images/thumb/8/87/Arch_Window_options.jpg/600px-Arch_Window_options.jpg +/wiki/images/thumb/6/6c/Arch_door.jpg/600px-Arch_door.jpg +/wiki/images/thumb/b/bf/Arch_window_openings.png/600px-Arch_window_openings.png +Arch_Rebar +/wiki/images/thumb/7/7f/Arch_Rebar.png/32px-Arch_Rebar.png +/wiki/images/thumb/e/e1/Arch_Rebar_example.jpg/400px-Arch_Rebar_example.jpg +/wiki/images/thumb/4/46/Sketcher_NewSketch.png/16px-Sketcher_NewSketch.png +/wiki/images/thumb/c/ce/Sketcher_LeaveSketch.png/16px-Sketcher_LeaveSketch.png +/wiki/images/thumb/7/7f/Arch_Rebar.png/16px-Arch_Rebar.png +Arch_Structure +/wiki/images/thumb/3/35/Arch_Structure.png/32px-Arch_Structure.png +/wiki/images/6/62/Arch_Structure_example.jpg +/wiki/images/thumb/3/35/Arch_Structure.png/16px-Arch_Structure.png +/wiki/images/3/34/Arch_presets_example.jpg +/wiki/images/thumb/f/fb/Arch_precast_example.jpg/960px-Arch_precast_example.jpg +/wiki/images/c/cd/Arch_structural_nodes.jpg +Arch_Pipe +/wiki/images/thumb/c/c5/Arch_Pipe.png/32px-Arch_Pipe.png +/wiki/images/thumb/c/c5/Arch_Pipe.png/16px-Arch_Pipe.png +/wiki/images/a/a8/Arch_pipe_example_01.jpg +/wiki/images/2/2b/Arch_pipe_example_02.jpg +/wiki/images/a/ae/Arch_pipe_example_03.jpg +/wiki/images/5/54/Arch_pipe_example_04.jpg +/wiki/images/2/23/Arch_pipe_example_05.jpg +/wiki/images/1/1d/Arch_pipe_example_06.jpg +/wiki/images/8/82/Arch_pipe_example_07.jpg +Draft_Special +/wiki/images/thumb/f/f7/Draft_Special.png/32px-Draft_Special.png +Arch_Equipment +/wiki/images/thumb/2/21/Arch_Equipment.png/32px-Arch_Equipment.png +/wiki/images/9/91/Arch_equipment_example.jpg +/wiki/images/3/34/Arch_equipment_mesh.jpg +/wiki/images/thumb/2/21/Arch_Equipment.png/16px-Arch_Equipment.png +Arch_3Views +/wiki/images/thumb/9/99/Arch_3Views.png/32px-Arch_3Views.png +/wiki/images/thumb/9/99/Arch_3Views.png/16px-Arch_3Views.png +Arch_PipeConnector +/wiki/images/thumb/0/0b/Arch_PipeConnector.png/32px-Arch_PipeConnector.png +/wiki/images/thumb/0/0b/Arch_PipeConnector.png/16px-Arch_PipeConnector.png +Std_Part +/wiki/images/thumb/1/19/Std_Part.png/32px-Std_Part.png +/wiki/images/8/86/Std_Part-tree.png +/wiki/images/6/6c/Std_Part_example.png +/wiki/images/1/18/Std_Part-tree-active.png +/wiki/images/thumb/1/19/Std_Part.png/24px-Std_Part.png +Std_DependencyGraph +/wiki/images/6/6a/Std_DependencyGraph.png +/wiki/images/b/b2/DependencyGraph1.png +/wiki/images/8/8d/FreeCAD-0.17-missing-Graphviz-error-dialogue.png +Std_ViewScreenShot +/wiki/images/thumb/3/35/Std_ViewScreenShot.png/32px-Std_ViewScreenShot.png +/wiki/images/thumb/d/d2/Save_picture.png/550px-Save_picture.png +MIBA +/wiki/images/d/d2/Save_picture.png +Std_Export +/wiki/images/thumb/0/0c/Std_Export.png/32px-Std_Export.png +Std_Import +/wiki/images/thumb/d/dc/Std_Import.png/32px-Std_Import.png +Std_Open +/wiki/images/thumb/1/1a/Std_Open.png/32px-Std_Open.png +Std_Save +/wiki/images/thumb/7/78/Std_Save.png/32px-Std_Save.png +/wiki/images/d/d5/FileSaveAs.png +/wiki/images/0/07/UnsavedDocument.png +/wiki/images/1/15/FileOpenSavePath.png +Std_File_Menu +Std_Exit +/wiki/images/3/33/Std_Exit.png +Std_RecentFiles +/wiki/images/thumb/7/7a/Std_RecentFiles.png/32px-Std_RecentFiles.png +Std_PrintPdf +/wiki/images/thumb/c/cd/Std_PrintPdf.png/32px-Std_PrintPdf.png +Std_PrintPreview +/wiki/images/thumb/5/54/Std_PrintPreview.png/32px-Std_PrintPreview.png +/wiki/images/d/d9/PrintPreview1.png +Std_Print +/wiki/images/thumb/7/72/Std_Print.png/32px-Std_Print.png +Std_ProjectInfo +/wiki/images/thumb/2/27/Std_ProjectInfo.png/32px-Std_ProjectInfo.png +Std_MergeProject +/wiki/images/thumb/1/18/Std_MergeProject.png/32px-Std_MergeProject.png +Std_Revert +/wiki/images/6/60/Std_Revert.png +Std_SaveaCopy +/wiki/images/7/73/Std_SaveaCopy.png +Std_CloseAll +/wiki/images/a/ae/Std_CloseAll.png +Std_Close +/wiki/images/2/29/Std_Close.png +Std_New +/wiki/images/thumb/8/80/Std_New.png/32px-Std_New.png +Std_SaveAs +/wiki/images/thumb/c/c1/Std_SaveAs.png/32px-Std_SaveAs.png +Std_Tools_Menu +/wiki/images/thumb/3/35/Std_ViewScreenShot.png/24px-Std_ViewScreenShot.png +Spinning +Project_utility +/wiki/images/thumb/8/8c/Std_Project_utility.png/32px-Std_Project_utility.png +/wiki/images/2/20/Project_utility_en.png +Std_SceneInspector +/wiki/images/thumb/9/97/Std_SceneInspector.png/32px-Std_SceneInspector.png +Std_DlgParameter +/wiki/images/0/0e/Parameter_Editor.jpg +AddonManager +/wiki/images/e/e6/Addon_manager.png +/wiki/images/thumb/a/ac/Std_Refresh.png/24px-Std_Refresh.png +Download +/wiki/images/a/ab/AppImage-logo.png +Release_notes_0.15 +/wiki/images/thumb/4/4e/Spark-Plug-Plane.jpg/1024px-Spark-Plug-Plane.jpg +/wiki/images/0/0f/FeatureSelectionView.jpg +/wiki/images/f/f0/Ellipse-example.png +/wiki/images/thumb/2/25/Spreadsheet_screenshot.jpg/640px-Spreadsheet_screenshot.jpg +/wiki/images/3/3b/Stickyfonts.jpg +/wiki/images/b/ba/Drawing-dxf-export.jpg +/wiki/images/f/f1/Arch_CutPlane_example.jpg +/wiki/images/6/6b/RoofExample.png +/wiki/images/thumb/4/4b/Arch_Panel_example.jpg/640px-Arch_Panel_example.jpg +Arch_CutPlane +/wiki/images/thumb/f/f2/Arch_CutPlane.png/32px-Arch_CutPlane.png +/wiki/images/0/09/Arch_CutPlane.svg +Draft_Dimensions +/wiki/images/thumb/8/82/Draft_Dimensions.png/32px-Draft_Dimensions.png +Constraint_Symmetric +/wiki/images/thumb/b/b6/SymmetricConstraint1.png/256px-SymmetricConstraint1.png +/wiki/images/thumb/4/41/SymmetricConstraint2.png/256px-SymmetricConstraint2.png +/wiki/images/thumb/b/be/Constraint_Symmetric.png/16px-Constraint_Symmetric.png +/wiki/images/thumb/e/ea/SymmetricConstraint3.png/256px-SymmetricConstraint3.png +Constraint_EqualLength +/wiki/images/thumb/9/9a/EqualConstraint1.png/256px-EqualConstraint1.png +/wiki/images/thumb/6/6c/EqualConstraint2.png/256px-EqualConstraint2.png +/wiki/images/thumb/b/bb/Constraint_EqualLength.png/16px-Constraint_EqualLength.png +/wiki/images/thumb/8/8a/EqualConstraint3.png/256px-EqualConstraint3.png +/wiki/images/thumb/4/4c/EqualConstraint4.png/256px-EqualConstraint4.png +/wiki/images/thumb/4/49/EqualConstraint5.png/256px-EqualConstraint5.png +/wiki/images/thumb/d/d6/EqualConstraint6.png/256px-EqualConstraint6.png +/wiki/images/thumb/7/7d/EqualConstraint7.png/256px-EqualConstraint7.png +/wiki/images/thumb/d/d8/EqualConstraint8.png/256px-EqualConstraint8.png +/wiki/images/thumb/c/c9/EqualConstraint9.png/256px-EqualConstraint9.png +Sketcher_ConstrainTangent +/wiki/images/3/37/Sketcher_ConstrainTangent.png +Constraint_Perpendicular +/wiki/images/thumb/c/cd/Sketcher_ConsraintPerpendicular_mode1.png/600px-Sketcher_ConsraintPerpendicular_mode1.png +/wiki/images/thumb/6/6a/Sketcher_ConsraintPerpendicular_mode2.png/600px-Sketcher_ConsraintPerpendicular_mode2.png +/wiki/images/thumb/6/66/Sketcher_ConsraintPerpendicular_mode3.png/600px-Sketcher_ConsraintPerpendicular_mode3.png +/wiki/images/thumb/6/6a/Sketcher_ConsraintPerpendicular_mode4.png/600px-Sketcher_ConsraintPerpendicular_mode4.png +Constraint_Parallel +/wiki/images/thumb/5/51/ConstrainParallel1.png/256px-ConstrainParallel1.png +/wiki/images/thumb/5/5e/ConstrainParallel2.png/256px-ConstrainParallel2.png +/wiki/images/thumb/0/0b/Constraint_Parallel.png/16px-Constraint_Parallel.png +/wiki/images/thumb/3/39/ConstrainParallel3.png/256px-ConstrainParallel3.png +Constraint_Horizontal +/wiki/images/thumb/5/5f/HorizontalConstraint1.png/256px-HorizontalConstraint1.png +/wiki/images/thumb/5/59/HorizontalConstraint2.png/256px-HorizontalConstraint2.png +/wiki/images/thumb/7/78/HorizontalConstraint3.png/256px-HorizontalConstraint3.png +/wiki/images/thumb/3/3f/Constraint_Horizontal.png/16px-Constraint_Horizontal.png +/wiki/images/thumb/2/25/HorizontalConstraint4.png/256px-HorizontalConstraint4.png +/wiki/images/thumb/c/c8/HorizontalConstraint5.png/256px-HorizontalConstraint5.png +Constraint_Vertical +Constraint_PointOnObject +/wiki/images/thumb/7/7d/Constraint_PointOnObject.png/24px-Constraint_PointOnObject.png +Constraint_PointOnPoint +/wiki/images/thumb/0/0e/PartDesignConstraintPointOnPointScriptingFigure1.jpg/600px-PartDesignConstraintPointOnPointScriptingFigure1.jpg +/wiki/images/thumb/d/db/PartDesignConstraintPointOnPointScriptingFigure2.jpg/600px-PartDesignConstraintPointOnPointScriptingFigure2.jpg +/wiki/images/thumb/2/23/PartDesignConstraintPointOnPointScriptingFigure3.jpg/600px-PartDesignConstraintPointOnPointScriptingFigure3.jpg +/wiki/images/5/52/PartDesignConstraintPointOnPointScriptingFigure3Bis.jpg +/wiki/images/2/28/PartDesignConstraintPointOnPointScriptingFigure4.jpg +/wiki/images/thumb/7/7d/PartDesignConstraintPointOnPointScriptingFigure5.jpg/600px-PartDesignConstraintPointOnPointScriptingFigure5.jpg +Sketcher_helper_constraint +/wiki/images/thumb/a/ad/Sketcher_helper_constraint_example1.png/500px-Sketcher_helper_constraint_example1.png +Sketcher_ConstructionMode +/wiki/images/thumb/0/0d/Sketcher_ConstructionMode_fr_01.png/480px-Sketcher_ConstructionMode_fr_01.png +/wiki/images/thumb/0/0d/Sketcher_ConstructionMode_fr_01.png/267px-Sketcher_ConstructionMode_fr_01.png +/wiki/images/thumb/2/25/Sketcher_ConstructionMode_fr_02.png/267px-Sketcher_ConstructionMode_fr_02.png +PartDesign_Revolution +/wiki/images/thumb/6/6a/PartDesign_Revolution.png/32px-PartDesign_Revolution.png +/wiki/images/a/a0/PartDesign_Revolution_example.svg +/wiki/images/thumb/6/6a/PartDesign_Revolution.png/24px-PartDesign_Revolution.png +/wiki/images/0/00/Partdesign_revolution_parameters.png +/wiki/images/b/b9/PartDesign_Revolution_axis_fromconstructionlines1.jpg +Sketcher_External +/wiki/images/e/ed/Sketcher_ExternalEsempio1.png +/wiki/images/8/8b/Sketcher_ExternalEsempio2.png +/wiki/images/1/16/Sketcher_ExternalEsempio4.png +/wiki/images/0/08/Sketcher_ExternalEsempio3.png +Sketcher_Trimming +/wiki/images/f/f1/SketcherTrimExample1.png +/wiki/images/c/c9/SketcherTrimExample2.png +/wiki/images/6/6b/SketcherTrimExample3.png +Sketcher_Fillet +/wiki/images/6/6b/SketcherCreateFilletExample.png +Sketcher_Slot +/wiki/images/d/d9/SketcherCreateSlotExample.png +/wiki/images/thumb/1/16/Sketcher_CreateSlot.png/16px-Sketcher_CreateSlot.png +Sketcher_Octagon +/wiki/images/5/5b/SketcherCreateOctagonExample.png +/wiki/images/thumb/0/00/Sketcher_CreateOctagon.png/16px-Sketcher_CreateOctagon.png +Sketcher_Heptagon +/wiki/images/0/05/SketcherCreateHeptagonExample.png +/wiki/images/thumb/d/df/Sketcher_CreateHeptagon.png/16px-Sketcher_CreateHeptagon.png +Sketcher_Hexagon +/wiki/images/c/cf/SketcherCreateHexagonExample.png +/wiki/images/thumb/d/d8/Sketcher_CreateHexagon.png/16px-Sketcher_CreateHexagon.png +Sketcher_Pentagon +/wiki/images/2/26/SketcherCreatePentagonExample.png +/wiki/images/thumb/c/c0/Sketcher_CreatePentagon.png/16px-Sketcher_CreatePentagon.png +Sketcher_Square +/wiki/images/a/af/SketcherCreateSquareExample.png +/wiki/images/thumb/8/85/Sketcher_CreateSquare.png/16px-Sketcher_CreateSquare.png +Sketcher_Triangle +/wiki/images/8/8f/SketcherCreateTriangleExample.png +/wiki/images/thumb/d/d7/Sketcher_CreateTriangle.png/16px-Sketcher_CreateTriangle.png +Sketcher_Rectangle +/wiki/images/2/2d/SketcherCreateRectangleExample.png +Sketcher_Polyline +/wiki/images/a/a9/Sketcher_PolylineExample1.png +Sketcher_Arc_of_Ellipse +/wiki/images/thumb/6/69/Sketcher_CreateArcOfEllipse.png/32px-Sketcher_CreateArcOfEllipse.png +/wiki/images/thumb/b/b3/Sketcher_ArcOfEllipseExample1.png/500px-Sketcher_ArcOfEllipseExample1.png +Sketcher_Ellipse_by_3_Points +/wiki/images/thumb/6/65/Sketcher_CreateEllipse3Point.png/32px-Sketcher_CreateEllipse3Point.png +Sketcher_Ellipse +/wiki/images/thumb/6/63/Sketcher_EllipseExample1.png/500px-Sketcher_EllipseExample1.png +Sketcher_Conic_Sections +Sketcher_Circle3Point +Sketcher_Circle +/wiki/images/e/ee/Sketcher_CircleExample1.png +Sketcher_Arc3Point +Sketcher_Arc +/wiki/images/1/16/Sketcher_ArcExample1.png +/wiki/images/thumb/3/39/Sketcher_ArcExample2.png/407px-Sketcher_ArcExample2.png +Sketcher_Line +/wiki/images/3/34/Sketcher_LineExample1.png +Sketcher_Point +/wiki/images/thumb/a/a7/Sketcher_Point_fr_01.png/480px-Sketcher_Point_fr_01.png +/wiki/images/thumb/8/83/Sketcher_Point.png/24px-Sketcher_Point.png +Part_Wedge +/wiki/images/thumb/5/54/Part_Wedge.png/32px-Part_Wedge.png +/wiki/images/d/d8/PartWedgeProperty.png +/wiki/images/9/94/PartWedgeProperty_Inputs.png +/wiki/images/8/80/Wedge_examples.png +Part_Prism +/wiki/images/thumb/d/d3/Part_Prism.png/32px-Part_Prism.png +Part_Torus +/wiki/images/thumb/8/8b/Part_Torus.png/32px-Part_Torus.png +/wiki/images/thumb/c/c8/SimpleTorus.jpg/400px-SimpleTorus.jpg +/wiki/images/6/62/TorusExampleOverviewParameters.jpg +/wiki/images/b/bd/TorusExampleRadius1.jpg +/wiki/images/d/d8/TorusExampleRadius2.jpg +/wiki/images/0/0f/TorusExampleAngle1.jpg +/wiki/images/2/2a/TorusExampleAngle2.jpg +/wiki/images/4/45/TorusExampleAngle3.jpg +Part_Ellipsoid +/wiki/images/thumb/e/e1/Part_Ellipsoid.png/32px-Part_Ellipsoid.png +/wiki/images/5/59/Part_Ellipsoid_screenshot.jpg +Part_Sphere +/wiki/images/thumb/4/4b/Part_Sphere.png/32px-Part_Sphere.png +/wiki/images/thumb/9/9f/SimpleSphere.jpg/400px-SimpleSphere.jpg +/wiki/images/1/1e/PartDesign_Sphere_Parameter_en.jpg +/wiki/images/thumb/0/0e/SphereCutThreeAngles.jpg/400px-SphereCutThreeAngles.jpg +Part_Cone +/wiki/images/7/7f/PartConeProperty_en.png +/wiki/images/3/30/Otherwisedefault270degree_Part_Cone.png +Part_Plane +/wiki/images/7/77/PartPlane.png +/wiki/images/7/79/PartPlaneProperty.png +Part_Shapebuilder +/wiki/images/thumb/a/a6/Part_Shapebuilder.png/32px-Part_Shapebuilder.png +Part_Cylinder +/wiki/images/thumb/2/21/Cylinder.png/650px-Cylinder.png +Placement +/wiki/images/9/9a/PlacementPropertiesv10-800x800.png +/wiki/images/0/09/PlacePyConv10.png +/wiki/images/2/20/PlacementDialogv10.png +/wiki/images/e/e7/PlacementDialogv10b.png +/wiki/images/thumb/9/96/RotationAboutZBefore.png/600px-RotationAboutZBefore.png +/wiki/images/thumb/e/e2/RotationAboutZAfter.png/600px-RotationAboutZAfter.png +/wiki/images/thumb/b/bd/RotationAboutYXAfter.png/600px-RotationAboutYXAfter.png +/wiki/images/thumb/2/21/RotationOffsetBefore.png/600px-RotationOffsetBefore.png +/wiki/images/thumb/7/71/RotationOffsetAfter.png/600px-RotationOffsetAfter.png +/wiki/images/thumb/c/c6/RotationEulerBefore.png/600px-RotationEulerBefore.png +/wiki/images/thumb/c/c4/RotationEulerAfter.png/600px-RotationEulerAfter.png +/wiki/images/b/be/2Placements800.png +/wiki/images/3/34/LocalZBefore2.png +/wiki/images/5/59/LocalZAfter2.png +Placement_API +/wiki/images/0/0f/Class.png +/wiki/images/4/47/Property.png +/wiki/images/2/20/Method.png +Tasks_Placement +/wiki/images/9/9b/Tache_Placement_fr_01.png +/wiki/images/thumb/8/80/Tache_Placement_01_fr_00.png/256px-Tache_Placement_01_fr_00.png +/wiki/images/a/a4/Tache_Placement_en_02.png +/wiki/images/thumb/5/5c/Tache_Placement_Translation_X_fr.gif/150px-Tache_Placement_Translation_X_fr.gif +/wiki/images/thumb/c/ca/Tache_Placement_Translation_Y_fr.gif/150px-Tache_Placement_Translation_Y_fr.gif +/wiki/images/thumb/6/63/Tache_Placement_Translation_Z_fr.gif/150px-Tache_Placement_Translation_Z_fr.gif +/wiki/images/thumb/4/42/Part_Revolve_fr_06.png/96px-Part_Revolve_fr_06.png +/wiki/images/thumb/d/d2/Tache_Placement_fr_05.png/256px-Tache_Placement_fr_05.png +/wiki/images/thumb/4/48/Tache_Placement_fr_04.png/256px-Tache_Placement_fr_04.png +/wiki/images/e/ef/Tache_Placement_en_03.png +Std_Delete +/wiki/images/thumb/a/a2/Std_Delete.png/32px-Std_Delete.png +Std_SelectAll +/wiki/images/thumb/7/7b/Std_SelectAll.png/32px-Std_SelectAll.png +Std_BoxSelection +/wiki/images/thumb/2/2a/Std_BoxSelection.png/32px-Std_BoxSelection.png +Std_DuplicateSelection +/wiki/images/thumb/7/73/Std_DuplicateSelection.png/32px-Std_DuplicateSelection.png +Copying_Objects +Part_CreateSimpleCopy +/wiki/images/f/fb/Part_CreateSimpleCopy.png +PartDesign_MultiTransform +/wiki/images/thumb/4/46/PartDesign_MultiTransform.png/32px-PartDesign_MultiTransform.png +/wiki/images/thumb/a/aa/Multitransform_example.png/600px-Multitransform_example.png +/wiki/images/c/cb/Multitransfrom_parameters.png +/wiki/images/thumb/9/93/Mt_example2.png/800px-Mt_example2.png +/wiki/images/thumb/0/0f/Mt_example3.png/800px-Mt_example3.png +PartDesign_Scaled +/wiki/images/thumb/7/72/PartDesign_Scaled.png/32px-PartDesign_Scaled.png +/wiki/images/5/5b/Scaled_parameters.png +PartDesign_PolarPattern +/wiki/images/thumb/8/8f/PartDesign_PolarPattern.png/32px-PartDesign_PolarPattern.png +/wiki/images/thumb/6/6c/Polarpattern_example.png/600px-Polarpattern_example.png +/wiki/images/7/7c/PartDesign_PolarPattern_EdgeReference.gif +/wiki/images/4/49/Polarpattern_example2.jpg +PartDesign_LinearPattern +/wiki/images/thumb/9/98/PartDesign_LinearPattern.png/32px-PartDesign_LinearPattern.png +/wiki/images/0/08/PartDesign_LinearPattern_example.svg +/wiki/images/thumb/9/98/PartDesign_LinearPattern.png/24px-PartDesign_LinearPattern.png +/wiki/images/5/50/Linearpattern_parameters.png +/wiki/images/a/ab/Linearpattern_parameters_v017.png +PartDesign_Mirrored +/wiki/images/thumb/5/55/PartDesign_Mirrored.png/32px-PartDesign_Mirrored.png +/wiki/images/0/07/PartDesign_Mirrored_example.svg +/wiki/images/thumb/5/55/PartDesign_Mirrored.png/24px-PartDesign_Mirrored.png +/wiki/images/7/77/Mirrored_parameters.png +/wiki/images/b/b7/Mirrored_parameters_v017.png +/wiki/images/2/24/PartDesign_Mirrored_axis_fromconstructionlines.jpg +Std_Paste +/wiki/images/thumb/9/9f/Std_Paste.png/32px-Std_Paste.png +Std_Copy +/wiki/images/thumb/8/83/Std_Copy.png/32px-Std_Copy.png +Std_Cut +/wiki/images/thumb/e/e9/Std_Cut.png/32px-Std_Cut.png +Std_Redo +/wiki/images/thumb/b/bf/Std_Redo.png/32px-Std_Redo.png +Std_Undo +/wiki/images/thumb/a/a7/Std_Undo.png/32px-Std_Undo.png +Macro_MacroMenu +Macro_Easy_cutouts_for_Enclosure_Design +/wiki/images/7/71/Macro_Easy_cutouts_for_Enclosure_Design_icon.png +/wiki/images/7/71/Easy-cutouts.gif +Macro_Center_Align_Objects_with_Faces_or_Edges +/wiki/images/thumb/b/bb/Macro_Center_Align_Objects_with_Faces_or_Edges.png/32px-Macro_Center_Align_Objects_with_Faces_or_Edges.png +/wiki/images/5/5c/Center-align-faces.png +/wiki/images/d/d8/Center-align-faces-in-action.gif +/wiki/images/9/91/Center-align-Body-objects.gif +/wiki/images/8/83/Utube-alignment-tool-tutorial.png +/wiki/images/1/10/Utube-alignment-STEP-models.png +/wiki/images/thumb/b/bb/Macro_Center_Align_Objects_with_Faces_or_Edges.png/50px-Macro_Center_Align_Objects_with_Faces_or_Edges.png +Macro_CenterFace +/wiki/images/thumb/1/16/CenterFace.png/32px-CenterFace.png +/wiki/images/thumb/3/37/Macro_CenterFace_00.png/480px-Macro_CenterFace_00.png +/wiki/images/1/16/CenterFace.png +Macro_FCSpreadSheet_Extract +/wiki/images/thumb/d/d5/Macro_FCSpreadsheet_Extract.png/32px-Macro_FCSpreadsheet_Extract.png +/wiki/images/d/d5/Macro_FCSpreadsheet_Extract.png +Macro_SpreadsheetTools +/wiki/images/8/86/Screenshot_from_2017-09-02_20-01-49.png +Macro_Alias_Manager +/wiki/images/thumb/d/d7/Aliasmanager_icon.png/32px-Aliasmanager_icon.png +/wiki/images/e/e3/Aliasmanager_screenshot.png +Macro_FreeCAD_to_Kerkythea +Macro_3d_Printer_Slicer +/wiki/images/thumb/d/d2/Macro_3d_Printer_Slicer_00.png/480px-Macro_3d_Printer_Slicer_00.png +Macro_Overlap +/wiki/images/thumb/a/ac/Macro_Overlap.png/32px-Macro_Overlap.png +/wiki/images/thumb/8/87/Macro_Boolean_Overlap_Screenshot.png/1000px-Macro_Boolean_Overlap_Screenshot.png +Macro_Section +/wiki/images/thumb/b/b6/Macro_Section_Screenshot.png/1000px-Macro_Section_Screenshot.png +Part_Section +/wiki/images/thumb/a/ab/Part_Section.png/32px-Part_Section.png +/wiki/images/f/fd/PartSection1_it.png +Part_SectionCross +/wiki/images/thumb/8/8b/Part_SectionCross.png/32px-Part_SectionCross.png +/wiki/images/thumb/8/8b/Part_SectionCross.png/24px-Part_SectionCross.png +/wiki/images/d/d4/SectionCross1.png +/wiki/images/2/2d/SectionCross2.png +/wiki/images/9/98/SectionCross3.png +Macro_Connect_And_Sweep +/wiki/images/thumb/c/c9/Macro_Connect_And_Sweep.png/32px-Macro_Connect_And_Sweep.png +/wiki/images/thumb/1/1c/Macro_Connect_And_Sweep_00.png/480px-Macro_Connect_And_Sweep_00.png +/wiki/images/f/f7/Macro_Connect_And_Sweep_01.png +/wiki/images/a/a8/Macro_Connect_And_Sweep_CE.png +/wiki/images/f/f7/Macro_Connect_And_Sweep_TL.png +/wiki/images/b/b7/Macro_Connect_And_Sweep_TR.png +/wiki/images/5/5d/Macro_Connect_And_Sweep_LL.png +/wiki/images/b/b9/Macro_Connect_And_Sweep_LR.png +/wiki/images/c/c9/Macro_Connect_And_Sweep.png +/wiki/images/thumb/a/a3/Macro_ReproWire.png/32px-Macro_ReproWire.png +/wiki/images/thumb/d/dd/Macro_Connect_And_Sweep_02.png/400px-Macro_Connect_And_Sweep_02.png +/wiki/images/thumb/6/6e/Macro_Connect_And_Sweep_03.png/400px-Macro_Connect_And_Sweep_03.png +/wiki/images/thumb/9/93/Macro_Connect_And_Sweep_04.png/400px-Macro_Connect_And_Sweep_04.png +/wiki/images/thumb/1/17/Macro_Connect_And_Sweep_05.png/400px-Macro_Connect_And_Sweep_05.png +/wiki/images/thumb/a/a2/Macro_Connect_And_Sweep_06.png/400px-Macro_Connect_And_Sweep_06.png +/wiki/images/thumb/a/a4/Macro_Connect_And_Sweep_07.png/400px-Macro_Connect_And_Sweep_07.png +/wiki/images/thumb/f/fb/Macro_Connect_And_Sweep_08.png/400px-Macro_Connect_And_Sweep_08.png +Macro_Repro_Wire +/wiki/images/thumb/1/11/Macro_ReproWire_00.png/480px-Macro_ReproWire_00.png +/wiki/images/a/a3/Macro_ReproWire.png +Macro_MatrixTransform +Macro_Image_Scaling +/wiki/images/4/4d/Perspective.png +/wiki/images/d/d8/Parallax.jpg +Macro_CloneConvert +/wiki/images/thumb/0/0a/Macro_CloneConvert.png/32px-Macro_CloneConvert.png +/wiki/images/thumb/c/cd/Macro_CloneConvert_01.png/220px-Macro_CloneConvert_01.png +/wiki/images/0/0a/Macro_CloneConvert.png +Macro_HealArcs +Macro_SuperWire +Macro_Remove_parametric_history +/wiki/images/b/ba/RPH_before.png +/wiki/images/5/52/RPH_after.png +Macro_JointWire +Macro_FlattenWire3Points +Macro_FlattenWire +Macro_ArrayCopy +Macro_Guitar_fretboard +/wiki/images/thumb/f/f1/Fretboard_freecad2.png/480px-Fretboard_freecad2.png +Macro_FCSpring_Helix_Variable +/wiki/images/thumb/6/69/FCSpring_Helix_Variable.png/32px-FCSpring_Helix_Variable.png +/wiki/images/thumb/6/6b/TruncateSpring00.png/400px-TruncateSpring00.png +/wiki/images/4/47/Macro_TruncateSpring_01.png +/wiki/images/e/e8/Macro_FCSpring_Helix_Variable_01.png +/wiki/images/a/af/Macro_FCSpring_Helix_Variable_02.png +/wiki/images/0/0d/Macro_FCSpring_Helix_Variable_03.png +/wiki/images/6/64/Macro_FCSpring_Helix_Variable_02_2.png +/wiki/images/5/5e/Macro_FCSpring_Helix_Variable_04.png +/wiki/images/b/bf/Macro_FCSpring_Helix_Variable_05.png +/wiki/images/9/91/Macro_FCSpring_Helix_Variable_06.png +/wiki/images/b/ba/Macro_FCSpring_Helix_Variable_07.png +/wiki/images/4/46/Macro_FCSpring_Helix_Variable_08.png +/wiki/images/6/69/FCSpring_Helix_Variable.png +/wiki/images/1/13/FCSpring_Helix_Variable_Icon_01.png +/wiki/images/c/cd/FCSpring_Helix_Variable_Icon_02.png +/wiki/images/b/bc/FCSpring_Helix_Variable_Icon_02b.png +/wiki/images/2/2f/FCSpring_Helix_Variable_Icon_03.png +/wiki/images/3/3a/FCSpring_Helix_Variable_Icon_03b.png +/wiki/images/0/05/FCSpring_Helix_Variable_Icon_04.png +/wiki/images/d/d8/FCSpring_Helix_Variable_Icon_05.png +/wiki/images/3/38/FCSpring_Helix_Variable_Icon_06.png +/wiki/images/thumb/4/48/Valves_Assembly_IN_EX.png/260px-Valves_Assembly_IN_EX.png +/wiki/images/thumb/2/29/Macro_FCSpring_Helix_Variable_12.png/200px-Macro_FCSpring_Helix_Variable_12.png +/wiki/images/thumb/c/c0/Macro_FCSpring_Helix_Variable_13.png/267px-Macro_FCSpring_Helix_Variable_13.png +/wiki/images/thumb/1/18/Macro_FCSpring_Helix_Variable_14.png/267px-Macro_FCSpring_Helix_Variable_14.png +/wiki/images/thumb/0/08/Macro_FCSpring_Helix_Variable_15.png/267px-Macro_FCSpring_Helix_Variable_15.png +/wiki/images/thumb/6/62/Macro_FCSpring_Helix_Variable_16.png/267px-Macro_FCSpring_Helix_Variable_16.png +/wiki/images/thumb/a/a0/Macro_FCSpring_Helix_Variable_17.png/267px-Macro_FCSpring_Helix_Variable_17.png +/wiki/images/thumb/8/86/Macro_FCSpring_Helix_Variable_18.png/267px-Macro_FCSpring_Helix_Variable_18.png +/wiki/images/thumb/0/0f/Macro_FCSpring_Helix_Variable_19.png/600px-Macro_FCSpring_Helix_Variable_19.png +/wiki/images/f/ff/Macro_FCSpring_Helix_Variable.gif +/wiki/images/a/a7/Macro_FCSpringHelixVariable_Example_02.gif +/wiki/images/thumb/0/0f/Macro_FCSpring_Helix_Variable_20.png/267px-Macro_FCSpring_Helix_Variable_20.png +/wiki/images/thumb/5/55/Macro_FCSpring_Helix_Variable_09.png/300px-Macro_FCSpring_Helix_Variable_09.png +/wiki/images/thumb/4/46/Macro_FCSpring_Helix_Variable_10.png/85px-Macro_FCSpring_Helix_Variable_10.png +/wiki/images/thumb/4/4a/Macro_FCSpring_Helix_Variable_11.png/93px-Macro_FCSpring_Helix_Variable_11.png +Macro_ReproWire +Macro_WireXYZ +Macro_FCCircularText +/wiki/images/thumb/c/c1/FCCircularTextButtom.png/32px-FCCircularTextButtom.png +/wiki/images/thumb/f/f1/FCCircularText_01.png/400px-FCCircularText_01.png +/wiki/images/e/e0/FCCircularText_06.png +/wiki/images/7/71/FCCircularText_07.png +/wiki/images/e/ec/FCCircularText_08.png +/wiki/images/a/ac/FCCircularText_09.png +/wiki/images/thumb/5/52/FCCircularText_20.png/88px-FCCircularText_20.png +/wiki/images/thumb/3/34/FCCircularText_21.png/88px-FCCircularText_21.png +/wiki/images/thumb/4/47/FCCircularText_22.png/88px-FCCircularText_22.png +/wiki/images/thumb/9/9b/FCCircularText_23.png/88px-FCCircularText_23.png +/wiki/images/0/00/FCCircularText_24.png +/wiki/images/thumb/f/f1/FCCircularText_01.png/200px-FCCircularText_01.png +/wiki/images/thumb/5/58/FCCircularText_40.png/200px-FCCircularText_40.png +/wiki/images/thumb/6/65/FCCircularText_39.png/200px-FCCircularText_39.png +/wiki/images/thumb/2/22/FCCircularText_03.png/200px-FCCircularText_03.png +/wiki/images/2/26/FCCircularText_10.png +/wiki/images/5/52/FCCircularText_20.png +/wiki/images/thumb/8/85/FCCircularText_25.png/200px-FCCircularText_25.png +/wiki/images/thumb/c/cb/FCCircularText_30.png/200px-FCCircularText_30.png +/wiki/images/3/34/FCCircularText_21.png +/wiki/images/thumb/6/6b/FCCircularText_27.png/200px-FCCircularText_27.png +/wiki/images/4/47/FCCircularText_22.png +/wiki/images/thumb/f/f7/FCCircularText_33.png/200px-FCCircularText_33.png +/wiki/images/thumb/2/21/FCCircularText_34.png/200px-FCCircularText_34.png +/wiki/images/2/29/FCCircularText_11.png +/wiki/images/7/77/FCCircularText_14.png +/wiki/images/d/dc/FCCircularText_15.png +/wiki/images/9/9b/FCCircularText_23.png +/wiki/images/thumb/e/ea/FCCircularText_35.png/200px-FCCircularText_35.png +/wiki/images/thumb/2/25/FCCircularText_36.png/200px-FCCircularText_36.png +/wiki/images/0/03/FCCircularText_12.png +/wiki/images/b/ba/FCCircularText_16.png +/wiki/images/7/73/FCCircularText_19.png +/wiki/images/5/56/FCCircularText_17.png +/wiki/images/thumb/b/b8/FCCircularText_38.png/200px-FCCircularText_38.png +/wiki/images/8/8f/FCCircularText_18.png +/wiki/images/thumb/8/89/FCCircularText_37.png/200px-FCCircularText_37.png +/wiki/images/1/1f/FCCircularText_13.png +/wiki/images/c/c1/FCCircularTextButtom.png +/wiki/images/0/04/FCCircularTextButtom.svg +/wiki/images/thumb/e/ed/FCCircularText_02.png/275px-FCCircularText_02.png +/wiki/images/thumb/2/22/FCCircularText_03.png/254px-FCCircularText_03.png +/wiki/images/thumb/5/53/FCCircularText_04.png/265px-FCCircularText_04.png +/wiki/images/thumb/f/f0/FCCircularText_05.png/252px-FCCircularText_05.png +/wiki/images/thumb/6/68/FCCircularText_26.png/267px-FCCircularText_26.png +/wiki/images/thumb/d/d6/FCCircularText_28.png/267px-FCCircularText_28.png +/wiki/images/thumb/f/f4/FCCircularText_29.png/267px-FCCircularText_29.png +/wiki/images/thumb/9/93/FCCircularText_31.png/267px-FCCircularText_31.png +/wiki/images/thumb/3/35/FCCircularText_32.png/267px-FCCircularText_32.png +/wiki/images/thumb/a/a3/FCCircularText_41.png/267px-FCCircularText_41.png +/wiki/images/thumb/d/d6/FCCircularText_42.png/300px-FCCircularText_42.png +/wiki/images/thumb/d/d7/FCCircularText_61.png/267px-FCCircularText_61.png +/wiki/images/thumb/a/ab/FCCircularText_43.png/267px-FCCircularText_43.png +/wiki/images/thumb/a/ac/FCCircularText_44.png/267px-FCCircularText_44.png +/wiki/images/thumb/1/14/FCCircularText_45.png/267px-FCCircularText_45.png +/wiki/images/thumb/3/3b/FCCircularText_46.png/267px-FCCircularText_46.png +/wiki/images/thumb/a/a4/FCCircularText_47.png/267px-FCCircularText_47.png +/wiki/images/thumb/e/e1/FCCircularText_48.png/267px-FCCircularText_48.png +/wiki/images/thumb/f/f9/FCCircularText_49.png/267px-FCCircularText_49.png +/wiki/images/thumb/b/b2/FCCircularText_50.png/267px-FCCircularText_50.png +/wiki/images/thumb/e/e9/FCCircularText_51.png/267px-FCCircularText_51.png +/wiki/images/thumb/3/34/FCCircularText_52.png/267px-FCCircularText_52.png +/wiki/images/thumb/2/27/FCCircularText_53.png/267px-FCCircularText_53.png +/wiki/images/1/13/Draft_Ellipse.png +/wiki/images/thumb/a/a1/FCCircularText_54.png/267px-FCCircularText_54.png +/wiki/images/1/14/Draft_Rectangle.png +/wiki/images/thumb/6/66/FCCircularText_55.png/267px-FCCircularText_55.png +/wiki/images/thumb/0/0f/FCCircularText_56.png/267px-FCCircularText_56.png +/wiki/images/thumb/c/c3/FCCircularText_57.png/267px-FCCircularText_57.png +/wiki/images/thumb/e/eb/FCCircularText_58.png/267px-FCCircularText_58.png +/wiki/images/thumb/3/3e/FCCircularText_59.png/267px-FCCircularText_59.png +/wiki/images/f/fe/FCCircularText_Correction.gif +Macro_Circular_Text +Macro_FCCreaLoft +/wiki/images/2/29/FCCreaLoft.png +/wiki/images/thumb/5/5c/Texture_001_Logo.png/480px-Texture_001_Logo.png +/wiki/images/f/f9/Macro_FCCreaLoft_01.png +Macro_Loft +Macro_Texture +/wiki/images/thumb/9/90/FCTexture.png/32px-FCTexture.png +/wiki/images/thumb/f/f0/Texture_004_Honda.png/480px-Texture_004_Honda.png +/wiki/images/thumb/e/e5/Texture_002.png/200px-Texture_002.png +/wiki/images/9/90/FCTexture.png +/wiki/images/c/cc/FCTexture.svg +/wiki/images/thumb/4/4a/FCTexture_008.png/482px-FCTexture_008.png +/wiki/images/thumb/a/a9/Macro_FCTexture_008b.png/400px-Macro_FCTexture_008b.png +/wiki/images/thumb/9/9a/Texture_Nano_Photo.png/182px-Texture_Nano_Photo.png +/wiki/images/thumb/4/46/Texture_NanoDesign.png/158px-Texture_NanoDesign.png +/wiki/images/thumb/5/5c/Texture_001_Logo.png/232px-Texture_001_Logo.png +/wiki/images/thumb/c/cd/Texture_002_Fe_FC.png/300px-Texture_002_Fe_FC.png +/wiki/images/thumb/5/54/Texture_003_napperon.png/299px-Texture_003_napperon.png +/wiki/images/thumb/6/65/Texture_005_larme.png/268px-Texture_005_larme.png +/wiki/images/thumb/4/4b/FCTexture_006.png/400px-FCTexture_006.png +/wiki/images/thumb/7/73/Texture_Topographie.png/397px-Texture_Topographie.png +/wiki/images/thumb/e/e2/FCTexture_007_FreeCAD_ASCII_00.png/600px-FCTexture_007_FreeCAD_ASCII_00.png +/wiki/images/5/5a/FCTexture_Example.gif +/wiki/images/1/15/Part_RuledSurface.svg +/wiki/images/3/38/Part_Extrude.svg +/wiki/images/c/c4/FCTexture_Example_Mesh.png +Macro_FCTexture +Macro_triangleAH +Macro_Triangle_AH +Macro_cutCircle +/wiki/images/thumb/6/69/Macro_CutCircle_00.png/400px-Macro_CutCircle_00.png +Macro_Cut_Circle +Macro_circle +/wiki/images/thumb/6/61/Macro_Circle_01.png/640px-Macro_Circle_01.png +/wiki/images/thumb/2/23/Macro_Circle_02.png/640px-Macro_Circle_02.png +Macro_Circle +Macro_cutLine +/wiki/images/thumb/d/dd/Macro_cutLine_00.png/400px-Macro_cutLine_00.png +Macro_Cut_Line +Macro_Line_Length +Macro_Geodesic_Dome +/wiki/images/thumb/9/97/Geodesic_macro.png/600px-Geodesic_macro.png +Macro_Solid_Sweep +/wiki/images/thumb/f/fd/Solid_sweep.png/500px-Solid_sweep.png +/wiki/images/a/af/Draft_BSpline.png +Macro_Make_Cube +/wiki/images/3/36/Macro_makeCube.png +Macro_WorkFeatures +/wiki/images/thumb/9/9d/WF_wf.png/32px-WF_wf.png +/wiki/images/thumb/8/8a/Macro_WorkFeatures_01.png/200px-Macro_WorkFeatures_01.png +/wiki/images/thumb/2/28/Macro_WorkFeatures_07.png/200px-Macro_WorkFeatures_07.png +/wiki/images/thumb/e/e9/Macro_WorkFeatures_08.png/200px-Macro_WorkFeatures_08.png +/wiki/images/thumb/d/da/Macro_WorkFeatures_02.png/200px-Macro_WorkFeatures_02.png +/wiki/images/thumb/a/ab/Macro_WorkFeatures_03.png/200px-Macro_WorkFeatures_03.png +/wiki/images/thumb/f/f3/Macro_WorkFeatures_04.png/200px-Macro_WorkFeatures_04.png +/wiki/images/thumb/a/ae/Macro_WorkFeatures_05.png/200px-Macro_WorkFeatures_05.png +/wiki/images/thumb/6/6e/Macro_WorkFeatures_06.png/200px-Macro_WorkFeatures_06.png +/wiki/images/thumb/7/7b/Macro_WorkFeatures_09.png/200px-Macro_WorkFeatures_09.png +/wiki/images/thumb/9/9d/Macro_WorkFeatures_10.png/200px-Macro_WorkFeatures_10.png +/wiki/images/thumb/e/e1/Macro_WorkFeatures_11.png/200px-Macro_WorkFeatures_11.png +/wiki/images/thumb/1/17/Macro_Work_Features_GitHub_00.png/640px-Macro_Work_Features_GitHub_00.png +/wiki/images/thumb/b/b9/CuttingSettings.jpg/338px-CuttingSettings.jpg +/wiki/images/thumb/1/1b/CuttingResult.jpg/330px-CuttingResult.jpg +/wiki/images/thumb/6/66/Macro_Work_Features_Cutting_01.png/351px-Macro_Work_Features_Cutting_01.png +/wiki/images/thumb/2/2e/Macro_Work_Features_Cutting_02.png/351px-Macro_Work_Features_Cutting_02.png +/wiki/images/thumb/8/87/Macro_Work_Features_Cutting_03.png/351px-Macro_Work_Features_Cutting_03.png +/wiki/images/thumb/b/b9/Macro_Work_Features_Cutting_04.png/351px-Macro_Work_Features_Cutting_04.png +/wiki/images/thumb/b/bf/Macro_Work_Features_Cutting_05.png/351px-Macro_Work_Features_Cutting_05.png +/wiki/images/thumb/e/e1/Macro_Work_Features_Cutting_06.png/351px-Macro_Work_Features_Cutting_06.png +/wiki/images/thumb/5/58/Macro_Work_Features_Cutting_07.png/351px-Macro_Work_Features_Cutting_07.png +/wiki/images/thumb/1/14/Macro_Work_Features_Cutting_08.png/351px-Macro_Work_Features_Cutting_08.png +/wiki/images/thumb/8/89/Macro_Work_Features_Cutting_09.png/351px-Macro_Work_Features_Cutting_09.png +/wiki/images/9/90/Concentric_Constraint_Between_two_non_cylindrical_parts.gif +/wiki/images/thumb/f/f2/WorkFeature_Rotation_Object.gif/500px-WorkFeature_Rotation_Object.gif +/wiki/images/9/9d/WF_wf.png +/wiki/images/c/c4/WF_centerObjectsPlanes.png +Macro_Draw_Parametric_2D_Function +/wiki/images/thumb/5/50/Macro_drawParametric2Dfunction.png/480px-Macro_drawParametric2Dfunction.png +Macro_Draw_2D_Function +Macro_3D_Parametric_Curve +/wiki/images/thumb/4/42/ParametricCurve.png/600px-ParametricCurve.png +/wiki/images/thumb/f/f5/Macro_3D_Parametric_Curve.png/600px-Macro_3D_Parametric_Curve.png +Macro_PartsLibrary +/wiki/images/thumb/9/9d/FreeCAD_Doc.png/32px-FreeCAD_Doc.png +/wiki/images/thumb/2/20/Freecad-parts-library.jpg/760px-Freecad-parts-library.jpg +Macro_BOLTS +/wiki/images/thumb/5/50/Macro_BOLTS.png/32px-Macro_BOLTS.png +/wiki/images/thumb/f/fa/Freecad-bearing.png/480px-Freecad-bearing.png +Macro_MeasureCircle +/wiki/images/thumb/b/bd/Macro_MeasureCircle.png/32px-Macro_MeasureCircle.png +Macro_Dump_Objects +/wiki/images/thumb/2/2e/Macro_Dump_Objects.png/32px-Macro_Dump_Objects.png +/wiki/images/1/1f/DumpObjectsScreenSnapshot.jpg +/wiki/images/f/fa/DumpObjectsGui1.jpg +/wiki/images/5/52/DumpObjectsGui2.jpg +Macro_ObjectInfo +/wiki/images/thumb/1/1d/ObjectInfoIt.png/480px-ObjectInfoIt.png +Macro_Delta_xyz +/wiki/images/f/f5/DeltaXYZ.png +Macro_FCInfoToMouse +/wiki/images/thumb/1/10/FCInfoToMouse.png/32px-FCInfoToMouse.png +/wiki/images/thumb/5/58/Macro_FCInfoToMouse_00.png/480px-Macro_FCInfoToMouse_00.png +/wiki/images/2/2b/Macro_FCInfoToMouse_01.png +/wiki/images/a/a2/Macro_FCInfoToMouse_02.png +/wiki/images/thumb/9/98/Macro_FCInfoToMouse_03.png/240px-Macro_FCInfoToMouse_03.png +/wiki/images/1/10/FCInfoToMouse.png +Customize_ToolsBar +Macro_FCInfoGlass +/wiki/images/thumb/6/6b/Macro_FCInfoGlass.png/32px-Macro_FCInfoGlass.png +/wiki/images/thumb/5/5f/Macro_FCTransparentInfo_00.FCMacro.png/480px-Macro_FCTransparentInfo_00.FCMacro.png +/wiki/images/thumb/5/5c/Macro_FCInfoGlass_01.png/300px-Macro_FCInfoGlass_01.png +/wiki/images/thumb/5/5f/Macro_FCInfoGlass_02.png/300px-Macro_FCInfoGlass_02.png +/wiki/images/thumb/b/b4/Macro_FCInfoGlass_03.png/300px-Macro_FCInfoGlass_03.png +/wiki/images/thumb/2/2f/Macro_FCInfoGlass_04.png/300px-Macro_FCInfoGlass_04.png +/wiki/images/thumb/6/6b/Macro_FCInfoGlass.png/64px-Macro_FCInfoGlass.png +Macro_FCInfo_Alternate_Linux +/wiki/images/thumb/5/53/FCInfo.png/32px-FCInfo.png +Macro_FCInfo +/wiki/images/thumb/6/69/Macro_FCInfo_00_en.png/480px-Macro_FCInfo_00_en.png +/wiki/images/thumb/9/99/Macro_FCInfo_06.png/200px-Macro_FCInfo_06.png +/wiki/images/thumb/f/f0/Macro_FCInfo_07.png/200px-Macro_FCInfo_07.png +/wiki/images/thumb/2/20/Macro_FCInfo_04.png/245px-Macro_FCInfo_04.png +/wiki/images/thumb/4/44/Macro_FCInfo_05.png/245px-Macro_FCInfo_05.png +/wiki/images/thumb/6/6e/Macro_FCInfo_02.png/267px-Macro_FCInfo_02.png +/wiki/images/thumb/7/7a/Macro_FCInfo_03.gif/277px-Macro_FCInfo_03.gif +/wiki/images/5/53/FCInfo.png +/wiki/images/1/16/FCInfoSpreadsheet.png +/wiki/images/thumb/2/26/Nuvola_apps_download_manager.png/35px-Nuvola_apps_download_manager.png +/wiki/images/c/c8/Macro_FCInfo_08.png +/wiki/images/e/eb/FCInfo_begin_00.gif +Macro_Dxf_To_Shape +/wiki/images/thumb/f/f4/Macro_Dxf_To_Shape.png/32px-Macro_Dxf_To_Shape.png +/wiki/images/c/c6/Macro_DXF_To_Shape_00.png +/wiki/images/f/f4/Macro_Dxf_To_Shape.png +/wiki/images/8/87/Macro_Dxf_To_Shape_Convert_Wire_To_BSplineCurve.gif +/wiki/images/2/2a/Macro_Dxf_To_Shape_Convert_Wire_To_BSplineCurve02.gif +Macro_Compound_Plus +/wiki/images/thumb/f/fd/Macro_Compound_Plus.png/32px-Macro_Compound_Plus.png +/wiki/images/b/b1/Macro_Compound_Plus_00.png +/wiki/images/9/9f/Draft_Text.png +/wiki/images/f/f7/Draft_ShapeString.png +/wiki/images/8/86/Draft_Downgrade.png +/wiki/images/f/fd/Macro_Compound_Plus.png +Macro_DXF_to_Face_and_Sketch +Macro_Creating_faces_from_a_DXF_file +Macro_EdgesToArc +Macro_FCConvertLines +/wiki/images/thumb/e/e2/Macro_FCConvertLines.png/32px-Macro_FCConvertLines.png +/wiki/images/thumb/e/e4/Macro_FCConvertLines_00.png/400px-Macro_FCConvertLines_00.png +/wiki/images/f/f4/Macro_FCConvertLines_01.png +/wiki/images/c/cb/Macro_FCConvertLines_02.png +/wiki/images/6/6c/Macro_FCConvertLines_03.png +/wiki/images/4/43/Macro_FCConvertLines_04.png +/wiki/images/7/77/Macro_FCConvertLines_05.png +/wiki/images/7/7d/Macro_FCConvertLines_06.png +/wiki/images/d/df/Macro_FCConvertLines_07.png +/wiki/images/b/b5/Macro_FCConvertLines_08.png +/wiki/images/b/b2/Macro_FCConvertLines_09.png +/wiki/images/3/30/Macro_FCConvertLines_10.png +/wiki/images/e/e2/Macro_FCConvertLines.png +/wiki/images/8/89/Macro_FCConvertLines_Title.png +/wiki/images/9/99/Macro_FCConvertLines_Dash.png +/wiki/images/e/e1/Macro_FCConvertLines_DashDot.png +/wiki/images/2/27/Macro_FCConvertLines_DashDotDot.png +/wiki/images/3/31/Macro_FCConvertLines_Zigzag.png +/wiki/images/8/8f/Macro_FCConvertLines_Hand.png +/wiki/images/5/57/Macro_FCConvrtLines_View-front.png +/wiki/images/5/5b/Macro_FCConvrtLines_View-right.png +/wiki/images/f/f6/Macro_FCConvrtLines_View-top.png +/wiki/images/thumb/2/2d/Macro_FCConvertLines_11b.png/500px-Macro_FCConvertLines_11b.png +/wiki/images/thumb/9/9e/Macro_FCConvertLines_11.png/500px-Macro_FCConvertLines_11.png +/wiki/images/b/b1/Macro_FCConvertLines_012.png +/wiki/images/thumb/4/43/Macro_FCConvertLines_013.png/500px-Macro_FCConvertLines_013.png +/wiki/images/1/19/ShapeString_To_Sketch.gif +Macro_FC_Convert_Lines +Macro_Ellipse-Center%2B2Points +/wiki/images/9/97/EllipseCenter2Point.png +Macro_Make_Arc_3_Points +/wiki/images/thumb/9/92/Macro_Make_Arc_3_Points.png/32px-Macro_Make_Arc_3_Points.png +/wiki/images/thumb/9/92/Macro_Make_Arc_3_Points.png/36px-Macro_Make_Arc_3_Points.png +Macro_Draft_Circle_3_Points_3D +/wiki/images/thumb/1/10/Macro_Draft_Circle_3_Points.png/32px-Macro_Draft_Circle_3_Points.png +/wiki/images/thumb/1/1a/Macro_Draft_Circle_3_Points_3D.png/480px-Macro_Draft_Circle_3_Points_3D.png +Macro_Draft_Circle_3_Points +/wiki/images/thumb/6/6d/Macro_Draft_Circle_3_Points01.png/480px-Macro_Draft_Circle_3_Points01.png +/wiki/images/thumb/e/e8/Macro_Draft_Circle_3_Points02.png/133px-Macro_Draft_Circle_3_Points02.png +/wiki/images/thumb/4/49/Macro_Draft_Circle_3_Points03.png/133px-Macro_Draft_Circle_3_Points03.png +/wiki/images/thumb/e/eb/Macro_Draft_Circle_3_Points04.png/133px-Macro_Draft_Circle_3_Points04.png +/wiki/images/thumb/7/7e/Macro_Draft_Circle_3_Points05.png/133px-Macro_Draft_Circle_3_Points05.png +/wiki/images/thumb/d/dd/Anaglyph_Tango.png/24px-Anaglyph_Tango.png +/wiki/images/thumb/d/d1/Cercle3Points2D_anaglyphe.png/480px-Cercle3Points2D_anaglyphe.png +Macro_Make_Circle_3_Points +/wiki/images/e/ec/Circle_on_3_points.png +/wiki/images/f/fb/View-Top.png +/wiki/images/c/ca/View-Left.png +/wiki/images/6/64/View-Front.png +/wiki/images/1/19/View-C3P.png +Macro_Rectellipse +/wiki/images/a/a1/Rectellipse.png +Macro_Normal_Vector +Macro_CartoucheFC_2 +/wiki/images/thumb/f/fc/Macro_CartoucheFC_Modele_02.png/680px-Macro_CartoucheFC_Modele_02.png +Misc_templates_Full +/wiki/images/3/38/A3_Landscape_US_FULL.svg +/wiki/images/c/cb/A3_Portrait_US_FULL.svg +/wiki/images/b/bf/A4_Landscape_US_FULL.svg +/wiki/images/4/4b/A4_Portrait_US_FULL.svg +Macro_CartoucheFC_Full +/wiki/images/thumb/6/68/Macro_CartoucheFC_Full.png/32px-Macro_CartoucheFC_Full.png +/wiki/images/thumb/2/23/Macro_CartoucheFC_Full_00.png/680px-Macro_CartoucheFC_Full_00.png +/wiki/images/6/68/Macro_CartoucheFC_Full.png +Macro_CartoucheFC +/wiki/images/thumb/1/1a/CartoucheFC.png/480px-CartoucheFC.png +Macro_Automatic_drawing +Macro_DeepCopy +/wiki/images/thumb/0/0a/Macro_DeepCopy.png/32px-Macro_DeepCopy.png +Macro_FCWire_To_Volume +/wiki/images/thumb/f/f2/Macro_FCWire_To_Volume.png/32px-Macro_FCWire_To_Volume.png +/wiki/images/thumb/9/9b/Macro_FCWire_To_Volume_01.png/400px-Macro_FCWire_To_Volume_01.png +/wiki/images/0/01/Macro_FCWire_To_Volume_00.png +Macro_FaceToSketch +Macro_PartToVRML +/wiki/images/thumb/f/f8/PartToVRML.png/32px-PartToVRML.png +/wiki/images/f/f8/PartToVRML.png +Macro_MeshToPart +Macro_Extract_Wires_from_Mesh +Macro_Global_Variable_Watcher +/wiki/images/thumb/c/c1/Macro_Global_Variable_Watcher.png/32px-Macro_Global_Variable_Watcher.png +/wiki/images/f/f2/MacroVariableWatcherGui1.jpg +Macro_Build_Utility +/wiki/images/thumb/8/87/Macro_Build_Utility.png/32px-Macro_Build_Utility.png +/wiki/images/thumb/3/31/MacroBuildUtilityTreeDiagram.jpg/500px-MacroBuildUtilityTreeDiagram.jpg +Macro_Python_Assistant_Window +/wiki/images/thumb/4/45/Macro_Python_Assistant_Window.png/32px-Macro_Python_Assistant_Window.png +/wiki/images/thumb/c/c6/PythonAssistantWindowScreenSnapshot.jpg/500px-PythonAssistantWindowScreenSnapshot.jpg +/wiki/images/thumb/7/72/PythonAssistantWindowGui2.jpg/500px-PythonAssistantWindowGui2.jpg +Macro_MessageBox +/wiki/images/thumb/c/cc/Macro_MessageBox_00.png/480px-Macro_MessageBox_00.png +Macro_Rubik_Cube +/wiki/images/7/7c/Macro_Rubik_Cube.png +Macro_Constraint_Draft +/wiki/images/b/b3/Constraint_Draft00.gif +/wiki/images/9/99/Constraint_Draft_Code01.gif +/wiki/images/e/ee/Constraint_Draft01.gif +Macro_Assemblage_Imprimante_3D +/wiki/images/6/6b/Assemblage_Imprimante_3D.gif +Macro_Animated_Constrain +Macro_Assembly +/wiki/images/1/13/Assy.gif +Macro_hinge +/wiki/images/f/fd/Hing_00.gif +/wiki/images/thumb/7/7b/Hing_01.png/300px-Hing_01.png +Macro_Spring +/wiki/images/7/71/Spring_00.gif +/wiki/images/thumb/6/6b/Spring_02.png/300px-Spring_02.png +Macro_crank_simul +/wiki/images/b/b6/Crank_00.gif +Macro_Select_Hovering +/wiki/images/thumb/d/d8/Macro_Select_Hovering.png/32px-Macro_Select_Hovering.png +/wiki/images/a/a8/Macro_Select_Hovering_00.png +/wiki/images/d/d8/Macro_Select_Hovering.png +Macro_FCTreeView +/wiki/images/thumb/6/64/Macro_FCTreeView.png/32px-Macro_FCTreeView.png +/wiki/images/6/6b/FCTreeView.gif +/wiki/images/c/c1/Macro_FCTreeView_00.png +/wiki/images/9/99/Macro_FCTreeView_05.png +/wiki/images/b/b7/Macro_FCTreeView_01.png +/wiki/images/1/13/Macro_FCTreeView_02.png +/wiki/images/5/50/Macro_FCTreeView_17.png +/wiki/images/7/7b/Macro_FCTreeView_03.png +/wiki/images/5/53/Macro_FCTreeView_04.png +/wiki/images/thumb/2/22/Macro_FCTreeView_10.png/18px-Macro_FCTreeView_10.png +/wiki/images/thumb/a/a5/Macro_FCTreeView_11.png/18px-Macro_FCTreeView_11.png +/wiki/images/thumb/0/08/Macro_FCTreeView_12.png/18px-Macro_FCTreeView_12.png +/wiki/images/thumb/f/f5/Macro_FCTreeView_13.png/18px-Macro_FCTreeView_13.png +/wiki/images/thumb/7/7d/Macro_FCTreeView_19.png/18px-Macro_FCTreeView_19.png +/wiki/images/thumb/a/ae/Macro_FCTreeView_21.png/18px-Macro_FCTreeView_21.png +/wiki/images/thumb/8/8f/Macro_FCTreeView_22.png/18px-Macro_FCTreeView_22.png +/wiki/images/thumb/b/b5/Macro_FCTreeView_14.png/18px-Macro_FCTreeView_14.png +/wiki/images/thumb/b/b9/Macro_FCTreeView_15.png/18px-Macro_FCTreeView_15.png +/wiki/images/thumb/7/78/Macro_FCTreeView_06.png/18px-Macro_FCTreeView_06.png +/wiki/images/thumb/c/cd/Macro_FCTreeView_07.png/18px-Macro_FCTreeView_07.png +/wiki/images/thumb/a/ad/Macro_FCTreeView_16.png/18px-Macro_FCTreeView_16.png +/wiki/images/thumb/8/87/Macro_FCTreeView_18.png/18px-Macro_FCTreeView_18.png +/wiki/images/thumb/b/b7/Macro_FCTreeView_01.png/18px-Macro_FCTreeView_01.png +/wiki/images/thumb/1/13/Macro_FCTreeView_02.png/18px-Macro_FCTreeView_02.png +/wiki/images/thumb/a/ab/Macro_FCTreeView_20.png/18px-Macro_FCTreeView_20.png +/wiki/images/thumb/2/25/Macro_FCTreeView_23.png/18px-Macro_FCTreeView_23.png +/wiki/images/thumb/6/60/Macro_FCTreeView_24.png/18px-Macro_FCTreeView_24.png +/wiki/images/thumb/5/50/Macro_FCTreeView_25.png/18px-Macro_FCTreeView_25.png +/wiki/images/8/8a/TreeView_SpeadSheet.gif +/wiki/images/0/01/Macro_FCTreeView_001.png +/wiki/images/2/27/Macro_FCTreeView_002.png +/wiki/images/thumb/c/ca/Macro_FCTreeView_28.png/18px-Macro_FCTreeView_28.png +/wiki/images/thumb/7/73/Macro_FCTreeView_29.png/18px-Macro_FCTreeView_29.png +/wiki/images/2/2e/Macro_FCTreeView_003.png +/wiki/images/8/81/Macro_FCTreeView_30.png +/wiki/images/3/3d/Macro_FCTreeView_31.png +/wiki/images/1/1a/Macro_FCTreeView_32.png +/wiki/images/7/74/Macro_FCTreeView_33.png +/wiki/images/1/18/Macro_FCTreeView_004.png +/wiki/images/5/5c/Macro_FCTreeView_005.png +/wiki/images/a/a8/Macro_FCTreeView_006.png +/wiki/images/thumb/6/69/Macro_FCTreeView_27.png/18px-Macro_FCTreeView_27.png +/wiki/images/thumb/c/c8/Macro_FCTreeView_26.png/18px-Macro_FCTreeView_26.png +/wiki/images/7/78/Macro_FCTreeView_06.png +/wiki/images/c/cd/Macro_FCTreeView_07.png +/wiki/images/1/19/Macro_FCTreeView_08.png +/wiki/images/a/ae/Macro_FCTreeView_09.png +/wiki/images/2/22/Macro_FCTreeView_10.png +/wiki/images/a/a5/Macro_FCTreeView_11.png +/wiki/images/0/08/Macro_FCTreeView_12.png +/wiki/images/f/f5/Macro_FCTreeView_13.png +/wiki/images/b/b5/Macro_FCTreeView_14.png +/wiki/images/b/b9/Macro_FCTreeView_15.png +/wiki/images/a/ad/Macro_FCTreeView_16.png +/wiki/images/8/87/Macro_FCTreeView_18.png +/wiki/images/7/7d/Macro_FCTreeView_19.png +/wiki/images/a/ab/Macro_FCTreeView_20.png +/wiki/images/a/ae/Macro_FCTreeView_21.png +/wiki/images/8/8f/Macro_FCTreeView_22.png +/wiki/images/2/25/Macro_FCTreeView_23.png +/wiki/images/6/60/Macro_FCTreeView_24.png +/wiki/images/5/50/Macro_FCTreeView_25.png +/wiki/images/c/c8/Macro_FCTreeView_26.png +/wiki/images/6/69/Macro_FCTreeView_27.png +/wiki/images/c/ca/Macro_FCTreeView_28.png +/wiki/images/7/73/Macro_FCTreeView_29.png +/wiki/images/6/64/Macro_FCTreeView.png +Macro_Rotate_To_Point +/wiki/images/thumb/b/b4/Macro_Rotate_To_Point.png/32px-Macro_Rotate_To_Point.png +/wiki/images/e/e2/Macro_Rotate_To_Point_00.png +/wiki/images/b/b4/Macro_Rotate_To_Point.png +/wiki/images/d/d1/Macro_Rotate_To_Point.svg +/wiki/images/9/99/Macro_Rotate_To_Point_01.gif +Macro_Perpendicular_To_Wire +/wiki/images/thumb/0/0c/Macro_Perpendicular_To_Wire.png/32px-Macro_Perpendicular_To_Wire.png +/wiki/images/0/0c/Macro_Perpendicular_To_Wire.png +/wiki/images/7/75/Macro_Perpendicular_To_Wire_01.png +/wiki/images/5/51/Macro_Perpendicular_To_Wire_02.png +/wiki/images/d/d9/Macro_Perpendicular_To_Wire_03.png +/wiki/images/7/78/Macro_Perpendicular_To_Wire_04.png +/wiki/images/8/8e/Macro_Perpendicular_To_Wire.gif +Macro_Copy3DViewToClipboard +/wiki/images/thumb/8/84/Macro_Copy3DViewToClipboard.png/32px-Macro_Copy3DViewToClipboard.png +/wiki/images/8/84/Macro_Copy3DViewToClipboard.png +Macro_Duplicate_Selection +Macro_Manage_Navigational_Style +/wiki/images/9/92/Macro_Manage_Navigational_Styles1.png +/wiki/images/1/1c/Macro_Manage_Navigational_Styles2.png +Macro_SelectVisible +/wiki/images/thumb/5/51/SelectVisible.png/32px-SelectVisible.png +Macro_Toggle_Visibility2 +/wiki/images/thumb/d/d7/Macro_SelectVisible2.png/32px-Macro_SelectVisible2.png +/wiki/images/thumb/d/d7/Macro_SelectVisible2.png/48px-Macro_SelectVisible2.png +/wiki/images/thumb/e/ec/Macro_VisibleAlls2.png/48px-Macro_VisibleAlls2.png +Macro_Toggle_Visibility +/wiki/images/thumb/4/42/Macro_SelectVisible.png/32px-Macro_SelectVisible.png +/wiki/images/thumb/4/42/Macro_SelectVisible.png/48px-Macro_SelectVisible.png +/wiki/images/thumb/1/19/Macro_VisibleAlls.png/48px-Macro_VisibleAlls.png +/wiki/images/thumb/d/d6/Macro_HiddenAlls.png/48px-Macro_HiddenAlls.png +/wiki/images/thumb/6/62/Macro_If_Selected_Stay_If_Not_Then_Delete.png/48px-Macro_If_Selected_Stay_If_Not_Then_Delete.png +Macro_FCCamera +/wiki/images/thumb/2/25/FCCamera_00.png/32px-FCCamera_00.png +/wiki/images/7/75/Macro_FCCamera_00.png +/wiki/images/thumb/f/ff/FCCamera_01.png/24px-FCCamera_01.png +/wiki/images/thumb/d/d8/FCCamera_02.png/24px-FCCamera_02.png +/wiki/images/thumb/f/f5/FCCamera_03.png/24px-FCCamera_03.png +/wiki/images/thumb/7/78/FCCamera_04.png/24px-FCCamera_04.png +/wiki/images/thumb/d/d5/FCCamera_05.png/24px-FCCamera_05.png +/wiki/images/thumb/6/62/FCCamera_06.png/24px-FCCamera_06.png +/wiki/images/thumb/e/eb/FCCamera_07.png/24px-FCCamera_07.png +/wiki/images/thumb/c/ca/FCCamera_08.png/24px-FCCamera_08.png +/wiki/images/2/28/Macro_FCCamera_00b.png +/wiki/images/thumb/a/a0/FCCamera_15.png/489px-FCCamera_15.png +/wiki/images/2/25/FCCamera_00.png +/wiki/images/f/ff/FCCamera_01.png +/wiki/images/d/d8/FCCamera_02.png +/wiki/images/f/f5/FCCamera_03.png +/wiki/images/7/78/FCCamera_04.png +/wiki/images/d/d5/FCCamera_05.png +/wiki/images/6/62/FCCamera_06.png +/wiki/images/e/eb/FCCamera_07.png +/wiki/images/c/ca/FCCamera_08.png +/wiki/images/3/3c/FCCamera_Axis_rotation_X.png +/wiki/images/f/fa/FCCamera_Axis_rotation_Y.png +/wiki/images/1/1a/FCCamera_Axis_rotation_Z.png +/wiki/images/b/bb/FCCamera_Axis_rotation_D.png +/wiki/images/thumb/8/85/FCCamera_09.png/300px-FCCamera_09.png +/wiki/images/thumb/1/10/FCCamera_10.png/300px-FCCamera_10.png +/wiki/images/thumb/a/aa/FCCamera_11.png/300px-FCCamera_11.png +/wiki/images/thumb/f/f1/FCCamera_12.png/300px-FCCamera_12.png +/wiki/images/thumb/0/09/FCCamera_13.png/300px-FCCamera_13.png +/wiki/images/thumb/6/64/FCCamera_14.png/300px-FCCamera_14.png +/wiki/images/2/28/Macro_FCCamera_Align_To_Face.gif +Macro_Toggle_Panels_Visibility +/wiki/images/thumb/d/d0/Macro_Toggle_Views_Visibility.png/32px-Macro_Toggle_Views_Visibility.png +Macro_Align_Face_Object_to_View +Macro_Align_Working_Plane_to_Camera +Macro_Align_Camera_to_Working_Plane +Macro_Align_Object_to_View +/wiki/images/thumb/1/15/Macro_Align_Object_to_View_01.png/296px-Macro_Align_Object_to_View_01.png +/wiki/images/thumb/5/5d/Macro_Align_Object_to_View_02.png/296px-Macro_Align_Object_to_View_02.png +/wiki/images/thumb/b/b7/Macro_Align_Object_to_View_03.png/296px-Macro_Align_Object_to_View_03.png +/wiki/images/thumb/e/e5/Macro_Align_Object_to_View_04.png/296px-Macro_Align_Object_to_View_04.png +Macro_Align_View_to_Face +Macro_Mouse_Cross +/wiki/images/thumb/8/82/Macro_Mouse_Cross_00.png/480px-Macro_Mouse_Cross_00.png +Macro_Texture_Objects +/wiki/images/thumb/c/cd/Textured_objects.jpg/680px-Textured_objects.jpg +Macro_View_Rotation +/wiki/images/thumb/6/63/Macro_View_Rotation_00.png/480px-Macro_View_Rotation_00.png +Macro_Rotate_View +/wiki/images/a/a0/Macro_Rotate_View_view_90_Degrees.png +/wiki/images/2/2e/Macro_Rotate_View_with_Y_pointing_upwards_.png +/wiki/images/a/a2/Macro_Rotate_View_with_Z_pointing_upwards_.png +Arch_Schedule +/wiki/images/thumb/1/11/Arch_Schedule.png/32px-Arch_Schedule.png +/wiki/images/thumb/1/11/Arch_Schedule.png/16px-Arch_Schedule.png +/wiki/images/e/ed/Arch_schedule_example01.jpg +/wiki/images/d/db/Arch_schedule_example02.jpg +/wiki/images/2/2a/Arch_schedule_example03.jpg +/wiki/images/b/b4/Arch_schedule_example04.jpg +/wiki/images/b/b9/Arch_schedule_example05.jpg +Arch_SectionPlane +/wiki/images/thumb/a/ab/Arch_SectionPlane.png/32px-Arch_SectionPlane.png +/wiki/images/thumb/b/b0/Arch_SectionPlane_example.jpg/600px-Arch_SectionPlane_example.jpg +/wiki/images/thumb/a/ab/Arch_SectionPlane.png/16px-Arch_SectionPlane.png +/wiki/images/thumb/0/06/Arch_Section_example2.jpg/600px-Arch_Section_example2.jpg +/wiki/images/thumb/e/eb/Arch_Section_example3.jpg/600px-Arch_Section_example3.jpg +/wiki/images/thumb/1/13/Arch_SectionPlane_CutView.jpg/600px-Arch_SectionPlane_CutView.jpg +TechDraw_NewArch +/wiki/images/thumb/4/4f/TechDraw_NewArch.png/32px-TechDraw_NewArch.png +/wiki/images/1/12/TechDraw_Arch_example.jpg +/wiki/images/thumb/d/d5/Techdraw-arch-view.png/24px-Techdraw-arch-view.png +/wiki/images/9/9d/TechDraw_Arch_rendering.jpg +/wiki/images/3/31/TechDraw_Arch_piping.jpg +TechDraw_New_Default +/wiki/images/thumb/2/27/TechDraw_New_Default.png/32px-TechDraw_New_Default.png +/wiki/images/thumb/2/27/TechDraw_New_Default.png/24px-TechDraw_New_Default.png +TechDraw_Templates +TechDraw_TemplateHowTo +/wiki/images/thumb/8/87/InkDocProp.png/800px-InkDocProp.png +/wiki/images/thumb/6/6b/InkXMLNameSpace.png/800px-InkXMLNameSpace.png +/wiki/images/thumb/b/b7/InkFinishedArt.png/800px-InkFinishedArt.png +/wiki/images/thumb/b/b2/InkXMLeditableTag.png/800px-InkXMLeditableTag.png +/wiki/images/thumb/a/a9/InkXMLviewBox.png/800px-InkXMLviewBox.png +/wiki/images/thumb/6/6e/InkMuchTooBig.png/800px-InkMuchTooBig.png +/wiki/images/d/d8/FCTemplateHow.png +TechDraw_Preferences +/wiki/images/9/94/TechDraw_Preferences1.png +/wiki/images/thumb/6/6e/TechDraw_NewProjGroup.png/24px-TechDraw_NewProjGroup.png +/wiki/images/thumb/c/cc/Techdraw-hatch.png/24px-Techdraw-hatch.png +/wiki/images/thumb/4/45/TechDraw_NewSection.png/24px-TechDraw_NewSection.png +/wiki/images/thumb/f/f9/TechDraw_New_Pick.png/24px-TechDraw_New_Pick.png +/wiki/images/thumb/0/00/TechDraw_Hatch.png/24px-TechDraw_Hatch.png +/wiki/images/c/cb/TechDraw_Preferences2.png +/wiki/images/thumb/9/93/TechDraw_New_Detail.png/24px-TechDraw_New_Detail.png +/wiki/images/thumb/6/6c/TechDraw_GeomHatch.png/24px-TechDraw_GeomHatch.png +TechDraw_GeomHatch +/wiki/images/6/6c/TechDraw_GeomHatch.png +/wiki/images/thumb/c/c9/Techdraw-geomhatch.png/16px-Techdraw-geomhatch.png +/wiki/images/thumb/5/5d/View-rotate-right.png/16px-View-rotate-right.png +TechDraw_NewDetail +/wiki/images/thumb/9/93/TechDraw_New_Detail.png/32px-TechDraw_New_Detail.png +/wiki/images/thumb/9/98/ViewDetail.png/300px-ViewDetail.png +/wiki/images/thumb/7/72/Techdraw-viewdetail.png/24px-Techdraw-viewdetail.png +TechDraw_LineGroup +TechDraw_NewSection +/wiki/images/thumb/4/45/TechDraw_NewSection.png/32px-TechDraw_NewSection.png +/wiki/images/7/76/ViewSection.png +/wiki/images/thumb/e/e9/Techdraw-viewsection.png/24px-Techdraw-viewsection.png +/wiki/images/thumb/2/2b/TaskViewSection.png/300px-TaskViewSection.png +TechDraw_Hatching +/wiki/images/thumb/c/cc/Techdraw-hatch.png/32px-Techdraw-hatch.png +/wiki/images/thumb/c/c9/Techdraw-geomhatch.png/32px-Techdraw-geomhatch.png +/wiki/images/c/c0/SelectFace.png +TechDraw_Hatch +/wiki/images/thumb/0/00/TechDraw_Hatch.png/32px-TechDraw_Hatch.png +/wiki/images/thumb/0/00/TechDraw_Hatch.png/16px-TechDraw_Hatch.png +TechDraw_NewProjGroup +/wiki/images/thumb/6/6e/TechDraw_NewProjGroup.png/32px-TechDraw_NewProjGroup.png +/wiki/images/8/8a/ProjGroupSample.png +/wiki/images/thumb/6/62/Techdraw-projgroup.png/24px-Techdraw-projgroup.png +/wiki/images/thumb/f/f7/TaskProjGroup.png/300px-TaskProjGroup.png +TechDraw_New_Pick +/wiki/images/thumb/f/f9/TechDraw_New_Pick.png/32px-TechDraw_New_Pick.png +Material +Arch_SetMaterial +/wiki/images/thumb/0/04/Arch_SetMaterial.png/32px-Arch_SetMaterial.png +/wiki/images/5/52/Arch_materials_01.jpg +/wiki/images/thumb/0/04/Arch_SetMaterial.png/16px-Arch_SetMaterial.png +/wiki/images/5/5c/Arch_materials_02.jpg +Material_editor +/wiki/images/d/db/Material_editor.jpg +Drawing_SpreadsheetView +/wiki/images/thumb/2/2f/Drawing_SpreadsheetView.png/32px-Drawing_SpreadsheetView.png +/wiki/images/thumb/0/02/Drawing_spreadsheetview.jpg/640px-Drawing_spreadsheetview.jpg +/wiki/images/thumb/2/2f/Drawing_SpreadsheetView.png/16px-Drawing_SpreadsheetView.png +Draft_Rectangle +/wiki/images/thumb/1/14/Draft_Rectangle.png/32px-Draft_Rectangle.png +/wiki/images/thumb/7/76/Draft_Rectangle_example.jpg/400px-Draft_Rectangle_example.jpg +/wiki/images/thumb/1/14/Draft_Rectangle.png/16px-Draft_Rectangle.png +Draft_Mirror +/wiki/images/thumb/3/3f/Draft_Mirror.png/32px-Draft_Mirror.png +/wiki/images/thumb/c/c8/Draft_Mirror_example.jpg/400px-Draft_Mirror_example.jpg +/wiki/images/thumb/3/3f/Draft_Mirror.png/16px-Draft_Mirror.png +Expressions +/wiki/images/thumb/b/b2/Sketcher_Expressions.png/24px-Sketcher_Expressions.png +Sketcher_ToggleConstraint +Part_JoinCutout +/wiki/images/thumb/c/c4/Part_JoinCutout.png/32px-Part_JoinCutout.png +/wiki/images/thumb/5/57/JoinFeatures_Cutout.png/600px-JoinFeatures_Cutout.png +/wiki/images/thumb/f/fb/JoinFeatures_Example_step1.png/320px-JoinFeatures_Example_step1.png +/wiki/images/thumb/d/da/JoinFeatures_Example_step2.png/320px-JoinFeatures_Example_step2.png +/wiki/images/thumb/9/9e/JoinFeatures_Example_step3_Cutout.png/320px-JoinFeatures_Example_step3_Cutout.png +/wiki/images/thumb/a/a0/JoinFeatures-Algo-Cutout.png/800px-JoinFeatures-Algo-Cutout.png +Part_JoinEmbed +/wiki/images/thumb/b/bc/Part_JoinEmbed.png/32px-Part_JoinEmbed.png +/wiki/images/thumb/5/5e/JoinFeatures_Embed.png/600px-JoinFeatures_Embed.png +/wiki/images/thumb/8/8b/JoinFeatures_Example_step3_Embed.png/320px-JoinFeatures_Example_step3_Embed.png +/wiki/images/thumb/5/54/JoinFeatures_Example_step4_Embed.png/320px-JoinFeatures_Example_step4_Embed.png +/wiki/images/thumb/8/87/JoinFeatures-Algo-Embed.png/800px-JoinFeatures-Algo-Embed.png +Part_JoinConnect +/wiki/images/thumb/9/95/Part_JoinConnect.png/32px-Part_JoinConnect.png +/wiki/images/thumb/f/f3/JoinFeatures_Connect.png/600px-JoinFeatures_Connect.png +/wiki/images/thumb/f/f6/JoinFeatures_Example_step3_Connect.png/320px-JoinFeatures_Example_step3_Connect.png +/wiki/images/thumb/6/6b/JoinFeatures_Example_step4_Connect.png/320px-JoinFeatures_Example_step4_Connect.png +Release_notes_011 +/wiki/images/thumb/2/2d/FreeCAD011.png/800px-FreeCAD011.png +/wiki/images/a/ab/Release011-translation.jpg +/wiki/images/1/17/Release011-dependency.jpg +/wiki/images/3/34/Release011-sketcher.jpg +/wiki/images/a/ab/Movie.png +/wiki/images/a/a5/Release011-robot.jpg +/wiki/images/e/ef/Release011-draft-drawing.jpg +/wiki/images/f/f1/Release011-draft.jpg +Draft_API +Release_notes_012 +/wiki/images/6/67/FreeCAD_start_center.jpg +/wiki/images/thumb/3/33/Rim_bling.png/800px-Rim_bling.png +/wiki/images/d/dd/Arch_screenshot.jpg +/wiki/images/4/45/Draft_taskview.jpg +Release_notes_013 +Release_notes_0.14 +Release_notes_015 +Draft_UndoLine +/wiki/images/thumb/d/dd/Draft_UndoLine.png/32px-Draft_UndoLine.png +/wiki/images/thumb/d/dd/Draft_UndoLine.png/16px-Draft_UndoLine.png +Draft_Constrain +/wiki/images/f/fc/Draft_Constrain_example.jpg +Draft_Snap +/wiki/images/thumb/3/30/Snap_Lock.png/32px-Snap_Lock.png +/wiki/images/0/06/Draft_Snap_example.jpg +/wiki/images/thumb/d/db/Snap_Midpoint.png/32px-Snap_Midpoint.png +/wiki/images/thumb/4/4a/Snap_Perpendicular.png/32px-Snap_Perpendicular.png +/wiki/images/thumb/f/f5/Snap_Grid.png/32px-Snap_Grid.png +/wiki/images/thumb/8/8c/Snap_Intersection.png/32px-Snap_Intersection.png +/wiki/images/thumb/6/66/Snap_Parallel.png/32px-Snap_Parallel.png +/wiki/images/thumb/4/4a/Snap_Endpoint.png/32px-Snap_Endpoint.png +/wiki/images/thumb/c/c0/Snap_Angle.png/32px-Snap_Angle.png +/wiki/images/thumb/4/4f/Snap_Center.png/32px-Snap_Center.png +/wiki/images/thumb/3/31/Snap_Extension.png/32px-Snap_Extension.png +/wiki/images/thumb/f/f7/Snap_Near.png/32px-Snap_Near.png +/wiki/images/thumb/e/e3/Snap_Ortho.png/32px-Snap_Ortho.png +/wiki/images/thumb/3/32/Snap_Special.png/32px-Snap_Special.png +/wiki/images/thumb/3/3b/Snap_Dimensions.png/32px-Snap_Dimensions.png +/wiki/images/thumb/9/99/Snap_WorkingPlane.png/32px-Snap_WorkingPlane.png +Draft_ToggleSnap +/wiki/images/thumb/2/25/Draft_ToggleSnap.png/32px-Draft_ToggleSnap.png +Draft_WorkingPlane +/wiki/images/thumb/8/81/Draft_WorkingPlane.png/32px-Draft_WorkingPlane.png +Draft_Ortho +/wiki/images/thumb/a/a5/Draft_Ortho.png/32px-Draft_Ortho.png +Draft_Near +/wiki/images/thumb/b/b3/Draft_Near.png/32px-Draft_Near.png +Draft_Extension +/wiki/images/thumb/c/c2/Draft_Extension.png/32px-Draft_Extension.png +Draft_Center +/wiki/images/thumb/9/9a/Draft_Center.png/32px-Draft_Center.png +Draft_Angle +/wiki/images/thumb/8/87/Draft_Angle.png/32px-Draft_Angle.png +Draft_Endpoint +/wiki/images/thumb/6/67/Draft_Endpoint.png/32px-Draft_Endpoint.png +Draft_Parallel +/wiki/images/thumb/2/23/Draft_Parallel.png/32px-Draft_Parallel.png +Draft_Intersection +/wiki/images/thumb/f/ff/Draft_Intersection.png/32px-Draft_Intersection.png +Draft_ToggleGrid +/wiki/images/thumb/f/fc/Draft_ToggleGrid.png/32px-Draft_ToggleGrid.png +Draft_Perpendicular +/wiki/images/thumb/f/f7/Draft_Perpendicular.png/32px-Draft_Perpendicular.png +Draft_Midpoint +/wiki/images/thumb/7/78/Draft_Midpoint.png/32px-Draft_Midpoint.png +Draft_Coordinates +/wiki/images/5/5e/Draft_Coordinates.jpg +/wiki/images/thumb/7/72/PreferencesDecimals_01_en.png/480px-PreferencesDecimals_01_en.png +Draft_Linestyle +/wiki/images/e/ea/Draft-linestyle.jpg +/wiki/images/d/dd/Draft_Style_01.png +/wiki/images/8/81/Draft_Style_Couleur_Ligne.png +/wiki/images/8/8c/Draft_Style_Couleur_Face.png +/wiki/images/9/91/Draft_Style_Epaisseur_Ligne.png +/wiki/images/1/14/Draft_Style_Style.png +/wiki/images/thumb/6/64/Draft_Apply.png/16px-Draft_Apply.png +Draft_Select +/wiki/images/thumb/b/b7/Draft_selection_01.png/267px-Draft_selection_01.png +/wiki/images/thumb/0/0c/Draft_selection_02.png/267px-Draft_selection_02.png +/wiki/images/thumb/7/7b/Draft_selection_03.png/267px-Draft_selection_03.png +/wiki/images/thumb/e/ec/Draft_Selection_Menu.png/142px-Draft_Selection_Menu.png +/wiki/images/thumb/2/2d/Draft_selection_04.png/267px-Draft_selection_04.png +/wiki/images/thumb/6/64/Draft_Apply.png/24px-Draft_Apply.png +/wiki/images/thumb/5/56/FreeCAD_Menu_Edition_Peferences.png/142px-FreeCAD_Menu_Edition_Peferences.png +/wiki/images/thumb/d/d4/Draft_Preferences_Selection_Couleurs.png/241px-Draft_Preferences_Selection_Couleurs.png +Draft_Apply +/wiki/images/thumb/6/64/Draft_Apply.png/32px-Draft_Apply.png +Draft_SelectPlane +/wiki/images/thumb/a/aa/Draft_SelectPlane.png/32px-Draft_SelectPlane.png +/wiki/images/7/7b/Workingplane_example.jpg +/wiki/images/thumb/a/aa/Draft_SelectPlane.png/16px-Draft_SelectPlane.png +Basic_modeling_tutorial +/wiki/images/1/1a/Switch_PartWorkbench.JPG +/wiki/images/4/43/Tutorial-normand01.jpg +/wiki/images/e/ea/Tutorial-normand02.jpg +/wiki/images/5/5a/Tutorial-normand03.jpg +/wiki/images/d/de/Tutorial-normand04.jpg +/wiki/images/0/0d/Tutorial-normand05.jpg +/wiki/images/thumb/4/4a/Part_Fillet.png/32px-Part_Fillet.png +/wiki/images/d/de/Tutorial-normand06.jpg +/wiki/images/8/8d/Switch_DraftWorkbench.JPG +/wiki/images/a/ac/DraftPlaneAuto.png +/wiki/images/thumb/0/00/Draft_Wire.png/32px-Draft_Wire.png +/wiki/images/9/96/Tutorial-normand07.jpg +/wiki/images/1/1e/Tutorial-normand08.jpg +/wiki/images/7/7e/DraftPlaneNone.png +/wiki/images/3/3e/DraftPlaneTop.png +/wiki/images/4/4e/DraftPlaneView.png +/wiki/images/b/b4/DraftPlaneTasks.png +/wiki/images/6/69/DraftPlaneToolbarMode.png +Part_Fillet +/wiki/images/a/ac/Dialog-fillet.jpg +PartDesign_Fillet +/wiki/images/thumb/c/c7/PartDesign_Fillet.png/32px-PartDesign_Fillet.png +/wiki/images/thumb/a/a3/PartDesign_Fillet-01.png/300px-PartDesign_Fillet-01.png +/wiki/images/thumb/6/6d/PartDesign_Fillet-02.png/300px-PartDesign_Fillet-02.png +/wiki/images/thumb/8/86/PartDesign_Fillet-03.png/300px-PartDesign_Fillet-03.png +/wiki/images/thumb/c/c7/PartDesign_Fillet.png/16px-PartDesign_Fillet.png +Part_Chamfer +/wiki/images/thumb/8/87/Part_Chamfer.png/32px-Part_Chamfer.png +/wiki/images/e/e8/Chamfer-example.png +/wiki/images/8/8c/Part_Chamfer.svg +/wiki/images/7/7f/Dialog-chamfer.png +/wiki/images/5/53/Part_Chamfer-Properties.png +Part_API +TopoShape_API +Draft_Wire +/wiki/images/thumb/4/47/Draft_Polyline_example.jpg/400px-Draft_Polyline_example.jpg +/wiki/images/thumb/0/00/Draft_Wire.png/16px-Draft_Wire.png +GuiCommand_model +/wiki/images/d/d8/FreeCAD05.png +/wiki/images/thumb/2/29/Std_Close.png/24px-Std_Close.png +/wiki/images/thumb/a/a5/Part_Box.png/24px-Part_Box.png +Draft_ShapeString +/wiki/images/thumb/f/f7/Draft_ShapeString.png/32px-Draft_ShapeString.png +/wiki/images/b/b7/Draft_ShapeString_Example400.png +/wiki/images/8/8a/Draft_ShapeString16.png +/wiki/images/9/9f/SSFontSelect.png +Draft_ShapeString_tutorial +/wiki/images/thumb/f/f7/Draft_ShapeString.png/16px-Draft_ShapeString.png +/wiki/images/thumb/8/8a/View-axometric.png/32px-View-axometric.png +/wiki/images/thumb/7/7b/View-zoom-all.png/32px-View-zoom-all.png +/wiki/images/thumb/1/18/TutorialDraftShapeString_BasicShape.jpg/300px-TutorialDraftShapeString_BasicShape.jpg +/wiki/images/thumb/a/a4/TutorialDraftShapeString_DraftShapestring.jpg/300px-TutorialDraftShapeString_DraftShapestring.jpg +/wiki/images/thumb/3/37/TutorialDraftShapeString_Sketch.jpg/600px-TutorialDraftShapeString_Sketch.jpg +/wiki/images/thumb/f/f4/TutorialDraftShapeString_Position.jpg/600px-TutorialDraftShapeString_Position.jpg +/wiki/images/thumb/4/48/TutorialDraftShapeString_Complete.jpg/300px-TutorialDraftShapeString_Complete.jpg +Import_text_and_geometry_from_Inkscape +Std_UnitsCalculator +/wiki/images/thumb/d/de/Std_UnitsCalculator.png/32px-Std_UnitsCalculator.png +/wiki/images/b/b5/Units_Calculator_it.png +UTF_Project +Raytracing_project +/wiki/images/0/0c/LuxRenderOutput.png +Quality_project +/wiki/images/thumb/2/25/HelpViewer.jpg/150px-HelpViewer.jpg +Robot_SetDefaultOrientation +/wiki/images/thumb/e/e0/Robot_SetDefaultOrientation.png/32px-Robot_SetDefaultOrientation.png +Std_WhatsThis +/wiki/images/thumb/d/d7/Std_WhatsThis.png/32px-Std_WhatsThis.png +Std_Help_Menu +/wiki/images/thumb/3/31/Std_Help.png/32px-Std_Help.png +/wiki/images/thumb/e/e1/Std_OnlineHelp.png/32px-Std_OnlineHelp.png +/wiki/images/thumb/8/8d/Std_About.png/32px-Std_About.png +Std_About +/wiki/images/a/a5/Std_About_en.png +Std_Help +Std_ViewXX +/wiki/images/thumb/6/6c/Std_ViewXX.png/32px-Std_ViewXX.png +Std_ViewExamples +/wiki/images/thumb/0/0c/Std_ViewExamples.png/32px-Std_ViewExamples.png +Std_TipOfTheDay +/wiki/images/thumb/a/ab/Std_TipOfTheDay.png/32px-Std_TipOfTheDay.png +Std_PythonWebsite +/wiki/images/thumb/2/2e/Std_PythonWebsite.png/32px-Std_PythonWebsite.png +Std_OnlineHelpWebsite +/wiki/images/thumb/3/31/Std_OnlineHelpWebsite.png/32px-Std_OnlineHelpWebsite.png +Std_OnlineHelpPython +/wiki/images/thumb/3/35/Std_OnlineHelpPython.png/32px-Std_OnlineHelpPython.png +Std_OnlineHelp +Std_FreeCADWebsite +Std_CommandLine +/wiki/images/thumb/2/26/Std_CommandLine.png/32px-Std_CommandLine.png +Mesh_VertexCurvature +Mesh_Transform +Mesh_ToolMesh +Mesh_PolySplit +Mesh_PolySegm +Mesh_PolyCut +Mesh_FromGeometry +Mesh_ExMakeUnion +Mesh_ExMakeTool +Mesh_ExMakeMesh +Mesh_Evaluation +Mesh_EvaluateSolid +/wiki/images/2/24/Mesh_EvaluateSolid.png +Mesh_Demolding +Mesh_CurvatureInfo +Resource_framework_project +/wiki/images/thumb/e/e5/ResourceFramework.png/1000px-ResourceFramework.png +Units_project +Arch_Concept +/wiki/images/thumb/a/a0/BldgComponents.png/800px-BldgComponents.png +Assembly_project +/wiki/images/thumb/7/78/Gripper.jpg/400px-Gripper.jpg +/wiki/images/thumb/7/70/MultiModel.png/600px-MultiModel.png +/wiki/images/thumb/f/f7/Product_structure_modeling_Process-Data_diagram.gif/500px-Product_structure_modeling_Process-Data_diagram.gif +Assembly_Basic_Tutorial +/wiki/images/thumb/d/d8/Bodycs.png/250px-Bodycs.png +/wiki/images/thumb/4/45/Partcs.png/350px-Partcs.png +/wiki/images/thumb/f/f2/Productcs.png/400px-Productcs.png +/wiki/images/thumb/5/58/Geometry.png/250px-Geometry.png +PartDesign_project +/wiki/images/thumb/7/78/Gripper.jpg/300px-Gripper.jpg +/wiki/images/thumb/7/7e/TaskPanel.jpg/400px-TaskPanel.jpg +/wiki/images/f/f4/CAD_Modeling.gif +/wiki/images/thumb/3/3b/Counterbore_settings.png/300px-Counterbore_settings.png +/wiki/images/thumb/5/53/Counterbore_settings2.png/300px-Counterbore_settings2.png +/wiki/images/thumb/3/3d/Countersink_settings.png/300px-Countersink_settings.png +/wiki/images/thumb/f/f0/PartDesign_ModlingObjectsHirachy.png/1000px-PartDesign_ModlingObjectsHirachy.png +PartDesign_Bearingholder_Tutorial_II +/wiki/images/thumb/9/90/HolderTop2-19.jpg/400px-HolderTop2-19.jpg +/wiki/images/thumb/1/19/HolderTop2-2.png/400px-HolderTop2-2.png +/wiki/images/thumb/1/14/HolderTop2-2-1.jpg/400px-HolderTop2-2-1.jpg +/wiki/images/thumb/8/86/HolderTop2-3.jpg/400px-HolderTop2-3.jpg +/wiki/images/thumb/c/cd/HolderTop2-4.jpg/400px-HolderTop2-4.jpg +/wiki/images/thumb/6/6a/HolderTop2-5.jpg/400px-HolderTop2-5.jpg +/wiki/images/thumb/b/bc/HolderTop2-6.jpg/400px-HolderTop2-6.jpg +/wiki/images/thumb/c/cc/HolderTop2-7.jpg/400px-HolderTop2-7.jpg +/wiki/images/thumb/3/32/HolderTop2-8.jpg/400px-HolderTop2-8.jpg +/wiki/images/thumb/6/6b/HolderTop2-13.jpg/400px-HolderTop2-13.jpg +/wiki/images/thumb/c/c7/HolderTop2-14.jpg/400px-HolderTop2-14.jpg +/wiki/images/thumb/6/6a/HolderTop2-16.jpg/400px-HolderTop2-16.jpg +/wiki/images/thumb/c/c5/HolderTop2-9.jpg/300px-HolderTop2-9.jpg +/wiki/images/thumb/e/e8/HolderTop2-10.jpg/400px-HolderTop2-10.jpg +/wiki/images/thumb/a/a9/HolderTop2-11.jpg/400px-HolderTop2-11.jpg +/wiki/images/thumb/d/d9/HolderTop2-15.jpg/400px-HolderTop2-15.jpg +/wiki/images/thumb/e/e3/HolderTop2-17.jpg/400px-HolderTop2-17.jpg +/wiki/images/thumb/b/bf/HolderTop2-18.jpg/400px-HolderTop2-18.jpg +PartDesign_Bearingholder_Tutorial_I +/wiki/images/thumb/e/e3/HolderTop1-1.jpg/400px-HolderTop1-1.jpg +/wiki/images/thumb/8/84/HolderTop1-2.jpg/400px-HolderTop1-2.jpg +/wiki/images/thumb/c/c7/HolderTop1-3.jpg/400px-HolderTop1-3.jpg +/wiki/images/thumb/e/e7/HolderTop1-4.jpg/400px-HolderTop1-4.jpg +/wiki/images/thumb/7/7a/HolderTop1-5.jpg/400px-HolderTop1-5.jpg +/wiki/images/thumb/b/b4/HolderTop1-6.jpg/400px-HolderTop1-6.jpg +/wiki/images/thumb/1/1f/HolderTop1-7.jpg/400px-HolderTop1-7.jpg +/wiki/images/thumb/d/d5/HolderTop1-8.jpg/400px-HolderTop1-8.jpg +/wiki/images/thumb/2/26/HolderTop1-9.jpg/400px-HolderTop1-9.jpg +/wiki/images/thumb/7/78/HolderTop1-10.jpg/400px-HolderTop1-10.jpg +/wiki/images/thumb/3/3e/HolderTop1-11.jpg/400px-HolderTop1-11.jpg +/wiki/images/thumb/1/1e/HolderTop1-13.jpg/400px-HolderTop1-13.jpg +/wiki/images/thumb/b/bd/HolderTop1-12.jpg/400px-HolderTop1-12.jpg +/wiki/images/thumb/8/8c/HolderTop1-14.jpg/400px-HolderTop1-14.jpg +/wiki/images/thumb/0/05/HolderTop1-15.jpg/400px-HolderTop1-15.jpg +/wiki/images/thumb/8/86/HolderTop1-16.jpg/400px-HolderTop1-16.jpg +/wiki/images/thumb/d/d6/HolderTop1-17.jpg/400px-HolderTop1-17.jpg +Sketcher_project +FreeCAD_development_model_project +FreeCAD_development_model +Naming_project +/wiki/images/c/c4/NamingExample.jpg +STEP_project +/wiki/images/f/f7/Product_structure_modeling_Process-Data_diagram.gif +Project_template +FEM_CalculiX +FEM_Mesh_CalculiX +/wiki/images/thumb/1/17/Seg2.png/250px-Seg2.png +/wiki/images/thumb/c/cc/Seg3--fc.png/250px-Seg3--fc.png +/wiki/images/thumb/1/1a/Seg3--ccx.png/250px-Seg3--ccx.png +/wiki/images/thumb/5/59/Tria3--fc.png/250px-Tria3--fc.png +/wiki/images/thumb/f/f7/Tria6--fc.png/250px-Tria6--fc.png +/wiki/images/thumb/9/9e/Tria3--ccx.png/250px-Tria3--ccx.png +/wiki/images/thumb/8/83/Tria6--ccx.png/250px-Tria6--ccx.png +/wiki/images/thumb/e/ef/Quad4--fc.png/250px-Quad4--fc.png +/wiki/images/thumb/9/9e/Quad8--fc.png/250px-Quad8--fc.png +/wiki/images/thumb/2/26/Quad4--ccx.png/250px-Quad4--ccx.png +/wiki/images/thumb/b/b8/Quad8--ccx.png/250px-Quad8--ccx.png +/wiki/images/thumb/0/06/Tetra4--fc.png/250px-Tetra4--fc.png +/wiki/images/thumb/1/16/Tetra10--fc.png/250px-Tetra10--fc.png +/wiki/images/thumb/0/0c/Tetra4--ccx.png/250px-Tetra4--ccx.png +/wiki/images/thumb/8/8d/Tetra10--ccx.png/250px-Tetra10--ccx.png +/wiki/images/thumb/e/e9/Hexa8--fc.png/250px-Hexa8--fc.png +/wiki/images/thumb/8/86/Hexa20--fc.png/250px-Hexa20--fc.png +/wiki/images/thumb/0/0f/Hexa8--ccx.png/250px-Hexa8--ccx.png +/wiki/images/thumb/e/eb/Hexa20--ccx.png/250px-Hexa20--ccx.png +/wiki/images/thumb/3/33/Penta6--fc.png/250px-Penta6--fc.png +/wiki/images/thumb/b/b4/Penta15--fc.png/250px-Penta15--fc.png +/wiki/images/thumb/1/1e/Penta6--ccx.png/250px-Penta6--ccx.png +/wiki/images/thumb/a/af/Penta15--ccx.png/250px-Penta15--ccx.png +FEM_Element_Types +/wiki/images/4/40/Segments.gif +/wiki/images/5/51/Triangles.gif +/wiki/images/8/88/Quadrangles.gif +/wiki/images/2/21/Tetraedres.gif +/wiki/images/a/aa/Pyramides.gif +/wiki/images/f/fe/Hexaedres.gif +/wiki/images/5/52/Pentaedres.gif +FEM_Mesh +/wiki/images/d/d4/Edit_OK.svg +Add_FEM_Constraint_Tutorial +Add_FEM_Equation_Tutorial +Extend_FEM_Module +FEM_Shear_of_a_Composite_Block +/wiki/images/thumb/c/c7/Pic1.png/700px-Pic1.png +/wiki/images/thumb/5/57/Pic2.png/700px-Pic2.png +/wiki/images/thumb/a/a7/Pic3.png/700px-Pic3.png +/wiki/images/thumb/c/cd/Pic4.png/700px-Pic4.png +/wiki/images/thumb/1/16/Pic5.png/700px-Pic5.png +/wiki/images/thumb/3/36/Pic6.png/700px-Pic6.png +/wiki/images/thumb/c/ca/Pic7.png/700px-Pic7.png +/wiki/images/thumb/7/7e/Pic8.png/700px-Pic8.png +/wiki/images/thumb/f/fb/PIC9.png/700px-PIC9.png +/wiki/images/thumb/a/a7/Pic10.png/700px-Pic10.png +/wiki/images/thumb/d/d9/Figure_11_Deformed_Mesh.png/700px-Figure_11_Deformed_Mesh.png +/wiki/images/thumb/3/31/Figure12_Deformed_Mesh_Clipped_View_%282%29.png/700px-Figure12_Deformed_Mesh_Clipped_View_%282%29.png +FEM_Tutorial_Python +/wiki/images/thumb/1/1a/FEM_example01_pic00.jpg/700px-FEM_example01_pic00.jpg +FEM_CalculiX_Cantilever_3D +/wiki/images/thumb/3/37/FEM_example01_pic01.jpg/700px-FEM_example01_pic01.jpg +/wiki/images/thumb/8/8f/FEM_example01_pic02.jpg/700px-FEM_example01_pic02.jpg +/wiki/images/thumb/b/b7/FEM_Solver.png/32px-FEM_Solver.png +/wiki/images/1/1e/FEM_Material.png +/wiki/images/thumb/d/d3/FEM_FixedConstraint.png/32px-FEM_FixedConstraint.png +/wiki/images/thumb/5/5f/FEM_ForceConstraint.png/32px-FEM_ForceConstraint.png +/wiki/images/thumb/1/19/FEM_Create.png/32px-FEM_Create.png +/wiki/images/thumb/f/f5/FEM_ShowResult.png/16px-FEM_ShowResult.png +/wiki/images/thumb/a/ac/FEM_example01_pic03.jpg/400px-FEM_example01_pic03.jpg +/wiki/images/thumb/e/eb/FEM_PurgeResults.png/32px-FEM_PurgeResults.png +/wiki/images/thumb/c/ca/FEM_example01_pic04.jpg/400px-FEM_example01_pic04.jpg +/wiki/images/thumb/8/85/FEM_RunCalculiXccx.png/32px-FEM_RunCalculiXccx.png +/wiki/images/thumb/2/29/FEM_example01_pic05.jpg/700px-FEM_example01_pic05.jpg +/wiki/images/thumb/d/da/FEM_example01_pic06.jpg/400px-FEM_example01_pic06.jpg +Fem_Preferences +/wiki/images/6/6c/Preference_Fem_Tab_01.png +/wiki/images/c/c9/Preference_Fem_Tab_02.png +/wiki/images/4/40/Preference_Fem_Tab_03.png +/wiki/images/0/0b/Preference_Fem_Tab_04.png +/wiki/images/b/b6/Preference_Fem_Tab_05.png +FEM_MeshPrintInfo +FEM_MeshClear +FEM_PostCreateFunctions +/wiki/images/thumb/7/7c/FEM_PostCreateFunctions.png/32px-FEM_PostCreateFunctions.png +FEM_PostCreateDataAtPointFilter +FEM_PostCreateLinearizedStressesFilter +FEM_PostCreateDataAlongLineFilter +FEM_PostCreateWarpVectorFilter +/wiki/images/thumb/4/48/FEM_PostCreateWarpVectorFilter.png/32px-FEM_PostCreateWarpVectorFilter.png +FEM_PostCreateCutFilter +/wiki/images/thumb/c/ce/FEM_PostCreateCutFilter.png/32px-FEM_PostCreateCutFilter.png +FEM_PostCreateScalarClipFilter +/wiki/images/thumb/3/32/FEM_PostCreateScalarClipFilter.png/32px-FEM_PostCreateScalarClipFilter.png +FEM_PostCreateClipFilter +/wiki/images/thumb/6/63/FEM_PostCreateClipFilter.png/32px-FEM_PostCreateClipFilter.png +FEM_PostPipelineFromResult +/wiki/images/thumb/1/10/FEM_PostPipelineFromResult.png/32px-FEM_PostPipelineFromResult.png +/wiki/images/thumb/1/10/FEM_PostPipelineFromResult.png/24px-FEM_PostPipelineFromResult.png +/wiki/images/9/93/Pipeline.PNG +/wiki/images/1/10/SIMTUT_05.PNG +FEM_PostApplyChanges +FEM_ResultShow +/wiki/images/thumb/f/f5/FEM_ShowResult.png/32px-FEM_ShowResult.png +FEM_ResultsPurge +FEM_SolverRun +/wiki/images/thumb/8/83/FEM_RunSolver.png/32px-FEM_RunSolver.png +FEM_SolverControl +/wiki/images/thumb/a/a4/FEM_ControlSolver.png/32px-FEM_ControlSolver.png +FEM_EquationFlow +FEM_EquationFluxsolver +FEM_EquationElectrostatic +FEM_EquationElasticity +FEM_EquationHeat +FEM_SolverZ88 +/wiki/images/thumb/1/15/FEM_SolverZ88.png/32px-FEM_SolverZ88.png +FEM_SolverElmer +FEM_SolverCalculiX +FEM_SolverCalculixCxxtools +/wiki/images/thumb/b/b7/FEM_Solver.png/24px-FEM_Solver.png +/wiki/images/thumb/0/01/FEM_MaterialMechanicalNonlinear.png/24px-FEM_MaterialMechanicalNonlinear.png +FEM_FemMesh2Mesh +/wiki/images/thumb/5/5f/FEM_FemMesh2Mesh.png/32px-FEM_FemMesh2Mesh.png +/wiki/images/thumb/5/5f/FEM_FemMesh2Mesh.png/24px-FEM_FemMesh2Mesh.png +FEM_CreateNodesSet +/wiki/images/thumb/f/f3/FEM_CreateNodesSet.png/32px-FEM_CreateNodesSet.png +FEM_MeshGroup +/wiki/images/thumb/9/9d/FEM_MeshGroup.png/32px-FEM_MeshGroup.png +FEM_MeshRegion +/wiki/images/thumb/a/a6/FEM_MeshRegion.png/32px-FEM_MeshRegion.png +FEM_MeshBoundaryLayer +FEM_MeshGmshFromShape +/wiki/images/thumb/b/b4/FEM_MeshGmshFromShape.png/32px-FEM_MeshGmshFromShape.png +FEM_MeshNetgenFromShape +/wiki/images/thumb/8/8f/FEM_MeshNetgenFromShape.png/32px-FEM_MeshNetgenFromShape.png +FEM_ConstraintFlowVelocity +FEM_ConstraintFluidBoundary +/wiki/images/thumb/8/8b/FEM_ConstraintFluidBoundary.png/32px-FEM_ConstraintFluidBoundary.png +FEM_ConstraintInitialFlowVelocity +FEM_ConstraintBodyHeatSource +FEM_ConstraintTemperature +/wiki/images/thumb/0/00/FEM_ConstraintTemperature.png/32px-FEM_ConstraintTemperature.png +FEM_ConstraintHeatflux +/wiki/images/thumb/f/f0/FEM_ConstraintHeatflux.png/32px-FEM_ConstraintHeatflux.png +FEM_ConstraintInitialTemperature +/wiki/images/thumb/6/66/FEM_ConstraintInitialTemperature.png/32px-FEM_ConstraintInitialTemperature.png +FEM_ConstraintPulley +/wiki/images/thumb/0/03/FEM_ConstraintPulley.png/32px-FEM_ConstraintPulley.png +FEM_ConstraintGear +/wiki/images/thumb/0/08/FEM_ConstraintGear.png/32px-FEM_ConstraintGear.png +FEM_ConstraintBearing +/wiki/images/thumb/e/ea/FEM_ConstraintBearing.png/32px-FEM_ConstraintBearing.png +FEM_ConstraintSelfWeight +/wiki/images/thumb/9/97/FEM_ConstraintSelfWeight.png/32px-FEM_ConstraintSelfWeight.png +FEM_ConstraintTransform +/wiki/images/thumb/3/38/FEM_ConstraintTransform.png/32px-FEM_ConstraintTransform.png +FEM_ConstraintContact +/wiki/images/thumb/a/a2/FEM_ConstraintContact.png/32px-FEM_ConstraintContact.png +FEM_ConstraintPlaneRotation +/wiki/images/thumb/8/8d/FEM_ConstraintPlaneRotation.png/32px-FEM_ConstraintPlaneRotation.png +FEM_ConstraintDisplacement +/wiki/images/thumb/c/c6/FEM_ConstraintDisplacement.png/32px-FEM_ConstraintDisplacement.png +FEM_ElementFluid1D +/wiki/images/thumb/d/d4/FEM_ElementFluid1D.png/32px-FEM_ElementFluid1D.png +FEM_ElementGeometry2D +/wiki/images/thumb/8/8f/FEM_ElementGeometry2D.png/32px-FEM_ElementGeometry2D.png +FEM_ElementRotation1D +FEM_ElementGeometry1D +/wiki/images/thumb/4/45/FEM_ElementGeometry1D.png/32px-FEM_ElementGeometry1D.png +FEM_MaterialMechanicalNonlinear +/wiki/images/thumb/0/01/FEM_MaterialMechanicalNonlinear.png/32px-FEM_MaterialMechanicalNonlinear.png +FEM_MaterialFluid +/wiki/images/thumb/7/77/FEM_MaterialFluid.png/32px-FEM_MaterialFluid.png +FEM_Install +FEM_ConstraintForce +/wiki/images/thumb/3/35/FEM_ConstraintForce.png/32px-FEM_ConstraintForce.png +/wiki/images/2/2d/FEMForceConstraintProperties.PNG +/wiki/images/1/1a/ApplyingForceToFace.PNG +/wiki/images/thumb/3/35/FEM_ConstraintForce.png/24px-FEM_ConstraintForce.png +/wiki/images/1/1b/FEMforceonline.PNG +FEM_ConstraintFixed +/wiki/images/thumb/1/14/FEM_ConstraintFixed.png/32px-FEM_ConstraintFixed.png +FEM_MaterialSolid +/wiki/images/thumb/0/09/FEM_MaterialSolid.png/32px-FEM_MaterialSolid.png +/wiki/images/0/0a/FEMMaterialProperties.PNG +FEM_tutorial +/wiki/images/thumb/9/9e/FEM_tutorial_result.png/480px-FEM_tutorial_result.png +/wiki/images/thumb/5/57/FEM_Analysis.png/16px-FEM_Analysis.png +/wiki/images/thumb/d/d3/FEM_FixedConstraint.png/16px-FEM_FixedConstraint.png +/wiki/images/thumb/5/5f/FEM_ForceConstraint.png/16px-FEM_ForceConstraint.png +/wiki/images/thumb/1/1e/FEM_Material.png/16px-FEM_Material.png +/wiki/images/thumb/b/b7/FEM_Solver.png/16px-FEM_Solver.png +/wiki/images/thumb/4/4a/FEM_Calculation.png/16px-FEM_Calculation.png +/wiki/images/thumb/8/85/FEM_RunCalculiXccx.png/16px-FEM_RunCalculiXccx.png +/wiki/images/thumb/e/eb/FEM_PurgeResults.png/16px-FEM_PurgeResults.png +TechDraw_Module +/wiki/images/f/fc/Preferences-techdraw.svg +/wiki/images/thumb/0/02/TechDraw_Workbench_Example.png/600px-TechDraw_Workbench_Example.png +/wiki/images/thumb/9/93/Techdraw-view.png/32px-Techdraw-view.png +/wiki/images/thumb/6/62/Techdraw-projgroup.png/32px-Techdraw-projgroup.png +/wiki/images/thumb/e/e9/Techdraw-viewsection.png/32px-Techdraw-viewsection.png +/wiki/images/thumb/7/72/Techdraw-viewdetail.png/32px-Techdraw-viewdetail.png +/wiki/images/thumb/d/d3/Techdraw-annotation.png/32px-Techdraw-annotation.png +/wiki/images/thumb/f/f3/Techdraw-draft-view.png/32px-Techdraw-draft-view.png +/wiki/images/thumb/d/d5/Techdraw-arch-view.png/32px-Techdraw-arch-view.png +/wiki/images/a/ac/Techdraw-spreadsheet.svg +/wiki/images/2/2e/Techdraw-clip.svg +/wiki/images/8/8c/Techdraw-clipplus.svg +/wiki/images/6/64/Techdraw-clipminus.svg +/wiki/images/thumb/3/38/Dimension_Length.png/32px-Dimension_Length.png +/wiki/images/thumb/b/b3/Dimension_Horizontal.png/32px-Dimension_Horizontal.png +/wiki/images/thumb/5/55/Dimension_Vertical.png/32px-Dimension_Vertical.png +/wiki/images/thumb/a/a2/Dimension_Radius.png/32px-Dimension_Radius.png +/wiki/images/thumb/2/2e/Dimension_Diameter.png/32px-Dimension_Diameter.png +/wiki/images/thumb/7/75/Dimension_Angle.png/32px-Dimension_Angle.png +/wiki/images/thumb/e/ed/Dimension_Link.png/32px-Dimension_Link.png +/wiki/images/thumb/0/08/Techdraw-saveSVG.png/32px-Techdraw-saveSVG.png +/wiki/images/thumb/c/c4/TechDraw_SaveDXF.png/32px-TechDraw_SaveDXF.png +/wiki/images/thumb/0/0e/Techdraw-symbol.png/32px-Techdraw-symbol.png +/wiki/images/thumb/d/d3/Techdraw-image.png/32px-Techdraw-image.png +/wiki/images/thumb/2/2d/Techdraw-toggleframe.png/32px-Techdraw-toggleframe.png +/wiki/images/thumb/2/2d/TechDraw_Tree_Page_Sync.png/32px-TechDraw_Tree_Page_Sync.png +TechDraw_Roadmap +TechDraw_API +TechDrawGui_API +TechDraw_Redraw +/wiki/images/thumb/a/a7/TechDraw_Redraw.png/32px-TechDraw_Redraw.png +/wiki/images/thumb/2/2d/TechDraw_Tree_Page_Sync.png/24px-TechDraw_Tree_Page_Sync.png +TechDraw_Toggle +/wiki/images/thumb/5/5d/TechDraw_Toggle.png/32px-TechDraw_Toggle.png +/wiki/images/4/4f/FramesOn.png +/wiki/images/thumb/6/6b/FramesOff.png/200px-FramesOff.png +/wiki/images/thumb/2/2d/Techdraw-toggleframe.png/24px-Techdraw-toggleframe.png +TechDraw_Image +/wiki/images/4/4d/TechDraw_Image.png +/wiki/images/thumb/d/d3/Techdraw-image.png/24px-Techdraw-image.png +TechDraw_Symbol +/wiki/images/thumb/8/88/TechDraw_Symbol.png/32px-TechDraw_Symbol.png +/wiki/images/thumb/4/46/Symbol.png/24px-Symbol.png +TechDraw_SaveDXF +/wiki/images/thumb/c/c4/TechDraw_SaveDXF.png/24px-TechDraw_SaveDXF.png +TechDraw_SaveSVG +/wiki/images/thumb/0/04/TechDraw_ExportPage.png/32px-TechDraw_ExportPage.png +/wiki/images/thumb/0/0a/TechDraw_SaveSVG.png/24px-TechDraw_SaveSVG.png +TechDraw_Dimension_Link +/wiki/images/thumb/5/58/TechDraw_Dimension_Link.png/32px-TechDraw_Dimension_Link.png +/wiki/images/thumb/5/58/TechDraw_Dimension_Link.png/24px-TechDraw_Dimension_Link.png +TechDraw_Dimension_Angle +/wiki/images/e/e3/TechDraw_Dimension_Angle.png +/wiki/images/thumb/e/e6/LinkDimension.png/24px-LinkDimension.png +/wiki/images/7/74/AngleSample.png +/wiki/images/thumb/7/75/Dimension_Angle.png/24px-Dimension_Angle.png +TechDraw_Dimension_Diameter +/wiki/images/thumb/6/68/TechDraw_Dimension_Diameter.png/32px-TechDraw_Dimension_Diameter.png +/wiki/images/2/29/DiameterSample.png +/wiki/images/thumb/2/2e/Dimension_Diameter.png/24px-Dimension_Diameter.png +TechDraw_Dimension_Radius +/wiki/images/thumb/f/fb/TechDraw_Dimension_Radius.png/32px-TechDraw_Dimension_Radius.png +/wiki/images/thumb/6/69/RadiusSample.png/200px-RadiusSample.png +/wiki/images/thumb/a/a2/Dimension_Radius.png/24px-Dimension_Radius.png +TechDraw_Dimension_Vertical +/wiki/images/thumb/2/20/TechDraw_Dimension_Vertical.png/32px-TechDraw_Dimension_Vertical.png +/wiki/images/a/af/VerticalSample.png +/wiki/images/thumb/5/55/Dimension_Vertical.png/24px-Dimension_Vertical.png +TechDraw_Dimension_Horizontal +/wiki/images/thumb/1/14/TechDraw_Dimension_Horizontal.png/32px-TechDraw_Dimension_Horizontal.png +/wiki/images/5/5d/HorizontalSample.png +/wiki/images/thumb/b/b3/Dimension_Horizontal.png/24px-Dimension_Horizontal.png +TechDraw_Dimension_Length +/wiki/images/thumb/9/99/TechDraw_Dimension_Length.png/32px-TechDraw_Dimension_Length.png +/wiki/images/thumb/8/8e/LengthSample.png/200px-LengthSample.png +/wiki/images/thumb/9/99/TechDraw_Dimension_Length.png/24px-TechDraw_Dimension_Length.png +TechDraw_ClipMinus +/wiki/images/thumb/a/a4/TechDraw_ClipMinus.png/32px-TechDraw_ClipMinus.png +/wiki/images/8/8a/TechDraw_Clipview.png +/wiki/images/thumb/a/a4/TechDraw_ClipMinus.png/16px-TechDraw_ClipMinus.png +TechDraw_ClipPlus +/wiki/images/thumb/2/2a/TechDraw_ClipPlus.png/32px-TechDraw_ClipPlus.png +/wiki/images/thumb/2/2a/TechDraw_ClipPlus.png/16px-TechDraw_ClipPlus.png +TechDraw_Clip +/wiki/images/thumb/e/e3/TechDraw_Clip.png/32px-TechDraw_Clip.png +/wiki/images/thumb/e/e3/TechDraw_Clip.png/16px-TechDraw_Clip.png +TechDraw_Spreadsheet +/wiki/images/thumb/d/d7/TechDraw_Spreadsheet.png/32px-TechDraw_Spreadsheet.png +/wiki/images/thumb/8/88/TechDraw_Spreadsheetview.png/200px-TechDraw_Spreadsheetview.png +/wiki/images/thumb/7/79/TechDraw-spreadsheet.png/16px-TechDraw-spreadsheet.png +TechDraw_NewDraft +/wiki/images/thumb/9/94/TechDraw_NewDraft.png/32px-TechDraw_NewDraft.png +/wiki/images/d/db/DraftViewSample.png +/wiki/images/thumb/9/94/TechDraw_NewDraft.png/24px-TechDraw_NewDraft.png +TechDraw_NewAnnotation +/wiki/images/thumb/7/74/TechDraw_NewAnnotation.png/32px-TechDraw_NewAnnotation.png +/wiki/images/thumb/7/7b/AnnotationSample.png/200px-AnnotationSample.png +/wiki/images/thumb/7/74/TechDraw_NewAnnotation.png/24px-TechDraw_NewAnnotation.png +/wiki/images/thumb/5/5d/View-rotate-right.png/32px-View-rotate-right.png +/wiki/images/thumb/c/cc/UpdateAnnotation.png/300px-UpdateAnnotation.png +TechDraw_NewView +/wiki/images/thumb/7/7f/TechDraw_NewView.png/32px-TechDraw_NewView.png +/wiki/images/a/a4/ViewOfBox2.png +/wiki/images/thumb/9/93/Techdraw-view.png/24px-Techdraw-view.png +TechDraw_Enhancement_Project +FreeCAD_Configuration_Management_Project +Artwork +/wiki/images/0/04/Freecad16.svg +/wiki/images/4/4f/Document-open.svg +/wiki/images/2/2f/Document-save-as.svg +/wiki/images/3/3d/Document-print.svg +/wiki/images/8/88/Edit-cut.svg +/wiki/images/a/a2/Edit-copy.svg +/wiki/images/8/83/Edit-paste.svg +/wiki/images/9/92/Edit-undo.svg +/wiki/images/a/a6/Edit-redo.svg +/wiki/images/6/6c/WhatsThis.svg +/wiki/images/9/9a/System-log-out.svg +/wiki/images/0/00/Edit-select-box.svg +/wiki/images/4/40/Edit-select-all.svg +/wiki/images/7/7f/Edit-delete.svg +/wiki/images/f/f1/Std_Edit.svg +/wiki/images/2/2b/Preferences-general.svg +/wiki/images/1/11/Preferences-system.svg +/wiki/images/6/6a/Preferences-display.svg +/wiki/images/4/4d/Preferences-arch.svg +/wiki/images/e/e2/Preferences-draft.svg +/wiki/images/1/1d/Preferences-fem.svg +/wiki/images/2/29/Preferences-import-export.svg +/wiki/images/f/fa/Preferences-openscad.svg +/wiki/images/c/c9/Preferences-part_design.svg +/wiki/images/5/5b/Preferences-path.svg +/wiki/images/b/b2/Window-new.svg +/wiki/images/7/7c/View-isometric.svg +/wiki/images/d/dc/View-fullscreen.svg +/wiki/images/e/e5/Std_Tool1.svg +/wiki/images/2/26/View-measurement.svg +/wiki/images/b/b1/View-zoom-all.svg +/wiki/images/7/79/View-zoom-selection.svg +/wiki/images/c/c3/View-axonometric.svg +/wiki/images/7/7b/View-front.svg +/wiki/images/e/e9/View-right.svg +/wiki/images/e/e3/View-rear.svg +/wiki/images/3/3f/View-bottom.svg +/wiki/images/a/a9/View-left.svg +/wiki/images/5/56/View-rotate-left.svg +/wiki/images/0/09/View-rotate-right.svg +/wiki/images/8/8f/DrawStyleAsIs.svg +/wiki/images/5/5d/DrawStyleFlatLines.svg +/wiki/images/a/ab/DrawStyleShaded.svg +/wiki/images/d/d9/DrawStyleWireFrame.svg +/wiki/images/1/15/DrawStylePoints.svg +/wiki/images/4/43/Std_Tool7.svg +/wiki/images/5/5f/Std_Tool6.svg +/wiki/images/c/cf/Std_Tool8.svg +/wiki/images/6/66/View-zoom-in.svg +/wiki/images/9/9a/View-zoom-out.svg +/wiki/images/4/4b/View-zoom-border.svg +/wiki/images/1/15/View-unselectable.svg +/wiki/images/b/b9/Part_Measure_Toggle_All.svg +/wiki/images/9/99/Workbench_Arch.svg +/wiki/images/2/23/Workbench_Complete.svg +/wiki/images/9/91/Workbench_Draft.svg +/wiki/images/0/0a/Workbench_Drawing.svg +/wiki/images/8/87/Workbench_FEM.svg +/wiki/images/8/84/Workbench_Mesh.svg +/wiki/images/0/04/Workbench_Part.svg +/wiki/images/7/70/Workbench_Plot.svg +/wiki/images/9/90/PointsWorkbench.svg +/wiki/images/a/aa/Workbench_Raytracing.svg +/wiki/images/7/7c/ReverseEngineeringWorkbench.svg +/wiki/images/e/e3/Workbench_Robot.svg +/wiki/images/9/91/Workbench_Sketcher.svg +/wiki/images/e/eb/Workbench_Start.svg +/wiki/images/6/60/Workbench_Test.png +/wiki/images/3/3e/Workbench_Web.svg +/wiki/images/8/80/Camera-photo.svg +/wiki/images/a/a7/Accessories-calculator.svg +/wiki/images/c/c2/Applications-accessories.svg +/wiki/images/2/2a/AddonManager.svg +/wiki/images/f/fc/Media-record.svg +/wiki/images/8/82/Media-playback-stop.svg +/wiki/images/6/67/MacroEditor.svg +/wiki/images/9/9b/Media-playback-start.svg +/wiki/images/4/44/Std_WindowNext.svg +/wiki/images/6/6f/Std_WindowPrev.svg +/wiki/images/9/9f/Std_WindowTileVer.svg +/wiki/images/c/c2/Std_WindowCascade.svg +/wiki/images/4/44/Help-browser.svg +/wiki/images/7/74/Internet-web-browser.svg +/wiki/images/3/3f/Geofeaturegroup.svg +/wiki/images/7/7e/Group.svg +/wiki/images/a/ab/FreeCAD05_Tango_Face-angel.svg +/wiki/images/2/25/FreeCAD05_Tango_Face-blush.svg +/wiki/images/6/66/FreeCAD05_Tango_Face-crying.svg +/wiki/images/5/5e/FreeCAD05_Tango_Face-devil-grin.svg +/wiki/images/4/43/FreeCAD05_Tango_Face-glasses.svg +/wiki/images/b/b1/FreeCAD05_Tango_Face-grin.svg +/wiki/images/f/fd/FreeCAD05_Tango_Face-grin-braces.svg +/wiki/images/5/5e/FreeCAD05_Tango_Face-kiss.svg +/wiki/images/7/79/FreeCAD05_Tango_Face-plain.svg +/wiki/images/e/e0/FreeCAD05_Tango_Face-sad.svg +/wiki/images/5/5d/FreeCAD05_Tango_Face-smile.svg +/wiki/images/c/c4/FreeCAD05_Tango_Face-smile-big.svg +/wiki/images/8/84/FreeCAD05_Tango_Face-surprise.svg +/wiki/images/d/d4/FreeCAD05_Tango_Face-wink.svg +/wiki/images/7/7c/FreeCAD05_Tango_Anaglyph.svg +/wiki/images/e/ee/FreeCAD05_Tango_Applications-games.svg +/wiki/images/2/23/FreeCAD05_Tango_Applications-ristretto.svg +/wiki/images/f/f5/FreeCAD05_Tango_Dialog-error.svg +/wiki/images/8/80/FreeCAD05_Tango_Dialog-warning.svg +/wiki/images/c/c3/FreeCAD05_Tango_Measure.svg +/wiki/images/1/15/FreeCAD05_Tango_Process-stop.svg +/wiki/images/2/25/FreeCAD05_Tango_Text-x-python.svg +/wiki/images/6/66/FreeCAD05_Tango_Camera-photo.svg +/wiki/images/3/3e/FreeCAD05_Tango_Preferences-system.svg +/wiki/images/a/a5/FreeCAD05_Tango_Camera-video.svg +/wiki/images/6/6d/FreeCAD05_Tango_Applications-graphics.svg +/wiki/images/6/6d/FC_Christmas.svg +/wiki/images/2/2e/Splashscreen09.png +/wiki/images/9/91/Splashscreen010.png +/wiki/images/5/53/Splash011.png +/wiki/images/f/f6/Splashscreen012.png +/wiki/images/b/b7/Splash013.jpg +/wiki/images/f/fc/Freecadsplash14.png +/wiki/images/2/21/Freecadsplash15.png +/wiki/images/5/5d/Freecadsplash016.png +/wiki/images/0/08/Freecadsplash017.png +/wiki/images/e/e0/Accessories-text-editor.svg +/wiki/images/f/f3/Application-exit.svg +/wiki/images/thumb/2/26/Background.png/64px-Background.png +/wiki/images/3/39/Bound-expression-unset.svg +/wiki/images/1/1d/Breakpoint.svg +/wiki/images/7/77/Button_add_all.svg +/wiki/images/3/37/Button_down.svg +/wiki/images/3/3c/Button_invalid.svg +/wiki/images/f/f6/Button_left.svg +/wiki/images/5/52/Button_right.svg +/wiki/images/c/cc/Button_sort.svg +/wiki/images/8/82/Button_up.svg +/wiki/images/a/a1/Button_valid.svg +/wiki/images/a/a8/Colors.svg +/wiki/images/d/df/CoordinateSystem.svg +/wiki/images/4/43/DagViewFail.svg +/wiki/images/4/43/DagViewPass.svg +/wiki/images/a/ac/DagViewPending.svg +/wiki/images/4/44/DagViewVisible.svg +/wiki/images/4/4d/Debug_marker.svg +/wiki/images/4/4c/Delete.svg +/wiki/images/d/df/Document.svg +/wiki/images/6/6f/Document-properties.svg +/wiki/images/f/f6/Edit_Cancel.svg +/wiki/images/d/d3/Edit-cleartext.svg +/wiki/images/f/f0/Edit-edit.svg +/wiki/images/b/b4/Feature.svg +/wiki/images/e/e7/Freecad-doc.svg +/wiki/images/thumb/0/08/Freecadsplash017.png/64px-Freecadsplash017.png +/wiki/images/8/8e/List-add.svg +/wiki/images/1/17/List-remove.svg +/wiki/images/4/41/Material.svg +/wiki/images/4/4f/Mouse_pointer.svg +/wiki/images/6/67/Param_Bool.svg +/wiki/images/9/9e/Param_Float.svg +/wiki/images/1/12/Param_Int.svg +/wiki/images/4/46/Param_Text.svg +/wiki/images/4/48/Param_UInt.svg +/wiki/images/5/5c/PolygonPick.svg +/wiki/images/0/04/Process-stop.svg +/wiki/images/a/a6/Px.svg +/wiki/images/0/0a/Python.svg +/wiki/images/8/8e/Spaceball_button.svg +/wiki/images/9/90/SpNav-PanLR.svg +/wiki/images/c/c6/SpNav-PanUD.svg +/wiki/images/f/f2/SpNav-Roll.svg +/wiki/images/b/bc/SpNav-Spin.svg +/wiki/images/a/a7/SpNav-Tilt.svg +/wiki/images/a/ad/SpNav-Zoom.svg +/wiki/images/3/30/Std_Axis.svg +/wiki/images/c/cf/Std_Plane.svg +/wiki/images/f/f3/Std_Tool2.svg +/wiki/images/0/0b/Std_Tool3.svg +/wiki/images/3/33/Std_Tool4.svg +/wiki/images/4/44/Std_Tool5.svg +/wiki/images/3/33/Std_Tool9.svg +/wiki/images/b/b4/Std_Tool10.svg +/wiki/images/3/34/Std_Tool11.svg +/wiki/images/e/e6/Std_Tool12.svg +/wiki/images/e/ee/Std_ViewScreenShot.svg +/wiki/images/1/15/TextDocument.svg +/wiki/images/9/9e/Tree_Annotation.svg +/wiki/images/f/ff/Tree_Dimension.svg +/wiki/images/7/79/Tree_Python.svg +/wiki/images/6/60/User.svg +/wiki/images/6/66/Utilities-terminal.svg +/wiki/images/1/10/View-select.svg +/wiki/images/c/c6/Zoom-all.svg +/wiki/images/8/87/Zoom-border.svg +/wiki/images/b/bc/Zoom-fit-best.svg +/wiki/images/0/03/Zoom-in.svg +/wiki/images/e/e3/Zoom-out.svg +/wiki/images/9/91/Zoom-selection.svg +/wiki/images/thumb/2/26/Background.png/240px-Background.png +/wiki/images/0/07/Const_member.svg +/wiki/images/9/90/Member.svg +/wiki/images/d/df/Method.svg +/wiki/images/b/b3/Property.svg +/wiki/images/f/fd/Type_class.svg +/wiki/images/b/b1/Type_enum.svg +/wiki/images/2/22/Type_module.svg +/wiki/images/1/1d/Arch_3Views.svg +/wiki/images/b/b7/Arch_Add.svg +/wiki/images/7/7b/Arch_Axis.svg +/wiki/images/2/21/Arch_Axis_System.svg +/wiki/images/e/e3/Arch_Axis_System_Tree.svg +/wiki/images/f/fc/Arch_Axis_Tree.svg +/wiki/images/e/e4/Arch_Bimserver.svg +/wiki/images/6/60/Arch_Building.svg +/wiki/images/0/04/Arch_Building_Tree.svg +/wiki/images/c/c4/Arch_Cell.svg +/wiki/images/0/01/Arch_Cell_Tree.svg +/wiki/images/c/c8/Arch_Check.svg +/wiki/images/5/51/Arch_CloseHoles.svg +/wiki/images/1/19/Arch_Component.svg +/wiki/images/2/2d/Arch_Component_Clone.svg +/wiki/images/d/d0/Arch_Equipment.svg +/wiki/images/b/ba/Arch_Equipment_Clone.svg +/wiki/images/3/3c/Arch_Equipment_Tree.svg +/wiki/images/1/12/Arch_Fixture.svg +/wiki/images/9/9b/Arch_Floor.svg +/wiki/images/6/62/Arch_Floor_Tree.svg +/wiki/images/4/4f/Arch_Frame.svg +/wiki/images/8/8e/Arch_Frame_Tree.svg +/wiki/images/a/af/Arch_Grid.svg +/wiki/images/e/ed/Arch_Material.svg +/wiki/images/f/fb/Arch_Material_Group.svg +/wiki/images/9/99/Arch_Material_Multi.svg +/wiki/images/3/3a/Arch_MergeWalls.svg +/wiki/images/5/56/Arch_Nest.svg +/wiki/images/1/18/Arch_Panel.svg +/wiki/images/6/63/Arch_Panel_Clone.svg +/wiki/images/e/ef/Arch_Panel_Cut.svg +/wiki/images/3/32/Arch_Panel_Sheet.svg +/wiki/images/d/df/Arch_Panel_Tree.svg +/wiki/images/e/eb/Arch_Pipe.svg +/wiki/images/8/8c/Arch_PipeConnector.svg +/wiki/images/9/91/Arch_Pipe_Tree.svg +/wiki/images/4/49/Arch_Rebar.svg +/wiki/images/8/87/Arch_Rebar_Tree.svg +/wiki/images/b/b9/Arch_Remove.svg +/wiki/images/8/82/Arch_RemoveShape.svg +/wiki/images/d/df/Arch_Roof.svg +/wiki/images/d/d3/Arch_Roof_Tree.svg +/wiki/images/9/90/Arch_Schedule.svg +/wiki/images/8/89/Arch_SectionPlane.svg +/wiki/images/f/fc/Arch_SectionPlane_Tree.svg +/wiki/images/c/c2/Arch_SelectNonManifold.svg +/wiki/images/8/8c/Arch_Site.svg +/wiki/images/7/7f/Arch_Site_Tree.svg +/wiki/images/b/b6/Arch_Space.svg +/wiki/images/c/cf/Arch_Space_Tree.svg +/wiki/images/e/eb/Arch_SplitMesh.svg +/wiki/images/a/a1/Arch_Stairs.svg +/wiki/images/f/f0/Arch_Stairs_Tree.svg +/wiki/images/4/44/Arch_StructuralSystem.svg +/wiki/images/8/83/Arch_StructuralSystem_Tree.svg +/wiki/images/b/bc/Arch_Structure.svg +/wiki/images/3/3a/Arch_Structure_Clone.svg +/wiki/images/f/f2/Arch_Structure_Tree.svg +/wiki/images/f/f7/Arch_ToggleIfcBrepFlag.svg +/wiki/images/1/1b/Arch_ToggleSubs.svg +/wiki/images/9/97/Arch_Wall.svg +/wiki/images/1/15/Arch_Wall_Tree.svg +/wiki/images/c/ca/Arch_Wall_Tree_Assembly.svg +/wiki/images/c/cd/Arch_Window.svg +/wiki/images/c/c5/Arch_Window_Clone.svg +/wiki/images/e/e5/Arch_Window_Tree.svg +/wiki/images/7/7c/ArchWorkbench.svg +/wiki/images/e/ee/Git.svg +/wiki/images/8/84/ParametersBeam.svg +/wiki/images/5/57/ParametersDent.svg +/wiki/images/4/41/ParametersIbeam.svg +/wiki/images/a/a6/ParametersPanel.svg +/wiki/images/9/92/ParametersPillar.svg +/wiki/images/f/fb/ParametersSlab.svg +/wiki/images/d/d7/ParametersStairs.svg +/wiki/images/2/25/Assembly_Add_Existing_Part.svg +/wiki/images/0/09/Assembly_Add_New_Part.svg +/wiki/images/b/b5/Assembly_Assembly_Constraints_Tree.svg +/wiki/images/b/b3/Assembly_Assembly_Create_New.svg +/wiki/images/e/e9/Assembly_Assembly_Part_Tree.svg +/wiki/images/b/b1/Assembly_Assembly_Tree.svg +/wiki/images/7/77/Assembly_Demo.svg +/wiki/images/8/8e/AssemblyWorkbench.svg +/wiki/images/6/6d/Axle_constraint.svg +/wiki/images/2/23/Assembly_ConstraintAlignment.svg +/wiki/images/7/77/Assembly_ConstraintAngle.svg +/wiki/images/d/d5/Assembly_ConstraintBidirectional.svg +/wiki/images/7/7e/Assembly_ConstraintCoincidence.svg +/wiki/images/0/06/Assembly_ConstraintDistance.svg +/wiki/images/5/5a/Assembly_ConstraintEqual.svg +/wiki/images/8/85/Assembly_ConstraintGeneral.svg +/wiki/images/0/06/Assembly_ConstraintLock.svg +/wiki/images/a/aa/Assembly_ConstraintOpposite.svg +/wiki/images/3/35/Assembly_ConstraintOrientation.svg +/wiki/images/f/f4/Assembly_ConstraintParallel.svg +/wiki/images/0/0b/Assembly_ConstraintPerpendicular.svg +/wiki/images/5/53/Assembly_ConstraintUnidirectional1.svg +/wiki/images/5/5f/Assembly_ConstraintUnidirectional2.svg +/wiki/images/0/09/CompleteWorkbench.svg +/wiki/images/3/31/Draft_2DShapeView.svg +/wiki/images/b/b2/Draft_AddPoint.svg +/wiki/images/e/e4/Draft_AddToGroup.svg +/wiki/images/c/c6/Draft_Apply.svg +/wiki/images/e/ee/Draft_Arc.svg +/wiki/images/1/17/Draft_Array.svg +/wiki/images/c/c6/Draft_AutoGroup.svg +/wiki/images/9/9f/Draft_AutoGroup_off.svg +/wiki/images/f/f1/Draft_AutoGroup_on.svg +/wiki/images/b/b9/Draft_BezCurve.svg +/wiki/images/b/b1/Draft_Circle.svg +/wiki/images/3/36/Draft_Clone.svg +/wiki/images/c/c9/Draft_Construction.svg +/wiki/images/b/b5/Draft_Cursor.svg +/wiki/images/0/06/Draft_DelPoint.svg +/wiki/images/8/83/Draft_Dimension.svg +/wiki/images/e/ef/Draft_Dot.svg +/wiki/images/8/84/Draft_Downgrade.svg +/wiki/images/2/23/Draft_Draft.svg +/wiki/images/b/b2/Draft_Draft2Sketch.svg +/wiki/images/2/25/Draft_Drawing.svg +/wiki/images/5/56/Draft_Edit.svg +/wiki/images/1/10/Draft_Ellipse.svg +/wiki/images/5/5a/Draft_Facebinder.svg +/wiki/images/0/07/Draft_Finish.svg +/wiki/images/3/31/Draft_Grid.svg +/wiki/images/5/56/Draft_Heal.svg +/wiki/images/1/12/Draft_Label.svg +/wiki/images/2/23/Draft_Line.svg +/wiki/images/c/c5/Draft_Lock.svg +/wiki/images/d/d4/Draft_Macro.svg +/wiki/images/4/4b/Draft_Mirror.svg +/wiki/images/3/3c/Draft_Move.svg +/wiki/images/6/6c/Draft_Offset.svg +/wiki/images/0/07/Draft_PathArray.svg +/wiki/images/1/1e/Draft_Point.svg +/wiki/images/9/91/Draft_Polygon.svg +/wiki/images/d/da/Draft_Rectangle.svg +/wiki/images/f/f0/Draft_Rotate.svg +/wiki/images/1/1e/Draft_Scale.svg +/wiki/images/5/5f/Draft_SelectGroup.svg +/wiki/images/3/39/Draft_SelectPlane.svg +/wiki/images/5/55/Draft_ShapeString.svg +/wiki/images/4/48/Draft_Slope.svg +/wiki/images/8/8f/Draft_Snap.svg +/wiki/images/3/3e/Draft_Stretch.svg +/wiki/images/1/1d/Draft_SwitchMode.svg +/wiki/images/a/a7/Draft_Text.svg +/wiki/images/e/e9/Draft_Trimex.svg +/wiki/images/b/ba/Draft_Upgrade.svg +/wiki/images/a/a7/Draft_Wipe.svg +/wiki/images/1/10/Draft_Wire.svg +/wiki/images/8/80/Draft_WireToBSpline.svg +/wiki/images/c/c4/DraftWorkbench.svg +/wiki/images/1/11/Snap_Angle.svg +/wiki/images/4/4a/Snap_Center.svg +/wiki/images/4/4a/Snap_Dimensions.svg +/wiki/images/4/48/Snap_Endpoint.svg +/wiki/images/2/27/Snap_Extension.svg +/wiki/images/e/e6/Snap_Grid.svg +/wiki/images/7/72/Snap_Intersection.svg +/wiki/images/d/d2/Snap_Lock.svg +/wiki/images/d/d9/Snap_Midpoint.svg +/wiki/images/0/06/Snap_Near.svg +/wiki/images/3/30/Snap_Ortho.svg +/wiki/images/1/11/Snap_Parallel.svg +/wiki/images/9/92/Snap_Perpendicular.svg +/wiki/images/c/ca/Snap_Special.svg +/wiki/images/f/f1/Snap_WorkingPlane.svg +/wiki/images/b/b7/Brick01.svg +/wiki/images/4/4d/Concrete.svg +/wiki/images/8/8b/Cross.svg +/wiki/images/a/aa/Diagonal1.svg +/wiki/images/5/5b/Diagonal2.svg +/wiki/images/b/be/Earth.svg +/wiki/images/4/4b/Hbone.svg +/wiki/images/3/38/Line.svg +/wiki/images/c/c0/Plus.svg +/wiki/images/1/1f/Simple.svg +/wiki/images/a/ae/Solid.svg +/wiki/images/d/da/Square.svg +/wiki/images/9/9a/Steel.svg +/wiki/images/2/29/Wood.svg +/wiki/images/4/44/Woodgrain.svg +/wiki/images/4/4d/DrawingWorkbench.svg +/wiki/images/b/b2/Page.svg +/wiki/images/b/b4/Pages.svg +/wiki/images/d/d9/Drawing-annotation.svg +/wiki/images/f/fd/Drawing-clip.svg +/wiki/images/f/fc/Drawing-draft-view.svg +/wiki/images/a/a2/Drawing-landscape.svg +/wiki/images/2/2f/Drawing-landscape-A0.svg +/wiki/images/7/7d/Drawing-landscape-A1.svg +/wiki/images/c/ce/Drawing-landscape-A2.svg +/wiki/images/6/68/Drawing-landscape-A3.svg +/wiki/images/f/f3/Drawing-landscape-A4.svg +/wiki/images/9/91/Drawing-landscape-new.svg +/wiki/images/2/20/Drawing-openbrowser.svg +/wiki/images/6/62/Drawing-portrait-A0.svg +/wiki/images/a/ae/Drawing-portrait-A1.svg +/wiki/images/7/7a/Drawing-portrait-A2.svg +/wiki/images/3/30/Drawing-portrait-A3.svg +/wiki/images/c/c9/Drawing-portrait-A4.svg +/wiki/images/5/5a/Drawing-spreadsheet.svg +/wiki/images/e/eb/Drawing-symbol.svg +/wiki/images/d/d2/Drawing-view.svg +/wiki/images/9/94/A0_Landscape_ISO7200.svg +/wiki/images/c/cb/A0_Landscape_plain.svg +/wiki/images/b/be/A0_Portrait_plain.svg +/wiki/images/7/76/A1_Landscape_ISO7200.svg +/wiki/images/1/18/A1_Landscape_plain.svg +/wiki/images/5/5b/A1_Portrait_plain.svg +/wiki/images/7/74/A2_Landscape_ISO7200.svg +/wiki/images/4/43/A2_Landscape_plain.svg +/wiki/images/e/e0/A2_Portrait_plain.svg +/wiki/images/4/49/A3_Landscape.svg +/wiki/images/a/a4/A3_Landscape_ISO7200.svg +/wiki/images/d/de/A3_Landscape_plain.svg +/wiki/images/6/65/A3_Portrait_plain.svg +/wiki/images/f/f5/A4_Landscape.svg +/wiki/images/5/52/A4_Landscape_ISO7200.svg +/wiki/images/4/45/A4_Landscape_plain.svg +/wiki/images/1/1e/A4_Portrait_ISO7200.svg +/wiki/images/1/1d/A4_Portrait_plain.svg +/wiki/images/9/91/A4_Simple.svg +/wiki/images/d/d7/Fem-add-fem-mesh.svg +/wiki/images/a/ae/Fem-add-material.svg +/wiki/images/5/51/Fem-add-part.svg +/wiki/images/1/1b/Fem-box.svg +/wiki/images/a/aa/Fem-cfd-analysis.svg +/wiki/images/b/b6/Fem-constraint-electrostatic-potential.svg +/wiki/images/a/aa/Fem-cylinder.svg +/wiki/images/2/2b/Fem-femmesh-result.svg +/wiki/images/0/01/Fem-frequency-analysis.svg +/wiki/images/7/77/Fem-inp-editor.svg +/wiki/images/f/fb/Fem-isosurface.svg +/wiki/images/3/3e/Fem-plane.svg +/wiki/images/3/37/Fem-static-analysis.svg +/wiki/images/e/e0/Fem-thermomechanical-analysis.svg +/wiki/images/0/0d/FemWorkbench.svg +/wiki/images/9/90/Image-import.svg +/wiki/images/0/0e/ImageWorkbench.svg +/wiki/images/6/62/InspectionWorkbench.svg +/wiki/images/1/12/Inspect_pipette.svg +/wiki/images/0/07/Preview-rendered.svg +/wiki/images/5/5a/Preview-vector.svg +/wiki/images/d/d3/Mesh_boundary.svg +/wiki/images/a/a5/Mesh_Curvature_Plot.svg +/wiki/images/e/ed/Mesh_cut.svg +/wiki/images/8/81/Mesh_Export_Mesh.svg +/wiki/images/f/f8/Mesh_Flip_Normals.svg +/wiki/images/c/ce/Mesh_Harmonize_Normals.svg +/wiki/images/b/bb/Mesh_Import_Mesh.svg +/wiki/images/d/dc/Mesh_pipette.svg +/wiki/images/e/e0/Mesh_Regular_Solid.svg +/wiki/images/e/e7/Mesh_Remove_Components.svg +/wiki/images/8/8c/Mesh_Tree_Curvature_Plot.svg +/wiki/images/0/01/MeshWorkbench.svg +/wiki/images/9/9a/Tree_Mesh.svg +/wiki/images/b/b5/Mesh_Cone.svg +/wiki/images/6/6d/Mesh_Cube.svg +/wiki/images/6/61/Mesh_Cylinder.svg +/wiki/images/8/83/Mesh_Ellipsoid.svg +/wiki/images/6/6e/Mesh_Sphere.svg +/wiki/images/4/4d/Mesh_Torus.svg +/wiki/images/f/f6/MeshFace.svg +/wiki/images/f/f3/OpenSCAD_AddOpenSCADElement.svg +/wiki/images/f/fe/OpenSCAD_ColorCodeShape.svg +/wiki/images/6/67/OpenSCAD_Explode_Group.svg +/wiki/images/7/76/OpenSCAD_Hull.svg +/wiki/images/d/d9/OpenSCAD_IncreaseToleranceFeature.svg +/wiki/images/4/4f/OpenSCAD_MeshBooleans.svg +/wiki/images/f/f8/OpenSCAD_Minkowski.svg +/wiki/images/5/54/OpenSCAD_RefineShapeFeature.svg +/wiki/images/9/9b/OpenSCAD_RemoveSubtree.svg +/wiki/images/a/a9/OpenSCAD_ReplaceObject.svg +/wiki/images/3/38/OpenSCADWorkbench.svg +/wiki/images/3/3e/Part_Attachment.svg +/wiki/images/5/5e/Part_BooleanFragments.svg +/wiki/images/a/a7/Part_Booleans.svg +/wiki/images/3/34/Part_Box.svg +/wiki/images/5/58/Part_Circle_Parametric.svg +/wiki/images/1/15/Part_Common.svg +/wiki/images/0/00/Part_CompoundFilter.svg +/wiki/images/3/35/Part_Cone.svg +/wiki/images/d/da/Part_CreatePrimitives.svg +/wiki/images/d/df/Part_CrossSections.svg +/wiki/images/f/fb/Part_Cut.svg +/wiki/images/e/e8/Part_Cylinder.svg +/wiki/images/4/40/Part_Ellipse_Parametric.svg +/wiki/images/a/a6/Part_Export.svg +/wiki/images/7/78/PartFeature.svg +/wiki/images/3/30/Part_Fillet.svg +/wiki/images/e/e4/Part_Fuse.svg +/wiki/images/a/a3/Part_Helix_Parametric.svg +/wiki/images/6/6f/Part_Import.svg +/wiki/images/5/58/Part_JoinBypass.svg +/wiki/images/a/ac/Part_JoinConnect.svg +/wiki/images/c/c0/Part_JoinCutout.svg +/wiki/images/4/45/Part_JoinEmbed.svg +/wiki/images/9/9e/Part_Line_Parametric.svg +/wiki/images/6/6b/Part_Loft.svg +/wiki/images/f/ff/Part_Measure_Angular.svg +/wiki/images/c/c7/Part_Measure_Linear.svg +/wiki/images/7/75/Part_Measure_Step_Active.svg +/wiki/images/2/2f/Part_Measure_Step_Done.svg +/wiki/images/9/98/Part_Measure_Toggle_3d.svg +/wiki/images/b/be/Part_Measure_Toggle_Delta.svg +/wiki/images/8/85/Part_Mirror.svg +/wiki/images/9/9a/Part_Offset.svg +/wiki/images/7/7b/Part_Offset2D.svg +/wiki/images/e/e4/Part_Point_Parametric.svg +/wiki/images/c/cd/Part_Polygon_Parametric.svg +/wiki/images/4/4d/Part_Refine_Shape.svg +/wiki/images/5/57/Part_Revolve.svg +/wiki/images/f/f7/Part_Section.svg +/wiki/images/f/f3/Part_Shapebuilder.svg +/wiki/images/9/93/Part_Shape_from_Mesh.svg +/wiki/images/1/11/Part_ShapeInfo.svg +/wiki/images/2/2b/Part_Slice.svg +/wiki/images/d/de/Part_Sphere.svg +/wiki/images/3/3d/Part_Spiral_Parametric.svg +/wiki/images/1/15/Part_Spline_Parametric.svg +/wiki/images/2/2a/Part_Sweep.svg +/wiki/images/d/d2/Part_Thickness.svg +/wiki/images/8/8f/Part_Torus.svg +/wiki/images/a/a0/Part_Workbench.svg +/wiki/images/7/73/Part_XOR.svg +/wiki/images/b/b9/Tree_Part.svg +/wiki/images/e/e9/Tree_Part_Box_Parametric.svg +/wiki/images/6/6f/Tree_Part_Cone_Parametric.svg +/wiki/images/5/58/Tree_Part_Cylinder_Parametric.svg +/wiki/images/5/50/Tree_Part_Ellipsoid_Parametric.svg +/wiki/images/4/4d/Tree_Part_Plane_Parametric.svg +/wiki/images/3/37/Tree_Part_Prism.svg +/wiki/images/6/6c/Tree_Part_Sphere_Parametric.svg +/wiki/images/7/7d/Tree_Part_Torus_Parametric.svg +/wiki/images/7/7d/Tree_Part_Wedge.svg +/wiki/images/2/22/PartDesign_Hole.svg +/wiki/images/d/d9/PartDesign_Additive_Box.svg +/wiki/images/3/35/PartDesign_Additive_Cone.svg +/wiki/images/e/ea/PartDesign_Additive_Cylinder.svg +/wiki/images/f/fd/PartDesign_Additive_Ellipsoid.svg +/wiki/images/0/01/PartDesign_Additive_Loft.svg +/wiki/images/4/47/PartDesign_Additive_Pipe.svg +/wiki/images/4/45/PartDesign_Additive_Prism.svg +/wiki/images/5/55/PartDesign_Additive_Sphere.svg +/wiki/images/e/e7/PartDesign_Additive_Torus.svg +/wiki/images/e/e1/PartDesign_Additive_Wedge.svg +/wiki/images/3/35/PartDesign_BaseFeature.svg +/wiki/images/1/10/PartDesign_Body.svg +/wiki/images/f/fa/PartDesign_Body_Create_New.svg +/wiki/images/a/aa/PartDesign_Body_Tree.svg +/wiki/images/d/d1/PartDesign_Boolean.svg +/wiki/images/e/ee/PartDesign_Chamfer.svg +/wiki/images/2/2f/PartDesign_Clone.svg +/wiki/images/5/57/PartDesign_CoordinateSystem.svg +/wiki/images/d/dc/PartDesign_Draft.svg +/wiki/images/4/41/PartDesign_Fillet.svg +/wiki/images/a/ac/PartDesign_Groove.svg +/wiki/images/f/ff/PartDesign_InternalExternalGear.svg +/wiki/images/d/d0/PartDesign_InvoluteGear.svg +/wiki/images/8/8a/PartDesign_Line.svg +/wiki/images/f/fa/PartDesign_LinearPattern.svg +/wiki/images/2/21/PartDesign_Mirrored.svg +/wiki/images/4/41/PartDesign_MoveTip.svg +/wiki/images/b/b7/PartDesign_MultiTransform.svg +/wiki/images/f/f8/PartDesign_Pad.svg +/wiki/images/e/e5/PartDesign_Plane.svg +/wiki/images/9/93/PartDesign_Pocket.svg +/wiki/images/2/27/PartDesign_Point.svg +/wiki/images/e/ef/PartDesign_PolarPattern.svg +/wiki/images/9/94/PartDesign_Revolution.svg +/wiki/images/5/51/PartDesign_Scaled.svg +/wiki/images/6/67/PartDesign_ShapeBinder.svg +/wiki/images/b/bd/PartDesign_Subtractive_Box.svg +/wiki/images/6/6d/PartDesign_Subtractive_Cone.svg +/wiki/images/0/0d/PartDesign_Subtractive_Cylinder.svg +/wiki/images/2/25/PartDesign_Subtractive_Ellipsoid.svg +/wiki/images/d/d3/PartDesign_Subtractive_Loft.svg +/wiki/images/f/f4/PartDesign_Subtractive_Pipe.svg +/wiki/images/5/58/PartDesign_Subtractive_Prism.svg +/wiki/images/e/e8/PartDesign_Subtractive_Sphere.svg +/wiki/images/d/d4/PartDesign_Subtractive_Torus.svg +/wiki/images/0/03/PartDesign_Subtractive_Wedge.svg +/wiki/images/f/fa/PartDesign_Thickness.svg +/wiki/images/7/7f/PartDesignWorkbench.svg +/wiki/images/d/dc/Tree_PartDesign_Pad.svg +/wiki/images/f/fb/Tree_PartDesign_Revolution.svg +/wiki/images/d/d1/WizardShaft.svg +/wiki/images/9/98/Path-3DPocket.svg +/wiki/images/d/de/Path-3DSurface.svg +/wiki/images/d/df/Path-Area.svg +/wiki/images/6/63/Path-Area-View.svg +/wiki/images/3/3c/Path-Area-Workplane.svg +/wiki/images/4/4e/Path-Array.svg +/wiki/images/f/ff/Path-Axis.svg +/wiki/images/d/d9/Path-BaseGeometry.svg +/wiki/images/e/ed/Path-BFastForward.svg +/wiki/images/f/fc/Path-BPause.svg +/wiki/images/0/0b/Path-BPlay.svg +/wiki/images/a/a4/Path-BStep.svg +/wiki/images/8/8a/Path-BStop.svg +/wiki/images/c/c9/Path-Comment.svg +/wiki/images/9/9b/Path-Compound.svg +/wiki/images/f/ff/Path-Contour.svg +/wiki/images/7/7e/Path-Copy.svg +/wiki/images/1/19/Path-Custom.svg +/wiki/images/c/c4/Path-Datums.svg +/wiki/images/0/04/Path-Depths.svg +/wiki/images/0/0f/Path-Dressup.svg +/wiki/images/7/7b/Path-Drilling.svg +/wiki/images/9/98/Path-Engrave.svg +/wiki/images/6/67/Path-ExportTemplate.svg +/wiki/images/0/04/Path-Face.svg +/wiki/images/1/16/Path-FacePocket.svg +/wiki/images/c/c6/Path-FaceProfile.svg +/wiki/images/3/30/Path-Heights.svg +/wiki/images/3/3a/Path-Helix.svg +/wiki/images/c/c3/Path-Holding.svg +/wiki/images/3/3d/Path-Hop.svg +/wiki/images/e/ec/Path-Inspect.svg +/wiki/images/5/55/Path-Job.svg +/wiki/images/c/c2/Path-Kurve.svg +/wiki/images/7/7b/Path-LengthOffset.svg +/wiki/images/3/3f/Path-Machine.svg +/wiki/images/f/f3/Path-MachineLathe.svg +/wiki/images/0/02/Path-MachineMill.svg +/wiki/images/a/a1/Path-Machine-test1.svg +/wiki/images/a/a5/Path-OpCopy.svg +/wiki/images/c/c6/Path-OperationA.svg +/wiki/images/2/22/Path-OperationB.svg +/wiki/images/a/a0/Path-Plane.svg +/wiki/images/d/dd/Path-Pocket.svg +/wiki/images/d/d9/Path-Post.svg +/wiki/images/b/b6/Path-Profile.svg +/wiki/images/8/86/Path-Profile-Edges.svg +/wiki/images/0/06/Path-Profile-Face.svg +/wiki/images/1/1c/Path-Sanity.svg +/wiki/images/0/0c/Path-SelectLoop.svg +/wiki/images/8/87/Path-SetupSheet.svg +/wiki/images/8/8a/Path-Shape.svg +/wiki/images/3/32/Path-Simple_copy.svg +/wiki/images/9/94/Path-Simulator.svg +/wiki/images/b/bf/Path-Speed.svg +/wiki/images/4/42/Path-Stock.svg +/wiki/images/f/f3/Path-Stop.svg +/wiki/images/a/ae/Path-Tags.svg +/wiki/images/4/47/Path-ToolChange.svg +/wiki/images/7/75/Path-ToolController.svg +/wiki/images/8/87/Path-Toolpath.svg +/wiki/images/5/53/Path-ToolTable.svg +/wiki/images/d/de/Path-Workbench.svg +/wiki/images/9/92/Axes.svg +/wiki/images/f/f2/Grid.svg +/wiki/images/1/16/Icon.svg +/wiki/images/8/88/Labels.svg +/wiki/images/c/ca/Legend.svg +/wiki/images/8/8b/PlotWorkbench.svg +/wiki/images/a/a1/Positions.svg +/wiki/images/e/e2/Save.svg +/wiki/images/1/17/Series.svg +/wiki/images/b/b4/Points_Export_Point_cloud.svg +/wiki/images/c/c9/Points_Import_Point_cloud.svg +/wiki/images/1/11/Raytrace_Camera.svg +/wiki/images/7/79/Raytrace_Export.svg +/wiki/images/6/67/Raytrace_ExportProject.svg +/wiki/images/f/fc/Raytrace_Lux.svg +/wiki/images/6/65/Raytrace_New.svg +/wiki/images/7/79/Raytrace_NewPartSegment.svg +/wiki/images/e/ec/Raytrace_Part.svg +/wiki/images/4/4e/Raytrace_Render.svg +/wiki/images/a/af/Raytrace_ResetCamera.svg +/wiki/images/f/fe/RaytracingWorkbench.svg +/wiki/images/a/aa/FitSurface.svg +/wiki/images/0/0a/Robot_CreateRobot.svg +/wiki/images/a/a2/Robot_CreateTrajectory.svg +/wiki/images/4/43/Robot_Edge2Trac.svg +/wiki/images/f/f2/Robot_Export.svg +/wiki/images/b/b8/Robot_InsertWaypoint.svg +/wiki/images/6/6f/Robot_InsertWaypointPre.svg +/wiki/images/9/96/Robot_RestoreHomePos.svg +/wiki/images/6/65/Robot_SetDefaultOrientation.svg +/wiki/images/d/d8/Robot_SetDefaultValues.svg +/wiki/images/4/4a/Robot_SetHomePos.svg +/wiki/images/8/80/Robot_Simulate.svg +/wiki/images/2/24/Robot_TrajectoryCompound.svg +/wiki/images/8/84/Robot_TrajectoryDressUp.svg +/wiki/images/9/99/Robot_Workbench.svg +/wiki/images/a/a6/Ship_AreaCurve.svg +/wiki/images/9/94/Ship_CapacityCurve.svg +/wiki/images/c/c6/Ship_Hydrostatics.svg +/wiki/images/b/b8/Ship_Instance.svg +/wiki/images/b/bd/Ship_Load.svg +/wiki/images/c/cd/Ship_LoadCondition.svg +/wiki/images/6/69/Ship_Logo.svg +/wiki/images/3/3a/Ship_Module.svg +/wiki/images/b/b3/Ship_OutlineDraw.svg +/wiki/images/b/b4/Ship_Tank.svg +/wiki/images/4/4b/Ship_Wieght.svg +/wiki/images/d/da/ShipWorkbench.svg +/wiki/images/a/af/Constraint_Concentric.svg +/wiki/images/8/8c/Constraint_Ellipse_Axis_Angle.svg +/wiki/images/a/a4/Constraint_Ellipse_Major_Radius.svg +/wiki/images/e/e8/Constraint_Ellipse_Minor_Radius.svg +/wiki/images/d/d5/Constraint_Ellipse_Radii.svg +/wiki/images/b/b9/Constraint_EqualLength.svg +/wiki/images/3/3d/Constraint_ExternalAngle.svg +/wiki/images/f/f2/Constraint_Horizontal.svg +/wiki/images/0/00/Constraint_HorizontalDistance.svg +/wiki/images/4/43/Constraint_HorizontalDistance_Driven.svg +/wiki/images/b/b3/Constraint_InternalAlignment.svg +/wiki/images/0/04/Constraint_InternalAlignment_Ellipse_Focus1.svg +/wiki/images/5/59/Constraint_InternalAlignment_Ellipse_Focus2.svg +/wiki/images/e/e0/Constraint_InternalAlignment_Ellipse_MajorAxis.svg +/wiki/images/a/af/Constraint_InternalAlignment_Ellipse_MinorAxis.svg +/wiki/images/3/3b/Constraint_InternalAngle.svg +/wiki/images/5/5d/Constraint_InternalAngle_Driven.svg +/wiki/images/c/cf/Constraint_Length.svg +/wiki/images/a/a9/Constraint_Length_Driven.svg +/wiki/images/9/95/Constraint_Parallel.svg +/wiki/images/4/4f/Constraint_Perpendicular.svg +/wiki/images/e/e3/Constraint_PointOnEnd.svg +/wiki/images/0/0b/Constraint_PointOnMidPoint.svg +/wiki/images/6/64/Constraint_PointOnObject.svg +/wiki/images/e/ea/Constraint_PointOnPoint.svg +/wiki/images/2/26/Constraint_PointOnStart.svg +/wiki/images/0/06/Constraint_PointToObject.svg +/wiki/images/b/b2/Constraint_Radius.svg +/wiki/images/8/8f/Constraint_Radius_Driven.svg +/wiki/images/e/eb/Constraint_SnellsLaw.svg +/wiki/images/e/e8/Constraint_SnellsLaw_Driven.svg +/wiki/images/d/dc/Constraint_Symmetric.svg +/wiki/images/5/56/Constraint_Tangent.svg +/wiki/images/3/34/Constraint_TangentToEnd.svg +/wiki/images/c/c1/Constraint_TangentToStart.svg +/wiki/images/c/c0/Constraint_Vertical.svg +/wiki/images/9/97/Constraint_VerticalDistance.svg +/wiki/images/6/63/Constraint_VerticalDistance_Driven.svg +/wiki/images/4/4c/Sketcher_AlterConstruction.svg +/wiki/images/9/90/Sketcher_AlterFillet.svg +/wiki/images/4/47/Sketcher_BSplineApproximate.svg +/wiki/images/5/50/Sketcher_BSplineComb.svg +/wiki/images/b/b1/Sketcher_BSplineDecreaseDegree.svg +/wiki/images/f/f1/Sketcher_BSplineDecreaseKnotMultiplicity.svg +/wiki/images/3/36/Sketcher_BSplineDegree.svg +/wiki/images/9/9e/Sketcher_BSplineIncreaseDegree.svg +/wiki/images/2/2f/Sketcher_BSplineIncreaseKnotMultiplicity.svg +/wiki/images/1/17/Sketcher_BSplineKnotMultiplicity.svg +/wiki/images/7/73/Sketcher_BSplinePolygon.svg +/wiki/images/6/62/Sketcher_CarbonCopy.svg +/wiki/images/b/b3/Sketcher_CarbonCopy_Constr.svg +/wiki/images/c/ce/Sketcher_Clone.svg +/wiki/images/b/be/Sketcher_CloseShape.svg +/wiki/images/a/a7/Sketcher_Conics.svg +/wiki/images/9/91/Sketcher_Conics_Constr.svg +/wiki/images/a/a6/Sketcher_Conics_Ellipse_3points.svg +/wiki/images/a/a9/Sketcher_Conics_Ellipse_Center.svg +/wiki/images/8/8a/Sketcher_ConnectLines.svg +/wiki/images/b/be/Sketcher_ConstrainBlock.svg +/wiki/images/9/95/Sketcher_ConstrainCoincident.svg +/wiki/images/9/95/Sketcher_ConstrainDistance.svg +/wiki/images/5/55/Sketcher_ConstrainHorizontal.svg +/wiki/images/8/85/Sketcher_ConstrainLock.svg +/wiki/images/e/e7/Sketcher_ConstrainLock_Driven.svg +/wiki/images/1/1d/Sketcher_ConstrainParallel.svg +/wiki/images/b/ba/Sketcher_ConstrainVertical.svg +/wiki/images/6/66/Sketcher_Copy.svg +/wiki/images/c/c9/Sketcher_Create3PointArc.svg +/wiki/images/4/4d/Sketcher_Create3PointArc_Constr.svg +/wiki/images/2/27/Sketcher_Create3PointCircle.svg +/wiki/images/5/57/Sketcher_Create3PointCircle_Constr.svg +/wiki/images/b/be/Sketcher_CreateArc.svg +/wiki/images/8/83/Sketcher_CreateArc_Constr.svg +/wiki/images/4/41/Sketcher_CreateBSpline.svg +/wiki/images/7/78/Sketcher_CreateBSpline_Constr.svg +/wiki/images/3/3f/Sketcher_CreateCircle.svg +/wiki/images/4/4f/Sketcher_CreateCircle_Constr.svg +/wiki/images/0/08/Sketcher_CreateEllipse.svg +/wiki/images/8/8f/Sketcher_CreateEllipse_Constr.svg +/wiki/images/8/86/Sketcher_CreateEllipse_3points.svg +/wiki/images/b/bf/Sketcher_CreateEllipse_3points_Constr.svg +/wiki/images/6/63/Sketcher_CreateFillet.svg +/wiki/images/3/34/Sketcher_CreateHeptagon.svg +/wiki/images/a/a9/Sketcher_CreateHeptagon_Constr.svg +/wiki/images/5/53/Sketcher_CreateHexagon.svg +/wiki/images/2/28/Sketcher_CreateHexagon_Constr.svg +/wiki/images/b/bd/Sketcher_CreateLine.svg +/wiki/images/8/82/Sketcher_CreateLine_Constr.svg +/wiki/images/1/12/Sketcher_CreateOctagon.svg +/wiki/images/0/01/Sketcher_CreateOctagon_Constr.svg +/wiki/images/2/25/Sketcher_CreatePentagon.svg +/wiki/images/a/a8/Sketcher_CreatePentagon_Constr.svg +/wiki/images/b/bc/Sketcher_Create_Periodic_BSpline.svg +/wiki/images/7/73/Sketcher_Create_Periodic_BSpline_Constr.svg +/wiki/images/6/6f/Sketcher_CreatePoint.svg +/wiki/images/b/bd/Sketcher_CreatePolyline.svg +/wiki/images/0/01/Sketcher_CreatePolyline_Constr.svg +/wiki/images/a/a2/Sketcher_CreateRectangle.svg +/wiki/images/7/74/Sketcher_CreateRectangle_Constr.svg +/wiki/images/2/2a/Sketcher_CreateRegularPolygon.svg +/wiki/images/e/ef/Sketcher_CreateRegularPolygon_Constr.svg +/wiki/images/d/dd/Sketcher_CreateSlot.svg +/wiki/images/e/e6/Sketcher_CreateSlot_Constr.svg +/wiki/images/0/0c/Sketcher_CreateSquare.svg +/wiki/images/3/3e/Sketcher_CreateSquare_Constr.svg +/wiki/images/b/b2/Sketcher_CreateText.svg +/wiki/images/8/8d/Sketcher_CreateTriangle.svg +/wiki/images/f/f7/Sketcher_CreateTriangle_Constr.svg +/wiki/images/b/bf/Sketcher_DraftLine.svg +/wiki/images/c/c2/Sketcher_EditSketch.svg +/wiki/images/9/9f/Sketcher_Element_Arc_Edge.svg +/wiki/images/8/89/Sketcher_Element_Arc_EndPoint.svg +/wiki/images/4/45/Sketcher_Element_Arc_MidPoint.svg +/wiki/images/1/16/Sketcher_Element_Arc_StartingPoint.svg +/wiki/images/4/4d/Sketcher_Element_BSpline_Edge.svg +/wiki/images/3/37/Sketcher_Element_BSpline_EndPoint.svg +/wiki/images/c/cf/Sketcher_Element_BSpline_StartPoint.svg +/wiki/images/a/ae/Sketcher_Element_Circle_Edge.svg +/wiki/images/9/97/Sketcher_Element_Circle_MidPoint.svg +/wiki/images/4/49/Sketcher_Element_Ellipse_All.svg +/wiki/images/7/7c/Sketcher_Element_Ellipse_CentrePoint.svg +/wiki/images/c/c7/Sketcher_Element_Ellipse_Edge_1.svg +/wiki/images/0/0f/Sketcher_Element_Ellipse_Edge_2.svg +/wiki/images/b/b0/Sketcher_Element_Ellipse_Focus1.svg +/wiki/images/0/0d/Sketcher_Element_Ellipse_Focus2.svg +/wiki/images/e/e9/Sketcher_Element_Ellipse_MajorAxis.svg +/wiki/images/c/c2/Sketcher_Element_Ellipse_MinorAxis.svg +/wiki/images/5/56/Sketcher_Element_Elliptical_Arc_Centre_Point.svg +/wiki/images/7/77/Sketcher_Element_Elliptical_Arc_Edge.svg +/wiki/images/8/86/Sketcher_Element_Elliptical_Arc_End_Point.svg +/wiki/images/0/0d/Sketcher_Element_Elliptical_Arc_Start_Point.svg +/wiki/images/e/ec/Sketcher_Element_Hyperbolic_Arc_Centre_Point.svg +/wiki/images/d/d0/Sketcher_Element_Hyperbolic_Arc_Edge.svg +/wiki/images/3/33/Sketcher_Element_Hyperbolic_Arc_End_Point.svg +/wiki/images/7/74/Sketcher_Element_Hyperbolic_Arc_Start_Point.svg +/wiki/images/5/56/Sketcher_Element_Line_Edge.svg +/wiki/images/6/6a/Sketcher_Element_Line_EndPoint.svg +/wiki/images/a/ac/Sketcher_Element_Line_StartingPoint.svg +/wiki/images/1/1a/Sketcher_Element_Parabolic_Arc_Centre_Point.svg +/wiki/images/f/f4/Sketcher_Element_Parabolic_Arc_Edge.svg +/wiki/images/4/4c/Sketcher_Element_Parabolic_Arc_End_Point.svg +/wiki/images/1/1e/Sketcher_Element_Parabolic_Arc_Start_Point.svg +/wiki/images/d/dc/Sketcher_Element_Point_StartingPoint.svg +/wiki/images/5/5a/Sketcher_Element_SelectionTypeInvalid.svg +/wiki/images/a/ad/Sketcher_Elliptical_Arc.svg +/wiki/images/0/05/Sketcher_Elliptical_Arc_Constr.svg +/wiki/images/6/65/Sketcher_Extend.svg +/wiki/images/b/b2/Sketcher_External.svg +/wiki/images/7/78/Sketcher_Hyperbolic_Arc.svg +/wiki/images/6/62/Sketcher_Hyperbolic_Arc_Constr.svg +/wiki/images/d/df/Sketcher_MapSketch.svg +/wiki/images/8/80/Sketcher_MergeSketch.svg +/wiki/images/c/cd/Sketcher_MirrorSketch.svg +/wiki/images/f/f0/Sketcher_Parabolic_Arc.svg +/wiki/images/e/e4/Sketcher_Parabolic_Arc_Constr.svg +/wiki/images/e/ee/Sketcher_ProfilesHexagon1.svg +/wiki/images/5/51/Sketcher_RectangularArray.svg +/wiki/images/b/b5/Sketcher_SelectConflictingConstraints.svg +/wiki/images/7/7a/Sketcher_SelectConstraints.svg +/wiki/images/2/23/Sketcher_SelectElementsAssociatedWithConstraints.svg +/wiki/images/9/9a/Sketcher_SelectHorizontalAxis.svg +/wiki/images/7/71/Sketcher_SelectOrigin.svg +/wiki/images/0/02/Sketcher_SelectRedundantConstraints.svg +/wiki/images/c/c1/Sketcher_SelectVerticalAxis.svg +/wiki/images/6/68/Sketcher_Sketch.svg +/wiki/images/4/4a/Sketcher_SwitchVirtualSpace.svg +/wiki/images/3/30/Sketcher_Symmetry.svg +/wiki/images/f/fd/Sketcher_ToggleConstraint.svg +/wiki/images/6/6d/Sketcher_ToggleConstraint_Driven.svg +/wiki/images/d/da/Sketcher_ToggleConstraint_Driving.svg +/wiki/images/5/54/Sketcher_ToggleConstruction.svg +/wiki/images/7/7a/Sketcher_ToggleNormal.svg +/wiki/images/4/4e/Sketcher_Trimming.svg +/wiki/images/f/f7/Sketcher_ViewSketch.svg +/wiki/images/c/c9/SketcherWorkbech.svg +/wiki/images/9/9e/SpreadsheetAlias.svg +/wiki/images/0/0d/SpreadsheetAlignBottom.svg +/wiki/images/0/0d/SpreadsheetAlignCenter.svg +/wiki/images/d/df/SpreadsheetAlignLeft.svg +/wiki/images/e/e4/SpreadsheetAlignRight.svg +/wiki/images/1/12/SpreadsheetAlignTop.svg +/wiki/images/b/b5/SpreadsheetAlignVCenter.svg +/wiki/images/7/7d/SpreadsheetController.svg +/wiki/images/d/d3/SpreadsheetExport.svg +/wiki/images/4/42/SpreadsheetImport.svg +/wiki/images/6/68/SpreadsheetMergeCells.svg +/wiki/images/9/99/SpreadsheetSplitCell.svg +/wiki/images/f/f7/SpreadsheetStyleBold.svg +/wiki/images/a/a5/SpreadsheetStyleItalic.svg +/wiki/images/5/59/SpreadsheetStyleUnderline.svg +/wiki/images/4/44/SpreadsheetWorkbench.svg +/wiki/images/3/31/StartWorkbench.svg +/wiki/images/5/50/ArchDesign.png +/wiki/images/d/d2/Blank.png +/wiki/images/0/02/Complete.png +/wiki/images/thumb/c/c7/Freecad.png/32px-Freecad.png +/wiki/images/3/36/Freecad-doc.png +/wiki/images/8/8b/Mesh.png +/wiki/images/f/fc/PartDesign.png +/wiki/images/9/95/Ship.png +/wiki/images/f/f8/Web.png +/wiki/images/4/43/ArchExample.png +/wiki/images/thumb/1/1f/Background.jpg/480px-Background.jpg +/wiki/images/4/47/Banner.jpeg +/wiki/images/9/90/Complete.jpg +/wiki/images/8/80/PartDesignExample.png +/wiki/images/0/07/ShipExample.png +/wiki/images/4/4d/BezSurf.svg +/wiki/images/b/b6/BSplineSurf.svg +/wiki/images/a/a9/Cut.svg +/wiki/images/e/e9/Filling.svg +/wiki/images/b/bc/Sewing.svg +/wiki/images/9/98/Surface.svg +/wiki/images/f/f6/Arrow-ccw.svg +/wiki/images/5/57/Arrow-cw.svg +/wiki/images/7/74/Arrowdot.svg +/wiki/images/9/9d/Arrow-down.svg +/wiki/images/b/b6/Arrowfilled.svg +/wiki/images/6/6f/Arrow-left.svg +/wiki/images/c/c8/Arrowopen.svg +/wiki/images/b/bc/Arrowopendot.svg +/wiki/images/a/af/Arrow-right.svg +/wiki/images/3/3b/Arrowtick.svg +/wiki/images/8/8a/Arrow-up.svg +/wiki/images/f/f2/TechDraw_Dimension.svg +/wiki/images/2/28/TechDraw_Dimension_Angle.svg +/wiki/images/1/17/TechDraw_Dimension_Diameter.svg +/wiki/images/1/13/TechDraw_Dimension_Horizontal.svg +/wiki/images/f/f1/TechDraw_Dimension_Length.svg +/wiki/images/0/0c/TechDraw_Dimension_Link.svg +/wiki/images/8/8b/TechDraw_Dimension_Radius.svg +/wiki/images/c/cd/TechDraw_Dimension_Vertical.svg +/wiki/images/3/37/TechDraw_Pages.svg +/wiki/images/e/e5/TechDraw_ProjBottom.svg +/wiki/images/2/27/TechDraw_ProjFront.svg +/wiki/images/c/c6/TechDraw_ProjFrontBottomLeft.svg +/wiki/images/d/df/TechDraw_ProjFrontBottomRight.svg +/wiki/images/6/6f/TechDraw_ProjFrontTopLeft.svg +/wiki/images/d/db/TechDraw_ProjFrontTopRight.svg +/wiki/images/e/ed/TechDraw_ProjLeft.svg +/wiki/images/e/ee/TechDraw_ProjRear.svg +/wiki/images/3/37/TechDraw_ProjRight.svg +/wiki/images/8/82/TechDraw_ProjTop.svg +/wiki/images/0/0c/TechDraw_Tree_Annotation.svg +/wiki/images/9/9a/TechDraw_Tree_Hatch.svg +/wiki/images/8/8a/TechDraw_Tree_Multi.svg +/wiki/images/3/32/TechDraw_Tree_Page.svg +/wiki/images/5/5e/TechDraw_Tree_Page_Sync.svg +/wiki/images/b/b6/TechDraw_Tree_PageTemplate.svg +/wiki/images/d/dc/TechDraw_Tree_Page_Unsync.svg +/wiki/images/7/78/TechDraw_Tree_ProjGroup.svg +/wiki/images/e/e2/TechDraw_Tree_Section.svg +/wiki/images/d/db/TechDraw_Tree_Spreadsheet.svg +/wiki/images/5/55/TechDraw_Tree_Symbol.svg +/wiki/images/d/da/TechDraw_Tree_View.svg +/wiki/images/d/dd/Section-down.svg +/wiki/images/4/4b/Section-left.svg +/wiki/images/2/2f/Section-right.svg +/wiki/images/c/ce/Section-up.svg +/wiki/images/d/df/Techdraw-annotation.svg +/wiki/images/3/38/Techdraw-arch-view.svg +/wiki/images/d/de/Techdraw-draft-view.svg +/wiki/images/9/92/Techdraw-geomhatch.svg +/wiki/images/8/84/Techdraw-hatch.svg +/wiki/images/e/e6/Techdraw-image.svg +/wiki/images/5/53/Techdraw-multiview.svg +/wiki/images/8/89/Techdraw-new-default.svg +/wiki/images/c/c5/Techdraw-new-pick.svg +/wiki/images/3/31/Techdraw-projgroup.svg +/wiki/images/b/b5/Techdraw-saveSVG.svg +/wiki/images/7/79/Techdraw-symbol.svg +/wiki/images/5/5a/Techdraw-toggleframe.svg +/wiki/images/f/f1/Techdraw-view.svg +/wiki/images/1/18/Techdraw-viewdetail.svg +/wiki/images/9/90/Techdraw-viewsection.svg +/wiki/images/5/57/Angularity.svg +/wiki/images/9/99/Circularity.svg +/wiki/images/b/ba/Circular_run-out.svg +/wiki/images/a/a1/Concentricity.svg +/wiki/images/9/9e/Cylindricity.svg +/wiki/images/1/15/Flatness.svg +/wiki/images/a/ad/Flatness_editable.svg +/wiki/images/a/a7/Parallelism.svg +/wiki/images/6/64/Perpendicularity.svg +/wiki/images/8/87/Position.svg +/wiki/images/6/65/Profile_of_line.svg +/wiki/images/a/aa/Profile_of_surface.svg +/wiki/images/d/dc/Reference_editable.svg +/wiki/images/d/d7/Straightness.svg +/wiki/images/c/cd/Symmetrie.svg +/wiki/images/8/81/Tolerance_editable.svg +/wiki/images/4/4c/Total_run-out.svg +/wiki/images/2/2e/A0_Landscape_ISO7200TD.svg +/wiki/images/6/66/A1_Landscape_ISO7200TD.svg +/wiki/images/4/4a/A2_Landscape_ISO7200TD.svg +/wiki/images/c/c7/A3_Landscape_ISO7200TD.svg +/wiki/images/3/3c/A3_LandscapeTD.svg +/wiki/images/6/60/A4_Landscape_ISO7200TD.svg +/wiki/images/1/1e/A4_LandscapeTD.svg +/wiki/images/1/19/A4_Portrait_ISO7200TD.svg +/wiki/images/0/0b/TestWorkbench.svg +/wiki/images/3/33/NavigationBlender.svg +/wiki/images/d/d4/NavigationBlender_Pan.svg +/wiki/images/a/a3/NavigationBlender_PanAlt.svg +/wiki/images/5/5c/NavigationBlender_Rotate.svg +/wiki/images/9/90/NavigationBlender_Select.svg +/wiki/images/1/1b/NavigationBlender_Zoom.svg +/wiki/images/6/61/NavigationCAD.svg +/wiki/images/3/30/NavigationCADAlt.svg +/wiki/images/8/87/NavigationCAD_Pan.svg +/wiki/images/d/df/NavigationCAD_Rotate.svg +/wiki/images/f/fa/NavigationCAD_RotateAlt.svg +/wiki/images/b/b8/NavigationCAD_Select.svg +/wiki/images/b/b4/NavigationCAD_Zoom.svg +/wiki/images/5/5f/NavigationGesture.svg +/wiki/images/d/dd/NavigationGesture_Pan.svg +/wiki/images/b/b2/NavigationGesture_PanTouch.svg +/wiki/images/c/c0/NavigationGesture_PanTouchAlt.svg +/wiki/images/c/c2/NavigationGesture_Rotate.svg +/wiki/images/f/ff/NavigationGesture_RotateAlt.svg +/wiki/images/b/b9/NavigationGesture_RotateTouch.svg +/wiki/images/a/ae/NavigationGesture_Select.svg +/wiki/images/3/31/NavigationGesture_SelectTouch.svg +/wiki/images/f/fa/NavigationGesture_Tilt.svg +/wiki/images/3/32/NavigationGesture_TiltTouch.svg +/wiki/images/b/b9/NavigationGesture_Zoom.svg +/wiki/images/f/fd/NavigationGesture_ZoomTouch.svg +/wiki/images/b/b4/NavigationMayaGesture.svg +/wiki/images/c/cf/NavigationMayaGesture_Pan.svg +/wiki/images/5/55/NavigationMayaGesture_PanTouch.svg +/wiki/images/a/af/NavigationMayaGesture_PanTouchAlt.svg +/wiki/images/3/3a/NavigationMayaGesture_Rotate.svg +/wiki/images/e/e9/NavigationMayaGesture_RotateTouch.svg +/wiki/images/5/5e/NavigationMayaGesture_Select.svg +/wiki/images/6/63/NavigationMayaGesture_SelectTouch.svg +/wiki/images/a/a1/NavigationMayaGesture_Tilt.svg +/wiki/images/f/f1/NavigationMayaGesture_TiltTouch.svg +/wiki/images/4/49/NavigationMayaGesture_Zoom.svg +/wiki/images/1/14/NavigationMayaGesture_ZoomAlt.svg +/wiki/images/3/30/NavigationMayaGesture_ZoomTouch.svg +/wiki/images/6/62/NavigationOpenCascade.svg +/wiki/images/7/7c/NavigationOpenCascade_Pan.svg +/wiki/images/4/46/NavigationOpenCascade_PanAlt.svg +/wiki/images/8/86/NavigationOpenCascade_Rotate.svg +/wiki/images/0/04/NavigationOpenCascade_Select.svg +/wiki/images/3/3c/NavigationOpenCascade_Zoom.svg +/wiki/images/6/66/NavigationOpenCascade_ZoomAlt.svg +/wiki/images/5/58/NavigationOpenInventor.svg +/wiki/images/3/39/NavigationOpenInventor_Pan.svg +/wiki/images/8/8a/NavigationOpenInventor_Rotate.svg +/wiki/images/5/58/NavigationOpenInventor_Select.svg +/wiki/images/8/8e/NavigationOpenInventor_Zoom.svg +/wiki/images/c/c7/NavigationOpenInventor_ZoomAlt.svg +/wiki/images/a/a1/NavigationTouchpad.svg +/wiki/images/2/22/NavigationTouchpad_Pan.svg +/wiki/images/f/f3/NavigationTouchpad_PanTouch.svg +/wiki/images/2/24/NavigationTouchpad_Rotate.svg +/wiki/images/8/81/NavigationTouchpad_RotateAlt.svg +/wiki/images/d/db/NavigationTouchpad_RotateTouch.svg +/wiki/images/8/86/NavigationTouchpad_RotateTouchAlt.svg +/wiki/images/4/44/NavigationTouchpad_Select.svg +/wiki/images/5/5f/NavigationTouchpad_SelectTouch.svg +/wiki/images/2/26/NavigationTouchpad_Zoom.svg +/wiki/images/b/b4/NavigationTouchpad_ZoomAlt.svg +/wiki/images/4/4a/NavigationTouchpad_ZoomTouch.svg +/wiki/images/4/43/NavigationUndefined.svg +/wiki/images/d/d1/Sketchfab.svg +/wiki/images/6/6e/WebWorkbench.svg +/wiki/images/7/75/Web-browser.svg +/wiki/images/7/7c/Web-home.svg +/wiki/images/b/bd/Web-next.svg +/wiki/images/5/5d/Web-previous.svg +/wiki/images/4/40/Web-refresh.svg +/wiki/images/9/9d/Web-sketchfab.svg +/wiki/images/c/c6/Web-stop.svg +/wiki/images/7/7d/Web-zoom-in.svg +/wiki/images/2/20/Web-zoom-out.svg +/wiki/images/thumb/2/20/IconAnatomy.png/256px-IconAnatomy.png +/wiki/images/9/9b/Green_tones.PNG +/wiki/images/b/b3/IconSize.png +/wiki/images/8/8e/Artwork_Grid.png +/wiki/images/c/c5/Draft_Point.png +/wiki/images/c/c5/Draft_Move.png +/wiki/images/3/39/Draft_Clone.png +Bugtracker +/wiki/images/3/35/Mantis_logo_262x90.png +/wiki/images/thumb/b/bb/MantisBT-setting-Feature-Request.jpg/300px-MantisBT-setting-Feature-Request.jpg +/wiki/images/thumb/b/ba/Mantisbt-mention-example.jpg/600px-Mantisbt-mention-example.jpg +/wiki/images/thumb/4/47/Mantisbt-ticket-shortcut-example.jpg/600px-Mantisbt-ticket-shortcut-example.jpg +/wiki/images/thumb/2/23/Mantisbt-comment-shortcut-example.jpg/600px-Mantisbt-comment-shortcut-example.jpg +/wiki/images/thumb/4/49/Mantisbt-strikeout-text-example.jpg/600px-Mantisbt-strikeout-text-example.jpg +/wiki/images/thumb/f/f3/Mantisbt-colorized-code-example.jpg/600px-Mantisbt-colorized-code-example.jpg +/wiki/images/thumb/2/20/Mantisbt-source-integration-markup.jpg/600px-Mantisbt-source-integration-markup.jpg +Source_Code_Management +Source_code_management +Developing_FreeCAD_with_GitKraken +/wiki/images/7/7e/GitKraken-Clone-Repo-dialogue.png +/wiki/images/a/af/GitKraken-Main-Screen-sm.jpg +/wiki/images/e/ef/GitKraken-Rebasing.gif +/wiki/images/0/0e/Gitkraken-add-remote.gif +Bug_Triage +Command +Category:Command_Reference +Drawing_Save +/wiki/images/thumb/4/43/Drawing_Save.png/32px-Drawing_Save.png +Drawing_ProjectShape +/wiki/images/8/87/Drawing_ProjectShape.png +/wiki/images/0/04/ProjectShape1_it.png +/wiki/images/e/e5/ProjectShapeSet_it.png +/wiki/images/0/04/ProjectShapeOptions_it.png +Drawing_Open_SVG +/wiki/images/thumb/f/fc/Drawing_Open_SVG.png/32px-Drawing_Open_SVG.png +Draft_WireToBSpline +/wiki/images/thumb/a/a4/Draft_WireToBSpline.png/32px-Draft_WireToBSpline.png +/wiki/images/thumb/f/f4/Draft_Wire2BSpline_example.jpg/400px-Draft_Wire2BSpline_example.jpg +/wiki/images/thumb/a/a4/Draft_WireToBSpline.png/16px-Draft_WireToBSpline.png +Draft_ToggleContinueMode +/wiki/images/3/30/Draft_ToggleContinueMode.png +Draft_ToggleConstructionMode +/wiki/images/thumb/7/76/Draft_ToggleConstructionMode.png/32px-Draft_ToggleConstructionMode.png +/wiki/images/thumb/8/85/Draft_construction_mode_example.jpg/400px-Draft_construction_mode_example.jpg +/wiki/images/thumb/7/76/Draft_ToggleConstructionMode.png/16px-Draft_ToggleConstructionMode.png +Draft_ShowSnapBar +/wiki/images/thumb/c/c3/Draft_ShowSnapBar.png/32px-Draft_ShowSnapBar.png +Draft_Heal +/wiki/images/thumb/d/d9/Draft_Heal.png/32px-Draft_Heal.png +/wiki/images/thumb/d/d9/Draft_Heal.png/16px-Draft_Heal.png +Draft_AddConstruction +/wiki/images/1/18/Draft_AddConstruction.png +Constraint_TangentToStart +/wiki/images/thumb/2/23/Constraint_TangentToStart.png/32px-Constraint_TangentToStart.png +Constraint_TangentToEnd +/wiki/images/thumb/e/e1/Constraint_TangentToEnd.png/32px-Constraint_TangentToEnd.png +Constraint_PointToObject +/wiki/images/thumb/8/8f/Constraint_PointToObject.png/32px-Constraint_PointToObject.png +Constraint_PointOnStart +/wiki/images/thumb/f/f9/Constraint_PointOnStart.png/32px-Constraint_PointOnStart.png +Constraint_PointOnMidPoint +/wiki/images/thumb/2/2c/Constraint_PointOnMidPoint.png/32px-Constraint_PointOnMidPoint.png +Constraint_PointOnEnd +/wiki/images/thumb/e/ee/Constraint_PointOnEnd.png/32px-Constraint_PointOnEnd.png +Constraint_ExternalAngle +/wiki/images/thumb/8/81/Constraint_ExternalAngle.png/32px-Constraint_ExternalAngle.png +Constraint_Concentric +/wiki/images/thumb/2/25/Constraint_Concentric.png/32px-Constraint_Concentric.png +Arch_ToggleSubs +/wiki/images/thumb/5/56/Arch_ToggleSubs.png/32px-Arch_ToggleSubs.png +/wiki/images/thumb/5/56/Arch_ToggleSubs.png/16px-Arch_ToggleSubs.png +Arch_ToggleIfcBrepFlag +/wiki/images/thumb/1/11/Arch_ToggleIfcBrepFlag.png/32px-Arch_ToggleIfcBrepFlag.png +/wiki/images/thumb/1/11/Arch_ToggleIfcBrepFlag.png/16px-Arch_ToggleIfcBrepFlag.png +Arch_SplitMesh +/wiki/images/thumb/8/8e/Arch_SplitMesh.png/32px-Arch_SplitMesh.png +/wiki/images/thumb/8/8e/Arch_SplitMesh.png/16px-Arch_SplitMesh.png +Arch_SelectNonSolidMeshes +/wiki/images/thumb/0/0c/Arch_SelectNonSolidMeshes.png/32px-Arch_SelectNonSolidMeshes.png +/wiki/images/thumb/0/0c/Arch_SelectNonSolidMeshes.png/16px-Arch_SelectNonSolidMeshes.png +Arch_RemoveShape +/wiki/images/thumb/0/02/Arch_RemoveShape.png/32px-Arch_RemoveShape.png +/wiki/images/thumb/0/02/Arch_RemoveShape.png/16px-Arch_RemoveShape.png +Arch_Rebar_UShape +/wiki/images/thumb/4/4d/Arch_Rebar_UShape.png/32px-Arch_Rebar_UShape.png +/wiki/images/thumb/0/01/UShapeRebar.png/16px-UShapeRebar.png +/wiki/images/thumb/3/35/Footing_UShapeRebar.png/800px-Footing_UShapeRebar.png +/wiki/images/thumb/8/8c/UShapeDialog.png/250px-UShapeDialog.png +Custom_Spacing +/wiki/images/c/c3/RebarDistributionDialog.png +/wiki/images/thumb/a/a1/RebarDistribution.png/800px-RebarDistribution.png +Arch_Rebar_Straight +/wiki/images/thumb/6/69/Arch_Rebar_Straight.png/32px-Arch_Rebar_Straight.png +/wiki/images/thumb/6/69/Arch_Rebar_Straight.png/16px-Arch_Rebar_Straight.png +/wiki/images/thumb/f/fd/StraightRebar.png/800px-StraightRebar.png +/wiki/images/thumb/a/ad/StraightRebarDialog.png/250px-StraightRebarDialog.png +Arch_Rebar_Stirrup +/wiki/images/thumb/e/ef/Arch_Rebar_Stirrup.png/32px-Arch_Rebar_Stirrup.png +/wiki/images/thumb/e/ef/Arch_Rebar_Stirrup.png/16px-Arch_Rebar_Stirrup.png +/wiki/images/thumb/9/9b/Stirrup.png/800px-Stirrup.png +/wiki/images/thumb/9/94/StirrupDialog.png/250px-StirrupDialog.png +Arch_Rebar_LShape +/wiki/images/thumb/3/38/Arch_Rebar_LShape.png/32px-Arch_Rebar_LShape.png +/wiki/images/thumb/3/38/Arch_Rebar_LShape.png/16px-Arch_Rebar_LShape.png +/wiki/images/thumb/1/10/LShapeRebarNew.png/800px-LShapeRebarNew.png +/wiki/images/thumb/3/31/LShapeDialog.png/250px-LShapeDialog.png +Arch_Rebar_Helical +/wiki/images/thumb/c/c9/Arch_Rebar_Helical.png/32px-Arch_Rebar_Helical.png +/wiki/images/thumb/c/c9/Arch_Rebar_Helical.png/16px-Arch_Rebar_Helical.png +/wiki/images/thumb/2/2f/HelicalRebar.png/800px-HelicalRebar.png +/wiki/images/thumb/3/31/HelicalRebarDialog.png/250px-HelicalRebarDialog.png +Arch_Rebar_BentShape +/wiki/images/thumb/0/0b/Arch_Rebar_BentShape.png/32px-Arch_Rebar_BentShape.png +/wiki/images/thumb/0/0b/Arch_Rebar_BentShape.png/16px-Arch_Rebar_BentShape.png +/wiki/images/thumb/e/e3/BentShapeRebar.png/800px-BentShapeRebar.png +/wiki/images/thumb/8/8f/BentShapeDialog.png/250px-BentShapeDialog.png +Arch_MeshToShape +/wiki/images/thumb/6/6f/Arch_MeshToShape.png/32px-Arch_MeshToShape.png +/wiki/images/thumb/6/6f/Arch_MeshToShape.png/16px-Arch_MeshToShape.png +Arch_MergeWalls +/wiki/images/thumb/0/07/Arch_MergeWalls.png/32px-Arch_MergeWalls.png +Arch_IfcExplorer +/wiki/images/thumb/2/22/Arch_IfcExplorer.png/32px-Arch_IfcExplorer.png +/wiki/images/thumb/5/5c/Arch_IfcExplorer_example.jpg/640px-Arch_IfcExplorer_example.jpg +Arch_CloseHoles +/wiki/images/thumb/e/ee/Arch_CloseHoles.png/32px-Arch_CloseHoles.png +/wiki/images/thumb/e/ee/Arch_CloseHoles.png/16px-Arch_CloseHoles.png +Arch_CloneComponent +/wiki/images/thumb/8/80/Arch_cloneComponent.png/32px-Arch_cloneComponent.png +Arch_Check +/wiki/images/thumb/9/91/Arch_Check.png/32px-Arch_Check.png +/wiki/images/thumb/9/91/Arch_Check.png/16px-Arch_Check.png +Arch_Cell +/wiki/images/7/7c/Arch_Cell_example.jpg +/wiki/images/thumb/0/09/Arch_Cell.png/16px-Arch_Cell.png +Scripting_examples +Python_Development_Environment +/wiki/images/6/61/PythonDevelopmentEnvironment.jpg +Scripted_objects +PySide +Scenegraph +/wiki/images/b/b7/Scenegraph.gif +Topological_data_scripting +/wiki/images/1/13/Part_Classes.jpg +/wiki/images/7/77/Wire.png +/wiki/images/e/ec/Circel.png +/wiki/images/5/5b/Line.png +Scripting +/wiki/images/1/1a/Crystal_Clear_app_terminal.png +FreeCAD_Community_Portal +David +/wiki/images/thumb/0/07/LaserLine.JPG/120px-LaserLine.JPG +/wiki/images/thumb/9/91/Cam.JPG/84px-Cam.JPG +/wiki/images/thumb/a/ad/WaWue.JPG/118px-WaWue.JPG +/wiki/images/thumb/e/e8/Band.JPG/120px-Band.JPG +/wiki/images/thumb/c/c6/Blade.JPG/120px-Blade.JPG +/wiki/images/thumb/5/5a/Setup_Bottle.JPG/250px-Setup_Bottle.JPG +/wiki/images/thumb/7/75/Setup_WaWue.JPG/250px-Setup_WaWue.JPG +/wiki/images/thumb/5/59/Bottle_raw.jpg/120px-Bottle_raw.jpg +/wiki/images/thumb/0/0c/Bottle.jpg/120px-Bottle.jpg +/wiki/images/thumb/d/d7/Bottle_detail.jpg/120px-Bottle_detail.jpg +/wiki/images/thumb/1/10/Bottle_detail_interpol.jpg/120px-Bottle_detail_interpol.jpg +/wiki/images/thumb/a/a8/Wawue_Top.jpg/120px-Wawue_Top.jpg +/wiki/images/thumb/e/e1/Wawue_Side.jpg/120px-Wawue_Side.jpg +/wiki/images/thumb/4/40/WaWue_SphrerFit.jpg/120px-WaWue_SphrerFit.jpg +FreeCAD_vector_math_library +Embedding_FreeCADGui +PythonOCC +Workbench_creation +Builtin_modules +ViewObject_API +Object_API +Selection_API +FreeCADGui_API +Console_API +Matrix_API +Vector_API +Base_API +FreeCAD_API +Installing_more_workbenches +Mesh_Scripting +Mesh_API +Macros +/wiki/images/0/09/Macros_toolbar.jpg +/wiki/images/8/84/Macros.png +/wiki/images/b/ba/Macros_config.jpg +Standard_Menu +Std_Windows_Menu +/wiki/images/thumb/a/ab/Std_WindowNext.png/24px-Std_WindowNext.png +/wiki/images/thumb/c/c4/Std_WindowPrev.png/24px-Std_WindowPrev.png +/wiki/images/thumb/d/dc/Std_WindowTileVer.png/24px-Std_WindowTileVer.png +/wiki/images/thumb/4/4c/Std_WindowCascade.png/24px-Std_WindowCascade.png +Std_Workbench_Menu +FreeCAD_Scripting_Basics +/wiki/images/9/98/Screenshot_pythoninterpreter.jpg +/wiki/images/f/f2/Screenshot_classbrowser.jpg +Introduction_to_Python +List_of_Commands +Arch_MakeIfcSpreadsheet +Interface_Customization +/wiki/images/f/ff/Screenshot-customize.jpg +/wiki/images/a/a8/CustomizeWorkbenches.png +Robot_Workbench +/wiki/images/thumb/c/c5/KukaKR16FreeCAD.jpg/400px-KukaKR16FreeCAD.jpg +/wiki/images/thumb/8/8e/Robot_CreateRobot.png/30px-Robot_CreateRobot.png +/wiki/images/thumb/4/42/Robot_Simulate.png/30px-Robot_Simulate.png +/wiki/images/thumb/8/8e/Robot_Export.png/30px-Robot_Export.png +/wiki/images/thumb/3/3c/Robot_SetHomePos.png/30px-Robot_SetHomePos.png +/wiki/images/thumb/9/95/Robot_RestoreHomePos.png/30px-Robot_RestoreHomePos.png +/wiki/images/thumb/9/90/Robot_CreateTrajectory.png/30px-Robot_CreateTrajectory.png +/wiki/images/thumb/e/e0/Robot_SetDefaultOrientation.png/30px-Robot_SetDefaultOrientation.png +/wiki/images/thumb/f/fc/Robot_SetDefaultValues.png/30px-Robot_SetDefaultValues.png +/wiki/images/thumb/7/74/Robot_InsertWaypoint.png/30px-Robot_InsertWaypoint.png +/wiki/images/thumb/8/8f/Robot_InsertWaypointPre.png/30px-Robot_InsertWaypointPre.png +/wiki/images/thumb/a/a7/Robot_Edge2Trac.png/30px-Robot_Edge2Trac.png +/wiki/images/thumb/2/28/Robot_TrajectoryDressUp.png/30px-Robot_TrajectoryDressUp.png +/wiki/images/thumb/f/fb/Robot_TrajectoryCompound.png/30px-Robot_TrajectoryCompound.png +VRML_Preparation_for_Robot_Simulation +/wiki/images/thumb/f/f6/Staeubli_step_import.png/1024px-Staeubli_step_import.png +/wiki/images/e/ee/Staeubli_important_points.png +Robot_TrajectoryCompound +/wiki/images/thumb/f/fb/Robot_TrajectoryCompound.png/32px-Robot_TrajectoryCompound.png +Robot_TrajectoryDressUp +/wiki/images/thumb/2/28/Robot_TrajectoryDressUp.png/32px-Robot_TrajectoryDressUp.png +Robot_Edge2Trac +/wiki/images/thumb/a/a7/Robot_Edge2Trac.png/32px-Robot_Edge2Trac.png +/wiki/images/a/a5/Robot_Edge2Trac_Menu.jpg +Robot_InsertWaypointPre +/wiki/images/thumb/8/8f/Robot_InsertWaypointPre.png/32px-Robot_InsertWaypointPre.png +Robot_InsertWaypoint +/wiki/images/thumb/7/74/Robot_InsertWaypoint.png/32px-Robot_InsertWaypoint.png +Robot_SetDefaultValues +/wiki/images/thumb/f/fc/Robot_SetDefaultValues.png/32px-Robot_SetDefaultValues.png +Robot_CreateTrajectory +/wiki/images/thumb/9/90/Robot_CreateTrajectory.png/32px-Robot_CreateTrajectory.png +Robot_RestoreHomePos +/wiki/images/thumb/9/95/Robot_RestoreHomePos.png/32px-Robot_RestoreHomePos.png +Robot_SetHomePos +/wiki/images/thumb/3/3c/Robot_SetHomePos.png/32px-Robot_SetHomePos.png +Robot_Export +/wiki/images/thumb/8/8e/Robot_Export.png/32px-Robot_Export.png +Robot_Simulate +/wiki/images/thumb/4/42/Robot_Simulate.png/32px-Robot_Simulate.png +/wiki/images/1/12/Robot_Simulation_Player.jpg +Robot_CreateRobot +/wiki/images/thumb/8/8e/Robot_CreateRobot.png/32px-Robot_CreateRobot.png +Robot_tutorial +/wiki/images/e/ef/Robot_Tutorial_RobotSimulation.gif +Robot_6-Axis +/wiki/images/b/b3/KukaKR16.jpg +/wiki/images/0/07/KukaParts.jpg +/wiki/images/6/61/KukaAxisPosition.jpg +/wiki/images/2/25/KukaBase.jpg +/wiki/images/9/9e/KukaSegment1.jpg +/wiki/images/d/de/KukaSegment2.jpg +/wiki/images/4/4a/KukaSegment3.jpg +/wiki/images/4/4b/KukaSegment4.jpg +/wiki/images/6/63/KukaSegment5.jpg +/wiki/images/9/9b/KukaSegment6.jpg +/wiki/images/9/94/KukaAxisData.jpg +/wiki/images/c/c5/KukaKR16FreeCAD.jpg +Ray_Tracing_Workbench +Drawing_Workbench +/wiki/images/thumb/d/dc/Drawing_New.png/32px-Drawing_New.png +/wiki/images/thumb/f/ff/Drawing_DraftView.png/32px-Drawing_DraftView.png +/wiki/images/thumb/f/f4/Drawing_extraction.png/800px-Drawing_extraction.png +/wiki/images/thumb/2/2e/DrawingScriptResult.jpg/800px-DrawingScriptResult.jpg +Drawing_tutorial +/wiki/images/thumb/8/88/Drawing_tutorial_result.png/480px-Drawing_tutorial_result.png +/wiki/images/9/91/Draft_PutOnSheet.png +Draft_tutorial +/wiki/images/thumb/9/99/Draft_tutorial_result.png/480px-Draft_tutorial_result.png +/wiki/images/a/a8/Draft_Arc.png +/wiki/images/a/a8/Draft_Line.png +/wiki/images/b/be/Draft_Upgrade.png +/wiki/images/1/10/Draft_Circle.png +/wiki/images/8/8e/Draft_Polygon.png +/wiki/images/b/b0/Draft_Dimension.png +Drawing_Documentation +Arch_Workbench +Arch_panel_tutorial +/wiki/images/thumb/2/2d/Arch_panel_tutorial_01.jpg/800px-Arch_panel_tutorial_01.jpg +/wiki/images/d/df/Arch_panel_tutorial_02.jpg +/wiki/images/b/b7/Arch_panel_tutorial_03.jpg +/wiki/images/6/67/Arch_panel_tutorial_04.jpg +/wiki/images/2/26/Arch_panel_tutorial_05.jpg +/wiki/images/c/c3/Arch_panel_tutorial_06.jpg +/wiki/images/d/d5/Arch_panel_tutorial_07.jpg +/wiki/images/4/43/Arch_panel_tutorial_08.jpg +/wiki/images/7/73/Arch_panel_tutorial_09.jpg +/wiki/images/a/ab/Arch_panel_tutorial_10.jpg +/wiki/images/f/f2/Arch_panel_tutorial_11.jpg +/wiki/images/a/a1/Arch_panel_tutorial_12.jpg +/wiki/images/6/6a/Arch_panel_tutorial_13.jpg +/wiki/images/5/5d/Arch_panel_tutorial_14.jpg +/wiki/images/f/f4/Arch_panel_tutorial_15.jpg +/wiki/images/7/7d/Arch_panel_tutorial_16.jpg +/wiki/images/7/78/Arch_panel_tutorial_17.jpg +/wiki/images/8/8a/Arch_panel_tutorial_18.jpg +/wiki/images/9/96/Arch_panel_tutorial_19.jpg +/wiki/images/2/23/Arch_panel_tutorial_20.jpg +Arch_JSON +Arch_Preferences +/wiki/images/9/92/Preference_Arch_Tab_01.png +/wiki/images/6/6d/Preference_Arch_Tab_02.png +Part_Workbench +/wiki/images/8/85/Part_example.jpg +/wiki/images/thumb/4/45/Part_Union.png/32px-Part_Union.png +/wiki/images/thumb/e/e7/Part_XOR.png/32px-Part_XOR.png +/wiki/images/thumb/2/26/Part_RuledSurface.png/32px-Part_RuledSurface.png +/wiki/images/thumb/d/d6/Part_ImportCAD.png/32px-Part_ImportCAD.png +/wiki/images/thumb/b/bd/Part_ExportCAD.png/32px-Part_ExportCAD.png +/wiki/images/thumb/5/5f/Part_CheckGeometry.png/32px-Part_CheckGeometry.png +/wiki/images/thumb/d/df/Part_BooleanOperations.png/500px-Part_BooleanOperations.png +Whiffle_Ball_tutorial +/wiki/images/c/c4/Tutorial_WhiffleBall.jpg +/wiki/images/4/49/Tutorial_WhiffleBall_BasicShape.jpg +/wiki/images/2/2e/Tutorial_WhiffleBall_UnfinishedShape.jpg +Import_Export_Preference +/wiki/images/2/23/Preference_Import_Export_Tab_01.png +/wiki/images/e/e9/Preference_Import_Export_Tab_02.png +/wiki/images/a/a9/Preference_Import_Export_Tab_03.png +/wiki/images/3/3c/Preference_Import_Export_Tab_04.png +/wiki/images/8/82/Preference_Import_Export_Tab_05.png +/wiki/images/a/a7/Preference_Import_Export_Tab_06.png +/wiki/images/d/d5/Preference_Import_Export_Tab_07.png +/wiki/images/9/95/Preference_Import_Export_Tab_08.png +/wiki/images/4/4f/Preference_Import_Export_Tab_09.png +Draft_OCA +Draft_SVG +/wiki/images/a/ac/Screenshot_inkscape.jpg +FreeCAD_and_DXF_Import +Part_CheckGeometry +/wiki/images/c/c4/PartCheckGeometry.png +/wiki/images/e/e4/GeometryCheck_Errors.jpg +Part_ReverseShapes +/wiki/images/7/72/Part_ReverseShapes.png +Part_ConvertToSolid +/wiki/images/6/6b/Part_ConvertToSolid.png +Part_ShapeFromMesh +Part_ExportCAD +/wiki/images/thumb/b/bd/Part_ExportCAD.png/24px-Part_ExportCAD.png +Part_ImportCAD +/wiki/images/thumb/d/d6/Part_ImportCAD.png/24px-Part_ImportCAD.png +Part_RuledSurface +/wiki/images/7/77/PartRuledSurface_it.png +Mesh_Workbench +/wiki/images/8/88/Mesh_example.jpg +/wiki/images/thumb/2/27/Mesh_ImportMesh.png/32px-Mesh_ImportMesh.png +/wiki/images/thumb/3/31/Mesh_FlipNormals.png/32px-Mesh_FlipNormals.png +/wiki/images/thumb/b/b0/Mesh_RemoveComponents.png/32px-Mesh_RemoveComponents.png +/wiki/images/thumb/9/96/Mesh_EvaluateFacet.png/32px-Mesh_EvaluateFacet.png +/wiki/images/thumb/d/d9/Mesh_Regular_Solid.png/32px-Mesh_Regular_Solid.png +/wiki/images/thumb/d/df/Mesh_Cube.png/32px-Mesh_Cube.png +/wiki/images/thumb/2/26/Mesh_Cylinder.png/32px-Mesh_Cylinder.png +/wiki/images/thumb/d/df/Mesh_Cone.png/32px-Mesh_Cone.png +/wiki/images/thumb/9/98/Mesh_Sphere.png/32px-Mesh_Sphere.png +/wiki/images/thumb/9/9f/Mesh_Ellipsoid.png/32px-Mesh_Ellipsoid.png +/wiki/images/thumb/3/36/Mesh_Torus.png/32px-Mesh_Torus.png +/wiki/images/thumb/7/73/Mesh_Cut.png/32px-Mesh_Cut.png +/wiki/images/thumb/0/0f/Mesh_MakeSegment.png/32px-Mesh_MakeSegment.png +/wiki/images/thumb/3/3b/Mesh_CurvaturePlot.png/32px-Mesh_CurvaturePlot.png +FreeCAD_and_Mesh_Import +Mesh_CurvaturePlot +Mesh_CreateMeshSegment +/wiki/images/7/7b/Mesh_CreateMeshSegment.png +Mesh_TrimMeshWithPlane +/wiki/images/d/dd/Mesh_TrimMeshWithPlane.png +Mesh_TrimMesh +/wiki/images/3/3b/Mesh_TrimMesh.png +Mesh_MakeSegment +Mesh_SplitMesh +/wiki/images/7/7e/Mesh_SplitMesh.png +Mesh_Cut +Mesh_SelectMesh +/wiki/images/a/a3/Mesh_SelectMesh.png +Mesh_Merge +/wiki/images/8/88/Mesh_Merge.png +Mesh_Difference +/wiki/images/5/53/Mesh_Difference.png +/wiki/images/8/83/Meshes_Boolean_Difference.jpg +Mesh_Intersection +/wiki/images/9/93/Mesh_Intersection.png +/wiki/images/0/09/Meshes_Boolean_Intersection.jpg +Mesh_Union +/wiki/images/1/12/Mesh_Union.png +/wiki/images/0/01/Meshes_Boolean_Union.jpg +Mesh_BuildRegularSolid +/wiki/images/b/b0/Meshes_RegularSolid_Cube.jpg +/wiki/images/6/64/Meshes_RegularSolid_Cylinder.jpg +/wiki/images/a/a2/Meshes_RegularSolid_Cone.jpg +/wiki/images/b/b9/Meshes_RegularSolid_Sphere.jpg +/wiki/images/c/c1/Meshes_RegularSolid_Ellipsoid.jpg +/wiki/images/e/e6/Meshes_RegularSolid_Torus.jpg +Mesh_BoundingBox +/wiki/images/b/bf/Mesh_BoundingBox.png +/wiki/images/0/02/Mesh_BoundingsInfo.jpg +Mesh_EvaluateCurvature +/wiki/images/8/87/Mesh_EvaluateCurvature.png +Mesh_EvaluateFacet +Mesh_EvaluateRepair +/wiki/images/3/3d/Mesh_EvaluateRepair.png +/wiki/images/c/ca/Mesh_EvaluateRepairMesh.jpg +Mesh_Smooth +/wiki/images/f/f8/Mesh_Smooth.png +/wiki/images/7/70/Meshes_Smooth.jpg +Mesh_AddTriangle +/wiki/images/9/9b/Mesh_AddTriangle.png +Mesh_RemoveCompByHand +/wiki/images/3/3a/Mesh_RemoveCompByHand.png +Mesh_RemoveComponents +/wiki/images/c/c6/Meshes_RemoveComponents.jpg +Mesh_FillInteractiveHole +Mesh_FillHoles +/wiki/images/9/92/Mesh_FillHoles.png +Mesh_FlipNormals +Mesh_HarmonizeNormals +Mesh_Export +/wiki/images/thumb/0/0f/Mesh_ExportMesh.png/24px-Mesh_ExportMesh.png +Mesh_Import +/wiki/images/thumb/2/27/Mesh_ImportMesh.png/24px-Mesh_ImportMesh.png +PartDesign_Workbench +/wiki/images/thumb/c/c5/PartDesign_Example.png/400px-PartDesign_Example.png +/wiki/images/4/43/PartDesign_NewSketch.png +/wiki/images/thumb/f/f2/PartDesign_ShapeBinder.png/32px-PartDesign_ShapeBinder.png +/wiki/images/thumb/a/ab/PartDesign_Clone.png/32px-PartDesign_Clone.png +/wiki/images/thumb/6/67/PartDesign_Pocket.png/32px-PartDesign_Pocket.png +/wiki/images/thumb/f/f8/PartDesign_Hole.png/32px-PartDesign_Hole.png +/wiki/images/thumb/8/8d/PartDesign_Groove.png/32px-PartDesign_Groove.png +/wiki/images/1/10/PartDesign_SubtractiveLoft.png +/wiki/images/8/8a/PartDesign_SubtractivePipe.png +/wiki/images/thumb/a/a7/PartDesign_Chamfer.png/32px-PartDesign_Chamfer.png +/wiki/images/thumb/8/87/PartDesign_Draft.png/32px-PartDesign_Draft.png +/wiki/images/thumb/d/d2/PartDesign_Boolean.png/32px-PartDesign_Boolean.png +/wiki/images/thumb/2/2b/PartDesign_WizardShaft.png/32px-PartDesign_WizardShaft.png +/wiki/images/thumb/b/b0/PartDesign_InternalExternalGear.png/32px-PartDesign_InternalExternalGear.png +Basic_Part_Design_Tutorial_017 +/wiki/images/c/c7/Tut17_final_refined.png +/wiki/images/a/a7/Tutorial_Drawing_Sheet.png +/wiki/images/thumb/3/39/Tut17_sketchplanes.png/250px-Tut17_sketchplanes.png +/wiki/images/0/04/Tut17_sketcherempty.png +/wiki/images/7/78/Tut17_profile.png +/wiki/images/2/25/PD_WB_Tutorial003.png +/wiki/images/a/ab/Tut17_slot_unconstrained.png +/wiki/images/a/a0/Tut17_slote_constrained.png +/wiki/images/7/79/Tut17_profilewithslots.png +/wiki/images/7/7d/Tut17_profilewithslotsrearplane.png +/wiki/images/f/f7/Tut17_sidblockunconstrained.png +/wiki/images/7/72/Tut17_sideblockconstraind.png +/wiki/images/8/82/Tut17_sideblock.png +/wiki/images/3/3c/Tut17_profilewithsideblocks.png +/wiki/images/0/0f/Tut17_innerplane.png +/wiki/images/3/34/Tut17_rechtangleholeunconstrained.png +/wiki/images/f/ff/Tut17_rectangleholeconstrained.png +/wiki/images/5/5c/Tut17_wrongplaneforpocket.png +/wiki/images/b/b9/Tut17_profilewithsideblocksrearplane.png +/wiki/images/b/b7/Tut17_rectangleunconstrained.png +/wiki/images/e/ef/Tut17_rectangleconstrained.png +/wiki/images/d/d1/Tut17_final.png +/wiki/images/2/27/Tut17_refine.png +Basic_Part_Design_Tutorial +/wiki/images/b/bc/PD_WB_Tutorial018.png +/wiki/images/3/35/PD_WB_Tutorial001.png +/wiki/images/2/22/PD_WB_Tutorial002.png +/wiki/images/4/4d/PD_WB_Tutorial004.png +/wiki/images/a/a4/PD_WB_Tutorial005.png +/wiki/images/d/de/PD_WB_Tutorial006.png +/wiki/images/1/1c/PD_WB_Tutorial007.png +/wiki/images/c/c8/PD_WB_Tutorial008.png +/wiki/images/1/1f/PD_WB_Tutorial009.png +/wiki/images/c/c7/PD_WB_Tutorial010.png +/wiki/images/e/ef/PD_WB_Tutorial011.png +/wiki/images/1/12/PD_WB_Tutorial012.png +/wiki/images/d/d1/PD_WB_Tutorial013.png +/wiki/images/d/d6/PD_WB_Tutorial014.png +/wiki/images/8/85/PD_WB_Tutorial015.png +/wiki/images/1/19/PD_WB_Tutorial016.png +/wiki/images/2/2f/PD_WB_Tutorial017.png +/wiki/images/7/76/PD_WB_Tutorial019.png +Creating_a_simple_part_with_PartDesign +/wiki/images/c/ce/GGTuto1_Vue.PNG +/wiki/images/8/8d/GGTuto1_0.PNG +/wiki/images/9/9e/GGTuto1_1.PNG +/wiki/images/a/ab/GGTuto1_2.PNG +/wiki/images/6/66/GGTuto1_3.PNG +/wiki/images/7/7a/GGTuto1_4.PNG +/wiki/images/5/59/GGTuto1_5.PNG +/wiki/images/1/1b/GGTuto1_6.PNG +/wiki/images/f/f9/GGTuto1_10.PNG +/wiki/images/c/c0/GGTuto1_11.PNG +/wiki/images/0/03/GGTuto1_7.PNG +/wiki/images/9/98/GGTuto1_8.PNG +/wiki/images/b/b8/GGTuto1_12.PNG +/wiki/images/9/98/GGTuto1_9.PNG +PartDesign_Preferences +/wiki/images/2/20/Preference_Part_Design_Tab_01.png +/wiki/images/6/68/Preference_Part_Design_Tab_02.png +PartDesign_WizardShaft +/wiki/images/thumb/1/1e/WizardShaft_Part.jpg/780px-WizardShaft_Part.jpg +/wiki/images/thumb/e/ee/Shaftwizard1.jpg/1024px-Shaftwizard1.jpg +PartDesign_Migrate +PartDesign_Boolean +/wiki/images/1/16/PartDesign_Boolean_example.png +/wiki/images/thumb/d/d2/PartDesign_Boolean.png/24px-PartDesign_Boolean.png +PartDesign_Draft +/wiki/images/thumb/0/0f/PartDesign_Draft-01.png/300px-PartDesign_Draft-01.png +/wiki/images/thumb/9/9c/PartDesign_Draft-02.png/300px-PartDesign_Draft-02.png +/wiki/images/thumb/b/b6/PartDesign_Draft-03.png/300px-PartDesign_Draft-03.png +/wiki/images/thumb/b/bf/PartDesign_Draft-04.png/300px-PartDesign_Draft-04.png +/wiki/images/thumb/b/b7/PartDesign_Draft-05.png/300px-PartDesign_Draft-05.png +/wiki/images/thumb/b/b5/PartDesign_Draft-06.png/300px-PartDesign_Draft-06.png +PartDesign_Chamfer +/wiki/images/thumb/1/17/PartDesign_Chamfer-01.png/300px-PartDesign_Chamfer-01.png +/wiki/images/thumb/3/37/PartDesign_Chamfer-02.png/300px-PartDesign_Chamfer-02.png +/wiki/images/thumb/3/34/PartDesign_Chamfer-03.png/300px-PartDesign_Chamfer-03.png +PartDesign_SubtractivePipe +/wiki/images/thumb/8/8a/PartDesign_SubtractivePipe.png/24px-PartDesign_SubtractivePipe.png +PartDesign_SubtractiveLoft +/wiki/images/thumb/1/10/PartDesign_SubtractiveLoft.png/24px-PartDesign_SubtractiveLoft.png +PartDesign_Groove +/wiki/images/d/d1/PartDesign_Groove_example.svg +/wiki/images/thumb/8/8d/PartDesign_Groove.png/24px-PartDesign_Groove.png +/wiki/images/0/0a/Partdesign_groove_parameters.png +PartDesign_Hole +/wiki/images/0/0c/Countersunk_and_counterbored_holes_cross-section1.png +/wiki/images/thumb/f/f8/PartDesign_Hole.png/24px-PartDesign_Hole.png +/wiki/images/b/bc/PartDesign_Hole_parameters.png +PartDesign_Pocket +/wiki/images/a/a9/PartDesign_Pocket_example.svg +/wiki/images/thumb/6/67/PartDesign_Pocket.png/16px-PartDesign_Pocket.png +/wiki/images/1/16/Pocket_options.png +PartDesign_Clone +/wiki/images/3/34/Clone.png +/wiki/images/thumb/a/ab/PartDesign_Clone.png/24px-PartDesign_Clone.png +PartDesign_ShapeBinder +/wiki/images/8/83/Shapebinder_tree.png +/wiki/images/e/ef/Shapebinder_flow.png +/wiki/images/thumb/f/f2/PartDesign_ShapeBinder.png/24px-PartDesign_ShapeBinder.png +PartDesign_NewSketch +/wiki/images/thumb/4/43/PartDesign_NewSketch.png/24px-PartDesign_NewSketch.png +PartDesign_Legacy +/wiki/images/thumb/9/92/PartDesign_Revolution_en_03.png/300px-PartDesign_Revolution_en_03.png +/wiki/images/thumb/a/a1/Vue_DisplayModePartDesign_fr_00.png/96px-Vue_DisplayModePartDesign_fr_00.png +/wiki/images/thumb/6/67/Vue_Lighting_fr_00.png/96px-Vue_Lighting_fr_00.png +/wiki/images/thumb/6/65/PartDesign_Revolution_en_04.png/300px-PartDesign_Revolution_en_04.png +PartDesign_tutorial +/wiki/images/thumb/5/56/PartDesign_revolution_exercise.png/480px-PartDesign_revolution_exercise.png +/wiki/images/thumb/8/8c/PartDesign_pocket_exercise.png/480px-PartDesign_pocket_exercise.png +/wiki/images/thumb/8/8b/PartDesign_multitransform_exercise.png/480px-PartDesign_multitransform_exercise.png +Assembly_Workbench +Draft_Workbench +/wiki/images/thumb/9/91/Draft_PutOnSheet.png/32px-Draft_PutOnSheet.png +/wiki/images/thumb/1/16/Draft_ApplyStyle.png/32px-Draft_ApplyStyle.png +Draft_tutorial_Outdated +/wiki/images/b/bc/Doublecad.jpg +/wiki/images/d/de/Situation.jpg +/wiki/images/thumb/c/c5/Tutorial-treeview.jpg/100px-Tutorial-treeview.jpg +/wiki/images/4/41/Draft-tutorial-01.jpg +/wiki/images/6/68/Draft-tutorial-walls.jpg +/wiki/images/9/9c/Draft-tutorial-blocks.jpg +/wiki/images/2/2e/Draft-tutorial-dims.jpg +/wiki/images/a/a6/Draft-tutorial-typical-tree.jpg +/wiki/images/1/13/Draft-tutorial-elevation.jpg +/wiki/images/thumb/6/66/Draft-tutorial05.jpg/340px-Draft-tutorial05.jpg +/wiki/images/7/77/Fctutorial-complete.jpg +FreeCAD_and_DWG_Import +Draft_DAT +Workbench_Concept +/wiki/images/f/f8/Workbench_Inspection.svg +/wiki/images/4/4e/Workbench_OpenSCAD.svg +/wiki/images/8/88/Workbench_Path.svg +/wiki/images/6/6c/Workbench_Points.svg +/wiki/images/8/83/Workbench_Reverse_Engineering.svg +/wiki/images/8/84/Workbench_Ship.svg +/wiki/images/b/be/Workbench_Spreadsheet.svg +/wiki/images/b/b6/Workbench_TechDraw.svg +/wiki/images/b/bf/Workbench_Test.svg +Preferences_Editor +/wiki/images/9/97/Preference_General_Tab_01.png +/wiki/images/9/95/Preference_General_Tab_02.png +/wiki/images/0/01/Preference_General_Tab_03.png +/wiki/images/3/3a/Preference_General_Tab_04.png +/wiki/images/3/30/Preference_General_Tab_05.png +/wiki/images/0/05/Preference_General_Tab_06.png +/wiki/images/6/68/Preference_Display_Tab_01.png +/wiki/images/7/73/Preference_Display_Tab_02.png +/wiki/images/e/e9/Preference_Display_Tab_03.png +Document_structure +/wiki/images/d/d5/Screenshot_treeview.jpg +Mouse_Model +/wiki/images/b/b1/Hand_cursor.png +/wiki/images/b/b0/Pan_cursor.png +/wiki/images/1/19/Zoom_cursor.png +/wiki/images/2/20/Rotate_cursor.png +/wiki/images/7/7e/Select-mouse.svg +/wiki/images/e/e9/Pan-mouse.svg +/wiki/images/b/bf/Zoom-mouse.svg +/wiki/images/9/92/Rotate-mouse.svg +/wiki/images/b/b9/Rotate-mouse-MMB%2BRMB.svg +/wiki/images/f/f4/Pan-mouse-CTRL.svg +/wiki/images/9/99/Zoom-mouse-CTRL-SHIFT.svg +/wiki/images/9/9f/Rotate-mouse-SHIFT.svg +/wiki/images/5/51/Mouse_LMB%2BRMB.svg +/wiki/images/thumb/b/bb/Select-touchpad.png/70px-Select-touchpad.png +/wiki/images/thumb/7/78/Touchpad.png/70px-Touchpad.png +/wiki/images/0/06/Pan-mouse-Ctrl.svg +/wiki/images/3/3f/Touch_Tap.svg +/wiki/images/d/d8/Touch_Tap-Hold-Drag.svg +/wiki/images/1/10/Touch_Two-Finger-Drag.svg +/wiki/images/f/f6/Touch_Pinch.svg +/wiki/images/9/93/Touch_One-Finger-Drag.svg +/wiki/images/1/1c/Touch_Rotate.svg +3D_input_devices +3Dconnexion_input_devices +/wiki/images/thumb/e/ea/SpaceNavigator.jpg/200px-SpaceNavigator.jpg +/wiki/images/thumb/8/80/Spaceball_Motion.png/450px-Spaceball_Motion.png +/wiki/images/thumb/9/93/Spaceball_Buttons.png/450px-Spaceball_Buttons.png +Manipulator +/wiki/images/e/e8/Manipulators.png +Installing +/wiki/images/1/1e/Macro_installer_01.jpg +Installing_Helpfile +About_FreeCAD +/wiki/images/thumb/2/2a/Freecad_default.jpg/1024px-Freecad_default.jpg +History +/wiki/images/thumb/d/d8/Screenshot_mesh.jpg/300px-Screenshot_mesh.jpg +/wiki/images/thumb/d/df/Part_BooleanOperations.png/300px-Part_BooleanOperations.png +Release_notes_016 +Tutorials +/wiki/images/thumb/0/08/Arch_tutorial_00.jpg/578px-Arch_tutorial_00.jpg +/wiki/images/thumb/2/2d/Arch_panel_tutorial_01.jpg/534px-Arch_panel_tutorial_01.jpg +/wiki/images/thumb/c/cb/Exercise_arch_01.jpg/406px-Exercise_arch_01.jpg +/wiki/images/thumb/c/ce/GGTuto1_Vue.PNG/410px-GGTuto1_Vue.PNG +/wiki/images/thumb/b/bc/PD_WB_Tutorial018.png/300px-PD_WB_Tutorial018.png +/wiki/images/thumb/c/cf/TBHS-model.png/600px-TBHS-model.png +/wiki/images/thumb/c/c5/Exercise_lego_01.jpg/478px-Exercise_lego_01.jpg +/wiki/images/thumb/9/99/Exercise_table_complete.jpg/374px-Exercise_table_complete.jpg +/wiki/images/thumb/4/48/TutorialDraftShapeString_Complete.jpg/346px-TutorialDraftShapeString_Complete.jpg +/wiki/images/thumb/c/c4/Tutorial_WhiffleBall.jpg/503px-Tutorial_WhiffleBall.jpg +/wiki/images/thumb/3/35/Exercise_cabin_01.jpg/463px-Exercise_cabin_01.jpg +/wiki/images/thumb/9/99/Draft_tutorial_result.png/468px-Draft_tutorial_result.png +/wiki/images/thumb/6/6f/Sketcher_tutorial_result.png/329px-Sketcher_tutorial_result.png +/wiki/images/thumb/7/71/Constrain3.png/282px-Constrain3.png +/wiki/images/thumb/8/88/Drawing_tutorial_result.png/429px-Drawing_tutorial_result.png +/wiki/images/thumb/4/40/Exercise_drawing_01.jpg/212px-Exercise_drawing_01.jpg +/wiki/images/thumb/1/1a/FEM_example01_pic00.jpg/480px-FEM_example01_pic00.jpg +/wiki/images/thumb/d/d9/Figure_11_Deformed_Mesh.png/599px-Figure_11_Deformed_Mesh.png +/wiki/images/thumb/9/9e/FEM_tutorial_result.png/534px-FEM_tutorial_result.png +/wiki/images/thumb/a/ae/Path-WalkThroughResult.gif/315px-Path-WalkThroughResult.gif +/wiki/images/thumb/9/9c/Exercise_meshing_03.jpg/482px-Exercise_meshing_03.jpg +/wiki/images/thumb/c/c3/Dxf_Importer_Install_11.png/434px-Dxf_Importer_Install_11.png +/wiki/images/thumb/a/aa/Exercise_raytracing_05.jpg/452px-Exercise_raytracing_05.jpg +/wiki/images/thumb/5/56/Raytracing_tutorial_result.png/534px-Raytracing_tutorial_result.png +/wiki/images/thumb/e/ef/Robot_Tutorial_RobotSimulation.gif/330px-Robot_Tutorial_RobotSimulation.gif +Path_Walkthrough_for_the_Impatient +/wiki/images/a/a6/Path-SquarePocketModel.png +/wiki/images/thumb/b/b6/Path-Job.png/32px-Path-Job.png +/wiki/images/4/44/Path-JobCreationDialog.png +/wiki/images/e/e3/Path-JobOutput.png +/wiki/images/7/7a/Path-JobTools.png +/wiki/images/1/18/Path-ToolConfig.gif +/wiki/images/9/91/Path-TreeWithJob.png +/wiki/images/thumb/8/83/Path_Profile.png/32px-Path_Profile.png +/wiki/images/6/68/Path-PocketOperation.gif +/wiki/images/a/ae/Path-WalkThroughResult.gif +/wiki/images/thumb/9/9f/Path_Inspect.png/32px-Path_Inspect.png +/wiki/images/9/96/Path-InspectWindow.gif +/wiki/images/3/30/Path-PostOutput.gif +Toothbrush_Head_Stand +/wiki/images/c/cf/TBHS-model.png +/wiki/images/8/89/Workbench_PartDesign.png +/wiki/images/4/4e/TBHS-0.png +/wiki/images/thumb/6/66/TBHS-1.JPG/800px-TBHS-1.JPG +/wiki/images/thumb/4/47/TBHS-2.JPG/800px-TBHS-2.JPG +/wiki/images/thumb/4/4f/TBHS-3.JPG/800px-TBHS-3.JPG +/wiki/images/thumb/a/a1/TBHS-4.JPG/800px-TBHS-4.JPG +/wiki/images/thumb/0/0e/TBHS-5.JPG/800px-TBHS-5.JPG +/wiki/images/thumb/6/63/TBHS-6.JPG/800px-TBHS-6.JPG +/wiki/images/thumb/9/9c/TBHS-7.JPG/800px-TBHS-7.JPG +/wiki/images/thumb/6/65/TBHS-8.JPG/800px-TBHS-8.JPG +/wiki/images/thumb/8/87/TBHS-9.JPG/800px-TBHS-9.JPG +/wiki/images/thumb/2/2e/TBHS-10.JPG/800px-TBHS-10.JPG +/wiki/images/thumb/a/ac/TBHS-11.JPG/800px-TBHS-11.JPG +/wiki/images/thumb/2/2c/TBHS-12.JPG/800px-TBHS-12.JPG +/wiki/images/thumb/f/ff/TBHS-13.JPG/800px-TBHS-13.JPG +/wiki/images/thumb/a/a1/TBHS-14.JPG/800px-TBHS-14.JPG +/wiki/images/thumb/3/32/TBHS-15.JPG/800px-TBHS-15.JPG +/wiki/images/thumb/1/10/TBHS-16.JPG/800px-TBHS-16.JPG +/wiki/images/thumb/6/6a/TBHS-17.JPG/800px-TBHS-17.JPG +/wiki/images/thumb/5/57/TBHS-18.JPG/800px-TBHS-18.JPG +/wiki/images/thumb/6/61/TBHS-19.JPG/800px-TBHS-19.JPG +/wiki/images/thumb/e/ea/TBHS-20.JPG/800px-TBHS-20.JPG +/wiki/images/thumb/8/8f/TBHS-21.JPG/800px-TBHS-21.JPG +/wiki/images/thumb/5/57/TBHS-23.JPG/800px-TBHS-23.JPG +/wiki/images/thumb/9/9c/TBHS-22.JPG/800px-TBHS-22.JPG +/wiki/images/thumb/6/68/TBHS-24.JPG/800px-TBHS-24.JPG +/wiki/images/thumb/d/d1/TBHS-v2.jpg/800px-TBHS-v2.jpg +/wiki/images/thumb/a/a3/TBHS2-1.JPG/800px-TBHS2-1.JPG +/wiki/images/thumb/3/3c/TBHS2-2.JPG/800px-TBHS2-2.JPG +/wiki/images/thumb/8/8b/TBHS2-3.JPG/800px-TBHS2-3.JPG +/wiki/images/thumb/f/f9/TBHS2-4.JPG/800px-TBHS2-4.JPG +/wiki/images/thumb/c/ca/TBHS2-5.JPG/800px-TBHS2-5.JPG +/wiki/images/thumb/b/b5/TBHS2-6.JPG/800px-TBHS2-6.JPG +/wiki/images/thumb/0/02/TBHS2-7.JPG/800px-TBHS2-7.JPG +/wiki/images/thumb/9/97/TBHS2-8.JPG/800px-TBHS2-8.JPG +/wiki/images/thumb/8/8c/TBHS2-9.JPG/800px-TBHS2-9.JPG +/wiki/images/thumb/6/69/TBHS2-10.JPG/800px-TBHS2-10.JPG +/wiki/images/thumb/c/c5/TBHS2-11.JPG/800px-TBHS2-11.JPG +/wiki/images/thumb/e/ee/TBHS2-12.JPG/800px-TBHS2-12.JPG +/wiki/images/thumb/1/11/TBHS2-13.JPG/800px-TBHS2-13.JPG +/wiki/images/thumb/c/cb/TBHS2-14.JPG/800px-TBHS2-14.JPG +/wiki/images/thumb/d/de/TBHS2-15.JPG/800px-TBHS2-15.JPG +/wiki/images/thumb/c/cc/TBHS2-16.JPG/800px-TBHS2-16.JPG +/wiki/images/thumb/9/96/TBHS2-17.JPG/800px-TBHS2-17.JPG +/wiki/images/thumb/2/2d/TBHS2-18.JPG/800px-TBHS2-18.JPG +/wiki/images/thumb/f/f1/TBHS2-19.JPG/800px-TBHS2-19.JPG +/wiki/images/thumb/8/80/TBHS2-20.JPG/800px-TBHS2-20.JPG +/wiki/images/thumb/2/27/TBHS2-21.JPG/800px-TBHS2-21.JPG +/wiki/images/thumb/e/ef/TBHS2-22.JPG/800px-TBHS2-22.JPG +/wiki/images/thumb/5/50/TBHS2-23.JPG/800px-TBHS2-23.JPG +/wiki/images/thumb/8/86/TBHS2-24.JPG/800px-TBHS2-24.JPG +/wiki/images/thumb/6/65/TBHS2-25.JPG/800px-TBHS2-25.JPG +/wiki/images/thumb/4/4a/TBHS2-26.JPG/800px-TBHS2-26.JPG +/wiki/images/thumb/2/2d/TBHS2-27.JPG/800px-TBHS2-27.JPG +/wiki/images/thumb/d/dc/TBHS2-28.JPG/800px-TBHS2-28.JPG +/wiki/images/thumb/f/f7/TBHS2-29.JPG/800px-TBHS2-29.JPG +/wiki/images/thumb/b/b4/TBHS2-30.JPG/800px-TBHS2-30.JPG +/wiki/images/thumb/f/f9/TBHS2-30-chamfer.JPG/200px-TBHS2-30-chamfer.JPG +/wiki/images/thumb/4/4f/TBHS2-30-draft.JPG/200px-TBHS2-30-draft.JPG +/wiki/images/thumb/6/6f/TBHS2-31-bottom.JPG/200px-TBHS2-31-bottom.JPG +/wiki/images/thumb/4/49/TBHS2-31-top.JPG/200px-TBHS2-31-top.JPG +/wiki/images/thumb/d/d5/TBHS2-31.JPG/800px-TBHS2-31.JPG +/wiki/images/thumb/9/9e/TBHS2-32.JPG/800px-TBHS2-32.JPG +Video_tutorials +Offsite_tutorials +FAQ +/wiki/images/thumb/c/c0/Jj62l.png/480px-Jj62l.png +/wiki/images/thumb/7/73/Style_of_navigation.png/189px-Style_of_navigation.png +/wiki/images/thumb/1/10/Style_of_navigation_menu.png/250px-Style_of_navigation_menu.png +FreeCAD_Howto_Import_Export +Getting_started +/wiki/images/thumb/d/d8/Freecad-interface.jpg/1024px-Freecad-interface.jpg +/wiki/images/thumb/6/66/Startcenter.jpg/1024px-Startcenter.jpg +/wiki/images/thumb/5/53/Partdesign_example.jpg/1024px-Partdesign_example.jpg +/wiki/images/thumb/d/df/Arch_workflow_example.jpg/1024px-Arch_workflow_example.jpg +Downloads +Screenshots +/wiki/images/thumb/d/dc/6DPLEQ2.jpg/1024px-6DPLEQ2.jpg +/wiki/images/thumb/c/cc/Screenshot_from_2018-01-25_20-53-18.jpg/1024px-Screenshot_from_2018-01-25_20-53-18.jpg +/wiki/images/thumb/9/93/VIIC_2.jpg/1024px-VIIC_2.jpg +/wiki/images/e/ee/Truggy_differential_full.jpg +/wiki/images/thumb/9/98/216.png/1024px-216.png +/wiki/images/4/43/Custom_extruder.jpg +/wiki/images/thumb/a/a5/Wheel.JPG/1024px-Wheel.JPG +/wiki/images/9/94/Axoview-r.JPG +/wiki/images/thumb/0/01/BaseStation004.JPG/1024px-BaseStation004.JPG +/wiki/images/thumb/4/4c/Drill-FreeCAD.png/1024px-Drill-FreeCAD.png +/wiki/images/0/0a/Drone_Design_Full.jpg +/wiki/images/thumb/0/0c/Pic_06.jpg/1024px-Pic_06.jpg +/wiki/images/thumb/0/0f/FreeCAD-guitar.jpg/1024px-FreeCAD-guitar.jpg +/wiki/images/thumb/6/6e/Hhassey.png/1024px-Hhassey.png +/wiki/images/thumb/d/dc/JMG.png/1024px-JMG.png +/wiki/images/thumb/1/1e/PrzemoF.png/1024px-PrzemoF.png +/wiki/images/thumb/f/f7/Rockn.png/1024px-Rockn.png +/wiki/images/thumb/8/81/Easyw_fc.png/1024px-Easyw_fc.png +/wiki/images/thumb/d/d6/R_tec.jpeg/1024px-R_tec.jpeg +/wiki/images/thumb/d/d3/Obijuan.png/1024px-Obijuan.png +/wiki/images/thumb/6/67/Obijuan2.png/1024px-Obijuan2.png +/wiki/images/thumb/c/c6/Gsuter.png/1024px-Gsuter.png +/wiki/images/thumb/3/35/Lhf.jpg/1024px-Lhf.jpg +/wiki/images/9/95/Lou_papet.png +/wiki/images/thumb/0/0a/Rockn_house1.png/1024px-Rockn_house1.png +/wiki/images/thumb/7/77/Rockn_house2.png/1024px-Rockn_house2.png +/wiki/images/thumb/2/20/Mesh_curvature_plot1.jpeg/1024px-Mesh_curvature_plot1.jpeg +/wiki/images/thumb/4/42/Cura_export.png/1024px-Cura_export.png +/wiki/images/thumb/1/18/FreeCAD_aeroponic_system.jpg/1024px-FreeCAD_aeroponic_system.jpg +/wiki/images/thumb/3/33/Rim_bling.png/1024px-Rim_bling.png +/wiki/images/2/2d/FreeCAD011.png +/wiki/images/b/b3/Freecad010.png +/wiki/images/thumb/1/1d/Measurement.jpeg/800px-Measurement.jpeg +/wiki/images/8/81/Freecad09.jpg +/wiki/images/thumb/7/7e/TaskPanel.jpg/800px-TaskPanel.jpg +/wiki/images/4/43/FreeCAD_Screenshot.png +/wiki/images/thumb/d/df/Part_BooleanOperations.png/800px-Part_BooleanOperations.png +/wiki/images/6/67/Screenshot-gcad.jpg +/wiki/images/6/64/Freecad-vista01.jpg +/wiki/images/0/01/Sceenshot-reversevid.jpg +/wiki/images/d/d8/Screenshot_mesh.jpg +/wiki/images/f/fb/Fcblender.jpg +/wiki/images/c/c4/Screenshot_draft.jpg +/wiki/images/9/97/Freecad-vista02.jpg +/wiki/images/3/37/Interface_screenshot.jpg +/wiki/images/4/41/Screenshot_installer.jpg +/wiki/images/9/9a/Screenshot_console.jpg +Feature_list +/wiki/images/c/c3/Feature1.jpg +/wiki/images/0/00/Feature3.jpg +/wiki/images/a/ae/Feature4.jpg +/wiki/images/5/59/Feature5.jpg +/wiki/images/f/fa/Feature7.jpg +/wiki/images/2/22/Feature9.jpg +/wiki/images/f/f1/Feature8.jpg +/wiki/images/e/e0/Feature-raytracing.jpg +/wiki/images/5/56/Feature-arch.jpg +/wiki/images/1/13/Feature-CAM.jpg +/wiki/images/d/d2/Feature_spreadsheet.png +/wiki/images/1/1b/Feature-assembly.jpg +Online_Help_Toc +Glossary +Contributors +Extra_python_modules +Continuous_Integration +/wiki/images/thumb/c/c0/Travis-logo.png/50px-Travis-logo.png +/wiki/images/f/f4/Appveyor.svg +Testing +Debugging +Module_Creation +FreeCAD_Build_Tool +Third_Party_Tools +Third_Party_Libraries +Compiling_(Speeding_up) +CompileOnMac +OpenGL_on_MacOS +CompileOnUnix +CompileOnWindows +CompileOnWindows_-_Reducing_Disk_Footprint +/wiki/images/thumb/5/52/Msvc-no-vs_compiler-setup-32.png/600px-Msvc-no-vs_compiler-setup-32.png +/wiki/images/thumb/a/a0/Msvc-no-vs_kit-setup-32.png/600px-Msvc-no-vs_kit-setup-32.png +Compile_on_Windows_with_VS2013 +Tracker +Dialog_creation +/wiki/images/c/ca/Qttestdialog.jpg +/wiki/images/0/0f/Qtdesigner-screenshot.jpg +/wiki/images/0/0e/Qtpropeditor.jpg +/wiki/images/e/e8/Icone01.png +/wiki/images/c/c1/Icone02.png +/wiki/images/6/65/Icone03.png +/wiki/images/thumb/f/fe/Qt_Example_00.png/167px-Qt_Example_00.png +/wiki/images/thumb/d/d4/Qt_Example_01.png/167px-Qt_Example_01.png +/wiki/images/thumb/8/86/FreeCADIco.png/24px-FreeCADIco.png +/wiki/images/0/04/Qt_Example_02.png +Qt_Example +/wiki/images/e/e4/MEPlan.png +/wiki/images/a/a7/MEpipe01.png +/wiki/images/5/5b/MEpipe02.png +/wiki/images/3/30/MEPlanD.png +/wiki/images/d/d8/MEPlanF.png +/wiki/images/9/9f/MEPlanT.png +/wiki/images/f/f2/MEPlanI.png +/wiki/images/e/e6/MEPlanFC.png +/wiki/images/d/d2/MEPlanPY.png +Line_drawing_function +Code_snippets +API_documentation +Embedding_FreeCAD +Pivy +Mesh_to_Part +Python_scripting_tutorial +TechDraw_Workbench +Path_Workbench +/wiki/images/thumb/8/8d/Pathwb.png/840px-Pathwb.png +/wiki/images/thumb/0/0d/Path-ExportTemplate.png/32px-Path-ExportTemplate.png +/wiki/images/thumb/6/68/Path-CompleteLoop.png/32px-Path-CompleteLoop.png +/wiki/images/thumb/a/a9/Path-Profile-Face.png/32px-Path-Profile-Face.png +/wiki/images/thumb/b/b7/Path-Profile-Edges.png/32px-Path-Profile-Edges.png +/wiki/images/thumb/2/21/Path-Engrave.png/32px-Path-Engrave.png +/wiki/images/thumb/6/64/Path-Helix.png/32px-Path-Helix.png +/wiki/images/thumb/a/a9/Path-3DPocket.png/32px-Path-3DPocket.png +/wiki/images/thumb/f/f9/Path_Dressup.png/32px-Path_Dressup.png +/wiki/images/thumb/6/62/Path_Fixture.png/32px-Path_Fixture.png +/wiki/images/thumb/f/fe/Path_Comment.png/32px-Path_Comment.png +/wiki/images/thumb/d/d6/Path_Stop.png/32px-Path_Stop.png +/wiki/images/thumb/9/9e/Path_Custom.png/32px-Path_Custom.png +/wiki/images/thumb/1/1c/Path_GcodeFromShape.png/32px-Path_GcodeFromShape.png +/wiki/images/thumb/1/19/Path_Copy.png/32px-Path_Copy.png +/wiki/images/thumb/c/c7/Path_Array.png/32px-Path_Array.png +/wiki/images/thumb/d/d6/Path_SimpleCopy.png/32px-Path_SimpleCopy.png +/wiki/images/thumb/e/e0/Path-3DSurface.png/32px-Path-3DSurface.png +/wiki/images/thumb/0/0f/Path-Area.png/32px-Path-Area.png +/wiki/images/thumb/6/68/Path-Area-Workplane.png/32px-Path-Area-Workplane.png +/wiki/images/thumb/0/06/Path_Sanity.png/32px-Path_Sanity.png +Path_FAQ +Path_Preferences +/wiki/images/3/38/Preference_Path_Tab_01_1.png +/wiki/images/4/46/Preference_Path_Tab_01_2.png +/wiki/images/5/58/Preference_Path_Tab_01_3.png +/wiki/images/a/ab/Preference_Path_Tab_02.png +/wiki/images/4/4a/Preference_Path_Tab_03.png +Path_Sanity +Path_experimental +/wiki/images/3/31/Path_wb_enable_experimental_features.PNG +Path_Area_Workplane +Path_Area +Path_Surface +Path_SimpleCopy +/wiki/images/thumb/d/d6/Path_SimpleCopy.png/16px-Path_SimpleCopy.png +Path_Array +/wiki/images/thumb/c/c7/Path_Array.png/16px-Path_Array.png +Path_Copy +/wiki/images/thumb/1/19/Path_Copy.png/16px-Path_Copy.png +Path_FromShapes +/wiki/images/thumb/e/ef/Path_FromShapes.png/32px-Path_FromShapes.png +/wiki/images/f/fb/FromShape_image_0.png +/wiki/images/thumb/1/1c/Path_GcodeFromShape.png/16px-Path_GcodeFromShape.png +Path_Custom +/wiki/images/thumb/9/9e/Path_Custom.png/16px-Path_Custom.png +Path_Stop +/wiki/images/thumb/d/d6/Path_Stop.png/16px-Path_Stop.png +Path_Comment +/wiki/images/thumb/f/fe/Path_Comment.png/16px-Path_Comment.png +Path_Fixture +/wiki/images/thumb/6/62/Path_Fixture.png/16px-Path_Fixture.png +Path_Helix +/wiki/images/thumb/f/f6/Path_Helix.png/32px-Path_Helix.png +Path_Engrave +/wiki/images/f/fc/Path_Engrave.png +Path_ProfileEdges +/wiki/images/thumb/c/c4/Path_Profile_Edges.png/32px-Path_Profile_Edges.png +/wiki/images/b/b0/Path_Profile_by_Edges.png +/wiki/images/thumb/b/b7/Path-Profile-Edges.png/16px-Path-Profile-Edges.png +Path_SelectLoop +/wiki/images/thumb/c/c0/Path_SelectLoop.png/32px-Path_SelectLoop.png +Path_ExportTemplate +/wiki/images/thumb/2/23/Path_ExportTemplate.png/32px-Path_ExportTemplate.png +/wiki/images/thumb/0/0d/Path-ExportTemplate.png/16px-Path-ExportTemplate.png +Path_SetupSheet +Path_Core_Concepts +Path_Customization +Path_Postprocessor_Customization +Path_objects +Path_Profile +/wiki/images/9/98/Path_profile_example.jpg +/wiki/images/thumb/8/83/Path_Profile.png/16px-Path_Profile.png +Path_ToolNumberToLoad +/wiki/images/thumb/c/c1/Path_ToolNumberToLoad.png/32px-Path_ToolNumberToLoad.png +/wiki/images/thumb/c/c1/Path_ToolNumberToLoad.png/16px-Path_ToolNumberToLoad.png +Robot_Module +OpenSCAD_Module +Points_Module +Points_ExportPoints +/wiki/images/thumb/d/d4/Points_ExportPoints.png/32px-Points_ExportPoints.png +Points_ImportPoints +/wiki/images/thumb/7/75/Points_ImportPoints.png/32px-Points_ImportPoints.png +Start_Workbench +Reverse_Engineering_Workbench +Ship_Workbench +/wiki/images/thumb/c/c0/FreeCAD-Ship-LoadIco.png/32px-FreeCAD-Ship-LoadIco.png +/wiki/images/thumb/a/a1/FreeCAD-Ship-Ico.png/32px-FreeCAD-Ship-Ico.png +/wiki/images/thumb/e/ec/FreeCAD-Ship-OutlineDrawIco.png/32px-FreeCAD-Ship-OutlineDrawIco.png +/wiki/images/thumb/0/0b/FreeCAD-Ship-AreaCurveIco.png/32px-FreeCAD-Ship-AreaCurveIco.png +/wiki/images/thumb/9/9d/Ship_Hydrostatics.png/32px-Ship_Hydrostatics.png +/wiki/images/thumb/4/44/FreeCAD-Ship-WeightIco.png/32px-FreeCAD-Ship-WeightIco.png +/wiki/images/thumb/5/50/FreeCAD-Ship-TankIco.png/32px-FreeCAD-Ship-TankIco.png +/wiki/images/thumb/6/6c/Ship_TankCapacity.png/32px-Ship_TankCapacity.png +/wiki/images/thumb/8/85/Ship_Loading.png/32px-Ship_Loading.png +/wiki/images/thumb/3/31/Ship_PlotGZ.png/32px-Ship_PlotGZ.png +Ship_PlotGZ +Ship_Loading +Ship_TankCapacity +Ship_TankNew +/wiki/images/c/c4/Ship_TankNew.png +Ship_Weight +/wiki/images/5/57/Ship_Weight.png +Ship_Hydrostatics +Ship_Area +/wiki/images/3/3d/Ship_Area.png +Ship_Outline +/wiki/images/thumb/c/cc/Ship_Outline.png/32px-Ship_Outline.png +Ship_New +/wiki/images/thumb/c/c2/Ship_New.png/32px-Ship_New.png +Ship_Geometries_Examples +/wiki/images/thumb/6/69/Ship_Load_Example.png/32px-Ship_Load_Example.png +Web_Workbench +Plot_Module +/wiki/images/thumb/f/f6/Plot_Save.png/32px-Plot_Save.png +/wiki/images/thumb/1/10/Plot_Axes.png/32px-Plot_Axes.png +/wiki/images/thumb/1/16/Plot_Series.png/32px-Plot_Series.png +/wiki/images/thumb/a/a9/Plot_Grid.png/32px-Plot_Grid.png +/wiki/images/thumb/0/07/Plot_Legend.png/32px-Plot_Legend.png +/wiki/images/thumb/8/8e/Plot_Labels.png/32px-Plot_Labels.png +/wiki/images/thumb/a/a8/Plot_Positions.png/32px-Plot_Positions.png +Plot_MultiAxes_tutorial +/wiki/images/thumb/2/2f/Plot_MultiAxes_Example.png/600px-Plot_MultiAxes_Example.png +/wiki/images/1/10/Plot_Axes.png +/wiki/images/a/a8/Plot_Positions.png +Plot_Basic_tutorial +/wiki/images/thumb/4/46/Plot_Trigonometric_Example.png/600px-Plot_Trigonometric_Example.png +/wiki/images/a/a9/Plot_Grid.png +/wiki/images/0/07/Plot_Legend.png +/wiki/images/1/16/Plot_Series.png +/wiki/images/8/8e/Plot_Labels.png +/wiki/images/f/f6/Plot_Save.png +Plot_Positions +Plot_Labels +Plot_Legend +Plot_Grid +Plot_Series +Plot_Axes +Plot_Save +/wiki/images/e/e9/Plot_Save_Path.png +Spreadsheet_Module +Sketcher_Module +Raytracing_Module +Part_Module +Mesh_Module +Inspection_Workbench +/wiki/images/7/7b/InspectionEx.png +Image_Module +/wiki/images/thumb/b/b5/Image_Import.png/32px-Image_Import.png +Image_Import +FEM_Module +Drawing_Module +Draft_Module +Arch_Module +Import_Export +Workbenches +Property_editor +Install_on_Mac +/wiki/images/4/44/Mac_installer_1.png +Install_on_Unix +Install_on_Windows +Online_Help_Startpage +/wiki/images/0/0b/Crystal_Clear_app_tutorials.png